:root{--font-family:"Inter", system-ui, -apple-system, sans-serif;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-bg:#eff6ff;--color-on-primary:#fff;--color-bg:#f8fafc;--color-surface:#fff;--color-surface-alt:#f1f5f9;--color-text:#0f172a;--color-text-secondary:#64748b;--color-border:#e2e8f0;--color-success:#16a34a;--color-warning:#d97706;--color-danger:#dc2626;--badge-free-bg:#dcfce7;--badge-free-text:#15803d;--badge-paid-bg:#fef3c7;--badge-paid-text:#b45309;--badge-pro-bg:#ede9fe;--badge-pro-text:#6d28d9;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-card:0 1px 3px #0f172a14}[data-theme=dark]{--color-primary:#3b82f6;--color-primary-hover:#60a5fa;--color-primary-bg:#1e3a5f;--color-on-primary:#0f172a;--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-alt:#273449;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-border:#334155;--color-success:#22c55e;--color-warning:#fbbf24;--color-danger:#f87171}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.hamburger-btn{color:var(--color-text);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:8px;display:none}.sidebar-backdrop{display:none}@media (width<=768px){.hamburger-btn{justify-content:center;align-items:center;display:inline-flex}.sidebar{width:240px;height:100vh;transition:transform .25s;top:0;left:0;overflow-y:auto;transform:translate(-100%);background:var(--color-surface)!important;z-index:1100!important;position:fixed!important}.sidebar.sidebar-open{transform:translate(0)!important}.admin-sidebar{height:100vh;transition:transform .25s;top:0;left:0;overflow-y:auto;transform:translate(-100%);background:var(--color-surface)!important;z-index:1100!important;width:240px!important;position:fixed!important}.admin-sidebar.sidebar-open{transform:translate(0)!important}.admin-sidebar.sidebar-open .admin-brand-name,.admin-sidebar.sidebar-open .admin-menu-item span,.admin-sidebar.sidebar-open .btn-admin-portal-back span{display:inline!important}.sidebar-backdrop{background:#00000073;display:block;position:fixed;inset:0;z-index:1050!important}.topbar{left:0!important}.main-content,.admin-main-wrapper{margin-left:0!important}}.markdown-editor-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s;overflow:hidden}.markdown-editor-wrapper:focus-within{border-color:var(--color-primary)}.markdown-toolbar{background-color:var(--color-surface,var(--color-bg));border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:2px;padding:6px 8px;display:flex}.md-btn{color:var(--color-text-secondary,var(--color-text));cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:4px 7px;font-size:.8rem;line-height:1;transition:background .15s,color .15s;display:flex}.md-btn:hover{background-color:var(--color-border);color:var(--color-text)}.md-btn.active{background-color:var(--color-primary);color:#fff}.md-toolbar-separator{background:var(--color-border);width:1px;height:18px;margin:0 4px}.md-toolbar-spacer{flex:1}.md-btn-preview{font-size:.78rem}.markdown-preview-pane{background-color:var(--color-bg);min-height:100px;color:var(--color-text);padding:16px;font-size:.95rem}.markdown-preview-empty{color:var(--color-text-secondary,#999);font-style:italic}.md-rendered{line-height:1.6}.md-rendered p{margin:0 0 .5em}.md-rendered p:last-child{margin-bottom:0}.md-rendered strong{font-weight:700}.md-rendered em{font-style:italic}.md-rendered del{text-decoration:line-through}.md-rendered h1,.md-rendered h2,.md-rendered h3{margin:.6em 0 .3em;font-weight:700;line-height:1.3}.md-rendered h1{font-size:1.3em}.md-rendered h2{font-size:1.15em}.md-rendered h3{font-size:1em}.md-rendered ul,.md-rendered ol{margin:.4em 0;padding-left:1.4em}.md-rendered li{margin-bottom:.2em}.md-rendered blockquote{border-left:3px solid var(--color-primary);color:var(--color-text-secondary,#666);margin:.4em 0;padding-left:.8em;font-style:italic}.md-rendered code{background:var(--color-border);border-radius:3px;padding:.1em .35em;font-family:monospace;font-size:.9em}.md-rendered pre{background:var(--color-border);border-radius:6px;margin:.5em 0;padding:.8em 1em;overflow-x:auto}.md-rendered pre code{background:0 0;padding:0}.composer-textarea-content{background-color:var(--color-bg);color:var(--color-text);resize:vertical;box-sizing:border-box;border:none;border-radius:0;outline:none;width:100%;padding:16px;font-size:.95rem;line-height:1.5}.table-responsive{width:100%;overflow-x:auto}.table-responsive table{min-width:640px}@media (width<=768px){button,.menu-link,.hamburger-btn,a.btn{min-height:44px}}.layout-container{min-height:100vh;display:flex}.sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;justify-content:space-between;width:240px;padding:24px 16px;transition:background-color .3s,border-color .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{align-items:center;gap:12px;margin-bottom:24px;padding:8px;display:flex}.logo-icon{width:32px;height:32px;color:var(--color-primary);flex-shrink:0}.logo-text{color:var(--color-text);font-size:1.1rem;font-weight:700;line-height:1.2}.sidebar-menu{flex-direction:column;flex-grow:1;gap:4px;display:flex}.menu-link{border-radius:var(--radius-sm);color:var(--color-text-secondary);align-items:center;gap:12px;padding:10px 12px;font-size:.95rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.menu-link:hover{color:var(--color-primary);background-color:var(--color-primary-bg);transform:translate(4px)}.menu-link.active{color:var(--color-on-primary);background-color:var(--color-primary)}.menu-link.active:hover{color:var(--color-on-primary);background-color:var(--color-primary-hover);transform:none}.menu-icon{width:20px;height:20px}.sidebar-footer{border-top:1px solid var(--color-border);flex-direction:column;gap:12px;padding-top:16px;display:flex}.controls-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.theme-toggle-btn{background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.theme-toggle-btn:hover{background-color:var(--color-border);transform:scale(1.05)}.lang-select{background-color:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);cursor:pointer;outline:none;flex-grow:1;padding:8px 12px;font-size:.875rem;font-weight:500;transition:all .2s}.lang-select:focus{border-color:var(--color-primary)}.topbar{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:90;justify-content:space-between;align-items:center;height:64px;padding:0 32px;transition:background-color .3s,border-color .3s,left .3s;display:flex;position:fixed;top:0;left:240px;right:0}.page-title{color:var(--color-text);font-size:1.25rem;font-weight:600}.topbar-right{align-items:center;gap:16px;display:flex}.user-widget{position:relative}.avatar-btn{border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:10px;padding:4px 8px;transition:all .2s;display:flex}.avatar-btn:hover{background-color:var(--color-surface-alt)}.avatar-img{object-fit:cover;border:2px solid var(--color-border);border-radius:50%;width:32px;height:32px}.avatar-fallback{background-color:var(--color-primary-bg);width:32px;height:32px;color:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;font-weight:600;display:flex}.username-text{color:var(--color-text);font-size:.9rem;font-weight:500}.user-dropdown{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);z-index:200;flex-direction:column;width:180px;margin-top:8px;padding:6px 0;animation:.2s fadeIn;display:flex;position:absolute;top:100%;right:0;box-shadow:0 4px 12px #0f172a1a}.dropdown-item{color:var(--color-text);text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:.875rem;transition:background-color .2s;display:flex}.dropdown-item:hover{background-color:var(--color-surface-alt);color:var(--color-primary)}.dropdown-divider{background-color:var(--color-border);height:1px;margin:6px 0}.auth-actions{align-items:center;gap:16px;display:flex}.btn-primary{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.btn-register{color:var(--color-primary);border:1.5px solid var(--color-primary);border-radius:var(--radius-sm);background-color:#0000;align-items:center;gap:8px;padding:7px 16px;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.btn-register:hover{background-color:var(--color-primary-bg)}.login-link{color:var(--color-text-secondary);font-size:.825rem;font-weight:500;transition:color .2s}.login-link:hover{color:var(--color-primary);text-decoration:underline}.main-content{background-color:var(--color-bg);flex-grow:1;min-height:calc(100vh - 64px);margin-top:64px;margin-left:240px;padding:32px;transition:background-color .3s,margin-left .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.auth-container{background-color:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;transition:background-color .3s;display:flex}.auth-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-card);box-sizing:border-box;flex-direction:column;gap:24px;padding:40px 32px;transition:all .3s;display:flex}.auth-header{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.auth-logo{width:48px;height:48px;color:var(--color-primary)}.auth-title{color:var(--color-text);font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--color-text-secondary);font-size:.875rem}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--color-text);font-size:.875rem;font-weight:600}.form-input{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);outline:none;padding:10px 14px;font-size:.95rem;transition:border-color .2s}.form-input:focus{border-color:var(--color-primary)}.submit-btn{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:.95rem;font-weight:600;transition:background-color .2s;display:flex}.submit-btn:hover{background-color:var(--color-primary-hover)}.back-link{color:var(--color-primary);text-align:center;margin-top:12px;font-size:.875rem;font-weight:500;display:inline-block}.back-link:hover{text-decoration:underline}@media (width<=480px){.auth-container{padding:0 16px}.auth-card{padding:32px 16px}}.admin-layout-container{background-color:var(--color-bg);min-height:100vh;color:var(--color-text);font-family:var(--font-family);display:flex}.admin-sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 8px #00000005}.admin-sidebar-header{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;height:70px;padding:0 24px;display:flex}.admin-logo-box{background-color:var(--color-danger);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.admin-brand-name{color:var(--color-text);font-size:1.15rem;font-weight:800}.admin-sidebar-menu{flex-direction:column;flex-grow:1;gap:6px;padding:24px 16px;display:flex}.admin-menu-item{border-radius:var(--radius-md);color:var(--color-text-secondary);align-items:center;gap:12px;padding:12px 16px;font-size:.925rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.admin-menu-item:hover{background-color:var(--color-surface-alt);color:var(--color-text)}.admin-menu-item.active{color:var(--color-danger);background-color:#fee2e2}.admin-sidebar-footer{border-top:1px solid var(--color-border);padding:16px}.btn-admin-portal-back{border-radius:var(--radius-md);background-color:var(--color-surface-alt);border:1px solid var(--color-border);width:100%;color:var(--color-text-secondary);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.btn-admin-portal-back:hover{background-color:var(--color-border);color:var(--color-text)}.admin-main-wrapper{flex-direction:column;flex-grow:1;min-width:0;margin-left:240px;display:flex}.admin-topbar{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:90;justify-content:space-between;align-items:center;height:70px;padding:0 32px;display:flex;position:sticky;top:0}.topbar-console-title{color:var(--color-text);margin:0;font-size:1.25rem;font-weight:800}.topbar-right-section{align-items:center;gap:20px;display:flex}.topbar-theme-toggles{background-color:var(--color-surface-alt);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex}.theme-icon-btn{width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-icon-btn:hover{color:var(--color-text)}.theme-icon-btn.active{background-color:var(--color-surface);color:var(--color-primary);box-shadow:0 1px 2px #0000000d}.topbar-divider{background-color:var(--color-border);width:1px;height:24px}.topbar-admin-profile{align-items:center;gap:10px;display:flex}.admin-initials-badge{background-color:var(--color-danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:800;display:flex}.admin-meta-info{flex-direction:column;display:flex}.admin-name{color:var(--color-text);font-size:.85rem;font-weight:700}.admin-role{color:var(--color-text-secondary);font-size:.725rem}.btn-admin-logout{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.btn-admin-logout:hover{border-color:var(--color-danger);color:var(--color-danger);background-color:#fee2e2}.admin-subpage-content{flex-grow:1;padding:32px}.admin-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:20px;padding:24px;display:flex}.admin-page-title-row{justify-content:space-between;align-items:center;gap:24px;margin-bottom:24px;display:flex}.admin-page-title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:800}.btn-admin-primary{background-color:var(--color-danger);color:#fff;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 4px #dc26261a}.btn-admin-primary:hover{background-color:#b91c1c;transform:translateY(-1px)}.admin-table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto}.admin-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.admin-th{background-color:var(--color-surface-alt);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);padding:12px 16px;font-weight:700}.admin-td{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:14px 16px}.admin-table tr:last-child .admin-td{border-bottom:none}.admin-table tr:hover{background-color:#f8fafc80}.admin-status-badge{text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:800}.admin-status-badge.status-active{color:#16a34a;background-color:#dcfce7}.admin-status-badge.status-banned{color:var(--color-danger);background-color:#fee2e2}.admin-status-badge.status-pending{color:#d97706;background-color:#fef3c7}.btn-table-action-edit,.btn-table-action-delete,.btn-table-action-reset{border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-size:.8rem;font-weight:700;transition:all .2s;display:inline-flex}.btn-table-action-edit:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.btn-table-action-delete:hover{border-color:var(--color-danger);color:var(--color-danger);background-color:#fee2e2}.btn-table-action-reset:hover{border-color:var(--color-warning);color:var(--color-warning);background-color:#fef3c7}.admin-pagination-row{justify-content:space-between;align-items:center;margin-top:16px;display:flex}.admin-pagination-info{color:var(--color-text-secondary);font-size:.825rem}.admin-pagination-btns{gap:8px;display:flex}@media (width<=992px){.admin-sidebar{width:70px}.admin-brand-name,.admin-menu-item span,.btn-admin-portal-back span{display:none}.admin-main-wrapper{margin-left:70px}}.home-container{flex-direction:column;gap:32px;display:flex}.home-grid{grid-template-columns:1fr 280px;gap:32px;display:grid}.home-main{flex-direction:column;gap:32px;display:flex}.hero-banner{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));border-radius:var(--radius-lg);color:var(--color-on-primary);flex-direction:column;gap:16px;padding:48px 40px;display:flex;box-shadow:0 4px 20px #2563eb26}.hero-title{letter-spacing:-.025em;margin:0;font-size:2.5rem;font-weight:800}.hero-subtitle{opacity:.9;max-width:600px;font-size:1.1rem;line-height:1.6}.hero-cta{gap:16px;margin-top:8px;display:flex}.btn-cta-primary{background-color:var(--color-surface);color:var(--color-primary);border-radius:var(--radius-md);border:none;padding:12px 24px;font-size:.975rem;font-weight:600;transition:all .2s}.btn-cta-primary:hover{background-color:var(--color-surface-alt);transform:translateY(-1px)}.btn-cta-secondary{color:#fff;border-radius:var(--radius-md);background-color:#ffffff26;border:1px solid #ffffff40;padding:12px 24px;font-size:.975rem;font-weight:600;transition:all .2s}.btn-cta-secondary:hover{background-color:#ffffff40;transform:translateY(-1px)}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{color:var(--color-text);font-size:1.25rem;font-weight:700}.section-link{color:var(--color-primary);font-size:.875rem;font-weight:600;transition:opacity .2s}.section-link:hover{opacity:.8;text-decoration:underline}.resources-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;display:grid}.resource-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);flex-direction:column;justify-content:space-between;gap:16px;padding:20px;transition:all .2s;display:flex}.resource-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0f172a0d}.resource-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.resource-meta{flex-direction:column;gap:4px;display:flex}.resource-name{color:var(--color-text);font-size:1rem;font-weight:600}.resource-icon{object-fit:cover;border-radius:var(--radius-sm);background-color:var(--color-surface-alt);width:36px;height:36px}.resource-badge{text-transform:uppercase;border-radius:999px;padding:4px 8px;font-size:.725rem;font-weight:700}.badge-free{background-color:var(--badge-free-bg);color:var(--badge-free-text)}.badge-paid{background-color:var(--badge-paid-bg);color:var(--badge-paid-text)}.badge-pro{background-color:var(--badge-pro-bg);color:var(--badge-pro-text)}.resource-desc{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;height:42px;font-size:.875rem;line-height:1.5;display:-webkit-box;overflow:hidden}.btn-visit{background-color:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-align:center;width:fit-content;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s}.btn-visit:hover{background-color:var(--color-primary-bg);color:var(--color-primary);border-color:var(--color-primary)}.empty-state{background-color:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;color:var(--color-text-secondary);padding:40px;font-size:.95rem}.quick-links-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;display:grid}.quick-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:20px;padding:32px 28px;transition:all .2s;display:flex}.quick-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0f172a0d}.quick-card-icon{width:48px;height:48px;color:var(--color-primary);background-color:var(--color-primary-bg);border-radius:var(--radius-md);padding:10px}.quick-card-title{color:var(--color-text);font-size:1.25rem;font-weight:700}.quick-card-desc{color:var(--color-text-secondary);font-size:.9rem;line-height:1.6}.btn-browse{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;width:fit-content;padding:10px 20px;font-size:.9rem;font-weight:600;transition:background-color .2s}.btn-browse:hover{background-color:var(--color-primary-hover)}.home-sidebar{flex-direction:column;gap:24px;display:flex}.widget-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:24px 20px;display:flex}.widget-title{color:var(--color-text);margin-bottom:4px;font-size:1.1rem;font-weight:700}.widget-divider{background-color:var(--color-border);height:1px;margin-bottom:4px}.sidebar-post-list{flex-direction:column;gap:14px;display:flex}.sidebar-post-item{border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;gap:8px;padding:10px;transition:background-color .2s;display:flex}.sidebar-post-item:hover{background-color:var(--color-surface-alt)}.post-item-header{align-items:center;gap:8px;display:flex}.post-item-avatar{object-fit:cover;border:1px solid var(--color-border);border-radius:50%;width:24px;height:24px}.post-item-avatar-fallback{background-color:var(--color-primary-bg);width:24px;height:24px;color:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.675rem;font-weight:700;display:flex}.post-item-author{color:var(--color-text);font-size:.8rem;font-weight:600}.post-item-snippet{color:var(--color-text-secondary);word-break:break-word;font-size:.825rem;line-height:1.4}.post-item-meta{color:var(--color-text-secondary);align-items:center;gap:12px;font-size:.75rem;display:flex}.meta-group{align-items:center;gap:4px;display:flex}.btn-sidebar-action{background-color:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-sm);text-align:center;border:none;width:100%;padding:10px;font-size:.875rem;font-weight:600;transition:all .2s}.btn-sidebar-action:hover{background-color:var(--color-primary);color:var(--color-on-primary)}.promo-box{background-color:var(--color-surface-alt);border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex}.promo-text{color:var(--color-text-secondary);font-size:.825rem;font-weight:500;line-height:1.4}.btn-promo-login{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;width:100%;padding:8px 16px;font-size:.825rem;font-weight:600;transition:background-color .2s}.btn-promo-login:hover{background-color:var(--color-primary-hover)}.hero-search-form{width:100%;max-width:580px;position:relative}.hero-search-wrap{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#ffffff26;border:1.5px solid #ffffff59;align-items:center;gap:10px;padding:4px 4px 4px 14px;transition:border-color .2s,background-color .2s;display:flex}.hero-search-wrap:focus-within{background-color:#ffffff40;border-color:#ffffffb3}.hero-search-icon{color:#fffc;flex-shrink:0}.hero-search-input{color:#fff;background:0 0;border:none;outline:none;flex:1;padding:8px 0;font-size:.95rem}.hero-search-input::placeholder{color:#fff9}.hero-search-btn{color:var(--color-primary);border-radius:calc(var(--radius-md) - 4px);cursor:pointer;white-space:nowrap;background-color:#fff;border:none;padding:9px 18px;font-size:.875rem;font-weight:700;transition:background-color .2s}.hero-search-btn:hover{background-color:var(--color-surface-alt)}.hero-search-dropdown{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:500;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #00000026}.search-drop-loading{color:var(--color-text-secondary);padding:14px 16px;font-size:.875rem}.search-drop-item{cursor:pointer;color:var(--color-text);align-items:center;gap:10px;padding:10px 16px;font-size:.875rem;transition:background-color .15s;display:flex}.search-drop-item:hover{background-color:var(--color-surface-alt)}.drop-icon{color:var(--color-text-secondary);flex-shrink:0}.drop-tag{color:var(--color-text-secondary);background-color:var(--color-surface-alt);white-space:nowrap;border-radius:999px;margin-left:auto;padding:2px 8px;font-size:.75rem}.search-drop-viewall{color:var(--color-primary);cursor:pointer;border-top:1px solid var(--color-border);text-align:center;padding:10px 16px;font-size:.85rem;font-weight:600;transition:background-color .15s}.search-drop-viewall:hover{background-color:var(--color-primary-bg)}.top-searches-list{flex-direction:column;gap:4px;display:flex}.top-search-item{text-align:left;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background-color .15s;display:flex}.top-search-item:hover{background-color:var(--color-surface-alt)}.top-search-rank{color:var(--color-primary);min-width:24px;font-size:.75rem;font-weight:700}.top-search-term{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;font-weight:500;overflow:hidden}.top-search-count{color:var(--color-text-secondary);background-color:var(--color-surface-alt);border-radius:999px;padding:2px 7px;font-size:.75rem}@media (width>=769px) and (width<=1023px){.home-grid{grid-template-columns:1fr}.home-sidebar{display:none}}@media (width<=768px){.home-grid{grid-template-columns:1fr}.home-sidebar{width:100%;display:block}}@media (width<=640px){.hero-banner{padding:32px 24px}.hero-title{font-size:1.85rem}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0f172a66;justify-content:center;align-items:center;animation:.2s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.modal-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;gap:20px;width:100%;max-width:580px;max-height:90vh;padding:32px;animation:.3s cubic-bezier(.34,1.56,.64,1) modalSlideUp;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--color-text);font-size:1.25rem;font-weight:700}.btn-modal-close{color:var(--color-text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.btn-modal-close:hover{background-color:var(--color-surface-alt);color:var(--color-text)}.form-row{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.form-group-text{color:var(--color-text-secondary);margin-top:4px;font-size:.825rem}.icon-upload-section{background-color:var(--color-surface-alt);border:1px dashed var(--color-border);border-radius:var(--radius-md);align-items:center;gap:16px;padding:12px;display:flex}.icon-preview-box{border-radius:var(--radius-sm);background-color:var(--color-surface);border:1px solid var(--color-border);justify-content:center;align-items:center;width:54px;height:54px;display:flex;overflow:hidden}.icon-preview-img{object-fit:cover;width:100%;height:100%}.icon-upload-btn-wrapper{display:inline-block;position:relative;overflow:hidden}.btn-upload-file{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);cursor:pointer;padding:8px 16px;font-size:.825rem;font-weight:600;transition:all .2s}.btn-upload-file:hover{background-color:var(--color-surface-alt);border-color:var(--color-text-secondary)}.tag-input-container{flex-direction:column;gap:8px;display:flex}.tags-input-wrapper{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);flex-wrap:wrap;gap:6px;min-height:42px;padding:8px;display:flex}.tag-chip{background-color:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-sm);align-items:center;gap:6px;padding:4px 8px;font-size:.775rem;font-weight:600;display:flex}.btn-remove-tag{color:var(--color-primary);cursor:pointer;opacity:.8;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.btn-remove-tag:hover{opacity:1}.tags-inline-input{color:var(--color-text);background:0 0;border:none;outline:none;flex-grow:1;min-width:100px;font-size:.875rem}.modal-actions-row{border-top:1px solid var(--color-border);justify-content:flex-end;gap:12px;padding-top:16px;display:flex}.btn-modal-cancel{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);padding:10px 20px;font-size:.9rem;font-weight:600;transition:background-color .2s}.btn-modal-cancel:hover{background-color:var(--color-surface-alt)}.btn-modal-submit{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;padding:10px 20px;font-size:.9rem;font-weight:600;transition:background-color .2s}.btn-modal-submit:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-modal-submit:disabled{opacity:.6;cursor:not-allowed}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=640px){.modal-container{border-radius:0!important;width:100vw!important;max-width:none!important;height:100vh!important;max-height:none!important;margin:0!important;padding:24px 16px!important;overflow-y:auto!important}.form-row{grid-template-columns:1fr!important}}.resources-header-row{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.resources-title{color:var(--color-text);font-size:1.75rem;font-weight:800}.btn-new-resource{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:background-color .2s;display:flex}.btn-new-resource:hover{background-color:var(--color-primary-hover)}.filter-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);justify-content:space-between;align-items:center;gap:24px;margin-bottom:32px;padding:12px 20px;display:flex}.tabs-group{gap:8px;display:flex}.tab-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);background:0 0;border:none;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s}.tab-btn:hover{color:var(--color-text);background-color:var(--color-surface-alt)}.tab-btn.active{background-color:var(--color-primary-bg);color:var(--color-primary)}.search-wrapper{width:100%;max-width:320px;position:relative}.search-input{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);outline:none;padding:8px 16px 8px 36px;font-size:.875rem;transition:border-color .2s}.search-input:focus{border-color:var(--color-primary);background-color:var(--color-surface)}.search-icon-inside{color:var(--color-text-secondary);pointer-events:none;width:16px;height:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.directory-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;display:grid}.directory-card{position:relative}.card-actions-overlay{opacity:0;z-index:10;gap:6px;transition:opacity .2s;display:flex;position:absolute;top:12px;right:12px}.directory-card:hover .card-actions-overlay{opacity:1}.btn-card-action{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);width:28px;height:28px;box-shadow:var(--shadow-card);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-card-action:hover{background-color:var(--color-surface-alt);color:var(--color-primary);transform:scale(1.1)}.btn-card-action.delete:hover{color:var(--color-danger);background-color:#fee2e2;border-color:#fca5a5}.detail-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:32px;padding:40px;display:flex}.detail-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:24px;display:flex}.detail-header-left{align-items:center;gap:24px;display:flex}.detail-icon-large{border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--color-border);background-color:var(--color-surface-alt);width:80px;height:80px}.detail-meta{flex-direction:column;gap:8px;display:flex}.detail-name{color:var(--color-text);font-size:1.75rem;font-weight:800;line-height:1.2}.detail-badge-row,.detail-header-actions{align-items:center;gap:12px;display:flex}.btn-detail-edit{background-color:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.btn-detail-edit:hover{background-color:var(--color-border)}.btn-detail-delete{color:var(--color-danger);border-radius:var(--radius-sm);background-color:#fee2e2;border:1px solid #fca5a5;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.btn-detail-delete:hover{color:#fff;background-color:#fca5a5}.detail-content{flex-direction:column;gap:28px;display:flex}.detail-desc-block{flex-direction:column;gap:12px;display:flex}.detail-desc-title{color:var(--color-text);font-size:1.1rem;font-weight:700}.detail-desc-text{color:var(--color-text-secondary);white-space:pre-wrap;font-size:.975rem;line-height:1.6}.detail-info-block{border-top:1px solid var(--color-border);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px;padding-top:28px;display:grid}.info-column{flex-direction:column;gap:12px;display:flex}.info-title{color:var(--color-text);font-size:1rem;font-weight:700}.info-chips{flex-wrap:wrap;gap:8px;display:flex}.info-chip{background-color:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-sm);padding:6px 12px;font-size:.825rem;font-weight:600}.info-list{color:var(--color-text-secondary);flex-direction:column;gap:8px;padding-left:20px;font-size:.925rem;display:flex}.info-list-item{line-height:1.5}.pagination-row{justify-content:center;align-items:center;gap:16px;margin-top:32px;display:flex}.btn-page{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s}.btn-page:hover:not(:disabled){background-color:var(--color-primary-bg);color:var(--color-primary);border-color:var(--color-primary)}.btn-page:disabled{opacity:.4;cursor:not-allowed}.page-indicator{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}@media (width<=1023px){.directory-grid{grid-template-columns:repeat(2,1fr)}.detail-info-block{grid-template-columns:1fr;gap:24px}}@media (width<=640px){.directory-grid{grid-template-columns:1fr}.filter-section{flex-direction:column;align-items:stretch;gap:16px}.search-wrapper{max-width:100%}.detail-header{flex-direction:column;align-items:stretch;gap:20px}.detail-header-actions{width:100%}.detail-header-actions button,.detail-header-actions a{flex-grow:1;justify-content:center}}.knowledge-container{grid-template-columns:220px 1fr;align-items:flex-start;gap:32px;display:grid}.knowledge-sidebar{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:20px 16px;display:flex}.sidebar-title-row{justify-content:space-between;align-items:center;display:flex}.sidebar-title{color:var(--color-text);font-size:1.05rem;font-weight:700}.btn-add-subject{color:var(--color-primary);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.btn-add-subject:hover{background-color:var(--color-primary-bg);transform:scale(1.05)}.subjects-list{flex-direction:column;gap:6px;display:flex}.subject-item{border-radius:var(--radius-sm);flex-direction:column;display:flex;overflow:hidden}.subject-header{text-align:left;width:100%;color:var(--color-text);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px;font-size:.925rem;font-weight:600;transition:all .2s;display:flex}.subject-header:hover{background-color:var(--color-surface-alt)}.subject-header-left{flex-grow:1;align-items:center;gap:8px;display:flex}.subject-actions{align-items:center;gap:4px;display:flex}.btn-add-topic{color:var(--color-text-secondary);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:2px;transition:all .2s;display:flex}.btn-add-topic:hover{color:var(--color-primary);background-color:var(--color-primary-bg)}.topics-sublist{border-left:1px solid var(--color-border);flex-direction:column;gap:2px;margin-top:2px;margin-bottom:6px;padding-left:20px;display:flex}.topic-btn{text-align:left;color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:none;width:100%;padding:6px 8px;font-size:.85rem;transition:all .2s;overflow:hidden}.topic-btn:hover{color:var(--color-primary);background-color:var(--color-surface-alt)}.topic-btn.active{background-color:var(--color-primary-bg);color:var(--color-primary);font-weight:600}.knowledge-main{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:24px;min-height:480px;padding:32px;display:flex}.topic-header-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.topic-title{color:var(--color-text);font-size:1.5rem;font-weight:800}.btn-new-article{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);border:none;align-items:center;gap:6px;padding:8px 16px;font-size:.875rem;font-weight:600;transition:background-color .2s;display:flex}.btn-new-article:hover{background-color:var(--color-primary-hover)}.articles-list{flex-direction:column;gap:16px;display:flex}.article-card{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;gap:12px;padding:20px;transition:all .2s;display:flex}.article-card:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #0f172a0a}.article-card-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.article-title{color:var(--color-text);font-size:1.15rem;font-weight:700}.pdf-icon-indicator{color:var(--color-danger);border-radius:var(--radius-sm);background-color:#fee2e2;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;font-weight:700;display:flex}.article-snippet{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;height:40px;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.article-meta-row{color:var(--color-text-secondary);justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.article-status-badge{text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:700}.status-published{color:#16a34a;background-color:#dcfce7}.status-draft{color:#64748b;background-color:#f1f5f9}@media (width<=768px){.knowledge-container{grid-template-columns:1fr}}@media (width>=769px){.knowledge-subject-nav{display:contents}.knowledge-subject-nav summary{display:none}}@media (width<=768px){.knowledge-subject-nav summary{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;justify-content:space-between;align-items:center;padding:12px 16px;font-weight:700;display:flex}.knowledge-subject-nav summary::-webkit-details-marker{display:none}.knowledge-subject-nav summary:after{content:"▼";color:var(--color-text-secondary);font-size:.75rem}.knowledge-subject-nav[open] summary:after{content:"▲"}.knowledge-subject-nav>:not(summary){margin-top:16px}}.subject-header .subject-actions{display:none}.subject-header:hover .subject-actions{display:flex}.topic-item-row{justify-content:space-between;align-items:center;width:100%;display:flex;position:relative}.topic-item-row .topic-btn{flex-grow:1;padding-right:42px}.topic-actions{background-color:var(--color-surface);align-items:center;gap:4px;padding-left:4px;display:none;position:absolute;right:4px}.topic-item-row:hover .topic-actions{display:flex}.btn-edit-subject,.btn-delete-subject,.btn-edit-topic,.btn-delete-topic{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:2px;transition:all .2s;display:flex}.btn-edit-subject:hover,.btn-edit-topic:hover{color:var(--color-primary);background-color:var(--color-primary-bg)}.btn-delete-subject:hover,.btn-delete-topic:hover{color:var(--color-danger);background-color:#fee2e2}.article-detail-container{flex-direction:column;gap:20px;display:flex}.article-breadcrumbs{color:var(--color-text-secondary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);flex-wrap:wrap;align-items:center;gap:6px;padding:10px 16px;font-size:.85rem;font-weight:500;display:flex}.breadcrumb-item.link{color:var(--color-primary);cursor:pointer;transition:color .2s}.breadcrumb-item.link:hover{color:var(--color-primary-hover);text-decoration:underline}.breadcrumb-item.active{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;max-width:300px;font-weight:700;overflow:hidden}.breadcrumb-sep{opacity:.5;color:var(--color-text-secondary)}.article-detail-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:24px;padding:32px;display:flex}.article-detail-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:20px;display:flex}.article-detail-title{color:var(--color-text);margin:0;font-size:1.75rem;font-weight:800;line-height:1.3}.article-detail-meta{color:var(--color-text-secondary);align-items:center;gap:6px;font-size:.825rem;font-weight:500;display:flex}.article-content-block{min-height:200px}.no-content-text{color:var(--color-text-secondary);font-style:italic}.markdown-body{color:var(--color-text);font-size:1rem;line-height:1.7}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{color:var(--color-text);margin-top:24px;margin-bottom:12px;font-weight:700;line-height:1.25}.markdown-body h1{border-bottom:1px solid var(--color-border);padding-bottom:6px;font-size:1.5rem}.markdown-body h2{border-bottom:1px solid var(--color-border);padding-bottom:4px;font-size:1.35rem}.markdown-body h3{font-size:1.2rem}.markdown-body h4{font-size:1.05rem}.markdown-body p{margin-top:0;margin-bottom:16px}.markdown-body ul,.markdown-body ol{margin-top:0;margin-bottom:16px;padding-left:24px}.markdown-body li{margin-bottom:6px}.markdown-body code{background-color:var(--color-surface-alt);border-radius:var(--radius-sm);color:var(--color-danger);padding:2px 6px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85em}.markdown-body pre{background-color:var(--color-surface-alt);border-radius:var(--radius-md);margin-top:0;margin-bottom:16px;padding:16px;overflow-x:auto}.markdown-body pre code{color:inherit;background-color:#0000;padding:0;font-size:.9em}.markdown-body blockquote{border-left:4px solid var(--color-primary);color:var(--color-text-secondary);background-color:var(--color-primary-bg);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:0 0 16px;padding:8px 16px}.markdown-body table{border-collapse:collapse;width:100%;margin-top:12px;margin-bottom:24px;font-size:.9rem}.markdown-body th,.markdown-body td{border:1px solid var(--color-border);text-align:left;padding:8px 12px}.markdown-body th{background-color:var(--color-surface-alt);font-weight:700}.markdown-body tr:nth-child(2n){background-color:#f1f5f966}.article-attachment-section{border-top:1px solid var(--color-border);flex-direction:column;gap:12px;padding-top:24px;display:flex}.section-title{color:var(--color-text);margin:0;font-size:1rem;font-weight:700}.pdf-attachment-card{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:20px;padding:16px 20px;display:flex}.pdf-card-left{align-items:center;gap:16px;display:flex}.pdf-icon-box{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:44px;height:44px;color:var(--color-danger);justify-content:center;align-items:center;display:flex;box-shadow:0 1px 2px #0000000d}.pdf-info-box{flex-direction:column;gap:2px;display:flex}.pdf-name{color:var(--color-text);word-break:break-all;font-size:.9rem;font-weight:700}.pdf-size{color:var(--color-text-secondary);font-size:.775rem}.pdf-actions{gap:8px;display:flex}.btn-pdf-open,.btn-pdf-download{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:6px;padding:8px 14px;font-size:.825rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.btn-pdf-open:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.btn-pdf-download:hover{border-color:var(--color-success);color:var(--color-success);background-color:#dcfce7}.btn-pdf-download:disabled{opacity:.6;cursor:not-allowed}@media (width<=768px){.article-detail-header,.pdf-attachment-card{flex-direction:column;align-items:stretch;gap:16px}.pdf-actions{justify-content:space-between}.pdf-actions a,.pdf-actions button{flex-grow:1;justify-content:center}}.guides-container{flex-direction:column;gap:24px;display:flex}.guides-header-row{justify-content:space-between;align-items:center;gap:24px;display:flex}.guides-title-block{flex-direction:column;gap:4px;display:flex}.guides-title{color:var(--color-text);margin:0;font-size:1.75rem;font-weight:800}.guides-subtitle{color:var(--color-text-secondary);max-width:600px;margin:0;font-size:.95rem}.btn-create-guide{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 4px #2563eb1a}.btn-create-guide:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.guides-filter-row{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);justify-content:space-between;align-items:center;gap:16px;padding:10px 16px;display:flex}.guides-tabs{background-color:var(--color-surface-alt);border-radius:var(--radius-md);gap:4px;padding:4px;display:flex}.guide-tab-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.guide-tab-btn:hover{color:var(--color-text)}.guide-tab-btn.active{background-color:var(--color-surface);color:var(--color-primary);box-shadow:0 1px 2px #0000000d}.category-filter-wrapper{min-width:180px}.category-select{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);width:100%;color:var(--color-text);cursor:pointer;outline:none;padding:8px 12px;font-size:.875rem;font-weight:500;transition:border-color .2s}.category-select:focus{border-color:var(--color-primary)}.guides-list{flex-direction:column;gap:16px;display:flex}.guide-card-horizontal{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-card);align-items:center;gap:20px;padding:20px;transition:all .2s;display:flex}.guide-card-horizontal:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 16px #0f172a0f}.guide-card-icon-container{flex-shrink:0}.guide-card-icon-circle{border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.guide-card-icon-circle.icon-free{background-color:var(--color-primary-bg);color:var(--color-primary)}.guide-card-icon-circle.icon-pro{background-color:var(--badge-pro-bg);color:var(--badge-pro-text)}.guide-card-body{flex-direction:column;flex-grow:1;gap:4px;display:flex}.guide-card-category{color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.guide-card-title{color:var(--color-text);margin:0;font-size:1.15rem;font-weight:700}.guide-card-description{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.guide-card-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:12px;display:flex}.guide-access-badge{text-transform:uppercase;border-radius:6px;align-items:center;padding:4px 10px;font-size:.725rem;font-weight:800;display:flex}.guide-access-badge.badge-free{background-color:var(--badge-free-bg);color:var(--badge-free-text)}.guide-access-badge.badge-pro{background-color:var(--badge-pro-bg);color:var(--badge-pro-text)}.guide-card-btn-view{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);background:0 0;align-items:center;gap:4px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.guide-card-horizontal:hover .guide-card-btn-view{background-color:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.guides-pagination{justify-content:center;align-items:center;gap:16px;margin-top:12px;display:flex}.btn-guides-page{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-md);cursor:pointer;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s}.btn-guides-page:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-guides-page:disabled{opacity:.5;cursor:not-allowed}.guides-page-indicator{color:var(--color-text-secondary);font-size:.875rem}.empty-state-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-card);flex-direction:column;justify-content:center;align-items:center;padding:64px 32px;display:flex}.empty-state-card h3{color:var(--color-text);margin:0 0 8px;font-size:1.25rem;font-weight:700}.empty-state-card p{color:var(--color-text-secondary);max-width:380px;margin:0;font-size:.925rem;line-height:1.6}@media (width<=768px){.guides-header-row{flex-direction:column;align-items:flex-start;gap:16px}.btn-create-guide{justify-content:center;width:100%}.guides-filter-row{flex-direction:column;align-items:stretch}.guides-tabs{justify-content:space-between}.guide-tab-btn{text-align:center;flex-grow:1}.guide-card-horizontal{flex-direction:column;align-items:flex-start;gap:16px}.guide-card-actions{border-top:1px solid var(--color-border);flex-direction:row;justify-content:space-between;align-items:center;width:100%;padding-top:16px}}.guide-detail-container{flex-direction:column;gap:20px;display:flex;position:relative}.login-toast{background-color:var(--color-surface);border:1px solid var(--color-primary);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);z-index:1100;max-width:420px;padding:16px 20px;animation:.3s cubic-bezier(.16,1,.3,1) forwards slideInRight;position:fixed;top:24px;right:24px;box-shadow:0 10px 25px -5px #0f172a1f,0 8px 10px -6px #0f172a1f}@keyframes slideInRight{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:translate(0)}}.toast-content{flex-direction:column;gap:12px;display:flex}.toast-text{color:var(--color-text);font-size:.925rem;font-weight:600;line-height:1.4}.toast-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.btn-toast-signin{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:700;transition:background-color .2s;display:flex}.btn-toast-signin:hover{background-color:var(--color-primary-hover)}.btn-toast-close{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.btn-toast-close:hover{background-color:var(--color-surface-alt);color:var(--color-text)}.btn-back-link{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;background:0 0;background-color:var(--color-surface);align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-back-link:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translate(-2px)}.guide-detail-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:32px;padding:32px;display:flex}.guide-detail-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:32px;padding-bottom:24px;display:flex}.guide-detail-title-col{flex-direction:column;flex-grow:1;gap:12px;display:flex}.guide-meta-labels{align-items:center;gap:8px;display:flex}.guide-category-chip{background-color:var(--color-surface-alt);color:var(--color-text-secondary);text-transform:uppercase;border-radius:6px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:700;display:flex}.guide-detail-title{color:var(--color-text);margin:0;font-size:1.75rem;font-weight:800;line-height:1.3}.guide-timestamp{color:var(--color-text-secondary);align-items:center;font-size:.8rem;display:flex}.guide-detail-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:12px;display:flex}.owner-buttons{gap:8px;display:flex}.btn-action-edit,.btn-action-delete{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:6px;padding:8px 14px;font-size:.825rem;font-weight:600;transition:all .2s;display:flex}.btn-action-edit:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.btn-action-delete:hover{border-color:var(--color-danger);color:var(--color-danger);background-color:#fee2e2}.btn-download-trigger{color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:10px;padding:12px 24px;font-size:.95rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 6px -1px #0000001a}.btn-download-trigger.free-trigger{background-color:var(--color-primary)}.btn-download-trigger.free-trigger:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px)}.btn-download-trigger.pro-trigger{background:linear-gradient(135deg,#6d28d9 0%,#4c1d95 100%)}.btn-download-trigger.pro-trigger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 12px -2px #6d28d940}.btn-download-trigger:disabled{opacity:.6;cursor:not-allowed}.guide-detail-body{flex-direction:column;gap:20px;display:flex}.body-text-content{color:var(--color-text-secondary);white-space:pre-wrap;margin:0;font-size:.975rem;line-height:1.7}.attached-document-card{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:16px;margin-top:12px;padding:16px 20px;display:flex}.card-doc-icon{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:44px;height:44px;color:var(--color-danger);justify-content:center;align-items:center;display:flex;box-shadow:0 1px 2px #0000000d}.card-doc-info{flex-direction:column;flex-grow:1;gap:2px;display:flex}.doc-label{color:var(--color-text);font-size:.875rem;font-weight:700}.doc-type{color:var(--color-text-secondary);font-size:.775rem}.doc-license{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:.725rem;font-weight:800}@media (width<=768px){.guide-detail-header{flex-direction:column;align-items:stretch;gap:24px}.guide-detail-actions{align-items:stretch}.owner-buttons{justify-content:space-between}.owner-buttons button{flex-grow:1;justify-content:center}.btn-download-trigger{justify-content:center;width:100%}.login-toast{max-width:none;left:16px;right:16px}}.community-page-container{flex-direction:column;gap:24px;display:flex}.community-tabs-nav{border-bottom:2px solid var(--color-border);background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);gap:24px;padding:0 16px;display:flex}.community-tab-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:8px;margin-bottom:-2px;padding:16px 8px;font-size:.95rem;font-weight:700;transition:all .2s;display:flex}.community-tab-btn:hover{color:var(--color-text)}.community-tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.forum-tab-panel{flex-direction:column;gap:24px;display:flex}.post-composer-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:24px;display:flex}.composer-card-title{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:700}.composer-error-alert{color:var(--color-danger);border-radius:var(--radius-sm);background-color:#fee2e2;border:1px solid #fca5a5;align-items:center;gap:8px;padding:12px;font-size:.85rem;font-weight:600;display:flex}.composer-input-title{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text);outline:none;padding:12px 16px;font-size:.95rem;font-weight:600;transition:border-color .2s}.composer-input-title:focus{border-color:var(--color-primary)}.composer-tags-container{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;display:flex}.composer-tags-list{flex-wrap:wrap;gap:6px;display:flex}.composer-tag-chip{background-color:var(--color-primary-bg);color:var(--color-primary);border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:.8rem;font-weight:700;display:flex}.btn-remove-tag{color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:2px;display:flex}.btn-remove-tag:hover{background-color:var(--color-surface)}.composer-input-tag{color:var(--color-text);background-color:#0000;border:none;outline:none;flex-grow:1;min-width:120px;font-size:.875rem}.composer-attachment-row{align-items:center;display:flex}.attachment-preview-box{border-radius:var(--radius-sm);border:1px solid var(--color-border);background-color:var(--color-bg);width:90px;height:90px;position:relative;overflow:hidden}.attachment-img-preview{object-fit:cover;width:100%;height:100%}.btn-remove-attachment{color:#fff;cursor:pointer;background-color:#0f172a99;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;transition:background-color .2s;display:flex;position:absolute;top:4px;right:4px}.btn-remove-attachment:hover{background-color:#dc2626e6}.attachment-upload-btn-wrapper{position:relative;overflow:hidden}.btn-trigger-upload{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.btn-trigger-upload:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.file-input-hidden{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.composer-actions-row{border-top:1px solid var(--color-border);justify-content:flex-end;align-items:center;gap:16px;padding-top:16px;display:flex}.cooldown-countdown-text{color:var(--color-danger);font-size:.85rem;font-weight:600}.btn-submit-post{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px 24px;font-size:.9rem;font-weight:700;transition:all .2s}.btn-submit-post:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-submit-post:disabled{opacity:.5;cursor:not-allowed}.guest-composer-banner{background-color:var(--color-surface-alt);border:1px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center;padding:24px}.btn-guest-login{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:8px 20px;font-size:.875rem;font-weight:700;transition:background-color .2s}.btn-guest-login:hover{background-color:var(--color-primary-hover)}.posts-feed-list{flex-direction:column;gap:16px;display:flex}.post-feed-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:24px;display:flex}.post-card-header{align-items:center;gap:12px;display:flex}.post-user-avatar{object-fit:cover;border:1px solid var(--color-border);border-radius:50%;width:44px;height:44px}.post-user-avatar-placeholder{background-color:var(--color-primary-bg);width:44px;height:44px;color:var(--color-primary);border:1px solid var(--color-border);border-radius:50%;justify-content:center;align-items:center;font-size:1.15rem;font-weight:700;display:flex}.post-user-meta{flex-direction:column;gap:2px;display:flex}.post-user-display-name{color:var(--color-text);font-size:.95rem;font-weight:700}.post-user-username{color:var(--color-text-secondary);font-size:.85rem}.post-time-stamp{color:var(--color-text-secondary);font-size:.775rem}.post-card-content{flex-direction:column;gap:10px;display:flex}.post-title-content{color:var(--color-text);margin:0;font-size:1.25rem;font-weight:800}.post-text-content{color:var(--color-text);margin:0;font-size:.975rem;line-height:1.55}.post-content-image-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);width:100%;max-height:400px;overflow:hidden}.post-attached-image{object-fit:contain;width:100%;height:100%;max-height:400px;display:block}.post-tags-list{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.post-tag-chip{color:var(--color-primary);background-color:var(--color-primary-bg);border-radius:4px;padding:2px 8px;font-size:.8rem;font-weight:600}.post-card-actions{border-top:1px solid var(--color-border);align-items:center;gap:16px;padding-top:12px;display:flex}.action-btn-react,.action-btn-comments,.action-btn-report{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:8px 12px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.action-btn-react:hover{color:var(--color-danger);background-color:#ffe4e6}.action-btn-react.liked{color:var(--color-danger)}.action-btn-comments:hover{background-color:var(--color-primary-bg);color:var(--color-primary)}.action-btn-report{margin-left:auto;padding:8px}.action-btn-report:hover{background-color:var(--color-surface-alt);color:var(--color-warning)}.forum-empty-state,.projects-empty-state{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-card);flex-direction:column;justify-content:center;align-items:center;padding:64px 32px;display:flex}.forum-empty-state h3,.projects-empty-state h3{color:var(--color-text);margin:0 0 8px;font-size:1.25rem;font-weight:700}.forum-empty-state p,.projects-empty-state p{color:var(--color-text-secondary);max-width:380px;margin:0;font-size:.925rem;line-height:1.6}.projects-tab-panel{flex-direction:column;gap:24px;display:flex}.pending-invites-banner{border:1px solid #ddd6fe;border-left:4px solid var(--badge-pro-text);border-radius:var(--radius-md);box-shadow:var(--shadow-card);background-color:#ede9fe;flex-direction:column;gap:12px;padding:16px 20px;display:flex}.invites-list{flex-direction:column;gap:8px;display:flex}.invite-strip-item{background-color:var(--color-surface);border-radius:var(--radius-sm);border:1px solid #e9d5ff;justify-content:space-between;align-items:center;gap:16px;padding:10px 16px;display:flex}.invite-text-desc{color:var(--color-text);font-size:.875rem}.invite-strip-actions{gap:8px;display:flex}.btn-invite-accept,.btn-invite-decline{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:700;transition:background-color .2s;display:flex}.btn-invite-accept{background-color:var(--color-success);color:#fff}.btn-invite-accept:hover{background-color:#15803d}.btn-invite-decline{background-color:var(--color-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-invite-decline:hover{color:var(--color-text);background-color:#e2e8f0}.projects-section-header{justify-content:space-between;align-items:center;gap:24px;display:flex}.section-panel-title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:800}.section-panel-subtitle{color:var(--color-text-secondary);margin:4px 0 0;font-size:.925rem}.btn-create-project-trigger{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 4px #2563eb1a}.btn-create-project-trigger:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.projects-grid-list{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.project-grid-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-card);flex-direction:column;gap:16px;min-height:180px;padding:24px;transition:all .2s;display:flex}.project-grid-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 6px 20px #0f172a0f}.project-card-header-row{justify-content:space-between;align-items:center;display:flex}.project-status-badge{text-transform:uppercase;border-radius:4px;padding:3px 8px;font-size:.7rem;font-weight:800}.project-status-badge.status-recruiting{color:#16a34a;background-color:#dcfce7}.project-status-badge.status-in_progress{color:#2563eb;background-color:#eff6ff}.project-status-badge.status-completed{color:#475569;background-color:#f1f5f9}.project-status-badge.status-archived{color:#d97706;background-color:#fef3c7}.project-visibility-badge{color:var(--color-text-secondary);border:1px solid var(--color-border);text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:700}.project-card-title{color:var(--color-text);margin:0;font-size:1.2rem;font-weight:800;line-height:1.35}.project-card-desc{color:var(--color-text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex-grow:1;margin:0;font-size:.875rem;line-height:1.55;display:-webkit-box;overflow:hidden}.project-card-footer{border-top:1px solid var(--color-border);color:var(--color-text-secondary);justify-content:space-between;align-items:center;padding-top:12px;font-size:.8rem;display:flex}.project-owner-info{gap:4px;display:flex}.owner-label{font-weight:500}.owner-name{color:var(--color-text);font-weight:700}.project-members-count{align-items:center;gap:4px;font-weight:600;display:flex}.community-pagination{justify-content:center;align-items:center;gap:16px;margin-top:12px;display:flex}.btn-community-page{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-md);cursor:pointer;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s}.btn-community-page:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-community-page:disabled{opacity:.5;cursor:not-allowed}.community-page-indicator{color:var(--color-text-secondary);font-size:.875rem}@media (width<=768px){.community-tabs-nav{justify-content:space-between;padding:0}.community-tab-btn{flex-grow:1;justify-content:center}.post-composer-card,.post-feed-card{padding:16px}.projects-section-header{flex-direction:column;align-items:stretch;gap:16px}.btn-create-project-trigger{justify-content:center;width:100%}.invite-strip-item{flex-direction:column;align-items:stretch;gap:12px}.invite-strip-actions{justify-content:flex-end}}.post-detail-page-container{flex-direction:column;gap:20px;display:flex}.detailed-post-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:20px;padding:32px;display:flex}.detailed-post-header{border-bottom:1px solid var(--color-border);align-items:center;gap:16px;padding-bottom:16px;display:flex;position:relative}.post-detail-avatar{object-fit:cover;border:1px solid var(--color-border);border-radius:50%;width:48px;height:48px}.post-detail-avatar-placeholder{background-color:var(--color-primary-bg);width:48px;height:48px;color:var(--color-primary);border:1px solid var(--color-border);border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;font-weight:700;display:flex}.post-detail-user-meta{flex-direction:column;gap:4px;display:flex}.post-detail-display-name{color:var(--color-text);font-size:1rem;font-weight:700}.post-detail-username{color:var(--color-text-secondary);font-size:.875rem}.post-detail-timestamp{color:var(--color-text-secondary);align-items:center;font-size:.8rem;display:flex}.post-owner-actions{align-items:center;gap:6px;display:flex;position:absolute;top:0;right:0}.btn-edit-post{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.btn-edit-post:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:color-mix(in srgb, var(--color-primary) 8%, transparent)}.btn-delete-post{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.btn-delete-post:hover{border-color:var(--color-danger);color:var(--color-danger);background-color:#fee2e2}.post-edit-form{flex-direction:column;gap:0;padding:4px 0;display:flex}.post-edit-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.detailed-post-body{flex-direction:column;gap:16px;display:flex}.detailed-post-title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:800;line-height:1.3}.detailed-post-text{color:var(--color-text);margin:0;font-size:1.05rem;line-height:1.65}.detailed-post-image-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);max-height:500px;overflow:hidden}.detailed-post-image{object-fit:contain;width:100%;height:100%;max-height:500px;display:block}.detailed-post-tags{flex-wrap:wrap;gap:8px;display:flex}.detailed-tag-chip{color:var(--color-primary);background-color:var(--color-primary-bg);border-radius:6px;padding:4px 10px;font-size:.825rem;font-weight:700}.detailed-post-actions{border-top:1px solid var(--color-border);align-items:center;gap:24px;padding-top:16px;display:flex}.action-comments-indicator{color:var(--color-text-secondary);align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.discussion-thread-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:20px;padding:32px;display:flex}.discussion-section-title{color:var(--color-text);border-left:3px solid var(--color-primary);margin:0;padding-left:12px;font-size:1.25rem;font-weight:800}.main-comment-composer{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;padding:20px;display:flex}.guest-thread-notice{background-color:var(--color-surface-alt);border:1px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;color:var(--color-text-secondary);padding:16px;font-size:.9rem}.thread-loading,.thread-empty-state{text-align:center;color:var(--color-text-secondary);padding:32px;font-size:.925rem}.comments-tree-list{flex-direction:column;gap:20px;margin-top:12px;display:flex}.comment-node-wrapper{flex-direction:column;gap:12px;display:flex}.comment-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:16px;transition:all .2s;display:flex;position:relative}.comment-card:hover{border-color:#2563eb4d;box-shadow:0 2px 8px #0f172a08}.comment-header{align-items:center;gap:10px;display:flex}.comment-user-avatar{object-fit:cover;border:1px solid var(--color-border);border-radius:50%;width:32px;height:32px}.comment-user-avatar-placeholder{background-color:var(--color-primary-bg);width:32px;height:32px;color:var(--color-primary);border:1px solid var(--color-border);border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;font-weight:700;display:flex}.comment-user-info{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.comment-user-name{color:var(--color-text);font-size:.875rem;font-weight:700}.comment-user-handle{color:var(--color-text-secondary);font-size:.8rem}.comment-time{color:var(--color-text-secondary);font-size:.75rem}.comment-btn-report{color:var(--color-text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.comment-card:hover .comment-btn-report{opacity:1}.comment-btn-report:hover{background-color:var(--color-surface-alt);color:var(--color-warning)}.comment-body-content{color:var(--color-text);margin:0;font-size:.925rem;line-height:1.5}.comment-text{white-space:pre-wrap;margin:0}.comment-deleted-text{color:var(--color-text-secondary);font-style:italic}.comment-actions-row{align-items:center;gap:12px;display:flex}.comment-btn-reply-toggle{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.comment-btn-reply-toggle:hover{background-color:var(--color-surface-alt);color:var(--color-primary)}.reply-composer-form{border-top:1px solid var(--color-border);margin-top:4px;padding-top:16px}.reply-arrow-icon{color:var(--color-text-secondary);opacity:.7;margin-top:8px}.reply-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text);resize:vertical;outline:none;width:100%;padding:10px 12px;font-size:.9rem;line-height:1.4;transition:border-color .2s}.reply-textarea:focus{border-color:var(--color-primary)}.reply-error-text{color:var(--color-danger);margin-bottom:8px;margin-left:24px;font-size:.8rem;font-weight:600}.btn-reply-cancel,.btn-reply-submit{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:6px 14px;font-size:.8rem;font-weight:700;transition:background-color .2s}.btn-reply-cancel{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn-reply-cancel:hover{background-color:var(--color-surface-alt)}.btn-reply-submit{background-color:var(--color-primary);color:var(--color-on-primary)}.btn-reply-submit:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-reply-submit:disabled{opacity:.5;cursor:not-allowed}.comment-replies-thread{border-left:2px solid var(--color-border);flex-direction:column;gap:16px;margin-top:4px;margin-left:16px;padding-left:24px;display:flex}@media (width<=768px){.detailed-post-card,.discussion-thread-section{padding:16px}.comment-replies-thread{margin-left:8px;padding-left:12px}}.project-edit-form{flex-direction:column;gap:0;display:flex}.btn-edit-project{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-items:center;gap:5px;margin-left:auto;padding:4px 10px;font-size:.8rem;transition:all .2s;display:flex}.btn-edit-project:hover{border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent)}.action-btn-edit{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:5px 8px;font-size:.8rem;transition:color .2s,background .2s;display:flex}.action-btn-edit:hover{color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent)}.btn-edit-cancel{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:8px 16px;font-size:.875rem;transition:all .2s;display:flex}.btn-edit-cancel:hover{border-color:var(--color-text);color:var(--color-text)}.btn-edit-save{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;border:none;align-items:center;gap:5px;padding:8px 18px;font-size:.875rem;font-weight:600;transition:opacity .2s;display:flex}.btn-edit-save:disabled{opacity:.6;cursor:not-allowed}.post-edit-actions{justify-content:flex-end;gap:8px;display:flex}.project-detail-container{flex-direction:column;gap:20px;display:flex}.project-layout-grid{grid-template-columns:1fr 320px;align-items:flex-start;gap:24px;display:grid}.project-left-panel{flex-direction:column;gap:24px;display:flex}.project-details-header-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:32px;display:flex}.project-badge-row{align-items:center;gap:8px;display:flex}.project-details-title{color:var(--color-text);margin:0;font-size:1.75rem;font-weight:800;line-height:1.3}.project-details-description{color:var(--color-text-secondary);margin:0;font-size:1rem;line-height:1.6}.project-feed-section{flex-direction:column;gap:16px;display:flex}.feed-title{color:var(--color-text);border-left:3px solid var(--color-primary);margin:0;padding-left:12px;font-size:1.25rem;font-weight:800}.non-member-feed-notice{background-color:var(--color-surface-alt);border:1px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center;color:var(--color-text-secondary);box-shadow:var(--shadow-card);padding:32px 24px;font-size:.95rem;line-height:1.5}.project-right-panel{flex-direction:column;gap:24px;display:flex}.project-invite-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:12px;padding:24px;display:flex}.invite-card-title{color:var(--color-text);margin:0;font-size:1rem;font-weight:700}.invite-alert{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 12px;font-size:.8rem;font-weight:600;display:flex}.invite-alert.alert-success{color:var(--color-success);background-color:#dcfce7;border:1px solid #bbf7d0}.invite-alert.alert-danger{color:var(--color-danger);background-color:#fee2e2;border:1px solid #fca5a5}.invite-form{flex-direction:column;gap:10px;display:flex}.btn-invite-submit{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px;font-size:.875rem;font-weight:700;transition:background-color .2s}.btn-invite-submit:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-invite-submit:disabled{opacity:.5;cursor:not-allowed}.project-members-panel-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:24px;display:flex}.members-panel-title{color:var(--color-text);border-bottom:1px solid var(--color-border);align-items:center;gap:8px;margin:0;padding-bottom:12px;font-size:1rem;font-weight:700;display:flex}.members-list-container{flex-direction:column;gap:12px;display:flex}.member-strip-item{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.member-info-col{align-items:center;gap:10px;min-width:0;display:flex}.member-avatar{object-fit:cover;border:1px solid var(--color-border);border-radius:50%;flex-shrink:0;width:32px;height:32px}.member-avatar-placeholder{background-color:var(--color-primary-bg);width:32px;height:32px;color:var(--color-primary);border:1px solid var(--color-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.member-details{flex-direction:column;min-width:0;display:flex}.member-display-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;overflow:hidden}.member-username{color:var(--color-text-secondary);font-size:.775rem}.member-badge-col{flex-shrink:0;align-items:center;gap:8px;display:flex}.role-badge{text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.role-badge.role-owner{background-color:var(--badge-pro-bg);color:var(--badge-pro-text)}.role-badge.role-member{background-color:var(--color-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-remove-member-trigger{border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.btn-remove-member-trigger:hover{border-color:var(--color-danger);color:var(--color-danger);background-color:#fee2e2}@media (width<=992px){.project-layout-grid{grid-template-columns:1fr}}@media (width<=768px){.project-details-header-card{padding:24px 16px}}.profile-container{flex-direction:column;gap:20px;display:flex}.profile-success-alert,.profile-error-alert{border-radius:var(--radius-md);box-shadow:var(--shadow-card);align-items:center;gap:10px;padding:12px 16px;font-size:.9rem;font-weight:600;display:flex}.profile-success-alert{color:var(--color-success);background-color:#dcfce7;border:1px solid #bbf7d0}.profile-error-alert{color:var(--color-danger);background-color:#fee2e2;border:1px solid #fca5a5}.profile-layout-grid{grid-template-columns:280px 1fr;align-items:flex-start;gap:32px;display:grid}.avatar-card-panel{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);text-align:center;flex-direction:column;align-items:center;padding:32px;display:flex}.avatar-preview-container{border:3px solid var(--color-border);background-color:var(--color-bg);cursor:pointer;border-radius:50%;width:140px;height:140px;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.profile-large-avatar{object-fit:cover;width:100%;height:100%}.profile-large-avatar-placeholder{background-color:var(--color-primary-bg);width:100%;height:100%;color:var(--color-primary);justify-content:center;align-items:center;font-size:3.5rem;font-weight:800;display:flex}.avatar-upload-overlay{color:#fff;opacity:0;text-transform:uppercase;background-color:#0f172ab3;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;font-size:.75rem;font-weight:700;transition:opacity .2s;display:flex;position:absolute;top:0;left:0}.avatar-preview-container:hover .avatar-upload-overlay{opacity:1}.profile-panel-display-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin:16px 0 4px;font-size:1.25rem;font-weight:800;overflow:hidden}.profile-panel-username{color:var(--color-text-secondary);font-size:.9rem}.profile-badge-row{justify-content:center;margin-top:8px;display:flex}.profile-role-badge{text-transform:uppercase;border-radius:6px;align-items:center;padding:4px 10px;font-size:.725rem;font-weight:800;display:flex}.profile-role-badge.role-student{background-color:var(--color-primary-bg);color:var(--color-primary)}.profile-role-badge.role-teacher{background-color:var(--badge-pro-bg);color:var(--badge-pro-text)}.btn-view-public-profile{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:6px;width:100%;padding:8px;font-size:.825rem;font-weight:600;transition:all .2s;display:flex}.btn-view-public-profile:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.settings-fields-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:24px;padding:32px;display:flex}.settings-title{color:var(--color-text);border-bottom:1px solid var(--color-border);align-items:center;gap:8px;margin:0;padding-bottom:12px;font-size:1.25rem;font-weight:800;display:flex}.profile-settings-form{flex-direction:column;gap:20px;display:flex}.locked-label{color:var(--color-text-secondary);background-color:var(--color-surface-alt);border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:.725rem;font-weight:700;display:flex}.input-caption{color:var(--color-text-secondary);margin-top:4px;font-size:.75rem}.btn-save-profile{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-md);cursor:pointer;border:none;align-self:flex-start;padding:12px 24px;font-size:.95rem;font-weight:700;transition:all .2s}.btn-save-profile:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-save-profile:disabled{opacity:.5;cursor:not-allowed}.teacher-password-block{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:8px;padding:20px;display:flex}.settings-subtitle{color:var(--color-text);margin:0;font-size:1.05rem;font-weight:700}.settings-desc{color:var(--color-text-secondary);margin:0 0 8px;font-size:.85rem}.btn-change-password{background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:8px;width:fit-content;padding:10px 20px;font-size:.875rem;font-weight:700;transition:all .2s;display:flex}.btn-change-password:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.divider-line{border:none;border-top:1px solid var(--color-border);width:100%;margin:12px 0}@media (width<=768px){.profile-layout-grid{grid-template-columns:1fr;gap:24px}.avatar-card-panel,.settings-fields-card{padding:24px}.btn-save-profile{width:100%}.btn-change-password{justify-content:center;width:100%}}.search-page{flex-direction:column;gap:24px;max-width:760px;margin:0 auto;display:flex}.search-page-header{align-items:center;gap:16px;display:flex}.search-back-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:4px 0;font-size:.875rem;transition:color .2s;display:flex}.search-back-btn:hover{color:var(--color-primary)}.search-page-title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:700}.search-page-form{width:100%}.search-page-input-wrap{background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:10px;padding:4px 4px 4px 16px;transition:border-color .2s;display:flex}.search-page-input-wrap:focus-within{border-color:var(--color-primary)}.search-page-icon{color:var(--color-text-secondary);flex-shrink:0}.search-page-input{color:var(--color-text);background:0 0;border:none;outline:none;flex:1;padding:8px 0;font-size:1rem}.search-page-btn{background-color:var(--color-primary);color:var(--color-on-primary);border-radius:calc(var(--radius-md) - 4px);cursor:pointer;white-space:nowrap;border:none;padding:10px 20px;font-size:.9rem;font-weight:600;transition:background-color .2s}.search-page-btn:hover{background-color:var(--color-primary-hover)}.search-status{color:var(--color-text-secondary);text-align:center;padding:32px;font-size:.95rem}.search-error{color:var(--color-error,#dc2626)}.search-hint{color:var(--color-text-secondary)}.search-summary{color:var(--color-text-secondary);margin:0;font-size:.9rem}.search-section{flex-direction:column;gap:8px;display:flex}.search-section-title{color:var(--color-text);border-bottom:1px solid var(--color-border);align-items:center;gap:8px;margin:0;padding-bottom:8px;font-size:1rem;font-weight:700;display:flex}.search-result-list{flex-direction:column;gap:2px;display:flex}.search-result-item{border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;gap:4px;padding:12px 14px;transition:background-color .15s;display:flex}.search-result-item:hover{background-color:var(--color-surface-alt)}.result-title{color:var(--color-primary);font-size:.95rem;font-weight:600}.result-desc{color:var(--color-text-secondary);-webkit-line-clamp:1;-webkit-box-orient:vertical;font-size:.825rem;display:-webkit-box;overflow:hidden}.public-profile-container{flex-direction:column;gap:20px;display:flex}.public-profile-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:32px;padding:40px;display:flex}.public-profile-header{border-bottom:1px solid var(--color-border);align-items:center;gap:32px;padding-bottom:32px;display:flex}.public-avatar{object-fit:cover;border:3px solid var(--color-border);border-radius:50%;flex-shrink:0;width:140px;height:140px;box-shadow:0 4px 10px #0000000d}.public-avatar-placeholder{background-color:var(--color-primary-bg);width:140px;height:140px;color:var(--color-primary);border:3px solid var(--color-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:3.5rem;font-weight:800;display:flex;box-shadow:0 4px 10px #0000000d}.public-user-meta{flex-direction:column;flex-grow:1;gap:12px;display:flex}.display-name-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.public-display-name{color:var(--color-text);margin:0;font-size:1.75rem;font-weight:800}.admin-verified-badge{color:var(--color-danger);text-transform:uppercase;background-color:#fee2e2;border:1px solid #fca5a5;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:.725rem;font-weight:800;display:flex}.public-username{color:var(--color-text-secondary);font-size:1rem}.public-badges-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.dept-badge{text-transform:uppercase;color:#2563eb;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;align-items:center;padding:4px 10px;font-size:.725rem;font-weight:800;display:flex}.joined-timestamp{color:var(--color-text-secondary);align-items:center;font-size:.825rem;display:flex}.public-profile-body{flex-direction:column;gap:16px;display:flex}.body-section-title{color:var(--color-text);border-left:3px solid var(--color-primary);margin:0;padding-left:10px;font-size:1.1rem;font-weight:700}.public-bio-text{color:var(--color-text-secondary);white-space:pre-wrap;margin:0;font-size:1rem;line-height:1.7}@media (width<=640px){.public-profile-header{text-align:center;flex-direction:column;align-items:center;gap:20px}.public-profile-card{padding:24px}.display-name-row,.public-badges-row,.joined-timestamp{justify-content:center}}.auth-page{background-color:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-card);flex-direction:column;gap:20px;padding:40px 36px;display:flex}.auth-back-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;width:fit-content;margin-bottom:-4px;padding:0;font-size:.825rem;font-weight:600;transition:color .15s;display:inline-flex}.auth-back-btn:hover{color:var(--color-primary)}.role-picker{grid-template-columns:1fr 1fr;gap:14px;display:grid}.role-card{background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;transition:all .2s;display:flex}.role-card:hover{border-color:var(--color-primary);background-color:var(--color-primary-bg);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb1a}.role-card-icon{color:var(--color-primary)}.role-card-label{color:var(--color-text);font-size:1rem;font-weight:700}.role-card-desc{color:var(--color-text-secondary);font-size:.775rem;line-height:1.4}.auth-error{color:var(--color-danger,#dc2626);text-align:center;border-radius:var(--radius-sm);background-color:#fef2f2;border:1px solid #fecaca;padding:10px 14px;font-size:.875rem;font-weight:600}.auth-divider{color:var(--color-text-secondary);letter-spacing:.5px;text-transform:uppercase;align-items:center;gap:12px;font-size:.8rem;font-weight:600;display:flex}.auth-divider:before,.auth-divider:after{content:"";background-color:var(--color-border);flex:1;height:1px}.auth-footer-link{color:var(--color-text-secondary);text-align:center;margin:0;font-size:.85rem}.auth-footer-link a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-footer-link a:hover{text-decoration:underline}.teacher-apply-note{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);align-items:flex-start;gap:8px;padding:10px 14px;font-size:.825rem;line-height:1.5;display:flex}.pending-info-box{border-radius:var(--radius-md);color:#166534;background-color:#f0fdf4;border:1px solid #bbf7d0;align-items:flex-start;gap:12px;padding:14px 16px;font-size:.875rem;line-height:1.5;display:flex}.auth-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=480px){.auth-card{padding:32px 20px}.role-picker,.auth-form-row{grid-template-columns:1fr}}
