.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;line-height:1.5;text-align:center;text-decoration:none;border:1px solid transparent;border-radius:.375rem;cursor:pointer;transition:all .2s ease-in-out;white-space:nowrap}.btn:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.btn--primary:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.btn--secondary{background-color:#6b7280;color:#fff;border-color:#6b7280}.btn--secondary:hover:not(:disabled){background-color:#4b5563;border-color:#4b5563}.btn--danger{background-color:#ef4444;color:#fff;border-color:#ef4444}.btn--danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn--ghost{background-color:transparent;color:#374151;border-color:#d1d5db}.btn--ghost:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.btn--small{padding:.375rem .75rem;font-size:.75rem}.btn--medium{padding:.625rem 1.25rem;font-size:.875rem}.btn--large{padding:.75rem 1.5rem;font-size:1rem}.btn--full-width{width:100%}.btn--loading{pointer-events:none}.btn__spinner{display:inline-block;width:1rem;height:1rem;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.header{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:1000}.header__container{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.header__logo{font-size:1.5rem;font-weight:700;color:#3b82f6;text-decoration:none;transition:color .2s ease-in-out}.header__logo:hover{color:#2563eb}.header__nav{display:flex;align-items:center;gap:1.5rem}.header__link{font-size:.875rem;font-weight:500;color:#374151;text-decoration:none;transition:color .2s ease-in-out}.header__link:hover{color:#3b82f6}@media (max-width: 640px){.header__container{padding:.75rem 1rem}.header__logo{font-size:1.25rem}.header__nav{gap:1rem}.header__link{display:none}.header__link:last-child{display:block}}.footer{background-color:#f9fafb;border-top:1px solid #e5e7eb;margin-top:auto}.footer__container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;text-align:center}.footer__text{margin:0;font-size:.875rem;color:#6b7280}.layout{display:flex;flex-direction:column;min-height:100vh;background-color:#f9fafb}.layout__main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem 1.5rem}@media (max-width: 640px){.layout__main{padding:1rem}}.loader-container{display:flex;justify-content:center;align-items:center;padding:2rem}.loader-fullpage{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background-color:#ffffffe6;z-index:9999}.loader{border:3px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.loader--small{width:1.5rem;height:1.5rem;border-width:2px}.loader--medium{width:2.5rem;height:2.5rem;border-width:3px}.loader--large{width:4rem;height:4rem;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.board-card{display:block;padding:1.25rem 1.5rem;text-decoration:none;color:inherit;border-bottom:1px solid #e5e7eb;transition:background-color .2s ease-in-out}.board-card:last-child{border-bottom:none}.board-card:hover{background-color:#f9fafb}.board-card__content{display:flex;justify-content:space-between;gap:1.5rem}.board-card__main{flex:1}.board-card__title{margin:0 0 .375rem;font-size:1rem;font-weight:600;color:#3b82f6}.board-card__description{margin:0;font-size:.875rem;color:#6b7280}.board-card__stats{display:flex;align-items:center;gap:2rem}.board-card__stat{display:flex;flex-direction:column;align-items:center;min-width:60px}.board-card__stat-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.board-card__stat-value{font-size:1.25rem;font-weight:600;color:#1f2937}.board-card__last-post{display:flex;flex-direction:column;gap:.25rem;max-width:200px}.board-card__last-post-title{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.board-card__last-post-info{font-size:.875rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-card__last-post-info small{color:#9ca3af}@media (max-width: 768px){.board-card__content{flex-direction:column;gap:1rem}.board-card__stats{justify-content:space-between}.board-card__last-post{max-width:none}}.card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.25rem;box-shadow:0 1px 3px #0000001a;transition:all .2s ease-in-out}.card--hoverable:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.card--clickable{cursor:pointer}.card--clickable:hover{border-color:#d1d5db}.category-card{padding:0;overflow:hidden}.category-card__header{padding:1.5rem;background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.category-card__title{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.category-card__description{margin:0;font-size:.875rem;color:#6b7280}.category-card__boards{display:flex;flex-direction:column}.category-card__empty{padding:1.5rem;text-align:center;color:#9ca3af;font-size:.875rem;margin:0}.error-message{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b}.error-message__icon{flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:.125rem}.error-message__text{flex:1;margin:0;font-size:.875rem;line-height:1.5}.category-list{display:flex;flex-direction:column;gap:1.5rem}.category-list-empty{text-align:center;padding:3rem 1rem;color:#6b7280}.home-page{display:flex;flex-direction:column;gap:2rem}.home-header{text-align:center}.home-title{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#1f2937}.home-description{margin:0;font-size:1.125rem;color:#6b7280}@media (max-width: 640px){.home-title{font-size:1.5rem}.home-description{font-size:1rem}}.input-group{display:flex;flex-direction:column;gap:.375rem;width:100%}.input-label{font-size:.875rem;font-weight:500;color:#374151}.input{width:100%;padding:.625rem .875rem;font-size:.875rem;line-height:1.5;color:#1f2937;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;transition:all .2s ease-in-out}.input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.input::placeholder{color:#9ca3af}.input:disabled{background-color:#f3f4f6;cursor:not-allowed}.input--error{border-color:#ef4444}.input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.input-error{font-size:.75rem;color:#ef4444}.input-helper{font-size:.75rem;color:#6b7280}.auth-page{max-width:28rem;margin:3rem auto;padding:0 1rem}.auth-card{padding:2rem}.auth-title{margin:0 0 1.5rem;font-size:1.875rem;font-weight:700;text-align:center;color:#1f2937}.auth-form{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.875rem;color:#6b7280}.auth-link{color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s ease-in-out}.auth-link:hover{color:#2563eb}.post-card{padding:1rem 1.25rem}.post-card__content{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem}.post-card__main{flex:1;min-width:0}.post-card__header{display:flex;gap:.5rem;margin-bottom:.5rem}.post-card__badge{padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:.25rem;text-transform:uppercase;letter-spacing:.05em}.post-card__badge--pinned{background-color:#dbeafe;color:#1e40af}.post-card__badge--locked{background-color:#fef3c7;color:#92400e}.post-card__title{display:block;margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#1f2937;text-decoration:none;transition:color .2s ease-in-out}.post-card__title:hover{color:#3b82f6}.post-card__meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.post-card__author{font-weight:500}.post-card__separator{color:#d1d5db}.post-card__stats{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}.post-card__stat{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#6b7280}.post-card__stat-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.post-card__views{font-size:.75rem}@media (max-width: 640px){.post-card__content{flex-direction:column;gap:.75rem}.post-card__stats{flex-direction:row;align-items:center;justify-content:flex-start}}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem 0}.pagination__pages{display:flex;align-items:center;gap:.25rem}.pagination__page{min-width:2.5rem;height:2.5rem;padding:.5rem;font-size:.875rem;font-weight:500;color:#374151;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;transition:all .2s ease-in-out}.pagination__page:hover:not(.pagination__page--active){background-color:#f3f4f6;border-color:#9ca3af}.pagination__page--active{color:#fff;background-color:#3b82f6;border-color:#3b82f6;cursor:default}.pagination__ellipsis{padding:.5rem;color:#9ca3af}.post-list{display:flex;flex-direction:column;gap:1rem}.post-list__items{display:flex;flex-direction:column;gap:.75rem}.post-list-empty{text-align:center;padding:3rem 1rem;color:#6b7280}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background-color:#f9fafb;border-radius:.5rem;border:2px dashed #e5e7eb}.empty-state__icon{margin-bottom:1.5rem;color:#9ca3af}.empty-state__icon svg{width:4rem;height:4rem}.empty-state__title{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.empty-state__description{margin:0 0 1.5rem;font-size:1rem;color:#6b7280;max-width:28rem}.empty-state__action{margin-top:.5rem}@media (max-width: 640px){.empty-state{padding:3rem 1.5rem}.empty-state__icon svg{width:3rem;height:3rem}.empty-state__title{font-size:1.125rem}.empty-state__description{font-size:.9375rem}}.board-view{display:flex;flex-direction:column;gap:2rem}.board-view__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.board-view__title{margin:0 0 .5rem;font-size:1.875rem;font-weight:700;color:#1f2937}.board-view__description{margin:0;font-size:1rem;color:#6b7280}@media (max-width: 640px){.board-view__header{flex-direction:column;align-items:stretch}.board-view__title{font-size:1.5rem}}.textarea-group{display:flex;flex-direction:column;gap:.375rem;width:100%}.textarea-label{font-size:.875rem;font-weight:500;color:#374151}.textarea{width:100%;min-height:120px;padding:.625rem .875rem;font-size:.875rem;font-family:inherit;line-height:1.5;color:#1f2937;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;resize:vertical;transition:all .2s ease-in-out}.textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.textarea::placeholder{color:#9ca3af}.textarea:disabled{background-color:#f3f4f6;cursor:not-allowed}.textarea--error{border-color:#ef4444}.textarea--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.textarea-error{font-size:.75rem;color:#ef4444}.textarea-helper{font-size:.75rem;color:#6b7280}.comment-form{display:flex;flex-direction:column;gap:1rem}.comment-form__actions{display:flex;gap:.75rem;align-items:center}.comment-item{display:flex;flex-direction:column;gap:.75rem}.comment-item--nested{margin-left:2rem}.comment-item__card{padding:1rem}.comment-item__header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.comment-item__author{font-weight:600;color:#1f2937}.comment-item__time{font-size:.875rem;color:#9ca3af}.comment-item__content{color:#374151;line-height:1.6;white-space:pre-wrap;word-break:break-word}.comment-item__actions{display:flex;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.comment-item__action{padding:.25rem .5rem;font-size:.875rem;font-weight:500;color:#3b82f6;background:none;border:none;cursor:pointer;transition:color .2s ease-in-out}.comment-item__action:hover{color:#2563eb}.comment-item__reply-form{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.comment-item__replies{display:flex;flex-direction:column;gap:.75rem}@media (max-width: 640px){.comment-item--nested{margin-left:1rem}}.comment-list{display:flex;flex-direction:column;gap:1rem}.comment-list-empty{text-align:center;padding:2rem 1rem;color:#6b7280;background-color:#f9fafb;border-radius:.5rem}.post-view{display:flex;flex-direction:column;gap:2rem}.post-view__content{padding:2rem}.post-view__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.post-view__title{margin:0 0 .75rem;font-size:2rem;font-weight:700;color:#1f2937;line-height:1.3}.post-view__meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.post-view__author{font-weight:600}.post-view__separator{color:#d1d5db}.post-view__body{padding-top:1.5rem;font-size:1rem;line-height:1.7;color:#374151;white-space:pre-wrap;word-break:break-word}.post-view__comments{display:flex;flex-direction:column;gap:1.5rem}.post-view__comments-title{margin:0;font-size:1.5rem;font-weight:700;color:#1f2937}.post-view__locked{padding:1.5rem;background-color:#fef3c7;border:1px solid #fde68a;text-align:center;color:#92400e}.post-view__locked p{margin:0}@media (max-width: 640px){.post-view__content{padding:1.5rem}.post-view__header{flex-direction:column}.post-view__title{font-size:1.5rem}}.create-post-page{max-width:48rem;margin:0 auto}.create-post-card{padding:2rem}.create-post-title{margin:0 0 1.5rem;font-size:1.875rem;font-weight:700;color:#1f2937}.create-post-form{display:flex;flex-direction:column;gap:1.25rem}.create-post-actions{display:flex;gap:.75rem;padding-top:.5rem}@media (max-width: 640px){.create-post-card{padding:1.5rem}.create-post-title{font-size:1.5rem}}.user-profile{max-width:48rem;margin:0 auto}.user-profile__card{padding:2rem}.user-profile__header{display:flex;align-items:center;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.user-profile__avatar{width:5rem;height:5rem;border-radius:50%;overflow:hidden;flex-shrink:0}.user-profile__avatar img{width:100%;height:100%;object-fit:cover}.user-profile__avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#3b82f6;color:#fff;font-size:2rem;font-weight:700}.user-profile__info{flex:1}.user-profile__username{margin:0 0 .25rem;font-size:1.875rem;font-weight:700;color:#1f2937}.user-profile__role{margin:0 0 .5rem;font-size:.875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.user-profile__joined{margin:0;font-size:.875rem;color:#9ca3af}.user-profile__bio{padding-top:1.5rem}.user-profile__section-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:600;color:#1f2937}.user-profile__bio p{margin:0;color:#374151;line-height:1.6}.user-profile__stats{padding-top:1.5rem;border-top:1px solid #e5e7eb;margin-top:1.5rem}.user-profile__placeholder{margin:0;color:#9ca3af;font-style:italic}@media (max-width: 640px){.user-profile__card{padding:1.5rem}.user-profile__header{flex-direction:column;text-align:center}.user-profile__username{font-size:1.5rem}}.admin-dashboard{display:flex;flex-direction:column;gap:2rem}.admin-dashboard__title{margin:0;font-size:2rem;font-weight:700;color:#1f2937}.admin-dashboard__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.admin-dashboard__section-title{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#1f2937}.admin-dashboard__placeholder{margin:0;color:#9ca3af;font-style:italic}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 1rem;min-height:60vh}.not-found__title{margin:0;font-size:6rem;font-weight:700;color:#3b82f6;line-height:1}.not-found__subtitle{margin:1rem 0;font-size:2rem;font-weight:600;color:#1f2937}.not-found__text{margin:0 0 2rem;font-size:1.125rem;color:#6b7280;max-width:32rem}@media (max-width: 640px){.not-found__title{font-size:4rem}.not-found__subtitle{font-size:1.5rem}.not-found__text{font-size:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #3b82f6;--primary-dark: #2563eb;--secondary: #6b7280;--danger: #ef4444;--success: #10b981;--warning: #f59e0b;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--border-light: #f3f4f6;--border-normal: #e5e7eb;--border-dark: #d1d5db;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:inherit;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary)}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.3;color:var(--text-primary)}p{margin:0}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-dark)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}::selection{background-color:#3b82f633;color:var(--text-primary)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
