@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-brand:#1f3a5a;--color-brand-hover:#162c47;--color-brand-light:#eef2f6;--color-brand-alt:#e59a2f;--color-brand-alt-hover:#c8851f;--color-danger:#ef4444;--color-danger-hover:#b91c1c;--color-success:#059669;--color-warning:#d97706;--bg:#fafafa;--bg-soft:#f3f4f6;--ink:#111827;--ink-soft:#4b5563;--ink-muted:#6b7280;--line:#e5e7eb;--panel:#fff;--brand:var(--color-brand);--brand-alt:var(--color-brand-alt);--brand-light:var(--color-brand-light);--danger:var(--color-danger);--color-badge-blue-bg:#e0e7ff;--color-badge-blue-fg:#3730a3;--color-badge-green-bg:#dcfce7;--color-badge-green-fg:#166534;--color-badge-amber-bg:#fef3c7;--color-badge-amber-fg:#92400e;--color-badge-gray-bg:#f3f4f6;--color-badge-gray-fg:#374151;--color-notif-blue-bg:#ebf4fa;--color-notif-blue-fg:#2563eb;--color-notif-amber-bg:#fef3c7;--color-notif-amber-fg:#d97706;--color-avatar-orange:#e59a2f;--color-avatar-blue:#a0c4ff;--color-avatar-blue-fg:#1f3a5a;--color-avatar-green:#86efac;--color-avatar-green-fg:#1f3a5a;--color-avatar-purple:#c4b5fd;--color-avatar-purple-fg:#1f3a5a;--font-family-sans:"Inter", system-ui, -apple-system, sans-serif;--font-family-serif:"Inter", system-ui, -apple-system, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-size-6xl:3.75rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--line-height-none:1;--line-height-tight:1.25;--line-height-snug:1.375;--line-height-normal:1.5;--line-height-relaxed:1.625;--line-height-loose:2;--spacing-px:1px;--spacing-0:0;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--spacing-32:8rem;--border-radius-sm:.125rem;--border-radius:.25rem;--border-radius-md:.375rem;--border-radius-lg:.5rem;--border-radius-xl:.75rem;--border-radius-2xl:1rem;--border-radius-full:9999px;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #00000014, 0 1px 2px -1px #0000000f;--shadow:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #00000014;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #00000014;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #00000014;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--breakpoint-sm:640px;--breakpoint-md:1024px;--breakpoint-lg:1280px;--z-sticky:200;--z-dropdown:100;--z-modal:400;--z-toast:500}*{box-sizing:border-box}body{min-height:100vh;font-family:var(--font-family-sans);color:var(--ink);background:var(--bg);margin:0}#root{min-height:100vh}a{color:inherit}h1,h2,h3,h4{font-family:var(--font-family-serif);letter-spacing:-.03em;margin:0}p{margin:0}button,input,select,textarea{font:inherit}.panel{border:1px solid var(--line);border-radius:var(--border-radius-lg);background:var(--panel);box-shadow:var(--shadow);transition:box-shadow var(--transition-fast), transform var(--transition-fast)}.auth-shell{grid-template-columns:1.1fr 1fr;gap:1.25rem;width:min(1200px,94vw);margin:2.5rem auto;display:grid}.auth-hero{align-content:start;gap:1rem;padding:2rem;display:grid}.eyebrow{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.14em;color:var(--brand);font-weight:var(--font-weight-bold)}.auth-hero h1{font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.05}.auth-kpis{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;display:grid}.auth-kpis>div{border:1px solid var(--line);background:#fffdf8;border-radius:14px;padding:.8rem}.auth-kpis h2{color:var(--brand)}.auth-card{padding:1.3rem}.auth-toggle{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;margin-bottom:1rem;display:grid}.auth-toggle button{border:1px solid var(--line);background:#fff8eb;border-radius:999px;padding:.6rem;font-weight:700}.auth-toggle button.active{background:var(--ink);color:#fff;border-color:var(--ink)}.stack-form{gap:.85rem;display:grid}.grid-two{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;display:grid}label{color:var(--ink-soft);gap:.3rem;font-size:.92rem;display:grid}input,select,textarea{border:1px solid var(--line);border-radius:var(--border-radius-lg);padding:var(--spacing-2) var(--spacing-3);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#fff}input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #1f3a5a1f}textarea{resize:vertical}.cta,.danger,.top-nav button,.inline-buttons button,.notice-actions button,.between-row button{border-radius:var(--border-radius-lg);padding:var(--spacing-2) var(--spacing-4);font-weight:var(--font-weight-bold);cursor:pointer;transition:transform var(--transition-fast);border:none}.cta{background:var(--brand-alt);color:#fff}.cta:hover,.danger:hover,.top-nav button:hover,.inline-buttons button:hover,.notice-actions button:hover,.between-row button:hover{transform:translateY(-1px)}.danger{background:var(--danger);color:#fff}.hint{font-size:var(--font-size-sm);color:var(--ink-soft)}.error-text{color:var(--danger);font-weight:700}.checkbox-row{align-items:center;gap:.5rem;display:flex}.checkbox-row input{width:1rem;height:1rem}.app-shell{width:min(1240px,94vw);margin:1.3rem auto 2.3rem}.top-nav{border:1px solid var(--line);box-shadow:var(--shadow);z-index:10;background:#fffaefe6;border-radius:22px;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;padding:.95rem 1rem;display:grid;position:sticky;top:.9rem}.brand span{background:linear-gradient(145deg, var(--brand-alt), #f1a451);color:#fff;border-radius:50%;place-items:center;width:42px;height:42px;font-family:Sora,sans-serif;font-weight:700;display:inline-grid}.brand small{color:var(--ink-soft);display:block}.top-nav nav{flex-wrap:wrap;gap:.4rem;display:flex}.top-nav nav a{color:var(--ink-soft);border:1px solid #0000;border-radius:999px;padding:.42rem .76rem;font-weight:700;text-decoration:none}.top-nav nav a.active,.top-nav nav a:hover{border-color:var(--line);color:var(--ink);background:#fffdf7}.user-chip small{color:var(--ink-soft);text-transform:capitalize;display:block}.top-nav button{background:var(--ink);color:#fff}.page-stack{gap:.95rem;margin-top:1rem;display:grid}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;display:grid}.stat{padding:1rem}.stat h2{color:var(--brand);font-size:1.55rem}.simple-list{gap:.65rem;margin:0;padding:0;list-style:none;display:grid}.simple-list li{border:1px solid var(--line);border-radius:12px;gap:.25rem;padding:.7rem;display:grid}.simple-list small{color:var(--ink-soft)}.card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;display:grid}.mini-card,.profile-card,.article-card,.list-panel,.filter-grid,.inline-form,.panel{padding:1rem}@keyframes shimmer{0%{background-position:200%}to{background-position:-200%}}.empty-state{text-align:center;padding:var(--spacing-12) var(--spacing-4);color:var(--ink-soft);font-size:var(--font-size-sm)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.mini-card p,.article-card p,.profile-card p{color:var(--ink-soft)}.tag-row{flex-wrap:wrap;gap:.4rem;margin-top:.6rem;display:flex}.tag-row span{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.2rem .52rem;font-size:.76rem}.availability{color:var(--ink-soft);margin-top:.55rem;display:block}.filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;display:grid}.result-header{color:var(--ink-soft)}.inline-form{grid-template-columns:1fr auto;gap:.8rem;display:grid}.article-meta{color:var(--ink-soft);justify-content:space-between;font-size:.8rem;display:flex}.notice-item{border:1px solid var(--line);border-radius:14px;justify-content:space-between;gap:.8rem;margin-bottom:.7rem;padding:.8rem;display:flex}.notice-item.read{opacity:.72}.notice-actions{align-content:start;gap:.35rem;display:grid}.notice-actions button,.inline-buttons button,.between-row button{border:1px solid var(--line);background:#fff}.visibility-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;display:grid}.action-row{gap:.7rem;display:flex}.between-row{justify-content:space-between;align-items:center;margin-bottom:.7rem;display:flex}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid var(--line);text-align:left;padding:.6rem}.inline-buttons{gap:.4rem;display:flex}.skeleton{background:linear-gradient(90deg, var(--bg-soft) 25%, var(--line) 50%, var(--bg-soft) 75%);background-size:200% 100%;min-height:160px;animation:1.6s ease-in-out infinite shimmer}@media (width<=1080px){.auth-shell,.top-nav{grid-template-columns:1fr}.stats-grid,.card-grid,.filter-grid,.visibility-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=740px){.grid-two,.stats-grid,.card-grid,.filter-grid,.visibility-grid,.inline-form{grid-template-columns:1fr}.user-chip{justify-content:space-between}.notice-item,.action-row,.inline-buttons{flex-direction:column}}.app-layout{flex-direction:column;min-height:100vh;display:flex}.top-nav{padding:var(--spacing-4) var(--spacing-10);border-bottom:1px solid var(--line);z-index:var(--z-sticky);background:#fff;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.brand{align-items:center;gap:var(--spacing-2);display:flex}.brand .dot{background:var(--brand-alt);border-radius:50%;width:10px;height:10px;display:inline-block}.brand strong{font-weight:var(--font-weight-medium);color:var(--brand);font-size:var(--font-size-lg)}.nav-center{gap:var(--spacing-10);display:flex}.nav-center a{color:var(--ink-soft);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);padding-bottom:var(--spacing-1);transition:color var(--transition-fast);text-decoration:none;position:relative}.nav-center a:after{content:"";background:var(--brand);height:2px;transition:transform var(--transition-fast);border-radius:2px;position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.nav-center a:hover{color:var(--ink)}.nav-center a:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:2px}.nav-center a.active{color:var(--brand);font-weight:var(--font-weight-semibold)}.nav-center a.active:after{transform:scaleX(1)}.user-chip{align-items:center;gap:var(--spacing-5);display:flex}.bell-btn{font-size:var(--font-size-xl);cursor:pointer;color:var(--brand-alt);border-radius:var(--border-radius-full);width:38px;height:38px;transition:background-color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:relative}.bell-btn:hover{background-color:var(--bg-soft)}.bell-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.bell-dot{background:var(--brand-alt);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:4px;right:4px}.avatar{color:#fff;width:38px;height:38px;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);border-radius:50%;place-items:center;display:grid}.avatar-orange{background:var(--color-avatar-orange)}.avatar-blue{background:var(--color-avatar-blue);color:var(--color-avatar-blue-fg)}.avatar-green{background:var(--color-avatar-green);color:var(--color-avatar-green-fg)}.avatar-purple{background:var(--color-avatar-purple);color:var(--color-avatar-purple-fg)}.app-body{width:min(1200px,96vw);margin:var(--spacing-8) auto;flex:1}.admin-link{right:var(--spacing-8);top:var(--spacing-20);font-size:var(--font-size-sm);color:var(--ink-soft);text-decoration:none;position:absolute}.dashboard-grid{background:#fff;grid-template-columns:240px 1fr;min-height:calc(100vh - 80px);display:grid}.dashboard-sidebar{border-right:1px solid var(--line);flex-direction:column;padding:2rem 0;display:flex}.sidebar-profile{gap:var(--spacing-2);padding:0 var(--spacing-8) var(--spacing-8);border-bottom:1px solid var(--line);margin-bottom:var(--spacing-4);flex-direction:column;display:flex}.sidebar-profile h4{font-weight:var(--font-weight-medium);font-size:var(--font-size-base);color:var(--ink);margin:0}.sidebar-profile .promo{font-size:var(--font-size-sm);color:var(--ink-soft)}.sidebar-nav{flex-direction:column;display:flex}.sidebar-nav a{align-items:center;gap:var(--spacing-4);padding:var(--spacing-4) var(--spacing-8);color:var(--ink-soft);font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast), color var(--transition-fast);border-left:3px solid #0000;text-decoration:none;display:flex}.sidebar-nav a:hover{background:var(--bg-soft);color:var(--ink)}.sidebar-nav a:focus-visible{outline:2px solid var(--brand);outline-offset:-2px}.sidebar-nav a.active{background:var(--brand-light);color:var(--brand);border-left-color:var(--brand);font-weight:var(--font-weight-semibold)}.sidebar-nav .icon{font-size:var(--font-size-lg)}.app-content{padding:var(--spacing-10) var(--spacing-12);box-sizing:border-box;background:#fff;width:100%}@media (width<=768px){.dashboard-grid{flex-direction:column;grid-template-columns:1fr;display:flex}.top-nav{flex-wrap:wrap;gap:1rem;padding:.75rem 1rem}.nav-center{order:3;gap:1.5rem;width:100%;padding-bottom:.5rem;overflow-x:auto}.dashboard-sidebar{border-right:none;border-bottom:1px solid var(--line);padding:1rem 0}.sidebar-profile{text-align:center;align-items:center;padding:0 1rem 1rem}.sidebar-nav{flex-direction:row;gap:.5rem;padding:0 1rem .5rem;overflow-x:auto}.sidebar-nav a{white-space:nowrap;border-bottom:3px solid #0000;border-left:none;gap:.5rem;padding:.5rem 1rem}.sidebar-nav a.active{border-left-color:#0000;border-bottom-color:var(--brand)}.sidebar-nav .logout-btn{white-space:nowrap;border-bottom:3px solid #0000;padding:.5rem 1rem!important}.app-content{padding:1.5rem 1rem}.admin-link{top:1rem;right:1rem}.mobile-only{display:none!important}}.user-dropdown{border:1px solid var(--line);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);min-width:200px;z-index:var(--z-dropdown);background:#fff;flex-direction:column;display:flex;position:absolute;top:130%;right:0;overflow:hidden}.user-dropdown .dropdown-header{border-bottom:1px solid var(--line);flex-direction:column;padding:1rem;display:flex}.user-dropdown .dropdown-header strong{color:var(--ink);font-size:var(--font-size-sm)}.user-dropdown .dropdown-header span{color:var(--ink-soft);font-size:var(--font-size-xs)}.user-dropdown a,.user-dropdown button{padding:var(--spacing-3) var(--spacing-4);color:var(--ink);font-size:var(--font-size-sm);align-items:center;gap:var(--spacing-2);transition:background-color var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;text-decoration:none;display:flex}.user-dropdown a:focus-visible,.user-dropdown button:focus-visible{outline:2px solid var(--brand);outline-offset:-2px}.user-dropdown a:hover,.user-dropdown button:hover{background:var(--bg-soft)}.user-dropdown hr{border:none;border-top:1px solid var(--line);margin:0}.user-dropdown .logout-btn{color:var(--danger)}.mobile-only{display:none!important}.app-footer{background:var(--brand);color:#ffffffb3;justify-content:center;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4) var(--spacing-10);font-size:var(--font-size-xs);letter-spacing:.03em;display:flex}@media (width<=768px){.mobile-only{display:flex!important}.dashboard-sidebar{display:none!important}}.bottom-nav{display:none}@media (width<=768px){.bottom-nav{border-top:1px solid var(--line);height:60px;z-index:var(--z-sticky);background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.bottom-nav a{color:var(--ink-soft);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-1) 0;transition:color var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;text-decoration:none;display:flex}.bottom-nav a:focus-visible{outline:2px solid var(--brand);outline-offset:-2px}.bottom-nav a.active{color:var(--brand)}.bottom-nav-icon{font-size:var(--font-size-xl);line-height:1}.bottom-nav-avatar-wrap{display:inline-block;position:relative}.avatar-sm{color:#fff;width:24px;height:24px;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);border-radius:50%;place-items:center;display:grid}.bottom-nav-dot{background:var(--brand-alt);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:-2px;right:-2px}.app-content{padding-bottom:calc(1.5rem + 60px)}.app-footer{display:none}}.btn{border-radius:var(--border-radius-lg);font-weight:var(--font-weight-bold);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), opacity var(--transition-fast);justify-content:center;align-items:center;display:inline-flex}.btn:active:not([disabled]){transform:translateY(1px)}.btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--brand);color:#fff;border:1px solid var(--brand)}.btn-primary:hover{background-color:var(--color-brand-hover);border-color:var(--color-brand-hover)}.btn-primary:active{background-color:var(--color-brand-hover);box-shadow:inset 0 2px 4px #00000026}.btn-secondary{color:var(--ink);border:1px solid var(--line);background-color:#0000}.btn-secondary:hover{background-color:var(--bg-soft);border-color:var(--ink-muted)}.btn-secondary:active{background-color:var(--line)}.btn-danger{background-color:var(--danger);color:#fff;border:1px solid var(--danger)}.btn-danger:hover{background-color:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn-danger:active{background-color:var(--color-danger-hover);box-shadow:inset 0 2px 4px #00000026}.btn-danger:focus-visible{outline-color:var(--color-danger-hover)}.btn-sm{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm)}.btn-md{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base)}.btn-lg{padding:var(--spacing-4) var(--spacing-8);font-size:var(--font-size-lg)}.home-layout{flex-direction:column;min-height:100vh;display:flex}.home-nav{padding:var(--spacing-4) var(--spacing-10);z-index:var(--z-sticky);background:#fff;justify-content:space-between;align-items:center;display:flex}.nav-actions{gap:var(--spacing-4);display:flex}.connexion-btn{color:var(--ink-soft);border:1px solid var(--line);border-radius:var(--border-radius-full);padding:var(--spacing-2) var(--spacing-6);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0}.connexion-btn:hover{background-color:var(--bg-soft);color:var(--ink)}.connexion-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.rejoindre-btn{background:var(--brand);color:#fff;border-radius:var(--border-radius-full);padding:var(--spacing-2) var(--spacing-6);cursor:pointer;transition:background-color var(--transition-fast);border:none}.rejoindre-btn:hover{background-color:var(--color-brand-hover)}.rejoindre-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.hero-section{background:var(--brand);color:#fff;padding:var(--spacing-20) var(--spacing-12) 0;flex-direction:column;display:flex;position:relative;overflow:hidden}.hero-content{z-index:1;max-width:800px}.eyebrow{color:#ffffffb3;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-8);background:#ffffff1a;display:inline-block}.hero-content h1{font-size:clamp(2.2rem,4vw,3.5rem);font-weight:var(--font-weight-medium);line-height:var(--line-height-tight);color:#fff;margin-bottom:var(--spacing-6)}.subtitle{font-size:var(--font-size-lg);color:#fff9;line-height:var(--line-height-relaxed);max-width:600px;margin-bottom:var(--spacing-10)}.hero-actions{gap:var(--spacing-4);margin-bottom:var(--spacing-16);display:flex}.cta-yellow{background:var(--brand-alt);color:#fff;font-size:var(--font-size-base);padding:var(--spacing-3) var(--spacing-8);border-radius:var(--border-radius-lg);cursor:pointer;font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast);border:none}.cta-yellow:hover{background-color:var(--color-brand-alt-hover)}.cta-yellow:focus-visible{outline-offset:2px;outline:2px solid #fff}.outline-btn{color:#fff;font-size:var(--font-size-base);padding:var(--spacing-3) var(--spacing-8);border-radius:var(--border-radius-lg);cursor:pointer;font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:1px solid #fff3}.outline-btn:hover{background-color:#ffffff14;border-color:#fff6}.outline-btn:focus-visible{outline-offset:2px;outline:2px solid #fff}.hero-stats{gap:var(--spacing-12);padding:var(--spacing-8) 0 var(--spacing-12);border-top:1px solid #ffffff1a;display:flex}.hero-stats .stat h2{font-size:var(--font-size-4xl);font-weight:var(--font-weight-medium);color:var(--brand-alt);margin-bottom:var(--spacing-1)}.hero-stats .stat span{color:#fff9;font-size:var(--font-size-sm)}.news-preview{padding:var(--spacing-16) var(--spacing-12);background:#fff}.news-preview h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-8);color:var(--ink-soft)}.news-grid{gap:var(--spacing-8);grid-template-columns:repeat(3,1fr);display:grid}.news-card{flex-direction:column;display:flex}.news-cover{border-radius:var(--border-radius-lg);height:200px;margin-bottom:var(--spacing-4)}.bg-gray{background:var(--ink-soft)}.bg-amber{background:var(--color-warning)}.bg-green{background:var(--color-success)}.news-body{flex-direction:column;align-items:flex-start;display:flex}.news-tag{font-size:var(--font-size-xs);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius);margin-bottom:var(--spacing-3)}.text-blue{color:var(--brand)}.bg-blue-light{background:var(--brand-light)}.news-body h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--ink);margin-bottom:var(--spacing-2);line-height:var(--line-height-snug)}.news-body time{color:var(--ink-muted);font-size:var(--font-size-sm)}@media (width<=768px){.home-nav{padding:var(--spacing-4);gap:var(--spacing-4);flex-direction:column}.nav-center{justify-content:center;gap:var(--spacing-4);flex-wrap:wrap}.hero-section{padding:var(--spacing-12) var(--spacing-6) 0;text-align:center}.hero-actions{flex-direction:column;width:100%}.hero-actions .cta-yellow,.hero-actions .outline-btn{width:100%}.hero-stats{gap:var(--spacing-6);flex-direction:column;align-items:center}.news-preview{padding:var(--spacing-8) var(--spacing-6)}.news-grid{grid-template-columns:1fr}}.auth-page{background:var(--bg);min-height:100vh;padding:var(--spacing-8) var(--spacing-4);justify-content:center;align-items:center;display:flex}.auth-card{border:1px solid var(--line);border-radius:var(--border-radius-xl);width:100%;max-width:420px;padding:var(--spacing-10) var(--spacing-8);box-shadow:var(--shadow);background:#fff}.auth-brand{align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-8);padding-bottom:var(--spacing-6);border-bottom:1px solid var(--line);flex-direction:column;display:flex}.auth-tagline{font-size:var(--font-size-xs);color:var(--ink-soft);text-align:center;letter-spacing:.02em;margin:0}.auth-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--ink);margin-bottom:var(--spacing-6);text-align:center}.auth-error{padding:var(--spacing-2) var(--spacing-3);color:var(--danger);border-radius:var(--border-radius);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4);background:#fee2e2}.auth-form{gap:var(--spacing-4);flex-direction:column;display:flex}.auth-form-field{gap:var(--spacing-1);flex-direction:column;display:flex}.auth-form-field label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--ink)}.auth-form-hint{font-size:var(--font-size-xs);color:var(--ink-muted);margin-top:var(--spacing-1)}.auth-form-checkbox{align-items:center;gap:var(--spacing-2);display:flex}.auth-form-checkbox label{font-size:var(--font-size-sm);color:var(--ink);cursor:pointer}.auth-form .btn{margin-top:var(--spacing-4);width:100%}.auth-form-footer{margin-top:var(--spacing-4);text-align:center;font-size:var(--font-size-sm);color:var(--ink-soft)}.dashboard-content{background:#fff;padding:2.5rem 3rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.dashboard-header p{color:var(--ink-soft);font-size:var(--font-size-sm)}.kpi-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem;display:grid}.kpi-card{padding:var(--spacing-6) var(--spacing-8);background:var(--bg-soft);box-shadow:none;transition:box-shadow var(--transition-fast), transform var(--transition-fast);border:none}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card h2{color:var(--ink);margin-bottom:.25rem;font-size:2rem;font-weight:600}.kpi-card p{color:var(--ink-soft);font-size:var(--font-size-sm)}.section-split{margin-bottom:3rem}.section-split h2{border-bottom:none;margin-bottom:1.5rem;font-size:1.1rem;font-weight:600}.suggestions-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.suggestion-card{text-align:center;padding:var(--spacing-8) var(--spacing-4);border:1px solid var(--line);box-shadow:none;transition:box-shadow var(--transition-fast), transform var(--transition-fast);flex-direction:column;align-items:center;display:flex}.suggestion-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.suggestion-card .avatar-lg{margin-bottom:1rem}.suggestion-card h4{color:var(--ink);margin-bottom:.25rem;font-size:1rem;font-weight:500}.suggestion-card p{font-size:var(--font-size-sm);color:var(--ink-soft)}.notifications-list{flex-direction:column;display:flex}.notification-item{border-bottom:1px solid var(--line);align-items:flex-start;gap:1rem;padding:1rem 0;display:flex}.notification-item:last-child{border-bottom:none}.notif-icon{border-radius:50%;place-items:center;width:40px;height:40px;font-size:1rem;display:grid}.notif-icon.blue{background:var(--color-notif-blue-bg);color:var(--color-notif-blue-fg)}.notif-icon.gray{background:var(--bg-soft);color:var(--ink-soft)}.notif-icon.amber{background:var(--color-notif-amber-bg);color:var(--color-notif-amber-fg)}.notif-content p{color:var(--ink-soft);margin-bottom:.25rem}.notif-content strong{color:var(--ink);font-weight:500}.notif-content span{font-size:var(--font-size-xs);color:var(--ink-muted)}.notification-item.unread .notif-content p{color:var(--ink)}.section-header{margin-bottom:var(--spacing-6);justify-content:space-between;align-items:center;display:flex}.section-header h2{margin-bottom:0}.section-link{font-size:var(--font-size-sm);color:var(--brand);transition:color var(--transition-fast);text-decoration:none}.section-link:hover{color:var(--color-brand-hover)}.empty-text{color:var(--ink-soft);font-size:var(--font-size-sm);margin-top:var(--spacing-4)}.suggestion-card{cursor:pointer}@media (width<=768px){.dashboard-content{padding:1.5rem 1rem}.kpi-grid,.suggestions-grid{grid-template-columns:1fr;gap:1rem}}.directory-page{padding:1rem 0}.search-bar-container{align-items:center;gap:var(--spacing-4);padding:var(--spacing-2) var(--spacing-4);margin-bottom:var(--spacing-6);box-shadow:none;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--border-radius-lg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);display:flex}.search-input-wrapper{flex:1;align-items:center;gap:.5rem;display:flex}.search-input-wrapper input{padding:var(--spacing-2);font-size:var(--font-size-base);color:var(--ink);background:0 0;border:none;outline:none;flex:1}.search-bar-container:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #1f3a5a1a}.search-input-wrapper input::placeholder{color:var(--ink-muted)}.filter-btn{border:1px solid var(--line);color:var(--ink-soft);padding:var(--spacing-2) var(--spacing-6);border-radius:var(--border-radius-full);cursor:pointer;font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast), color var(--transition-fast);background:#fff}.filter-btn:hover{background-color:var(--bg-soft);color:var(--ink)}.filter-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.filter-pills{flex-wrap:wrap;gap:.8rem;margin-bottom:2rem;display:flex}.pill{border:1px solid var(--line);color:var(--ink-soft);padding:var(--spacing-1) var(--spacing-5);border-radius:var(--border-radius-full);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:#fff}.pill:hover{background-color:var(--bg-soft);color:var(--ink)}.pill:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.pill.active{background:var(--brand);color:#fff;border-color:var(--brand)}.alumni-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.alumni-card{text-align:center;padding:var(--spacing-8) var(--spacing-6);transition:box-shadow var(--transition-fast), transform var(--transition-fast);flex-direction:column;align-items:center;display:flex}.alumni-card:hover{box-shadow:var(--shadow-md)}.alumni-card:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.alumni-card .avatar-lg{width:64px;height:64px;margin-bottom:1rem;font-size:1.2rem}.alumni-card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--ink);margin-bottom:var(--spacing-1)}.alumni-card p{font-size:var(--font-size-sm);color:var(--ink-soft);margin-bottom:var(--spacing-4)}.availability-pill{border-radius:999px;padding:.3rem 1rem;font-size:.8rem;font-weight:500}.pill-blue{background:var(--color-badge-blue-bg);color:var(--color-badge-blue-fg)}.pill-green{background:var(--color-badge-green-bg);color:var(--color-badge-green-fg)}.pill-amber{background:var(--color-badge-amber-bg);color:var(--color-badge-amber-fg)}.pill-gray{background:var(--color-badge-gray-bg);color:var(--color-badge-gray-fg)}.filter-bar{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.filter-bar select{border:1px solid var(--line);background:var(--panel);font-size:var(--font-size-sm);color:var(--ink);border-radius:4px;padding:.5rem}.filter-select--right{margin-left:auto}.alumni-card--clickable{cursor:pointer}.inline-form{gap:var(--spacing-4);padding:var(--spacing-6);align-items:center;display:flex}.inline-form input{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--line);border-radius:var(--border-radius-md);background-color:var(--bg-soft);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-grow:1}.inline-form input:focus-visible{border-color:var(--brand);background-color:#fff;outline:none;box-shadow:0 0 0 3px #1f3a5a1f}.article-card{padding:var(--spacing-6);gap:var(--spacing-3);transition:box-shadow var(--transition-fast), transform var(--transition-fast);flex-direction:column;display:flex}.article-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.article-meta{font-size:var(--font-size-sm);justify-content:space-between;align-items:center;display:flex}.article-meta span{background-color:var(--brand-alt);color:#fff;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius-sm);font-weight:var(--font-weight-medium)}.article-meta small{color:var(--ink-soft)}.article-card h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.article-card p{color:var(--ink-soft)}.news-detail-skeleton{background:var(--bg-soft);border-radius:var(--border-radius-lg);height:400px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.news-detail-cover{object-fit:cover;border-radius:var(--border-radius-lg);width:100%;max-height:380px}.news-detail-body{padding:var(--spacing-8);gap:var(--spacing-5);flex-direction:column;display:flex}.news-detail-urgent{background-color:var(--color-badge-amber-bg);color:var(--color-badge-amber-fg);border:1px solid var(--brand-alt);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.news-detail-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.news-detail-content{gap:var(--spacing-4);color:var(--ink);line-height:var(--line-height-relaxed);font-size:var(--font-size-base);flex-direction:column;display:flex}.tag-row{gap:var(--spacing-2);flex-wrap:wrap;display:flex}.tag-row span{background-color:var(--bg-soft);color:var(--ink-soft);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--border-radius-full);font-size:var(--font-size-sm);border:1px solid var(--line)}.resource-card{padding:var(--spacing-6);gap:var(--spacing-3);transition:box-shadow var(--transition-fast), transform var(--transition-fast);flex-direction:column;display:flex}.resource-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.resource-card h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.resource-card p{color:var(--ink-soft)}.resource-card a{margin-top:var(--spacing-4);font-weight:var(--font-weight-bold);color:var(--brand);align-items:center;gap:var(--spacing-2);text-decoration:none;display:inline-flex}.resource-card a:hover{text-decoration:underline}.list-panel{padding:var(--spacing-6);gap:var(--spacing-4);flex-direction:column;display:flex}.notice-item{padding:var(--spacing-4);border:1px solid var(--line);border-radius:var(--border-radius-lg);background-color:var(--bg-soft);transition:box-shadow var(--transition-fast), transform var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.notice-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.notice-item.read{opacity:.7;background-color:#0000}.notice-item strong{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.notice-item p{margin:var(--spacing-1) 0}.notice-item small{color:var(--ink-soft)}.notice-actions{gap:var(--spacing-4);display:flex}.stack-form{padding:var(--spacing-6);gap:var(--spacing-6);flex-direction:column;display:flex}.grid-two{gap:var(--spacing-6);grid-template-columns:1fr 1fr;display:grid}.stack-form label{gap:var(--spacing-2);font-weight:var(--font-weight-medium);flex-direction:column;display:flex}.stack-form input,.stack-form select,.stack-form textarea{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--line);border-radius:var(--border-radius-md);background-color:var(--bg-soft);transition:border-color var(--transition-fast), box-shadow var(--transition-fast)}.stack-form input:focus-visible,.stack-form select:focus-visible,.stack-form textarea:focus-visible{border-color:var(--brand);background-color:#fff;outline:none;box-shadow:0 0 0 3px #1f3a5a1f}.visibility-grid{gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.visibility-grid label{align-items:center;gap:var(--spacing-2);flex-direction:row;display:flex}.form-actions{margin-top:var(--spacing-4);justify-content:space-between;align-items:center;display:flex}@media (width<=768px){.stack-form{padding:var(--spacing-4);gap:var(--spacing-4)}.grid-two{gap:var(--spacing-4);grid-template-columns:1fr}.form-actions{gap:var(--spacing-3);flex-direction:column;align-items:stretch}.form-actions button,.form-actions a{text-align:center;justify-content:center;width:100%}}.admin-layout{background:#fff;grid-template-columns:240px 1fr;min-height:100vh;display:grid}.admin-sidebar{background:var(--brand);color:#fff;flex-direction:column;display:flex}.admin-brand{font-size:var(--font-size-xl);padding:var(--spacing-6) var(--spacing-8);font-weight:var(--font-weight-medium);color:#fff9;border-bottom:1px solid #ffffff1a}.admin-brand .text-orange{color:var(--brand-alt)}.admin-nav{flex-direction:column;padding-top:1rem;display:flex}.admin-nav a{padding:var(--spacing-4) var(--spacing-8);color:#fff9;font-weight:var(--font-weight-medium);align-items:center;gap:var(--spacing-3);transition:background-color var(--transition-fast), color var(--transition-fast);border-left:3px solid #0000;text-decoration:none;display:flex}.admin-nav a.active{color:#fff;border-left-color:var(--brand-alt);background:#ffffff0d}.admin-nav a:hover{color:#fff;background:#ffffff0a}.admin-nav a:focus-visible{outline:2px solid var(--brand-alt);outline-offset:-2px}.admin-content{padding:var(--spacing-10) var(--spacing-12)}.admin-header{margin-bottom:var(--spacing-10);justify-content:space-between;align-items:center;display:flex}.admin-header h1{font-size:var(--font-size-2xl);color:var(--ink);font-weight:var(--font-weight-medium)}.admin-kpis{gap:var(--spacing-6);margin-bottom:var(--spacing-12);grid-template-columns:repeat(4,1fr);display:grid}.admin-kpi-card{background:var(--bg-soft);padding:var(--spacing-6);border-radius:var(--border-radius-lg)}.admin-kpi-card h2{font-size:var(--font-size-4xl);font-weight:var(--font-weight-normal);color:var(--ink);margin-bottom:var(--spacing-1)}.admin-kpi-card span{color:var(--ink-muted);font-size:var(--font-size-sm)}.admin-table-wrapper{border:1px solid var(--line);border-radius:var(--border-radius-lg);background:#fff;overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--line);color:var(--ink-muted);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.admin-table td{padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--line);color:var(--ink-soft);font-size:var(--font-size-sm);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tbody tr{transition:background-color var(--transition-fast)}.admin-table tbody tr:hover{background-color:var(--bg-soft)}.table-user{align-items:center;gap:1rem;display:flex}.table-user .avatar{width:40px;height:40px;font-size:.85rem}.table-user-info{flex-direction:column;gap:.2rem;display:flex}.table-user-info strong{color:var(--ink);font-weight:500}.text-blue-light{color:var(--color-notif-blue-fg)}.table-user-info span{font-size:var(--font-size-sm)}.status-pill{padding:var(--spacing-1) var(--spacing-3);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.status-active{background:var(--color-badge-green-bg);color:var(--color-badge-green-fg)}.status-pending{background:var(--color-badge-amber-bg);color:var(--color-badge-amber-fg)}@media (width<=1024px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{flex-direction:row;overflow-x:auto}.admin-nav{flex-direction:row;padding-top:0}.admin-nav a{white-space:nowrap;border-bottom:3px solid #0000;border-left:none}.admin-nav a.active{border-left-color:#0000;border-bottom-color:var(--brand-alt)}.admin-content{padding:var(--spacing-6) var(--spacing-4)}.admin-kpis{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.admin-kpis{grid-template-columns:1fr}.admin-table-wrapper{overflow-x:auto}}.admin-status-message{padding:var(--spacing-4);background:var(--color-badge-green-bg);color:var(--color-badge-green-fg);margin-bottom:var(--spacing-6);border-radius:var(--border-radius-lg);font-weight:var(--font-weight-medium);border:1px solid var(--color-success)}.admin-form-panel{padding:var(--spacing-8)}.admin-form{gap:var(--spacing-6);flex-direction:column;max-width:600px;display:flex}.admin-form-field{gap:var(--spacing-2);flex-direction:column;display:flex}.admin-form-field label{font-weight:var(--font-weight-medium);color:var(--ink);font-size:var(--font-size-sm)}.admin-form-field input,.admin-form-field select,.admin-form-field textarea{width:100%;padding:var(--spacing-3);border:1px solid var(--line);border-radius:var(--border-radius-lg);font-family:var(--font-family-sans);font-size:var(--font-size-base);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#fff}.admin-form-field input:focus-visible,.admin-form-field select:focus-visible,.admin-form-field textarea:focus-visible{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #1f3a5a1f}.admin-form-field textarea{resize:vertical;min-height:150px}.admin-form-checkbox{align-items:center;gap:var(--spacing-2);cursor:pointer;color:var(--ink);font-size:var(--font-size-sm);display:flex}.admin-form .btn{align-self:flex-start}.member-profile-page{padding:1rem 0}.back-btn{align-items:center;gap:var(--spacing-1);color:var(--ink-soft);cursor:pointer;font-size:var(--font-size-sm);padding:var(--spacing-1) 0;margin-bottom:var(--spacing-6);transition:color var(--transition-fast);background:0 0;border:none;display:inline-flex}.back-btn:hover{color:var(--brand)}.back-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:2px}.member-profile-layout{grid-template-columns:280px 1fr;align-items:start;gap:1.5rem;display:grid}.member-profile-aside{padding:var(--spacing-8) var(--spacing-6);align-items:center;gap:var(--spacing-3);text-align:center;flex-direction:column;display:flex}.avatar-xl{width:80px;height:80px;font-size:1.5rem}.member-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--ink);margin:0}.member-promotion{font-size:var(--font-size-sm);color:var(--ink-soft);margin:0}.member-contact-list{width:100%;margin-top:var(--spacing-2);gap:var(--spacing-2);text-align:left;flex-direction:column;display:flex}.member-contact-item{font-size:var(--font-size-sm);color:var(--ink-soft);align-items:center;gap:.5rem;display:flex}.member-contact-item a{color:var(--brand);word-break:break-all;text-decoration:none}.member-contact-item a:hover{text-decoration:underline}.member-profile-content{flex-direction:column;gap:1.25rem;display:flex}.member-section{padding:var(--spacing-6);transition:box-shadow var(--transition-fast)}.member-section:hover{box-shadow:var(--shadow-sm)}.member-section h2{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--ink);margin:0 0 .75rem}.member-bio{font-size:var(--font-size-sm);color:var(--ink-soft);line-height:var(--line-height-relaxed);white-space:pre-wrap;margin:0}.tag-list{flex-wrap:wrap;gap:.5rem;display:flex}.tag{background:var(--brand-light);color:var(--brand);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.tag-alt{background:var(--color-badge-amber-bg);color:var(--color-badge-amber-fg)}.member-profile-skeleton{align-items:center;gap:1.5rem;padding:2rem;display:flex}.skeleton-avatar{background:var(--bg-soft);border-radius:50%;flex-shrink:0;width:80px;height:80px;animation:1.5s ease-in-out infinite pulse}.skeleton-lines{flex-direction:column;flex:1;gap:.75rem;display:flex}.skeleton-line{border-radius:var(--border-radius-md);background:var(--bg-soft);height:14px;animation:1.5s ease-in-out infinite pulse}.w-40{width:40%}.w-60{width:60%}.w-80{width:80%}@media (width<=768px){.member-profile-layout{grid-template-columns:1fr}.member-profile-aside{padding:1.5rem 1rem}}
