@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@400;700;900&display=swap');
:root {
    --primary: #1a3c6e;
    --primary-light: #2d5a9e;
    --primary-dark: #0e2444;
    --accent: #c8102e;
    --accent-light: #e8354f;
    --green: #2e8b57;
    --teal: #0a8f8f;
    --orange: #e67e22;
    --purple: #6c3fa0;
    --gold: #d4a843;
    --blue-pale: #eef2ff;
    --gray-50:#fafbfc; --gray-100:#f1f3f5; --gray-200:#e2e6ea; --gray-300:#ced4da;
    --gray-400:#adb5bd; --gray-500:#6c757d; --gray-600:#495057; --gray-700:#343a40;
    --gray-800:#212529; --gray-900:#111315;
    --white:#fff;
    --radius:8px;
    --shadow: 0 0 0 1px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
    --shadow-md: 0 0 0 1px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.08);
    --shadow-lg: 0 0 0 1px rgba(0,0,0,.08),0 12px 36px rgba(0,0,0,.12);
    --max-w: 1200px;
    --transition: .25s cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{overflow-x:clip;}
body{background:var(--white);color:var(--gray-800);font-family:'Source Sans 3','Segoe UI',sans-serif;font-size:16px;line-height:1.7;overflow-x:clip;}
a{color:var(--primary-light);text-decoration:none;transition:color var(--transition);}
a:hover{color:var(--accent);text-decoration:none;}
img{max-width:100%;height:auto;}
.container{max-width:var(--max-w);margin:0 auto;padding:0 28px;}

/* ========== NAVBAR PRO ========== */
.navbar{background:var(--white);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100;box-shadow:0 0 0 1px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);-webkit-sticky:sticky;display:flex;flex-direction:column;}
.tricolor-bar{height:2px;background:var(--gray-200);flex-shrink:0;width:100%;position:relative;overflow:hidden;--progress:0%;}
.tricolor-bar::after{content:'';position:absolute;top:0;left:0;height:100%;width:var(--progress);background:var(--accent);transition:width .15s linear;}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 20px;display:flex;align-items:center;height:56px;gap:8px;flex-wrap:nowrap;}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;margin-right:8px;}
/* Search */
.nav-search{display:flex;align-items:center;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:8px;padding:0 12px;height:36px;flex:1;max-width:340px;transition:all .2s;position:relative;}
.nav-search.focused{background:var(--white);border-color:var(--primary-light);box-shadow:0 0 0 2px rgba(45,90,158,.15);}
.nav-search-icon{font-size:14px;color:var(--gray-400);margin-right:8px;flex-shrink:0;}
.nav-search input{border:none;background:transparent;font-size:13px;font-family:inherit;width:100%;outline:none;color:var(--gray-800);}
.nav-search input::placeholder{color:var(--gray-400);}
.nav-search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--white);border:1px solid var(--gray-200);border-radius:8px;box-shadow:var(--shadow-md);max-height:320px;overflow-y:auto;z-index:200;}
.nsr-item{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background .15s;font-size:13px;color:var(--gray-700);}
.nsr-item:hover{background:var(--gray-50);}
.nsr-item strong{color:var(--gray-900);}
/* Article body (rendered HTML from WYSIWYG) */
.article-body{font-size:15px;color:var(--gray-700);line-height:1.8;}
.article-body h2{font-size:22px;font-weight:800;color:var(--primary);margin:24px 0 10px;border-bottom:1px solid var(--gray-200);padding-bottom:6px;}
.article-body h3{font-size:18px;font-weight:700;color:var(--primary);margin:20px 0 8px;}
.article-body p{margin-bottom:14px;}
.article-body img{max-width:100%;border-radius:8px;margin:12px 0;box-shadow:0 2px 12px rgba(0,0,0,.1);}
.article-body figure{margin:20px 0;text-align:center;}
.article-body figcaption{font-size:12px;color:var(--gray-500);margin-top:6px;font-style:italic;}
.article-body blockquote{border-left:4px solid var(--primary);padding:12px 20px;margin:16px 0;background:var(--gray-50);color:var(--gray-600);font-style:italic;border-radius:0 8px 8px 0;}
.article-body ul,.article-body ol{padding-left:28px;margin:12px 0;}
.article-body li{margin-bottom:6px;}
.article-body a{color:var(--primary);font-weight:600;}
.article-body hr{border:none;border-top:2px solid var(--gray-200);margin:28px 0;}
.article-body iframe{border-radius:8px;}
body.dark-mode .article-body{color:#c9d1d9;}
body.dark-mode .article-body h2,body.dark-mode .article-body h3{color:#58a6ff;}
body.dark-mode .article-body blockquote{background:#0d1117;border-color:#58a6ff;color:#8b949e;}

/* WYSIWYG Editor — Word-like fullscreen */
.we-fullscreen{max-width:100%!important;width:100%;height:100vh;margin:0;border-radius:0;display:flex;flex-direction:column;padding:0;}
.we-fullscreen .we-editor{flex:1;min-height:0;max-height:none;border-radius:0;border-left:0;border-right:0;padding:28px max(24px,calc(50% - 380px));}
.we-maximized{position:fixed!important;top:0;left:0;right:0;bottom:0;z-index:10001;margin:0;}
.we-topbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--white);border-bottom:1px solid var(--gray-200);flex-shrink:0;}
.we-title-input{border:none;font-size:20px;font-weight:700;color:var(--primary);flex:1;min-width:0;padding:4px 0;outline:none;background:transparent;}
.we-title-input:focus{border-bottom:2px solid var(--primary);}
.we-title-input::placeholder{color:var(--gray-300);}
.we-meta-select{border:1px solid var(--gray-200);border-radius:6px;padding:6px 10px;font-size:13px;background:var(--white);color:var(--gray-600);}
.we-close-btn{width:36px;height:36px;border:none;background:none;font-size:18px;cursor:pointer;border-radius:6px;color:var(--gray-400);display:flex;align-items:center;justify-content:center;}
.we-close-btn:hover{background:var(--gray-100);color:var(--accent);}
.we-meta-drawer{padding:0 16px;border-bottom:1px solid var(--gray-100);flex-shrink:0;}
.we-meta-drawer summary{font-size:13px;color:var(--gray-500);cursor:pointer;padding:8px 0;font-weight:600;}
.we-meta-drawer summary:hover{color:var(--primary);}
.we-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px 10px;background:var(--gray-50);border-bottom:1px solid var(--gray-200);align-items:center;flex-shrink:0;}
.we-toolbar-row2{border-top:none;background:var(--white);border-bottom:1px solid var(--gray-200);}
.we-toolbar button{min-width:28px;height:28px;border:none;background:none;cursor:pointer;border-radius:4px;font-size:12px;color:var(--gray-600);display:inline-flex;align-items:center;justify-content:center;gap:3px;font-family:inherit;transition:all .1s;position:relative;padding:0 6px;white-space:nowrap;}
.we-toolbar button:hover{background:var(--gray-200);color:var(--primary);}
.we-select,.we-toolbar select{font-size:12px;border:1px solid var(--gray-200);border-radius:4px;padding:4px 6px;background:var(--white);color:var(--gray-600);cursor:pointer;height:28px;}
.we-sep{width:1px;height:20px;background:var(--gray-200);margin:0 4px;flex-shrink:0;}
.we-editor{min-height:350px;max-height:600px;overflow-y:auto;padding:24px 28px;border:1px solid var(--gray-200);font-size:15px;line-height:1.8;color:var(--gray-700);outline:none;background:var(--white);}
.we-editor:focus{box-shadow:none;background:var(--white);}
.we-editor h1{font-size:28px;font-weight:800;color:var(--primary);margin:24px 0 12px;}
.we-editor h2{font-size:22px;font-weight:800;color:var(--primary);margin:20px 0 10px;border-bottom:1px solid var(--gray-200);padding-bottom:6px;}
.we-editor h3{font-size:18px;font-weight:700;color:var(--primary);margin:16px 0 8px;}
.we-editor h4{font-size:15px;font-weight:700;color:var(--gray-600);margin:12px 0 6px;}
.we-editor p{margin-bottom:12px;}
.we-editor pre{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:6px;padding:12px 16px;font-family:'Courier New',monospace;font-size:13px;overflow-x:auto;margin:12px 0;}
.we-editor blockquote{border-left:4px solid var(--primary);padding:8px 16px;margin:12px 0;background:var(--gray-50);color:var(--gray-600);font-style:italic;border-radius:0 6px 6px 0;}
.we-editor img{max-width:100%;border-radius:8px;margin:8px 0;cursor:pointer;}
.we-editor figure{margin:16px 0;text-align:center;}
.we-editor figcaption{font-size:12px;color:var(--gray-500);margin-top:6px;}
.we-editor ul,.we-editor ol{padding-left:24px;margin:8px 0;}
.we-editor a{color:var(--primary);text-decoration:underline;}
.we-editor hr{border:none;border-top:2px solid var(--gray-200);margin:24px 0;}
.we-editor table{border-collapse:collapse;width:100%;margin:12px 0;}
.we-editor table td,.we-editor table th{border:1px solid var(--gray-200);padding:8px 12px;vertical-align:top;min-width:60px;}
.we-editor table th{background:var(--gray-50);font-weight:700;}
.we-source{display:none;flex:1;min-height:0;width:100%;padding:16px;border:none;border-top:1px solid var(--gray-200);font-family:'Courier New',monospace;font-size:13px;line-height:1.6;resize:none;background:#1e1e2e;color:#cdd6f4;outline:none;}
.we-statusbar{display:flex;align-items:center;gap:16px;padding:4px 16px;background:var(--gray-50);border-top:1px solid var(--gray-200);font-size:11px;color:var(--gray-400);flex-shrink:0;}
.we-statusbar-btn{border:none;background:none;color:var(--gray-400);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:3px;}
.we-statusbar-btn:hover{background:var(--gray-200);color:var(--primary);}
/* Preview panel */
.we-preview{flex:1;overflow-y:auto;background:var(--white);padding:32px;}
/* Focus mode */
.we-focus-mode .we-toolbar,.we-focus-mode .we-toolbar-row2,.we-focus-mode .we-topbar,.we-focus-mode .we-meta-drawer,.we-focus-mode .we-statusbar{opacity:.15;transition:opacity .3s;}
.we-focus-mode .we-toolbar:hover,.we-focus-mode .we-toolbar-row2:hover,.we-focus-mode .we-topbar:hover,.we-focus-mode .we-statusbar:hover{opacity:1;}
.we-focus-mode .we-editor{background:#faf9f6;padding:40px max(40px,calc(50% - 340px));font-size:17px;line-height:2;}
/* Find bar */
.we-findbar{display:flex;gap:6px;padding:6px 12px;background:var(--gray-50);border-bottom:1px solid var(--gray-200);align-items:center;flex-shrink:0;}
/* Format painter cursor */
.we-painting{cursor:crosshair!important;}
.we-painting *{cursor:crosshair!important;}
/* Keyboard shortcuts */
kbd{display:inline-block;padding:2px 6px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:4px;font-size:12px;font-family:monospace;}
/* Upload field (file explorer button) */
.we-upload-field{display:flex;gap:0;align-items:stretch;}
.we-upload-field input{flex:1;border-radius:6px 0 0 6px!important;border-right:none!important;}
.we-upload-btn{padding:6px 14px;border:1px solid var(--gray-200);border-radius:0 6px 6px 0;background:var(--gray-50);color:var(--primary);cursor:pointer;font-size:12px;font-weight:600;white-space:nowrap;transition:all .15s;}
.we-upload-btn:hover{background:var(--primary);color:#fff;}
/* Template buttons */
.we-tpl-btn{padding:12px;border:1px solid var(--gray-200);border-radius:8px;background:var(--white);cursor:pointer;text-align:left;font-size:14px;font-weight:600;color:var(--primary);width:100%;transition:all .15s;}
.we-tpl-btn:hover{background:var(--gray-50);border-color:var(--primary);}
/* Insert dialogs */
.we-dialog-bg{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:10002;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s;}
.we-dialog{background:var(--white);border-radius:12px;padding:24px;max-width:480px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.we-dialog h4{color:var(--primary);margin-bottom:16px;font-size:16px;}
/* Dark mode */
body.dark-mode .we-fullscreen,body.dark-mode .we-topbar{background:#0d1117;}
body.dark-mode .we-title-input{color:#58a6ff;}
body.dark-mode .we-toolbar{background:#161b22;border-color:#30363d;}
body.dark-mode .we-toolbar-row2{background:#0d1117;}
body.dark-mode .we-editor{background:#0d1117;border-color:#30363d;color:#c9d1d9;}
body.dark-mode .we-toolbar button{color:#8b949e;}
body.dark-mode .we-toolbar button:hover{background:#21262d;color:#58a6ff;}
body.dark-mode .we-toolbar select{background:#161b22;border-color:#30363d;color:#8b949e;}
body.dark-mode .we-statusbar{background:#161b22;border-color:#30363d;}
body.dark-mode .we-meta-drawer{border-color:#30363d;}
body.dark-mode .we-dialog{background:#161b22;color:#c9d1d9;}
body.dark-mode .we-dialog h4{color:#58a6ff;}
body.dark-mode .we-close-btn{color:#8b949e;}
body.dark-mode .we-close-btn:hover{background:#21262d;color:#f85149;}

/* Classic theme (style ingenieur-ferroviaire.net / Joomla) */
body.classic-theme{
    --primary:#001B4C;--primary-light:#236fa1;--accent:#001B4C;
    font-family:Georgia,'Times New Roman','Palatino Linotype',serif;
    background:#f0f4fb;color:#495057;
}
/* Navbar: bleu marine plein, pas d'arrondi, bordure rouge en bas */
body.classic-theme .navbar{background:#001B4C;box-shadow:none;border-bottom:3px solid #c8102e}
body.classic-theme .tricolor-bar{display:none}
body.classic-theme .nav-inner{max-width:1100px}
body.classic-theme .nav-link{padding:10px 14px}
body.classic-theme .nav-link-text{font-family:Georgia,serif;font-size:14px;letter-spacing:.3px}
body.classic-theme .nav-link:hover .nav-link-text{color:#fff}
body.classic-theme .nav-link.active{border-bottom-color:#c8102e}
body.classic-theme .nav-admin-btn{background:#c8102e;border-radius:2px}
body.classic-theme .nav-member-btn{background:#236fa1;border-radius:2px}
/* Textes et titres */
body.classic-theme h1,body.classic-theme h2,body.classic-theme h3,body.classic-theme h4{font-family:Georgia,serif;color:#001B4C}
body.classic-theme .section-title{font-family:Georgia,serif;color:#001B4C;font-size:26px;letter-spacing:-.5px}
body.classic-theme .section-sub{font-family:Georgia,serif;color:#6c757d}
body.classic-theme p,body.classic-theme li,body.classic-theme td,body.classic-theme th{font-family:Georgia,serif}
body.classic-theme a{color:#236fa1}
/* Cards: pas d'arrondi, bordure fine, ombre legere */
body.classic-theme .card{border-radius:2px;box-shadow:0 1px 3px rgba(0,0,0,.08);border:1px solid #d0d7de}
body.classic-theme .card:hover{box-shadow:0 2px 6px rgba(0,0,0,.12);transform:none}
body.classic-theme .card-title{font-family:Georgia,serif;color:#001B4C}
body.classic-theme .card-link{color:#236fa1;font-family:Georgia,serif;text-transform:uppercase;font-size:12px;letter-spacing:1px}
body.classic-theme .card-tag{border-radius:2px}
/* Boutons: carres, bleu marine ou rouge */
body.classic-theme .btn{border-radius:2px;font-family:Georgia,serif;letter-spacing:.3px}
body.classic-theme .btn-accent{background:#001B4C}
body.classic-theme .btn-primary{background:#236fa1}
body.classic-theme .btn-accent:hover{background:#002d6e}
/* Hero slider: pas d'arrondi */
body.classic-theme .hero-slider{border-radius:0}
body.classic-theme .slide-content h1{font-family:Georgia,serif;font-size:30px;text-shadow:2px 2px 6px rgba(0,0,0,.6);letter-spacing:-.5px}
body.classic-theme .slide-content p{font-family:Georgia,serif;font-size:16px}
body.classic-theme .btn-outline-white{border-radius:2px}
/* Association hero */
body.classic-theme .asso-hero{border-radius:0;background:#001B4C}
body.classic-theme .asso-hero-bg{background:#001B4C;opacity:1}
body.classic-theme .asso-hero-title{font-family:Georgia,serif;font-size:24px}
body.classic-theme .asso-kpi{border-radius:2px}
body.classic-theme .asso-block{border-radius:2px}
body.classic-theme .asso-quote{border-radius:0;border-left-color:#001B4C}
/* Annuaire LinkedIn cards */
body.classic-theme .ln-card{border-radius:2px}
body.classic-theme .ln-cover{background:#001B4C;border-radius:0}
body.classic-theme .ln-modal{border-radius:4px}
body.classic-theme .ln-name{font-family:Georgia,serif}
/* Footer: bleu marine, institutionnel */
body.classic-theme .footer-compact{background:#001B4C;border-top:3px solid #c8102e}
body.classic-theme .fc-brand{font-family:Georgia,serif}
body.classic-theme .fc-links a{font-family:Georgia,serif}
/* Onglets */
body.classic-theme .member-tabs-unified{border-bottom:2px solid #001B4C}
body.classic-theme .mtab-u{border-radius:0;font-family:Georgia,serif}
body.classic-theme .mtab-u.active{border-bottom:3px solid #c8102e;color:#001B4C}
/* Partenaires */
body.classic-theme .partner-tile{border-radius:0}
/* Divers */
body.classic-theme .kpi-card,.classic-theme .sk{border-radius:2px}
body.classic-theme .ch-panel,.classic-theme .ch-team-card,.classic-theme .ch-team-full{border-radius:2px}
body.classic-theme .legal-tab{font-family:Georgia,serif;border-radius:0}
body.classic-theme .about-list li::before{border-radius:2px}
body.classic-theme .cards-grid{gap:16px}
/* Timeline */
body.classic-theme .timeline-dot{background:#001B4C}
body.classic-theme .timeline-year{color:#001B4C;font-family:Georgia,serif}
/* Mobile bottom nav */
body.classic-theme .mobile-nav{background:#001B4C;border-color:#c8102e}
body.classic-theme .mnav-btn{color:rgba(255,255,255,.5)}
body.classic-theme .mnav-btn.active{color:#fff}
body.classic-theme .mnav-btn span{font-family:Georgia,serif}

/* Bug report widget */
.bug-btn{position:fixed;bottom:24px;right:24px;z-index:99;width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:20px;cursor:pointer;box-shadow:0 4px 16px rgba(200,16,46,.4);transition:all .2s;}
.bug-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(200,16,46,.5);}
.bug-panel{position:fixed;bottom:80px;right:24px;z-index:99;width:320px;background:var(--white);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);border:1px solid var(--gray-200);overflow:hidden;animation:lnModalIn .2s ease;}
.bug-header{background:var(--accent);color:#fff;padding:10px 14px;font-size:13px;font-weight:700;display:flex;justify-content:space-between;align-items:center;}
.bug-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;opacity:.7;}
.bug-close:hover{opacity:1;}
#bug-form-content{padding:12px;display:flex;flex-direction:column;gap:8px;}
.bug-input{width:100%;padding:8px 10px;border:1px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:13px;}
.bug-input:focus{border-color:var(--accent);outline:none;}
.bug-captcha{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-500);}
.bug-captcha-input{width:50px;padding:4px 8px;border:1px solid var(--gray-200);border-radius:4px;font-size:13px;text-align:center;}
.bug-page{font-size:11px;color:var(--gray-400);margin:0;}
.bug-submit{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;}
.bug-submit:hover{opacity:.9;}
.bug-submit:disabled{opacity:.5;}
body.dark-mode .bug-panel{background:#161b22;border-color:#30363d;}
body.dark-mode .bug-input{background:#0d1117;border-color:#30363d;color:#c9d1d9;}
@media(max-width:768px){
    .bug-btn{bottom:64px;right:12px;width:38px;height:38px;font-size:16px;}
    .bug-panel{bottom:110px;right:12px;width:calc(100vw - 24px);max-width:320px;}
}

/* Compact stat KPI */
.sk{background:var(--white);border:1px solid var(--gray-200);border-left:3px solid var(--gray-300);border-radius:6px;padding:8px 10px;text-align:center;}
.skv{font-size:18px;font-weight:900;color:var(--primary);line-height:1.1;}
.skl{font-size:9px;color:var(--gray-500);margin-top:2px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
body.dark-mode .sk{background:#161b22;border-color:#30363d;}
@media(max-width:768px){
    .sk{padding:6px;} .skv{font-size:14px;} .skl{font-size:8px;}
    #adm-stats-content > div{grid-template-columns:repeat(3,1fr)!important;}
}
.nsr-cat{padding:6px 14px;font-size:10px;font-weight:800;color:var(--gray-400);text-transform:uppercase;letter-spacing:1px;background:var(--gray-50);border-top:1px solid var(--gray-100);}
.nsr-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;}
/* Nav links */
.nav-links{display:flex;gap:0;margin:0 4px;flex-shrink:1;overflow:hidden;}
.nav-link{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 16px;color:var(--gray-500);font-size:11px;font-weight:600;text-decoration:none;transition:all var(--transition);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;}
.nav-link-icon{font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;width:24px;height:24px;}
.nav-link-icon svg{flex-shrink:0;stroke:var(--primary);}
.nav-link.active .nav-link-icon svg{stroke:var(--accent);}
.nav-link-text{line-height:1;}
.nav-link:hover{color:var(--gray-900);text-decoration:none;}
.nav-link.active{color:var(--gray-900);border-bottom-color:var(--gray-900);}
/* Actions group (bell, dark, user, hamburger) */
.nav-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-left:auto;}
/* Notification bell */
.nav-notif{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;transition:background .2s;}
.nav-notif:hover{background:var(--gray-100);}
.nav-notif-icon{font-size:20px;color:var(--gray-600);}
.nav-notif-badge{position:absolute;top:4px;right:4px;background:var(--accent);color:var(--white);font-size:10px;font-weight:800;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);}
/* User area */
.nav-user{display:flex;align-items:center;}
.nav-member-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:var(--white)!important;padding:8px 20px;border-radius:20px;font-size:13px;font-weight:700;text-decoration:none!important;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;}
.nav-member-btn:hover{background:var(--primary-light);text-decoration:none!important;color:var(--white)!important;}
.nav-admin-btn{display:none;align-items:center;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:700;color:var(--white)!important;background:var(--accent);text-decoration:none!important;white-space:nowrap;transition:opacity .2s;}
.nav-admin-btn:hover{opacity:.85;text-decoration:none!important;color:var(--white)!important;}
.admin-topbar{display:flex;align-items:center;gap:16px;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--accent);}
.admin-back-btn{background:none;border:none;color:var(--primary);font-size:13px;font-weight:700;cursor:pointer;padding:0;font-family:inherit;}
.admin-back-btn:hover{text-decoration:underline;}
.admin-topbar-title{font-size:18px;font-weight:900;color:var(--accent);margin:0;}
.nav-user-logged{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border-radius:20px;cursor:pointer;transition:background .2s;text-decoration:none!important;}
.nav-user-logged:hover{background:var(--gray-100);text-decoration:none!important;}
.nav-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;}
.nav-user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.nav-user-name{font-size:13px;font-weight:700;color:var(--gray-800);line-height:1.2;}
.nav-user-role{font-size:11px;color:var(--gray-400);font-weight:500;}
/* Sub nav */
.nav-sub{background:var(--gray-50);border-bottom:1px solid var(--gray-200);padding:0;}
.nav-sub-inner{max-width:var(--max-w);margin:0 auto;padding:0 20px;display:flex;gap:0;overflow-x:auto;}
.nav-sub-link{padding:10px 16px;font-size:13px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;text-decoration:none;}
.nav-sub-link:hover{color:var(--gray-800);text-decoration:none;}
.nav-sub-link.active{color:var(--primary);border-bottom-color:var(--primary);}
/* Hamburger */
.nav-hamburger{display:none;background:none;border:none;font-size:24px;cursor:pointer;color:var(--gray-600);width:40px;height:40px;border-radius:8px;transition:background .2s;flex-shrink:0;}
.nav-hamburger:hover{background:var(--gray-100);}

/* === RESPONSIVE === */
@media(max-width:1024px){
    .nav-links{display:none;}
    .nav-links.open{display:flex;position:absolute;top:56px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-md);flex-direction:row;justify-content:center;padding:8px;z-index:200;flex-wrap:wrap;}
    .nav-search{max-width:160px;}
    .nav-hamburger{display:flex;align-items:center;justify-content:center;}
    .nav-user-name{display:none;}
    .nav-user-role{display:none;}
    .nav-user-logged{padding:4px;}
    .nav-inner{flex-wrap:nowrap;}
}
@media(max-width:768px){
    .nav-inner{padding:0 12px;gap:4px;justify-content:space-between;width:100%;}
    .nav-logo{margin-right:auto;}
    .nav-logo img{height:30px!important;}
    .nav-actions{margin-left:auto;gap:4px;}
    .nav-search{max-width:120px;padding:0 8px;height:32px;}
    .nav-search input{font-size:12px;}
    .nav-notif{width:32px;height:32px;}
    .nav-notif-icon{font-size:16px;}
    .nav-dark-toggle{width:30px;height:30px;font-size:14px;}
    .nav-member-btn{padding:6px 14px;font-size:12px;}
    .nav-actions{gap:2px;}
    .nav-links.open{flex-wrap:wrap;gap:4px;padding:6px;}
    .nav-links.open .nav-link{padding:8px 12px;font-size:10px;}
    .nav-links.open .nav-link-icon{font-size:16px;}
    /* Hero */
    .hero-slider{height:350px;}
    .slide-content h1{font-size:28px;}
    .slide-content p{font-size:15px;}
    /* Cards */
    .cards-grid{grid-template-columns:1fr!important;}
    .kpi-row{grid-template-columns:1fr 1fr!important;}
    /* Section */
    .section-title{font-size:24px;}
    .container{padding:0 16px;}
    section{padding:32px 0;}
    /* Expert cards */
    .member-grid,.ecoles-grid{grid-template-columns:1fr!important;}
    /* Board */
    .board-grid{grid-template-columns:1fr 1fr!important;}
    /* Footer */
    .footer-grid{grid-template-columns:1fr 1fr!important;gap:16px;}
    .footer .container > p, .footer-bar{font-size:12px!important;line-height:1.5!important;}
    /* Welcome dashboard */
    .wd-stats{flex-direction:column;gap:16px;}
    .wd-name{font-size:24px;}
    .wd-actions{flex-direction:column;align-items:center;}
    .wd-container{min-height:auto;padding:20px 0;}
    /* Admin */
    .adm-table{font-size:12px;}
    .adm-table th,.adm-table td{padding:6px 8px;}
    .adm-modal{width:95vw!important;max-width:95vw!important;margin:10px!important;}
    /* Locked */
    .locked-page{min-height:250px;padding:20px;}
    .locked-page-icon{font-size:56px;}
    .locked-page-content h2{font-size:18px;}
    /* Polls */
    .poll-card{padding:14px;}
    /* Share */
    .share-bar{flex-wrap:wrap;}
    /* Stats */
    #adm-stats-content > div{grid-template-columns:1fr!important;}
    .stat-bar-label{width:100px;font-size:11px;}
    /* Contact & Adhesion responsive */
    #page-contact .container > div > div[style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
    #page-adhesion .kpi-row { grid-template-columns: repeat(2, 1fr) !important; }
}
@media(max-width:480px){
    .nav-search{display:none;}
    .nav-inner{height:48px;}
    .nav-links.open .nav-link{flex-direction:row;gap:6px;}
    .nav-links.open .nav-link-icon{font-size:14px;}
    .nav-links.open .nav-link-text{font-size:11px;}
    .slide-content h1{font-size:22px;}
    .kpi-row{grid-template-columns:1fr!important;}
    .board-grid{grid-template-columns:1fr!important;}
    .ec-body{padding:8px 12px 0;}
    .ec-expertise{padding:8px 12px 0;}
    .wd-content{padding:20px 16px;}
}

/* ========== HERO SLIDER ========== */
.hero-slider{position:relative;height:520px;overflow:hidden;}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;display:flex;align-items:center;justify-content:center;}
.slide.active{opacity:1;}
.slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.45);background-color:#1a3c6e;}
.slide-bg-1{background:linear-gradient(135deg,#0a1628 0%,#1a3c6e 40%,#2d5a9e 100%);}
.slide-bg-2{background:linear-gradient(135deg,#0e2444 0%,#1a5276 40%,#148f77 100%);}
.slide-bg-3{background:linear-gradient(135deg,#1a1a2e 0%,#6c3fa0 40%,#c8102e 100%);}
.slide-content{position:relative;z-index:2;text-align:center;color:var(--white);max-width:750px;padding:0 28px;}
.slide-content h1{font-size:48px;font-weight:900;line-height:1.15;margin-bottom:16px;text-shadow:0 2px 12px rgba(0,0,0,.4);}
.slide-content p{font-size:19px;color:rgba(255,255,255,.8);margin-bottom:28px;line-height:1.6;}
.slide-dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3;}
.slide-dot{width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:all .3s;}
.slide-dot.active{background:var(--white);transform:scale(1.2);}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:13px 32px;border-radius:4px;font-family:inherit;font-size:15px;font-weight:700;text-decoration:none;transition:all var(--transition);border:none;cursor:pointer;letter-spacing:.3px;}
.btn-accent{background:var(--accent);color:var(--white);}
.btn-accent:hover{background:var(--accent-light);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 16px rgba(200,16,46,.3);}
.btn-white{background:var(--white);color:var(--primary);}
.btn-white:hover{background:var(--gray-100);text-decoration:none;}
.btn-outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.4);}
.btn-outline-white:hover{background:rgba(255,255,255,.1);text-decoration:none;}
.btn-primary{background:var(--primary);color:var(--white);}
.btn-primary:hover{background:var(--primary-light);text-decoration:none;}

/* ========== THEMATIC ICONS ROW ========== */
.themes-row{display:grid;grid-template-columns:repeat(6,1fr);gap:0;margin:-60px auto 0;position:relative;z-index:10;max-width:var(--max-w);padding:0 28px;}
@media(max-width:768px){.themes-row{grid-template-columns:repeat(3,1fr);margin-top:-30px;}}
.theme-card{text-align:center;padding:32px 12px 24px;background:var(--white);border:1px solid var(--gray-200);transition:all var(--transition);cursor:pointer;}
.theme-card:first-child{border-radius:var(--radius) 0 0 var(--radius);}
.theme-card:last-child{border-radius:0 var(--radius) var(--radius) 0;}
.theme-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);z-index:2;}
.theme-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:26px;color:var(--white);}
.ti-1{background:var(--primary);} .ti-2{background:var(--teal);} .ti-3{background:var(--orange);}
.ti-4{background:var(--green);} .ti-5{background:var(--purple);} .ti-6{background:var(--gold);}
.theme-label{font-size:13px;font-weight:700;color:var(--gray-700);text-transform:uppercase;letter-spacing:.5px;line-height:1.3;}

/* ========== SECTIONS ========== */
section{padding:72px 0;}
.bg-light{background:var(--gray-50);}
.bg-primary{background:var(--primary);color:var(--white);}
.section-title{font-size:34px;font-weight:900;color:var(--primary);margin-bottom:8px;}
.section-title-white{color:var(--white);}
.section-title-center{text-align:center;}
.section-sub{color:var(--gray-500);margin-bottom:44px;font-size:17px;}
.section-sub-center{text-align:center;}
.section-line{width:60px;height:4px;background:var(--accent);margin-bottom:20px;}
.section-line-center{margin-left:auto;margin-right:auto;}

/* ========== CARDS ========== */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:28px;}
.card{background:var(--white);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;transition:all var(--transition);border:1px solid var(--gray-200);}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.card-img{width:100%;height:210px;object-fit:cover;}
.card-img-placeholder{width:100%;height:210px;display:flex;align-items:center;justify-content:center;font-size:52px;}
.cip-1{background:linear-gradient(135deg,var(--primary),var(--primary-light));}
.cip-2{background:linear-gradient(135deg,var(--teal),#0abfbf);}
.cip-3{background:linear-gradient(135deg,var(--orange),#f0a050);}
.cip-4{background:linear-gradient(135deg,var(--purple),#9b6fd0);}
.card-body{padding:24px;}
.card-date{display:inline-block;background:var(--accent);color:var(--white);padding:3px 12px;border-radius:3px;font-size:12px;font-weight:700;margin-bottom:12px;letter-spacing:.3px;}
.card-tag{display:inline-block;background:var(--gray-100);color:var(--gray-600);padding:3px 12px;border-radius:3px;font-size:12px;font-weight:600;margin:0 4px 8px 0;}
.card-tag-primary{background:var(--primary);color:var(--white);opacity:.85;}
.card-title{font-size:20px;font-weight:800;color:var(--gray-900);margin-bottom:10px;line-height:1.3;}
.card-title a{color:var(--gray-900);}
.card-title a:hover{color:var(--accent);}
.card-text{color:var(--gray-600);font-size:15px;line-height:1.7;margin-bottom:16px;}
.card-link{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;transition:gap var(--transition);}
.card-link:hover{gap:10px;text-decoration:none;}
.card-link::after{content:'\2192';}

/* ========== KPI ========== */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-bottom:56px;}
@media(max-width:768px){.kpi-row{grid-template-columns:repeat(2,1fr);}}
.kpi-card{text-align:center;padding:36px 20px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border-top:4px solid var(--primary);}
.kpi-icon{font-size:40px;margin-bottom:10px;}
.kpi-val{font-size:42px;font-weight:900;color:var(--primary);line-height:1;}
.kpi-label{font-size:14px;color:var(--gray-500);margin-top:6px;font-weight:500;}

/* ========== ABOUT ========== */
/* Association page — hero + layout */
.asso-hero{position:relative;border-radius:16px;overflow:hidden;margin-bottom:32px;padding:48px 32px;text-align:center;}
.asso-hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 50%,var(--teal) 100%);opacity:.95;}
.asso-hero-content{position:relative;z-index:1;}
.asso-hero-title{font-size:28px;font-weight:900;color:#fff;margin:0 0 8px;line-height:1.3;}
.asso-hero-sub{font-size:14px;color:rgba(255,255,255,.7);margin:0;}

/* KPI row */
.asso-kpi-row{display:flex;justify-content:center;gap:12px;margin:-20px auto 32px;position:relative;z-index:2;flex-wrap:wrap;max-width:800px;}
.asso-kpi{background:var(--white);border:1px solid var(--gray-200);border-radius:10px;padding:14px 20px;text-align:center;box-shadow:var(--shadow);min-width:100px;flex:1;}
.asso-kpi-val{font-size:26px;font-weight:900;color:var(--primary);line-height:1;}
.asso-kpi-label{font-size:11px;color:var(--gray-500);margin-top:4px;font-weight:600;}

/* 2-col grid */
.asso-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;}
.asso-block{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:24px;}
.asso-block h3{font-size:18px;font-weight:800;color:var(--primary);margin:0 0 12px;display:flex;align-items:center;gap:8px;}
.asso-block p{font-size:14px;color:var(--gray-600);line-height:1.7;margin-bottom:12px;}
.asso-icon{font-size:22px;}

/* Activity items */
.asso-activity{display:flex;flex-direction:column;gap:4px;}
.asso-act-item{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s;font-size:13px;color:var(--gray-600);line-height:1.5;}
.asso-act-item:hover{background:var(--gray-50);}
.asso-act-item strong{color:var(--gray-900);font-size:14px;}
.asso-act-item span{font-size:12px;}
.asso-act-icon{font-size:20px;flex-shrink:0;margin-top:2px;}

/* Quote */
.asso-quote{background:var(--gray-50);border-left:4px solid var(--primary);border-radius:0 12px 12px 0;padding:24px 28px;margin-bottom:24px;}
.asso-quote blockquote{font-size:15px;font-style:italic;color:var(--gray-600);line-height:1.7;margin:0 0 8px;}
.asso-quote cite{font-size:13px;color:var(--primary);font-weight:700;font-style:normal;}

/* About list (reuse) */
.about-list{list-style:none;padding:0;margin:12px 0;}
.about-list li{padding:8px 0 8px 32px;position:relative;color:var(--gray-700);font-size:14px;border-bottom:1px solid var(--gray-100);line-height:1.6;}
.about-list li:last-child{border:none;}
.about-list li::before{content:'\2713';position:absolute;left:0;top:8px;width:22px;height:22px;background:var(--accent);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;}

/* Dark mode association */
body.dark-mode .asso-kpi{background:#161b22;border-color:#30363d;}
body.dark-mode .asso-block{background:#161b22;border-color:#30363d;}
body.dark-mode .asso-block h3{color:#58a6ff;}
body.dark-mode .asso-act-item:hover{background:#21262d;}
body.dark-mode .asso-act-item strong{color:#f0f6fc;}
body.dark-mode .asso-quote{background:#0d1117;border-color:#58a6ff;}
body.dark-mode .asso-quote blockquote{color:#8b949e;}

/* Mobile association */
@media(max-width:768px){
    .asso-hero{padding:32px 16px;}
    .asso-hero-title{font-size:20px;}
    .asso-kpi-row{gap:6px;margin-top:-12px;}
    .asso-kpi{padding:10px 8px;min-width:60px;}
    .asso-kpi-val{font-size:18px;}
    .asso-kpi-label{font-size:9px;}
    .asso-grid{grid-template-columns:1fr;gap:16px;}
    .asso-block{padding:16px;}
    .asso-quote{padding:16px 20px;}
}

/* ========== BOARD ========== */
.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:24px;}
.board-card{text-align:center;padding:36px 20px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-200);transition:all var(--transition);}
.board-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.board-avatar{width:90px;height:90px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;margin:0 auto 16px;border:4px solid var(--gray-100);}
.board-name{font-size:18px;font-weight:700;color:var(--gray-900);}
.board-role{font-size:14px;color:var(--accent);font-weight:700;margin-top:4px;}

/* ========== ORG TILES ========== */
.org-section{margin-bottom:28px;}
.org-section-label{font-size:11px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;text-align:center;}
.org-tiles{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;}
.org-tile{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--gray-200);border-left:3px solid var(--primary);border-radius:8px;padding:10px 14px;transition:all .15s;cursor:default;min-width:180px;}
.org-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);}
.org-tile-lg{padding:14px 20px;border-left-width:4px;min-width:220px;}
.org-tile-sm{padding:8px 12px;min-width:150px;border-left-width:2px;}
.org-tile-xs{padding:6px 10px;min-width:130px;border-left-width:2px;}
.org-tile-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;}
.org-tile-lg .org-tile-avatar{width:48px;height:48px;font-size:16px;}
.org-tile-sm .org-tile-avatar{width:30px;height:30px;font-size:10px;}
.org-tile-info{min-width:0;}
.org-tile-name{font-size:13px;font-weight:700;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.org-tile-lg .org-tile-name{font-size:15px;}
.org-tile-role{font-size:11px;color:var(--gray-500);font-weight:600;}
.org-tile-lg .org-tile-role{font-size:13px;color:var(--accent);font-weight:700;}
.org-connector{width:2px;height:20px;background:var(--gray-300);margin:0 auto;}
/* dark-mode org rules moved to comprehensive block */
.board-company{font-size:13px;color:var(--gray-500);margin-top:4px;}

/* ========== TIMELINE ========== */
.timeline{position:relative;padding-left:36px;max-width:700px;margin:0 auto;}
.timeline::before{content:'';position:absolute;left:14px;top:0;bottom:0;width:3px;background:var(--gray-200);}
.timeline-item{position:relative;margin-bottom:36px;}
.timeline-dot{position:absolute;left:-29px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--accent);border:4px solid var(--white);box-shadow:0 0 0 3px var(--accent);}
.timeline-year{font-size:15px;font-weight:800;color:var(--accent);margin-bottom:4px;}
.timeline-text{color:var(--gray-600);font-size:15px;line-height:1.6;}

/* ========== CTA BANNER ========== */
.cta-banner{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);padding:64px 0;text-align:center;color:var(--white);}
.cta-banner h2{font-size:34px;font-weight:900;margin-bottom:12px;}
.cta-banner p{font-size:18px;color:rgba(255,255,255,.7);margin-bottom:28px;max-width:600px;margin-left:auto;margin-right:auto;}

/* ========== FORM ========== */
.form-card{max-width:600px;margin:0 auto;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:44px;box-shadow:var(--shadow-md);}
.form-group{margin-bottom:22px;}
.form-group label{display:block;font-size:14px;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:15px;color:var(--gray-800);transition:border-color var(--transition);}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(26,60,110,.08);}
.form-group textarea{min-height:130px;resize:vertical;}
.form-submit{display:flex;align-items:center;justify-content:center;width:100%;padding:14px;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius);font-family:inherit;font-size:16px;font-weight:700;cursor:pointer;transition:background var(--transition);letter-spacing:.3px;}
.form-submit:hover{background:var(--accent-light);}
.form-success{background:var(--green);color:var(--white);padding:14px;border-radius:var(--radius);text-align:center;margin-top:16px;display:none;font-weight:600;}
.adh-choice{display:flex;align-items:center;gap:12px;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .2s;}
.adh-choice:hover{border-color:var(--primary-light);background:rgba(26,60,110,.02);}
.adh-choice-selected{border-color:var(--primary);background:rgba(26,60,110,.04);}
.adh-pay-choice{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .2s;text-align:center;}
.adh-pay-choice:hover{border-color:var(--primary-light);}
.adh-pay-selected{border-color:var(--primary);background:rgba(26,60,110,.04);}

/* ========== PARTNERS ========== */
.partners-grid{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;align-items:center;}
.partner-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:24px 16px;text-align:center;display:flex;align-items:center;justify-content:center;min-height:90px;transition:all var(--transition);}
.partner-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.partner-logo{max-height:50px;max-width:120px;object-fit:contain;filter:grayscale(30%);transition:filter var(--transition);}
.partner-card:hover .partner-logo{filter:grayscale(0);}
.partner-name{font-size:15px;font-weight:700;color:var(--gray-600);}
.partner-tile{display:flex;align-items:center;justify-content:center;width:140px;height:80px;padding:12px;border-radius:8px;transition:all .2s;text-decoration:none;}
.partner-tile:hover{transform:scale(1.05);box-shadow:var(--shadow-md);}
.partner-tile-logo{max-width:120px;max-height:60px;object-fit:contain;}
.partner-tile-text{font-size:14px;font-weight:800;color:var(--primary);text-align:center;}

/* ========== FOOTER ========== */
.footer{background:var(--gray-900);color:rgba(255,255,255,.55);padding:36px 0 20px;display:none;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px;}
/* Compact footer */
.footer-compact{background:var(--gray-900);color:rgba(255,255,255,.6);padding:16px 0 12px;}
.fc-row{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:10px;}
.fc-brand{font-size:12px;line-height:1.5;}
.fc-brand strong{color:#fff;font-weight:800;}
.fc-links{display:flex;gap:16px;flex-wrap:wrap;}
.fc-links a{color:rgba(255,255,255,.65);font-size:12px;text-decoration:none;transition:color .15s;}
.fc-links a:hover{color:#fff;}
.fc-legal{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;padding:10px 0;border-top:1px solid rgba(255,255,255,.08);}
.fc-legal a{color:rgba(255,255,255,.5);font-size:11px;text-decoration:none;transition:color .15s;}
.fc-legal a:hover{color:rgba(255,255,255,.8);}
.fc-bar{border-top:1px solid rgba(255,255,255,.05);padding-top:8px;text-align:center;font-size:10px;color:rgba(255,255,255,.2);line-height:1.6;}
.fc-bar a{color:rgba(255,255,255,.3);text-decoration:none;}
.fc-bar a:hover{color:rgba(255,255,255,.6);}
@media(max-width:768px){
    .fc-row{flex-direction:column;text-align:center;gap:8px;}
    .fc-links{justify-content:center;}
    .fc-brand{font-size:11px;}
}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;}}
.footer h4{color:var(--white);font-size:14px;font-weight:800;margin-bottom:10px;text-transform:uppercase;letter-spacing:1px;}
.footer p{font-size:14px;line-height:1.8;}
.footer-links{list-style:none;padding:0;}
.footer-links li{margin-bottom:4px;}
.footer-links a{color:rgba(255,255,255,.65);font-size:14px;text-decoration:none;transition:color var(--transition);}
.footer-links a:hover{color:var(--white);}
.footer-bar{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;text-align:center;font-size:12px;color:rgba(255,255,255,.25);}

/* ========== NOTIFICATION BELL ========== */
.nav-bell{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;transition:background .2s;}
.nav-bell:hover{background:var(--gray-100);}
.nav-bell-icon{font-size:20px;color:var(--gray-600);}
.nav-bell-count{position:absolute;top:2px;right:2px;background:var(--accent);color:#fff;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);padding:0 4px;}
.notif-panel{position:absolute;top:52px;right:0;width:360px;max-height:440px;background:var(--white);border:1px solid var(--gray-200);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.15);z-index:200;overflow:hidden;animation:notifSlide .2s ease;}
@keyframes notifSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.notif-panel-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--gray-100);font-size:15px;}
.notif-panel-list{max-height:360px;overflow-y:auto;}
.notif-panel-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--gray-50);cursor:pointer;transition:background .1s;}
.notif-panel-item:hover{background:var(--gray-50);}
.notif-panel-item.notif-unread{background:rgba(26,60,110,.03);border-left:3px solid var(--primary);}
.notif-panel-icon{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.notif-panel-body{flex:1;min-width:0;}
.notif-panel-title{font-size:13px;font-weight:700;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.notif-panel-text{font-size:12px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.notif-panel-time{font-size:11px;color:var(--gray-400);margin-top:2px;}
.notif-panel-empty{text-align:center;padding:40px 20px;color:var(--gray-400);font-size:14px;}
/* dark-mode notif rules moved to comprehensive block */

/* ========== UTILS ========== */
/* ========== MEMBER TABS ========== */
.member-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid var(--gray-200);padding-bottom:0;flex-wrap:wrap;}
.mtab{padding:10px 20px;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;font-family:inherit;font-size:14px;font-weight:600;color:var(--gray-500);cursor:pointer;transition:all var(--transition);}
.mtab:hover{color:var(--primary);}
.mtab.active{color:var(--accent);border-bottom-color:var(--accent);}
.mtab-content{margin-top:8px;}

/* ========== MEMBER DIRECTORY ========== */
.member-grid{display:block;}
.member-card{display:flex;gap:16px;align-items:center;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:all var(--transition);}
.member-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.member-avatar{width:56px;height:56px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0;}
.member-info{flex:1;min-width:0;}
.member-name{font-size:16px;font-weight:700;color:var(--gray-900);}
.member-job{font-size:13px;color:var(--gray-600);margin-top:2px;}
.member-company{font-size:13px;color:var(--primary);font-weight:600;margin-top:1px;}

/* ========== EXPERT CARD (v3) ========== */
.expert-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition);cursor:pointer;position:relative;}
.expert-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--primary-light);}
.ec-banner{height:48px;background:linear-gradient(135deg,var(--primary),var(--primary-light));position:relative;display:flex;align-items:center;justify-content:flex-end;padding:0 12px;gap:6px;}
.ec-mentor-flag{background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;}
.ec-board-flag{background:var(--gold);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;}
.ec-avatar-wrap{width:72px;height:72px;border-radius:50%;border:3px solid var(--white);background:var(--primary);margin:-36px auto 0;position:relative;z-index:2;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.15);}
.ec-photo{width:100%;height:100%;object-fit:cover;}
.ec-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:22px;font-weight:900;background:var(--primary);}
.ec-body{text-align:center;padding:10px 16px 0;}
.ec-name{font-size:17px;font-weight:800;color:var(--gray-900);line-height:1.2;}
.ec-job{font-size:13px;color:var(--gray-600);margin-top:2px;}
.ec-company{font-size:13px;color:var(--primary);font-weight:700;margin-top:1px;}
.ec-location{font-size:12px;color:var(--gray-500);margin-top:4px;}
.ec-expertise{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;padding:10px 16px 0;}
.ec-tag{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;background:var(--gray-100);color:var(--gray-600);}
.ec-tag-specialty{background:var(--teal);color:#fff;}
.ec-expand{max-height:0;overflow:hidden;transition:max-height .4s ease, opacity .3s ease, padding .3s ease;opacity:0;padding:0 16px;}
.mc-expanded .ec-expand{max-height:400px;opacity:1;padding:12px 16px;}
.ec-bio{font-size:13px;color:var(--gray-500);line-height:1.6;font-style:italic;border-top:1px solid var(--gray-100);padding-top:10px;margin-bottom:8px;}
.ec-meta{font-size:12px;color:var(--gray-400);margin-bottom:10px;}
.ec-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.ec-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 16px;border-radius:6px;font-size:12px;font-weight:700;border:none;cursor:pointer;text-decoration:none;transition:all var(--transition);font-family:inherit;}
.ec-btn-msg{background:var(--primary);color:var(--white);}
.ec-btn-msg:hover{background:var(--primary-light);text-decoration:none;}
.ec-btn-li{background:#0077b5;color:var(--white);}
.ec-btn-li:hover{background:#005a8c;text-decoration:none;color:var(--white);}
.ec-footer{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-top:1px solid var(--gray-100);margin-top:10px;}
.ec-rgpd{font-size:11px;color:var(--gray-400);}
.ec-expand-hint{font-size:10px;color:var(--gray-300);transition:transform .3s;}
.mc-expanded .ec-expand-hint{transform:rotate(180deg);}
.card-tag-region{background:var(--purple);color:#fff;}

/* ========== LINKEDIN-STYLE ANNUAIRE ========== */
.ln-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;}
.ln-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:all .25s ease;cursor:pointer;position:relative;display:flex;flex-direction:column;}
.ln-card:hover{box-shadow:0 8px 30px rgba(0,0,0,.12);transform:translateY(-4px);border-color:var(--primary-light);}
.ln-cover{height:56px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 50%,var(--teal) 100%);position:relative;display:flex;align-items:center;justify-content:flex-end;padding:0 12px;gap:6px;}
.ln-flag{font-size:10px;font-weight:700;padding:3px 10px;border-radius:12px;color:#fff;}
.ln-flag-board{background:var(--gold);}
.ln-flag-mentor{background:var(--green);}
.ln-avatar{width:72px;height:72px;border-radius:50%;border:3px solid var(--white);background:var(--primary);margin:-36px auto 0;position:relative;z-index:2;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.15);flex-shrink:0;}
.ln-avatar img{width:100%;height:100%;object-fit:cover;}
.ln-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:900;}
.ln-avail-dot{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;border:2px solid var(--white);z-index:3;}
.ln-body{text-align:center;padding:10px 20px 0;flex:1;}
.ln-name{font-size:17px;font-weight:600;color:var(--gray-900);line-height:1.3;}
.ln-name strong{font-weight:900;}
.ln-name-blur{font-size:20px;font-weight:900;letter-spacing:6px;color:var(--gray-300);}
.ln-headline{font-size:13px;color:var(--gray-600);margin-top:2px;line-height:1.4;}
.ln-company{font-size:13px;color:var(--primary);font-weight:700;margin-top:2px;}
.ln-location{font-size:12px;color:var(--gray-500);margin-top:4px;display:flex;align-items:center;justify-content:center;gap:4px;}
.ln-location svg{opacity:.6;}
.ln-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;padding:10px 16px 0;}
.ln-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;background:var(--gray-100);color:var(--gray-600);transition:all .2s;}
.ln-tag-accent{background:var(--teal);color:#fff;}
.ln-bio{font-size:12px;color:var(--gray-500);line-height:1.5;padding:8px 20px 0;text-align:center;font-style:italic;}
.ln-badges{display:flex;gap:6px;justify-content:center;padding:6px 16px 0;}
.ln-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;}
.ln-badge-board{background:var(--primary);color:#fff;}
.ln-badge-mentor{background:var(--teal);color:#fff;}
.ln-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--gray-100);margin-top:12px;}
.ln-verified{font-size:11px;color:var(--gray-400);}
.ln-li-btn{width:28px;height:28px;border-radius:50%;background:#0077b5;color:#fff;display:flex;align-items:center;justify-content:center;transition:opacity .2s;text-decoration:none;}
.ln-li-btn:hover{opacity:.8;color:#fff;text-decoration:none;}

/* Locked card overlay */
.ln-card-locked{cursor:pointer;}
.ln-card-locked .ln-avatar{background:var(--gray-300);}
.ln-card-locked .ln-cover{background:linear-gradient(135deg,var(--gray-400),var(--gray-300));}
.ln-lock-overlay{padding:8px 16px 0;text-align:center;}
.ln-lock-msg{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--primary);background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:8px;padding:8px 16px;}

/* LinkedIn-style modal */
.ln-modal{background:var(--white);border-radius:16px;max-width:560px;width:95%;margin:auto;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3);position:relative;animation:lnModalIn .3s ease;}
@keyframes lnModalIn{from{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.ln-modal-close{position:absolute;top:12px;right:12px;z-index:5;width:32px;height:32px;border-radius:50%;border:none;background:rgba(0,0,0,.3);color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.ln-modal-close:hover{background:rgba(0,0,0,.5);}
.ln-modal-cover{height:100px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 50%,var(--teal) 100%);}
.ln-modal-header{display:flex;gap:16px;align-items:center;padding:16px 24px;position:relative;z-index:2;background:var(--white);}
.ln-modal-avatar{width:80px;height:80px;border-radius:50%;border:4px solid var(--white);background:var(--primary);overflow:hidden;flex-shrink:0;box-shadow:0 4px 16px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:900;margin-top:-56px;}
.ln-modal-avatar img{width:100%;height:100%;object-fit:cover;}
.ln-modal-info{padding-bottom:8px;min-width:0;}
.ln-modal-info h2{font-size:22px;font-weight:900;color:var(--gray-900);margin:0;line-height:1.2;}
.ln-modal-headline{font-size:14px;color:var(--gray-600);margin:2px 0 0;}
.ln-modal-company{font-size:14px;color:var(--primary);font-weight:700;margin:0;}
.ln-modal-loc{font-size:13px;color:var(--gray-500);margin:2px 0 0;display:flex;align-items:center;gap:4px;}
.ln-modal-badges{display:flex;gap:6px;flex-wrap:wrap;padding:16px 24px 0;}
.ln-modal-section{padding:0 24px;margin-top:16px;}
.ln-modal-section h4{font-size:11px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:1px;margin:0 0 6px;}
.ln-modal-section p{font-size:14px;color:var(--gray-600);margin:0;line-height:1.7;}
.ln-modal-details{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px 24px 0;}
.ln-modal-detail{display:flex;flex-direction:column;gap:2px;}
.ln-modal-label{font-size:11px;color:var(--gray-400);font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.ln-modal-detail span:last-child{font-size:14px;color:var(--gray-700);}
.ln-modal-actions{padding:20px 24px;display:flex;gap:10px;flex-wrap:wrap;}
.ln-modal-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;border-radius:24px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;border:none;cursor:pointer;font-family:inherit;}
.ln-modal-btn-li{background:#0077b5;color:#fff;}
.ln-modal-btn-li:hover{background:#005a8c;color:#fff;text-decoration:none;}

/* Dark mode LinkedIn annuaire */
body.dark-mode .ln-card{background:#161b22;border-color:#30363d;}
body.dark-mode .ln-card:hover{border-color:#58a6ff;box-shadow:0 8px 30px rgba(0,0,0,.4);}
body.dark-mode .ln-cover{background:linear-gradient(135deg,#161b22,#21262d,#0d4429);}
body.dark-mode .ln-name,body.dark-mode .ln-name strong{color:#f0f6fc;}
body.dark-mode .ln-name-blur{color:#484f58;}
body.dark-mode .ln-headline{color:#8b949e;}
body.dark-mode .ln-company{color:#58a6ff;}
body.dark-mode .ln-location{color:#6e7681;}
body.dark-mode .ln-tag{background:#30363d;color:#c9d1d9;}
body.dark-mode .ln-bio{color:#6e7681;}
body.dark-mode .ln-footer{border-color:#21262d;}
body.dark-mode .ln-verified{color:#484f58;}
body.dark-mode .ln-lock-msg{background:#0d1117;border-color:#30363d;color:#58a6ff;}
body.dark-mode .ln-card-locked .ln-cover{background:linear-gradient(135deg,#21262d,#30363d);}
body.dark-mode .ln-card-locked .ln-avatar{background:#30363d;}
body.dark-mode .ln-modal{background:#161b22;}
body.dark-mode .ln-modal-header{background:#161b22;}
body.dark-mode .ln-modal-cover{background:linear-gradient(135deg,#161b22,#21262d);}
body.dark-mode .ln-modal-info h2{color:#f0f6fc;}
body.dark-mode .ln-modal-headline{color:#8b949e;}
body.dark-mode .ln-modal-company{color:#58a6ff;}
body.dark-mode .ln-modal-section p{color:#8b949e;}
body.dark-mode .ln-modal-detail span:last-child{color:#c9d1d9;}

/* ========== RGPD BANNERS ========== */
.rgpd-banner{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(135deg,#eef2ff,#f0fdf4);border:1px solid #c7d2fe;border-radius:8px;padding:16px 20px;margin-bottom:24px;font-size:13px;line-height:1.7;color:var(--gray-700);}
.rgpd-banner-icon{font-size:28px;flex-shrink:0;margin-top:2px;}
.rgpd-banner strong{color:var(--primary);}
.rgpd-banner a{color:var(--primary-light);font-weight:600;}
.rgpd-notice{background:var(--gray-50);border:1px solid var(--gray-200);border-left:4px solid var(--primary);border-radius:var(--radius);padding:12px 16px;margin-bottom:20px;font-size:13px;line-height:1.7;color:var(--gray-600);}

/* ========== ANNOUNCEMENTS ========== */
.announcement-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:24px;margin-bottom:16px;box-shadow:var(--shadow);transition:all var(--transition);}
.announcement-card:hover{box-shadow:var(--shadow-md);}
.ann-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.ann-cat{display:inline-block;padding:3px 12px;border-radius:12px;color:var(--white);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.ann-date{font-size:12px;color:var(--gray-400);}
.ann-title{font-size:18px;font-weight:800;color:var(--gray-900);margin-bottom:8px;}
.ann-content{color:var(--gray-600);font-size:15px;line-height:1.7;}
.ann-author{margin-top:12px;font-size:13px;color:var(--gray-500);font-style:italic;}

/* ========== ADMIN ========== */
.adm-nav{display:flex;gap:4px;margin-bottom:20px;flex-wrap:wrap;}
.adm-nav-btn{padding:8px 16px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:13px;font-weight:600;color:var(--gray-600);cursor:pointer;transition:all var(--transition);}
.adm-nav-btn:hover{background:var(--gray-200);}
.adm-nav-btn.active{background:var(--primary);color:var(--white);border-color:var(--primary);}
.adm-section{display:none;}
.adm-table{width:100%;border-collapse:collapse;font-size:14px;}
.adm-table th{background:var(--gray-50);padding:10px 12px;text-align:left;font-size:12px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid var(--gray-200);}
.adm-table td{padding:10px 12px;border-bottom:1px solid var(--gray-100);vertical-align:middle;}
.adm-table tr:hover{background:var(--gray-50);}
.adm-actions{white-space:nowrap;}
.adm-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--gray-200);background:var(--white);border-radius:6px;cursor:pointer;font-size:14px;transition:all var(--transition);margin:0 2px;}
.adm-btn:hover{box-shadow:var(--shadow);}
.adm-btn-ok{color:var(--green);border-color:var(--green);}
.adm-btn-ok:hover{background:var(--green);color:var(--white);}
.adm-btn-warn{color:var(--orange);border-color:var(--orange);}
.adm-btn-warn:hover{background:var(--orange);color:var(--white);}
.adm-btn-danger{color:var(--accent);border-color:var(--accent);}
.adm-btn-danger:hover{background:var(--accent);color:var(--white);}
.adm-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:700;}
.adm-badge-active{background:#ecfdf5;color:#059669;}
.adm-badge-pending{background:#fffbeb;color:#d97706;}
.adm-badge-blocked{background:#fef2f2;color:#b91c1c;}
.adm-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.adm-modal{background:var(--white);border-radius:12px;padding:32px;max-width:600px;width:100%;box-shadow:var(--shadow-lg);margin:auto 0;flex-shrink:0;pointer-events:auto;position:relative;z-index:1001;}
.adm-toolbar{display:flex;gap:12px;margin-bottom:16px;align-items:center;flex-wrap:wrap;}
.adm-toolbar input,.adm-toolbar select{padding:8px 14px;border:2px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:13px;}

/* ========== FEED ========== */
.feed-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:24px;margin-bottom:16px;box-shadow:var(--shadow);}
.feed-header{display:flex;gap:12px;align-items:center;margin-bottom:14px;}
.feed-author{font-weight:700;color:var(--gray-900);font-size:15px;}
.feed-meta{font-size:12px;color:var(--gray-400);}
.feed-content{color:var(--gray-700);font-size:15px;line-height:1.7;margin-bottom:12px;white-space:pre-line;}
.feed-link{display:block;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:12px 16px;margin-bottom:12px;color:var(--primary);font-weight:600;font-size:14px;}
.feed-link:hover{background:var(--blue-pale);}
.feed-actions{display:flex;gap:8px;border-top:1px solid var(--gray-100);padding-top:10px;}
.feed-action-btn{background:none;border:1px solid var(--gray-200);padding:5px 14px;border-radius:20px;font-family:inherit;font-size:13px;color:var(--gray-600);cursor:pointer;transition:all var(--transition);}
.feed-action-btn:hover{background:var(--blue-pale);color:var(--primary);border-color:var(--primary);}
.feed-comments{border-top:1px solid var(--gray-100);padding-top:12px;margin-top:10px;}
.feed-comment{padding:8px 0;font-size:14px;color:var(--gray-600);border-bottom:1px solid var(--gray-50);}
.comment-form{display:flex;gap:8px;margin-top:10px;}
.comment-form input{flex:1;padding:8px 12px;border:1px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:13px;}
.comment-form button{background:var(--primary);color:var(--white);border:none;padding:8px 16px;border-radius:var(--radius);font-family:inherit;font-size:13px;cursor:pointer;}
.profile-badge{display:inline-block;background:var(--gold);color:var(--white);padding:1px 8px;border-radius:10px;font-size:10px;font-weight:700;margin-left:4px;vertical-align:middle;}

/* ========== JOBS ========== */
.job-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:24px;margin-bottom:16px;box-shadow:var(--shadow);transition:all var(--transition);}
.job-card:hover{box-shadow:var(--shadow-md);}
.job-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;}
.job-title{font-size:18px;font-weight:800;color:var(--gray-900);}
.job-company{font-size:14px;color:var(--primary);font-weight:600;margin-top:2px;}
.job-desc{color:var(--gray-600);font-size:14px;line-height:1.6;margin-bottom:14px;}
.job-footer{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.job-salary{font-weight:700;color:var(--green);font-size:14px;}

/* ========== MESSAGES ========== */
.conv-item{display:flex;gap:12px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background var(--transition);}
.conv-item:hover{background:var(--gray-50);}
.conv-unread{background:var(--blue-pale);}
.conv-info{flex:1;min-width:0;}
.conv-name{font-weight:700;font-size:14px;color:var(--gray-900);}
.conv-preview{font-size:13px;color:var(--gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.conv-date{font-size:11px;color:var(--gray-400);white-space:nowrap;}
.thread-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--gray-200);font-size:16px;}
.thread-messages{padding:16px;max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;}
.thread-msg{max-width:75%;padding:10px 14px;border-radius:12px;font-size:14px;}
.msg-mine{align-self:flex-end;background:var(--primary);color:var(--white);border-bottom-right-radius:4px;}
.msg-other{align-self:flex-start;background:var(--gray-100);color:var(--gray-800);border-bottom-left-radius:4px;}
.msg-time{font-size:10px;opacity:.6;margin-top:4px;}
.thread-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--gray-200);}
.thread-input input{flex:1;padding:10px 14px;border:2px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:14px;}

/* ========== NOTIFICATIONS ========== */
.notif-badge{position:absolute;top:12px;right:180px;background:var(--accent);color:var(--white);width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.notif-item{padding:14px 16px;border-bottom:1px solid var(--gray-100);transition:background var(--transition);}
.notif-unread{background:var(--blue-pale);border-left:3px solid var(--primary);}
.notif-title{font-weight:700;font-size:14px;color:var(--gray-900);}
.notif-text{font-size:13px;color:var(--gray-600);margin-top:2px;}
.notif-date{font-size:11px;color:var(--gray-400);margin-top:4px;}
.empty-msg{text-align:center;color:var(--gray-400);padding:40px;font-size:14px;}

/* ========== COURSES ========== */
.course-filter{padding:8px 20px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:20px;font-family:inherit;font-size:13px;font-weight:600;color:var(--gray-600);cursor:pointer;transition:all var(--transition);}
.course-filter:hover{background:var(--gray-200);}
.course-filter.active{background:var(--primary);color:var(--white);border-color:var(--primary);}
.course-card .card-body{display:flex;flex-direction:column;}
.course-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:16px;border-top:1px solid var(--gray-100);flex-wrap:wrap;gap:8px;}
.course-price{font-size:20px;font-weight:900;color:var(--accent);}

/* ========== MAP ========== */
#map-container{border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);}
.leaflet-popup-content{font-family:'Source Sans 3',sans-serif !important;}
.map-marker-company,.map-marker-member{background:transparent !important;border:none !important;}

/* ========== UTILS ========== */
.text-center{text-align:center;} .mt-24{margin-top:24px;} .mt-48{margin-top:48px;}
.hidden{display:none!important;} .page{display:none;} .page.active{display:block;}
.flex-gap{display:flex;gap:12px;flex-wrap:wrap;}

/* ========== PARTNER ROTATING BANNER ========== */
.partner-banner{position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--white);border-top:2px solid var(--primary);box-shadow:0 -2px 16px rgba(0,0,0,.1);padding:10px 0;transition:opacity .3s;}
.partner-banner-inner{max-width:var(--max-w);margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:16px;}
.partner-banner-label{background:var(--primary);color:#fff;font-size:11px;font-weight:800;padding:4px 12px;border-radius:20px;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;}
#partner-banner-content{flex:1;display:flex;align-items:center;gap:12px;font-size:14px;color:var(--gray-700);}
#partner-banner-content a{color:var(--primary);font-weight:700;text-decoration:none;}
#partner-banner-content a:hover{color:var(--accent);}
.partner-banner-close{background:none;border:none;font-size:22px;color:var(--gray-400);cursor:pointer;padding:4px 8px;line-height:1;}
.partner-banner-close:hover{color:var(--gray-700);}
@media(max-width:768px){.partner-banner{display:none!important;}}

/* ========== HOME WELCOME ========== */
.home-welcome{padding:64px 0;background:var(--white);}
.hw-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.hw-badge{display:inline-block;background:var(--primary);color:#fff;font-size:11px;font-weight:800;padding:5px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;}
.hw-title{font-size:36px;font-weight:900;color:var(--primary-dark);line-height:1.15;margin:0 0 16px;}
.hw-desc{font-size:16px;color:var(--gray-600);line-height:1.7;margin-bottom:24px;}
.hw-stats{display:flex;gap:32px;margin-bottom:28px;}
.hw-stat{text-align:center;}
.hw-stat-val{display:block;font-size:32px;font-weight:900;color:var(--primary);line-height:1;}
.hw-stat-label{font-size:12px;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.5px;}
.hw-actions{display:flex;gap:12px;flex-wrap:wrap;}
.hw-visual{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.hw-card{background:var(--white);border:1px solid var(--gray-200);border-radius:14px;padding:28px 20px;text-align:center;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.04);}
.hw-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-3px);}
.hw-card-icon{font-size:36px;margin-bottom:10px;}
.hw-card-text{font-size:13px;font-weight:700;color:var(--gray-700);}
.hw-card-1{border-top:3px solid var(--accent);}
.hw-card-2{border-top:3px solid var(--primary);}
.hw-card-3{border-top:3px solid var(--teal);}
.hw-card-4{border-top:3px solid var(--purple);}
@media(max-width:768px){
    .hw-layout{grid-template-columns:1fr;gap:32px;}
    .hw-title{font-size:28px;}
    .hw-stats{gap:20px;}
    .hw-stat-val{font-size:24px;}
    .hw-visual{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){.hw-visual{grid-template-columns:1fr;}.hw-stats{flex-wrap:wrap;gap:16px;}}
/* dark-mode hw rules moved to comprehensive block */

/* ========== POLL POPUP ========== */
.poll-popup-options{display:flex;flex-direction:column;gap:8px;}
.poll-popup-option{position:relative;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:10px;cursor:pointer;transition:all .15s;overflow:hidden;font-family:inherit;font-size:14px;text-align:left;width:100%;}
.poll-popup-option:hover{border-color:var(--primary-light);background:var(--white);}
.poll-popup-voted{border-color:var(--primary);background:rgba(26,60,110,.04);}
.poll-popup-opt-label{position:relative;z-index:1;font-weight:700;color:var(--gray-800);}
.poll-popup-opt-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(26,60,110,.08);transition:width .5s ease;border-radius:10px;}
.poll-popup-voted .poll-popup-opt-bar{background:rgba(26,60,110,.15);}
.poll-popup-opt-pct{position:relative;z-index:1;font-size:14px;font-weight:800;color:var(--primary);}
.poll-popup-result{cursor:default;}
.poll-popup-result:hover{border-color:var(--gray-200);background:var(--gray-50);}

/* ========== NEWS CAROUSEL ========== */
.news-carousel-wrap{position:relative;overflow:hidden;padding:0 48px;}
.news-carousel-wrap .nc-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--white);border:1px solid var(--gray-200);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gray-600);cursor:pointer;z-index:5;transition:all .15s;}
.news-carousel-wrap .nc-arrow:hover{background:var(--primary);color:var(--white);border-color:var(--primary);}
.nc-arrow-left{left:0;}
.nc-arrow-right{right:0;}
#news-carousel{display:flex;gap:20px;transition:transform .4s cubic-bezier(.25,.8,.25,1);will-change:transform;}
.news-carousel-card{min-width:280px;max-width:280px;background:var(--white);border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.06);border:1px solid var(--gray-200);overflow:hidden;cursor:pointer;transition:all .2s;flex-shrink:0;}
.news-carousel-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);transform:translateY(-4px);}
.ncc-img{position:relative;height:160px;overflow:hidden;}
.ncc-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;color:rgba(255,255,255,.4);}
.ncc-img img{width:100%;height:100%;object-fit:cover;}
.ncc-date{position:absolute;bottom:10px;left:10px;background:rgba(0,0,0,.7);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:4px;backdrop-filter:blur(4px);}
.ncc-body{padding:16px;}
.ncc-title{font-size:15px;font-weight:800;color:var(--gray-900);line-height:1.3;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.ncc-excerpt{font-size:13px;color:var(--gray-500);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.ncc-link{font-size:12px;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;}
.ncc-link:hover{text-decoration:underline;}
@media(max-width:768px){.news-carousel-wrap{padding:0 36px;}.news-carousel-card{min-width:240px;max-width:240px;}.nc-arrow{width:32px;height:32px;font-size:14px;}}
/* dark-mode news rules moved to comprehensive block */

/* ========== COOKIE BANNER ========== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--primary-dark);color:var(--white);padding:20px 0;box-shadow:0 -4px 24px rgba(0,0,0,.2);transition:opacity .3s;}
.cookie-inner{max-width:var(--max-w);margin:0 auto;padding:0 28px;display:flex;gap:24px;align-items:center;}
.cookie-text{flex:1;font-size:13px;line-height:1.6;}
.cookie-text strong{font-size:15px;display:block;margin-bottom:4px;}
.cookie-text a{color:var(--gold);font-weight:600;}
.cookie-actions{display:flex;gap:8px;flex-shrink:0;}
@media(max-width:768px){.cookie-inner{flex-direction:column;text-align:center;}.cookie-actions{justify-content:center;}}

/* ========== TOAST NOTIFICATIONS ========== */
.toast-container{position:fixed;top:90px;right:20px;z-index:1001;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--white);border:1px solid var(--gray-200);border-radius:8px;padding:14px 20px;box-shadow:var(--shadow-lg);font-size:14px;font-weight:600;transform:translateX(120%);transition:transform .3s ease;max-width:360px;}
.toast-visible{transform:translateX(0);}
.toast-success{border-left:4px solid var(--green);color:var(--green);}
.toast-error{border-left:4px solid var(--accent);color:var(--accent);}
.toast-info{border-left:4px solid var(--primary);color:var(--primary);}

/* ========== WELCOME DASHBOARD ========== */
.wd-container{position:relative;min-height:520px;background:linear-gradient(135deg,#0a1628 0%,#1a3c6e 40%,#2d5a9e 80%,#0a8f8f 100%);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.wd-particles{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;}
.wd-content{position:relative;z-index:2;text-align:center;color:var(--white);padding:40px 28px;max-width:700px;}
.wd-avatar-ring{width:96px;height:96px;border-radius:50%;border:3px solid rgba(255,255,255,.3);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;animation:wd-pulse 2s ease-in-out infinite;}
@keyframes wd-pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.2)}50%{box-shadow:0 0 0 16px rgba(255,255,255,0)}}
.wd-avatar{width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:var(--white);letter-spacing:2px;}
.wd-greeting{font-size:20px;font-weight:400;color:rgba(255,255,255,.7);margin-bottom:4px;animation:wd-fadein .6s ease .1s both;}
.wd-name{font-size:36px;font-weight:900;margin-bottom:4px;letter-spacing:-0.5px;animation:wd-fadein .6s ease .2s both;}
.wd-subtitle{font-size:15px;color:rgba(255,255,255,.6);margin-bottom:32px;animation:wd-fadein .6s ease .3s both;}
@keyframes wd-fadein{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.wd-stats{display:flex;gap:32px;justify-content:center;margin-bottom:36px;}
.wd-stat{text-align:center;animation:wd-fadein .6s ease both;animation-delay:var(--delay,0s);}
.wd-stat-val{font-size:36px;font-weight:900;color:var(--white);line-height:1;}
.wd-stat-label{font-size:12px;color:rgba(255,255,255,.5);margin-top:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;}
.wd-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;animation:wd-fadein .6s ease .7s both;}
.wd-action{display:flex;align-items:center;gap:8px;padding:12px 24px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:12px;color:var(--white);text-decoration:none;font-size:14px;font-weight:700;transition:all .3s ease;}
.wd-action:hover{background:rgba(255,255,255,.2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2);text-decoration:none;color:var(--white);}
.wd-action-icon{font-size:20px;}
@media(max-width:600px){.wd-stats{flex-direction:column;gap:16px;}.wd-name{font-size:28px;}.wd-actions{flex-direction:column;align-items:center;}}

/* ========== LOCKED PAGE ========== */
.locked-page{display:flex;align-items:center;justify-content:center;min-height:350px;padding:40px 20px;}
.locked-page-content{text-align:center;max-width:420px;}
.locked-page-icon{font-size:80px;margin-bottom:20px;filter:drop-shadow(0 4px 16px rgba(26,60,110,.15));animation:lock-bounce 2s ease infinite;}
@keyframes lock-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.locked-page-content h2{font-size:22px;font-weight:900;color:var(--primary);margin-bottom:8px;}
.locked-page-content p{font-size:15px;color:var(--gray-600);line-height:1.6;margin-bottom:0;}
.locked-banner{display:flex;gap:20px;align-items:center;background:linear-gradient(135deg,#eef2ff,#f8fafc);border:2px solid var(--primary-light);border-radius:12px;padding:20px 24px;margin-top:16px;}
.locked-banner-icon{font-size:36px;flex-shrink:0;}
.locked-banner strong{color:var(--primary);display:block;margin-bottom:2px;}
.locked-banner p{font-size:13px;color:var(--gray-500);margin:0;}
.locked-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#eef2ff,#f0fdf4);border:1px solid var(--primary-light);border-radius:8px;font-size:12px;font-weight:600;color:var(--primary);cursor:pointer;}
.locked-badge:hover{background:var(--primary);color:var(--white);}
.ec-anon-lock{text-align:center;padding:12px 16px;}
.expert-card-anon .ec-name{filter:none;font-size:20px;letter-spacing:4px;color:var(--gray-400);}
.expert-card-anon .ec-initials{background:var(--gray-400);}

/* make locked pages relative for overlay positioning */
.page{position:relative;min-height:calc(100vh - 120px);}

/* ========== DARK MODE TOGGLE BUTTON ========== */
.dark-mode-btn{background:none;border:1px solid var(--gray-200);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--gray-600);margin-right:4px;}
.dark-mode-btn:hover{background:var(--gray-100);color:var(--gray-800);}
body.dark-mode .dark-mode-btn{border-color:#30363d;color:#e6edf3;}
body.dark-mode .dark-mode-btn:hover{background:#21262d;}

/* ========== COMPREHENSIVE DARK MODE ========== */
body.dark-mode {
    --white: #161b22;
    --gray-50: #1c2128;
    --gray-100: #21262d;
    --gray-200: #30363d;
    --gray-300: #484f58;
    --gray-400: #6e7681;
    --gray-500: #8b949e;
    --gray-600: #c9d1d9;
    --gray-700: #e6edf3;
    --gray-800: #f0f6fc;
    --gray-900: #ffffff;
    --primary: #58a6ff;
    --primary-light: #79c0ff;
    --primary-dark: #388bfd;
    --accent: #f85149;
    --accent-light: #ff7b72;
    background: #0d1117;
    color: #e6edf3;
}
/* Navbar */
body.dark-mode .navbar { background: #161b22; border-color: #30363d; box-shadow: 0 1px 0 #30363d; }
body.dark-mode .nav-search { background: #0d1117; border-color: #30363d; }
body.dark-mode .nav-search input { color: #e6edf3; }
body.dark-mode .nav-search-results { background: #161b22; border-color: #30363d; }
body.dark-mode .nsr-item:hover { background: #21262d; }
body.dark-mode .nav-sub { background: #161b22; border-color: #30363d; }
body.dark-mode .nav-link { color: #8b949e; }
body.dark-mode .nav-link:hover, body.dark-mode .nav-link.active { color: #f0f6fc; }
body.dark-mode .nav-member-btn { background: #238636; }
body.dark-mode .nav-links.open { background: #161b22; border-color: #30363d; }
/* Cards & surfaces */
body.dark-mode .card { background: #161b22; border-color: #30363d; }
body.dark-mode .form-card { background: #161b22; border-color: #30363d; }
body.dark-mode .theme-card { background: #161b22; border-color: #30363d; }
/* Forms */
body.dark-mode input, body.dark-mode textarea, body.dark-mode select { background: #0d1117; border-color: #30363d; color: #e6edf3; }
body.dark-mode input::placeholder, body.dark-mode textarea::placeholder { color: #484f58; }
/* Hero */
body.dark-mode .hero-slider { background: #0d1117; }
body.dark-mode .slide-bg { filter: brightness(0.4); }
/* Sections */
body.dark-mode .section-title { color: #e6edf3; }
body.dark-mode .section-sub { color: #8b949e; }
/* Buttons */
body.dark-mode .btn-accent { background: #f85149; }
body.dark-mode .btn-primary { background: #388bfd; }
body.dark-mode .btn { border-color: #30363d; }
body.dark-mode .form-submit { background: #f85149; }
/* KPI */
body.dark-mode .kpi-card { background: #161b22; border-color: #30363d; }
body.dark-mode .kpi-val { color: #58a6ff; }
/* Expert cards */
body.dark-mode .expert-card { background: #161b22; border-color: #30363d; }
body.dark-mode .ec-banner { background: linear-gradient(135deg, #161b22, #21262d); }
body.dark-mode .ec-initials { background: #30363d; }
body.dark-mode .ec-name { color: #f0f6fc; }
/* Board */
body.dark-mode .board-card { background: #161b22; border-color: #30363d; }
/* Admin */
body.dark-mode .adm-modal { background: #161b22; border-color: #30363d; }
body.dark-mode .adm-table th { background: #21262d; color: #e6edf3; }
body.dark-mode .adm-table td { border-color: #21262d; }
body.dark-mode .adm-nav-btn { color: #8b949e; border-color: #30363d; }
body.dark-mode .adm-nav-btn.active { background: #388bfd; color: #fff; }
/* Auth */
body.dark-mode .auth-overlay { background: rgba(0,0,0,.75); }
body.dark-mode .auth-card { background: #161b22; }
body.dark-mode .auth-input { background: #0d1117; border-color: #30363d; color: #e6edf3; }
body.dark-mode .auth-divider span { background: #161b22; }
body.dark-mode .auth-close:hover { background: #21262d; }
body.dark-mode .auth-error { background: #3d1416; color: #ff7b72; }
/* Reading progress */
body.dark-mode .tricolor-bar { background: #21262d; }
body.dark-mode .tricolor-bar::after { background: #f85149; }
/* How it works */
body.dark-mode .hw-title { color: #e6edf3; }
body.dark-mode .hw-desc { color: #8b949e; }
body.dark-mode .hw-card { background: #161b22; border-color: #30363d; }
body.dark-mode .hw-stat-val { color: #58a6ff; }
/* Events */
body.dark-mode .evt-card { background: #161b22; border-color: #30363d; }
body.dark-mode .cal-header { background: #21262d; }
body.dark-mode .agenda-calendar { background: #161b22; border-color: #30363d; }
body.dark-mode .cal-day:hover { background: #21262d; }
/* Directory */
body.dark-mode .dir-member-card:hover { background: #21262d; }
body.dark-mode .dir-letter-anchor { border-color: #388bfd; color: #58a6ff; }
body.dark-mode .dir-alpha-bar { background: #0d1117; }
body.dark-mode .dir-mc-tag { background: #30363d; color: #c9d1d9; }
body.dark-mode .dir-tag { background: #30363d; color: #c9d1d9; }
body.dark-mode .dir-modal-header { background: linear-gradient(135deg, #161b22, #21262d); }
/* DataTable */
body.dark-mode .dt-wrapper { border-color: #30363d; background: #161b22; }
body.dark-mode .dt-toolbar, body.dark-mode .dt-header-row, body.dark-mode .dt-footer { background: #21262d; }
body.dark-mode .dt-th { color: #e6edf3; border-color: #30363d; }
body.dark-mode .dt-td { border-color: #21262d; color: #c9d1d9; }
body.dark-mode .dt-search { background: #0d1117; border-color: #30363d; color: #e6edf3; }
body.dark-mode .dt-btn { background: #21262d; border-color: #30363d; color: #c9d1d9; }
/* News carousel */
body.dark-mode .nc-arrow { background: #21262d; border-color: #30363d; color: #c9d1d9; }
body.dark-mode .news-carousel-card { background: #161b22; border-color: #30363d; }
/* Notifications */
body.dark-mode .notif-panel { background: #161b22; border-color: #30363d; }
body.dark-mode .notif-panel-item:hover { background: #21262d; }
body.dark-mode .notif-panel-item.notif-unread { background: rgba(56,139,253,.05); }
/* Org chart */
body.dark-mode .org-tile { background: #161b22; border-color: #30363d; }
body.dark-mode .org-tile-name { color: #f0f6fc; }
body.dark-mode .org-connector { background: #30363d; }
/* Member welcome */
.member-welcome-sub{color:var(--gray-500);font-size:14px;}
body.dark-mode .member-welcome .section-title { color: #f0f6fc; }
body.dark-mode .member-welcome-sub { color: #8b949e; }
/* Partners — keep white background for logos in dark mode */
body.dark-mode .partner-tile { background: #fff; border-radius: 8px; padding: 10px; }
body.dark-mode .partner-tile-text { color: #1a3c6e; }
body.dark-mode .pu-card { background: #161b22; border-color: #30363d; }
body.dark-mode .pu-logo { background: #fff; border-radius: 6px; padding: 4px; }
body.dark-mode .pu-card .pu-name { color: #f0f6fc; }
body.dark-mode .pu-card .pu-desc { color: #8b949e; }
/* Polls */
body.dark-mode .poll-card { background: #161b22; border-color: #30363d; }
body.dark-mode .poll-popup-option { background: #1c2128; border-color: #30363d; }
body.dark-mode .poll-popup-option:hover { background: #21262d; border-color: #58a6ff; }
/* Challenge timeline */
body.dark-mode .challenge-timeline::before { background: #30363d; }
body.dark-mode .ct-content { background: #161b22; border-color: #30363d; }
/* Member tabs */
body.dark-mode .mtab-u { color: #8b949e; }
body.dark-mode .mtab-u.active { color: #58a6ff; border-bottom-color: #58a6ff; }
/* Language switcher */
body.dark-mode .lang-current{background:#21262d;border-color:#30363d;color:#58a6ff;}
body.dark-mode .lang-dropdown{background:#161b22;border-color:#30363d;}
body.dark-mode .lang-opt{color:#c9d1d9;}
body.dark-mode .lang-opt:hover{background:#21262d;}
/* Footer */
body.dark-mode .footer { background: #010409; }
/* Stat bars */
body.dark-mode .stat-bar { background: #21262d; }
/* Cookie banner */
body.dark-mode .cookie-banner { background: #0d1117; }
/* Sector chips */
body.dark-mode .sector-chip { border-color: #30363d; color: #8b949e; }
body.dark-mode .sector-chip:hover { border-color: #58a6ff; color: #58a6ff; }
/* Timeline */
body.dark-mode .timeline::before { background: #30363d; }
body.dark-mode .timeline-dot { border-color: #161b22; }
/* Dark mode contrast improvements */
body.dark-mode .card-text{color:#8b949e;}
body.dark-mode .card-title{color:#e6edf3;}
body.dark-mode .card-date{background:var(--accent);}
body.dark-mode .card-tag{background:#30363d;color:#c9d1d9;}
body.dark-mode .form-group label{color:#c9d1d9;}
body.dark-mode .evt-title{color:#e6edf3;}
body.dark-mode .evt-desc{color:#8b949e;}
body.dark-mode .evt-meta{color:#6e7681;}
body.dark-mode .hw-card-text{color:#c9d1d9;}
body.dark-mode .dir-mc-name{color:#e6edf3;}
body.dark-mode .dir-mc-company{color:#6e7681;}
body.dark-mode .ncc-title{color:#e6edf3;}
body.dark-mode .ncc-excerpt{color:#8b949e;}
body.dark-mode .ncc-body{background:#161b22;}
body.dark-mode .course-filter{background:#21262d;border-color:#30363d;color:#8b949e;}
body.dark-mode .course-filter.active{background:#388bfd;color:#fff;}
body.dark-mode .adh-choice{border-color:#30363d;}
body.dark-mode .adh-choice-selected{border-color:#388bfd;background:rgba(56,139,253,.1);}
body.dark-mode .adh-pay-choice{border-color:#30363d;}
body.dark-mode .adh-pay-selected{border-color:#388bfd;}

/* ========== SHARE BUTTONS ========== */
.share-bar{display:flex;align-items:center;gap:6px;padding:8px 0;}
.share-label{font-size:12px;color:var(--gray-400);font-weight:600;}
.share-btn{width:28px;height:28px;border-radius:50%;border:none;cursor:pointer;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--white);}
.share-btn:hover{transform:scale(1.15);}
.share-li{background:#0077b5;}
.share-tw{background:#1da1f2;}
.share-em{background:var(--gray-500);}
.share-cp{background:var(--teal);}

/* ========== POLLS / SONDAGES ========== */
.poll-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow);}
.poll-title{font-size:17px;font-weight:800;color:var(--primary);margin-bottom:4px;}
.poll-desc{font-size:13px;color:var(--gray-500);margin-bottom:4px;}
.poll-meta{font-size:12px;color:var(--gray-400);}
.poll-options{margin-top:12px;display:flex;flex-direction:column;gap:6px;}
.poll-option{position:relative;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;padding:10px 14px;cursor:pointer;overflow:hidden;transition:all .2s;display:flex;justify-content:space-between;align-items:center;}
.poll-option:hover{border-color:var(--primary-light);}
.poll-voted{border-color:var(--primary);background:rgba(45,90,158,.05);}
.poll-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(45,90,158,.1);transition:width .5s ease;border-radius:8px;}
.poll-opt-label{position:relative;z-index:1;font-size:14px;font-weight:600;color:var(--gray-800);}
.poll-opt-pct{position:relative;z-index:1;font-size:14px;font-weight:800;color:var(--primary);}

/* ========== VERIFIED BADGE ========== */
.verified-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--primary);color:var(--white);font-size:11px;font-weight:900;margin-left:4px;vertical-align:middle;}

/* ========== ENDORSEMENTS ========== */
.endorse-skills{display:flex;flex-wrap:wrap;gap:6px;}
.endorse-skill-opt{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--gray-200);border-radius:20px;font-size:13px;cursor:pointer;transition:all .2s;}
.endorse-skill-opt:has(input:checked){background:var(--primary);color:var(--white);border-color:var(--primary);}
.endorse-skill-opt input{display:none;}
.poll-opt-input{width:100%;padding:8px 12px;border:1px solid var(--gray-200);border-radius:6px;font-family:inherit;margin-bottom:4px;}

/* ========== STATS BARS ========== */
.stat-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.stat-bar-label{font-size:12px;color:var(--gray-600);width:140px;flex-shrink:0;text-align:right;}
.stat-bar{flex:1;height:20px;background:var(--gray-100);border-radius:10px;overflow:hidden;}
.stat-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:10px;transition:width .5s ease;}
.stat-bar-val{font-size:13px;font-weight:700;color:var(--primary);width:30px;}
.chart-months{display:flex;align-items:flex-end;gap:8px;height:160px;padding-top:20px;}
.chart-col{display:flex;flex-direction:column;align-items:center;flex:1;}
.chart-bar{width:100%;background:linear-gradient(180deg,var(--primary),var(--primary-light));border-radius:6px 6px 0 0;transition:height .5s ease;min-width:24px;}
.chart-label{font-size:10px;color:var(--gray-400);margin-top:4px;}
.chart-val{font-size:11px;font-weight:700;color:var(--primary);}

/* ========== AGENDA LAYOUT ========== */
.agenda-layout{display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:start;}
@media(max-width:1024px){.agenda-layout{grid-template-columns:1fr;}}
.agenda-calendar{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;position:sticky;top:72px;}
.cal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--primary);color:var(--white);transition:border-radius .3s;}
.cal-header h3{font-size:16px;font-weight:800;margin:0;display:flex;align-items:center;gap:8px;}
.cal-toggle-icon{font-size:10px;opacity:.6;transition:transform .3s;}
.cal-body{overflow:hidden;max-height:400px;transition:max-height .35s ease, opacity .25s ease;opacity:1;}
.cal-collapsed .cal-body{max-height:0;opacity:0;}
.cal-collapsed .cal-header{border-radius:12px;}
.cal-collapsed .cal-toggle-icon{transform:rotate(0deg);}
.cal-nav{background:none;border:none;color:var(--white);font-size:20px;cursor:pointer;padding:4px 10px;border-radius:6px;transition:background .15s;}
.cal-nav:hover{background:rgba(255,255,255,.15);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;padding:8px;}
.cal-dow{font-size:11px;font-weight:700;color:var(--gray-400);padding:8px 0;text-transform:uppercase;}
.cal-day{padding:8px 4px;font-size:13px;border-radius:8px;cursor:pointer;transition:all .15s;position:relative;}
.cal-day:hover{background:var(--gray-100);}
.cal-day.cal-today{font-weight:900;color:var(--accent);background:rgba(200,16,46,.08);}
.cal-day.cal-has-event::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent);}
.cal-day.cal-other{color:var(--gray-300);}
.cal-day.cal-selected{background:var(--primary);color:var(--white);}
.cal-day.cal-selected::after{background:var(--white);}
.agenda-events{display:flex;flex-direction:column;gap:20px;}

/* Event cards — modern timeline style */
.evt-card{display:flex;gap:20px;background:var(--white);border:1px solid var(--gray-200);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;transition:all var(--transition);}
.evt-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.evt-date-col{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:80px;padding:20px 16px;background:var(--primary);color:var(--white);text-align:center;}
.evt-date-day{font-size:32px;font-weight:900;line-height:1;}
.evt-date-month{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:2px;}
.evt-date-year{font-size:11px;opacity:.7;}
.evt-body{flex:1;padding:20px;display:flex;flex-direction:column;gap:8px;}
.evt-tags{display:flex;gap:6px;flex-wrap:wrap;}
.evt-title{font-size:18px;font-weight:800;color:var(--gray-900);line-height:1.3;}
.evt-desc{font-size:14px;color:var(--gray-600);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.evt-meta{display:flex;gap:16px;font-size:13px;color:var(--gray-500);flex-wrap:wrap;align-items:center;}
.evt-actions{display:flex;gap:8px;margin-top:auto;padding-top:8px;flex-wrap:wrap;align-items:center;}
.evt-reg-btn{padding:8px 18px;border:2px solid var(--accent);background:var(--accent);color:#fff;border-radius:6px;font-size:13px;font-weight:800;cursor:pointer;font-family:inherit;transition:all .15s;text-transform:uppercase;letter-spacing:.5px;}
.evt-reg-btn:hover{background:var(--accent-light);transform:translateY(-1px);box-shadow:0 3px 8px rgba(200,16,46,.2);}
.evt-reg-done{background:var(--green);border-color:var(--green);}
.evt-reg-done:hover{background:#236b43;}
.evt-gauge{position:relative;height:6px;background:var(--gray-200);border-radius:3px;margin:6px 0;overflow:hidden;}
.evt-gauge-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--teal));border-radius:3px;transition:width .4s ease;}
.evt-gauge-text{position:absolute;right:0;top:-16px;font-size:11px;font-weight:700;color:var(--gray-500);}
@media(max-width:600px){.evt-card{flex-direction:column;}.evt-date-col{flex-direction:row;gap:8px;min-width:auto;padding:12px 16px;}}
/* dark-mode evt rules moved to comprehensive block */

/* ========== AUTH OVERLAY (LinkedIn-style) ========== */
.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:authFadeIn .2s ease;}
@keyframes authFadeIn{from{opacity:0}to{opacity:1}}
.auth-card{background:var(--white);border-radius:16px;width:100%;max-width:420px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:authSlideUp .3s ease;}
@keyframes authSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.auth-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;color:var(--gray-400);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .15s;z-index:1;}
.auth-close:hover{background:var(--gray-100);color:var(--gray-700);}
.auth-header{text-align:center;padding:32px 32px 0;}
.auth-logo{height:36px;margin-bottom:16px;}
.auth-title{font-size:24px;font-weight:900;color:var(--primary);margin:0 0 6px;}
.auth-subtitle{color:var(--gray-500);font-size:14px;margin:0;line-height:1.5;}
.auth-form{padding:24px 32px 0;}
.auth-field{margin-bottom:16px;}
.auth-label{display:block;font-size:13px;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.auth-input{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:8px;font-family:inherit;font-size:15px;transition:border-color .15s;outline:none;box-sizing:border-box;}
.auth-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px rgba(45,90,158,.1);}
.auth-input-code{text-align:center;font-size:28px;font-weight:900;letter-spacing:12px;padding:16px;}
.auth-password-wrap{position:relative;}
.auth-password-wrap .auth-input{padding-right:80px;}
.auth-toggle-pw{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--primary-light);font-size:13px;font-weight:700;cursor:pointer;padding:8px 12px;font-family:inherit;}
.auth-toggle-pw:hover{color:var(--accent);}
.auth-error{padding:10px 14px;background:#fef2f2;color:#b91c1c;border-radius:8px;font-size:13px;font-weight:600;text-align:center;margin-bottom:12px;}
.auth-submit{width:100%;padding:14px;background:var(--accent);color:var(--white);border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;}
.auth-submit:hover{background:var(--accent-light);transform:translateY(-1px);box-shadow:0 4px 12px rgba(200,16,46,.25);}
.auth-submit:disabled{opacity:.6;cursor:default;transform:none;box-shadow:none;}
.auth-divider{text-align:center;padding:20px 32px 0;position:relative;}
.auth-divider::before{content:'';position:absolute;left:32px;right:32px;top:50%;height:1px;background:var(--gray-200);}
.auth-divider span{background:var(--white);padding:0 16px;font-size:13px;color:var(--gray-400);position:relative;}
.auth-footer-links{text-align:center;padding:16px 32px 0;font-size:14px;}
.auth-footer-links a{color:var(--primary-light);font-weight:600;text-decoration:none;}
.auth-footer-links a:hover{color:var(--accent);text-decoration:underline;}
.auth-signup{text-align:center;padding:20px 32px 28px;font-size:14px;color:var(--gray-500);border-top:1px solid var(--gray-100);margin-top:20px;}
.auth-signup a{color:var(--accent);font-weight:700;text-decoration:none;}
.auth-signup a:hover{text-decoration:underline;}
.auth-success-icon{width:60px;height:60px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px;}
/* dark-mode auth rules moved to comprehensive block */

/* ========== READING PROGRESS BAR ========== */
.reading-progress{display:none;}

/* ========== LARGE FONT MODE ========== */
body.large-font{font-size:19px;}
body.large-font .card-title{font-size:24px;}
body.large-font .section-title{font-size:40px;}
body.large-font .evt-title{font-size:22px;}
body.large-font .nav-link-text{font-size:13px;}

/* ========== PAST EVENTS ========== */
.evt-card-past{opacity:.7;filter:grayscale(.3);}
.evt-card-past:hover{opacity:1;filter:none;}
.evt-past{opacity:.55;transition:opacity .3s;}
.evt-past:hover{opacity:.85;}
.evt-past .card-title,.evt-past .evt-title{color:#8a9bb5 !important;}
.evt-past .card-img-placeholder{background:linear-gradient(135deg,#b0bec5,#cfd8dc) !important;opacity:.7;}
.evt-past .card-tag-primary{background:#b0bec5 !important;}
.card.evt-past{border-left:4px solid #b0bec5;}
.evt-past-badge{display:inline-block;background:#b0bec5;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle;margin-right:6px;}

/* ========== EVENT GALLERY (in detail & publications) ========== */
.evt-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin:20px 0;}
.evt-gallery img{width:100%;height:auto;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:transform .2s;cursor:pointer;}
.evt-gallery img:hover{transform:scale(1.03);}
.edm-description img{max-width:100%;height:auto;border-radius:8px;margin:8px 0;box-shadow:0 2px 6px rgba(0,0,0,.08);}
.edm-description p{margin:0 0 12px;line-height:1.7;}
.edm-description a{color:var(--secondary);text-decoration:underline;}

/* ========== DIRECTORY (LinkedIn-style) ========== */
.dir-alpha-bar{display:flex;gap:4px;justify-content:center;flex-wrap:wrap;margin-bottom:16px;position:sticky;top:56px;z-index:3;background:var(--white);padding:8px 0;border-bottom:1px solid var(--gray-100);}
.dir-alpha-link{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:12px;font-weight:800;color:var(--primary);text-decoration:none;transition:all .1s;}
.dir-alpha-link:hover{background:var(--primary);color:#fff;text-decoration:none;}
.dir-results-count{font-size:13px;color:var(--gray-500);margin-bottom:12px;font-weight:600;}
.dir-letter-anchor{font-size:13px;font-weight:900;color:var(--primary);padding:12px 0 4px;border-bottom:2px solid var(--primary);margin-bottom:4px;scroll-margin-top:100px;}
.dir-member-card{display:flex;align-items:center;gap:14px;padding:12px;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background .1s;border-radius:8px;margin-bottom:2px;}
.dir-member-card:hover{background:var(--gray-50);}
.dir-mc-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0;overflow:hidden;position:relative;}
.dir-mc-avatar img{width:100%;height:100%;object-fit:cover;}
.dir-mc-avail-dot{position:absolute;bottom:1px;right:1px;width:12px;height:12px;border-radius:50%;border:2px solid var(--white);}
.dir-mc-info{flex:1;min-width:0;}
.dir-mc-name{font-size:15px;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dir-mc-title{font-size:13px;color:var(--primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dir-mc-company{font-size:12px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dir-mc-tags{display:flex;gap:4px;flex-shrink:0;}
.dir-mc-tag{font-size:11px;padding:2px 8px;background:var(--gray-100);color:var(--gray-600);border-radius:3px;white-space:nowrap;}
.dir-mc-actions{flex-shrink:0;}
.dir-mc-li{width:30px;height:30px;border-radius:50%;background:#0077b5;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;text-decoration:none;}
.dir-mc-li:hover{opacity:.85;color:#fff;text-decoration:none;}
.dir-badge{display:inline-block;font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;vertical-align:middle;margin-left:4px;}
.dir-badge-board{background:var(--primary);color:#fff;}
.dir-badge-mentor{background:var(--teal);color:#fff;}
.dir-tag{font-size:11px;padding:2px 8px;background:var(--gray-100);color:var(--gray-600);border-radius:3px;white-space:nowrap;}
/* Modal */
.dir-modal-header{background:linear-gradient(135deg,var(--primary),var(--primary-light));padding:24px;display:flex;gap:16px;align-items:center;position:relative;}
.dir-modal-avatar{width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;flex-shrink:0;overflow:hidden;border:3px solid rgba(255,255,255,.3);}
.dir-modal-avatar img{width:100%;height:100%;object-fit:cover;}
.dir-modal-info{color:#fff;min-width:0;}
.dir-modal-name{font-size:22px;font-weight:900;margin:0;color:#fff;}
.dir-modal-job{font-size:14px;margin:2px 0 0;opacity:.85;color:#fff;}
.dir-modal-company{font-size:13px;margin:0;opacity:.7;color:#fff;}
.dir-modal-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;}
.dir-modal-section{margin-bottom:14px;}
.dir-modal-section h4{font-size:11px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:1px;margin:0 0 4px;}
.dir-modal-section p{font-size:14px;color:var(--gray-600);margin:0;line-height:1.6;}
.dir-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:13px;}
.dir-modal-grid div{display:flex;flex-direction:column;gap:1px;}
.dir-modal-label{font-size:11px;color:var(--gray-400);font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.dir-modal-grid span:last-child{color:var(--gray-700);}
@media(max-width:768px){.dir-mc-tags{display:none;}.dir-modal-grid{grid-template-columns:1fr;}}
/* dark-mode dir rules moved to comprehensive block */

/* ========== SCROLL ANIMATIONS ========== */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease, transform .6s ease;}
.fade-in-visible{opacity:1;transform:translateY(0);}

/* ========== ACCESSIBILITY ========== */
.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:1000;font-weight:700;text-decoration:none;transition:top .2s;}
.skip-link:focus{top:0;}
:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px;}

/* ========== SMOOTH SCROLLBAR ========== */
html{scroll-behavior:smooth;}
::selection{background:var(--primary);color:var(--white);}

/* ========== MEMBER CARD TAGS ========== */
.member-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px;}
.card-tag-specialty{background:var(--teal);color:var(--white);}
.card-tag-mentor{background:var(--green);color:var(--white);}
.mentor-badge{position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:12px;border:2px solid var(--white);}
.member-avatar{position:relative;}

/* ========== REPLAYS / MEDIATHEQUE ========== */
.replays-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;}
.replay-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition);}
.replay-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.replay-thumb{position:relative;cursor:pointer;aspect-ratio:16/9;overflow:hidden;background:var(--gray-100);}
.replay-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.replay-card:hover .replay-thumb img{transform:scale(1.05);}
.replay-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);color:var(--white);font-size:48px;opacity:0;transition:opacity .3s;}
.replay-card:hover .replay-play{opacity:1;}
.replay-duration{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.75);color:var(--white);padding:2px 8px;border-radius:4px;font-size:12px;font-weight:700;}
.replay-body{padding:16px;}
.replay-title{font-size:16px;font-weight:800;color:var(--gray-900);margin:8px 0 6px;line-height:1.3;}
.replay-desc{font-size:13px;color:var(--gray-600);line-height:1.6;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.replay-speaker{font-size:13px;color:var(--primary);font-weight:600;}
.replay-filter{padding:8px 20px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:20px;font-family:inherit;font-size:13px;font-weight:600;color:var(--gray-600);cursor:pointer;transition:all var(--transition);}
.replay-filter:hover{background:var(--gray-200);}
.replay-filter.active{background:var(--primary);color:var(--white);border-color:var(--primary);}
.replay-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:1000;align-items:center;justify-content:center;padding:20px;}
.replay-modal-content{position:relative;width:100%;max-width:900px;aspect-ratio:16/9;background:#000;border-radius:8px;overflow:hidden;}
.replay-modal-content iframe{width:100%;height:100%;border:none;}
.replay-modal-close{position:absolute;top:-40px;right:0;background:none;border:none;color:var(--white);font-size:36px;cursor:pointer;z-index:10;}

/* ========== QUIZZ DU RAIL ========== */
.quizz-intro{text-align:center;padding:48px 24px;background:var(--white);border:2px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow);}
.quizz-intro h3{font-size:24px;font-weight:900;color:var(--primary);margin-bottom:8px;}
.quizz-intro p{color:var(--gray-600);font-size:16px;}
.quizz-progress{height:6px;background:var(--gray-200);border-radius:3px;margin-bottom:24px;overflow:hidden;}
.quizz-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:3px;transition:width .4s ease;}
.quizz-header{font-size:14px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}
.quizz-question{font-size:20px;font-weight:800;color:var(--gray-900);line-height:1.4;margin-bottom:24px;}
.quizz-choices{display:flex;flex-direction:column;gap:10px;}
.quizz-choice{display:block;width:100%;padding:16px 20px;background:var(--white);border:2px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:15px;font-weight:600;color:var(--gray-700);cursor:pointer;text-align:left;transition:all var(--transition);}
.quizz-choice:hover:not(:disabled){border-color:var(--primary);background:var(--gray-50);color:var(--primary);}
.quizz-choice:disabled{cursor:default;opacity:.7;}
.quizz-correct{border-color:var(--green)!important;background:#ecfdf5!important;color:var(--green)!important;opacity:1!important;}
.quizz-wrong{border-color:var(--accent)!important;background:#fef2f2!important;color:var(--accent)!important;opacity:1!important;}
.quizz-feedback-correct,.quizz-feedback-wrong{margin-top:20px;padding:16px 20px;border-radius:var(--radius);font-size:14px;line-height:1.6;}
.quizz-feedback-correct{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;}
.quizz-feedback-wrong{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;}
.quizz-result{text-align:center;padding:36px 24px;background:var(--white);border:2px solid var(--gray-200);border-radius:var(--radius);margin-bottom:24px;box-shadow:var(--shadow);}
.quizz-result h3{font-size:24px;font-weight:900;color:var(--primary);margin:12px 0 8px;}
.quizz-result p{color:var(--gray-600);font-size:16px;}
.quizz-leaderboard{background:var(--white);border:2px solid var(--gray-200);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);}
.quizz-leaderboard h3{font-size:18px;font-weight:800;color:var(--primary);margin-bottom:16px;}
.leaderboard-list{display:flex;flex-direction:column;gap:6px;}
.leaderboard-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--radius);background:var(--gray-50);transition:background .2s;}
.leaderboard-row:hover{background:var(--gray-100);}
.leaderboard-top{background:linear-gradient(90deg,rgba(212,168,67,.1),rgba(212,168,67,.05));border:1px solid rgba(212,168,67,.3);}
.leaderboard-rank{width:28px;height:28px;border-radius:50%;background:var(--gray-200);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--gray-600);flex-shrink:0;}
.leaderboard-top .leaderboard-rank{background:var(--gold);color:var(--white);}
.leaderboard-name{flex:1;font-weight:600;font-size:14px;color:var(--gray-800);}
.leaderboard-score{font-weight:800;font-size:14px;color:var(--primary);}

/* ========== QUIZZ CATALOG ========== */
.quizz-catalog-card{background:var(--white);border:2px solid var(--gray-200);border-radius:8px;padding:20px;cursor:pointer;transition:all var(--transition);text-align:center;}
.quizz-catalog-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-3px);}
.qcc-icon{font-size:40px;margin-bottom:8px;}
.qcc-title{font-size:15px;font-weight:800;color:var(--gray-900);margin-bottom:6px;line-height:1.3;}
.qcc-desc{font-size:12px;color:var(--gray-500);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.qcc-meta{font-size:11px;color:var(--gray-400);font-weight:600;text-transform:uppercase;letter-spacing:.5px;}

/* ========== ECOLES ========== */
.ecoles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;}
.ecole-card{background:var(--white);border:1px solid var(--gray-200);border-radius:8px;padding:20px;box-shadow:var(--shadow);transition:all var(--transition);}
.ecole-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.ecole-partenaire{border-left:4px solid var(--green);}
.ecole-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:12px;}
.ecole-icon{font-size:32px;flex-shrink:0;margin-top:2px;}
.ecole-name{font-size:16px;font-weight:800;color:var(--gray-900);line-height:1.3;}
.ecole-city{font-size:13px;color:var(--gray-500);margin-top:2px;}
.ecole-desc{font-size:13px;color:var(--gray-600);line-height:1.7;margin-bottom:12px;}
.ecole-specs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px;}
.ecole-link{font-size:13px;font-weight:600;color:var(--primary-light);text-decoration:none;display:inline-block;}
.ecole-link:hover{color:var(--accent);text-decoration:underline;}

/* ========== PARTENAIRES UNIFIED ========== */
.partenaires-unified-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.pu-card{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--gray-200);border-radius:8px;padding:18px;box-shadow:var(--shadow);transition:all var(--transition);text-decoration:none;color:inherit;cursor:pointer;}
.pu-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-light);text-decoration:none;}
.pu-logo{width:72px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.pu-logo img{max-width:100%;max-height:100%;object-fit:contain;}
.pu-body{flex:1;min-width:0;}
.pu-name{font-size:14px;font-weight:800;color:var(--primary);line-height:1.3;margin-bottom:2px;}
.pu-sector{font-size:11px;color:var(--gray-400);font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;}
.pu-desc{font-size:12px;color:var(--gray-600);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px;}
.pu-loc{font-size:11px;color:var(--gray-500);}
.pu-card-simple{cursor:default;}

/* ========== DATATABLE (Excel-like) ========== */
.dt-wrapper{border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;background:var(--white);}
.dt-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--gray-200);gap:12px;flex-wrap:wrap;background:var(--gray-50);}
.dt-toolbar-left{display:flex;align-items:center;gap:12px;}
.dt-toolbar-right{display:flex;align-items:center;gap:8px;}
.dt-search{display:flex;align-items:center;background:var(--white);border:1px solid var(--gray-200);border-radius:6px;padding:0 10px;height:34px;}
.dt-search-icon{font-size:14px;color:var(--gray-400);margin-right:6px;}
.dt-search-input{border:none;background:transparent;font-size:13px;font-family:inherit;outline:none;width:200px;color:var(--gray-800);}
.dt-count{font-size:12px;color:var(--gray-500);white-space:nowrap;}
.dt-page-size{padding:6px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:12px;font-family:inherit;background:var(--white);cursor:pointer;}
.dt-btn{padding:6px 12px;border:1px solid var(--gray-200);border-radius:6px;font-size:12px;font-family:inherit;background:var(--white);cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;}
.dt-btn:hover:not(:disabled){background:var(--gray-100);border-color:var(--gray-300);}
.dt-btn:disabled{opacity:.4;cursor:default;}
.dt-btn-active{background:var(--primary)!important;color:var(--white)!important;border-color:var(--primary)!important;}
.dt-btn-export{color:var(--green);}
.dt-btn-export-xl{color:var(--primary);}
.dt-table-wrap{overflow-x:auto;max-height:70vh;overflow-y:auto;}
.dt-table{width:100%;border-collapse:collapse;font-size:13px;}
.dt-table thead{position:sticky;top:0;z-index:2;}
.dt-header-row{background:var(--gray-50);}
.dt-th{padding:10px 12px;text-align:left;font-weight:700;color:var(--gray-700);border-bottom:2px solid var(--gray-200);white-space:nowrap;user-select:none;}
.dt-th-check{width:40px;text-align:center;}
.dt-th-actions{width:auto;text-align:right;}
.dt-sortable{cursor:pointer;transition:background .15s;}
.dt-sortable:hover{background:var(--gray-200);}
.dt-th-inner{display:flex;align-items:center;gap:6px;}
.dt-sort-icon{font-size:10px;color:var(--gray-400);}
.dt-row{transition:background .1s;}
.dt-row:hover{background:rgba(45,90,158,.04);}
.dt-row-selected{background:rgba(45,90,158,.08)!important;}
.dt-td{padding:8px 12px;border-bottom:1px solid var(--gray-100);color:var(--gray-700);vertical-align:middle;}
.dt-td-check{text-align:center;width:40px;}
.dt-td-actions{text-align:right;white-space:nowrap;}
.dt-empty{text-align:center;padding:40px;color:var(--gray-400);font-style:italic;}
.dt-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--gray-200);background:var(--gray-50);flex-wrap:wrap;gap:8px;}
.dt-footer-info{font-size:12px;color:var(--gray-500);display:flex;gap:12px;align-items:center;}
.dt-selected-count{background:var(--primary);color:var(--white);padding:2px 8px;border-radius:10px;font-weight:700;}
.dt-pagination{display:flex;gap:4px;}
/* dark-mode dt rules moved to comprehensive block */

/* ========== MEMBER TABS (flat) ========== */
.member-tabs-unified{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:20px;flex-wrap:wrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.member-tabs-unified::-webkit-scrollbar{display:none;}
.mtab-u{padding:10px 16px;font-size:13px;font-weight:700;color:var(--gray-500);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap;margin-bottom:-2px;display:inline-flex;align-items:center;gap:6px;}
.mtab-u svg{stroke:var(--gray-500);flex-shrink:0;}
.mtab-u.active svg{stroke:var(--primary);}
.mtab-u:hover{color:var(--gray-800);background:var(--gray-50);}
.mtab-u.active{color:var(--primary);border-bottom-color:var(--primary);}
/* dark-mode mtab rules moved to comprehensive block */

/* Sector chips */
.sector-chip{display:inline-block;padding:4px 12px;border:1px solid var(--gray-300);border-radius:20px;font-size:12px;cursor:pointer;transition:all .15s;color:var(--gray-600);user-select:none;}
.sector-chip:hover{border-color:var(--primary-light);color:var(--primary);}
.sector-chip-active{background:var(--primary);color:#fff;border-color:var(--primary);}

/* Directory modal button (kept for LinkedIn link in modal) */
.dir-card-btn{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:all .15s;}
.dir-card-btn:hover{opacity:.9;transform:translateY(-1px);text-decoration:none;color:#fff;}
/* Profile section improvements */
.prof-section-title{font-size:16px;font-weight:800;color:var(--primary);margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.prof-label{font-size:13px;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
#mtab-profile .form-group label{font-size:13px;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
#mtab-profile .form-group input,#mtab-profile .form-group select,#mtab-profile .form-group textarea{padding:10px 14px;}
/* Challenge Innovation Timeline */
.challenge-timeline{max-width:700px;margin:0 auto;position:relative;}
.challenge-timeline::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:3px;background:var(--gray-200);}
.ct-phase{display:flex;gap:20px;padding:20px 0;position:relative;}
.ct-phase-active .ct-number{background:var(--accent);color:#fff;}
.ct-number{width:48px;height:48px;border-radius:50%;background:var(--gray-200);color:var(--gray-600);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;flex-shrink:0;z-index:1;transition:all .2s;}
.ct-phase:hover .ct-number{background:var(--primary);color:#fff;transform:scale(1.1);}
.ct-content{flex:1;background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px;transition:all .2s;}
.ct-phase:hover .ct-content{box-shadow:var(--shadow-md);border-color:var(--primary-light);}
.ct-title{font-size:18px;font-weight:800;color:var(--gray-900);margin:0 0 6px;}
.ct-desc{font-size:14px;color:var(--gray-600);margin:0 0 10px;line-height:1.6;}
.ct-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.ct-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--primary);color:#fff;}
.ct-badge-entreprise{background:var(--primary);}
.ct-badge-etudiant{background:var(--teal);}
.ct-badge-expert{background:var(--accent);}
.ct-date{font-size:12px;color:var(--gray-400);font-weight:600;}
.ct-details{margin-top:12px;font-size:13px;color:var(--gray-600);line-height:1.7;}
.ct-details ul{margin:0;padding-left:20px;}
.ct-details li{margin-bottom:4px;}
/* dark-mode rules moved to comprehensive block */

/* I18N Language Switcher */
.lang-switcher{position:relative;cursor:pointer;margin-right:8px;}
.lang-current{display:flex;align-items:center;justify-content:center;padding:4px 10px;font-size:12px;font-weight:800;color:var(--primary);border:1px solid var(--gray-200);border-radius:6px;background:var(--white);min-height:32px;}
.lang-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:4px;background:var(--white);border:1px solid var(--gray-200);border-radius:8px;box-shadow:var(--shadow-lg);overflow:hidden;z-index:200;min-width:140px;}
.lang-opt{display:block;width:100%;padding:8px 14px;background:none;border:none;font-size:13px;font-weight:600;text-align:left;cursor:pointer;font-family:inherit;color:var(--gray-700);transition:background .1s;}
.lang-opt:hover{background:var(--gray-50);}

/* Bureau Kanban */
/* CR file cards */
.cr-batch-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;margin-bottom:12px;flex-wrap:wrap;}
.cr-batch-sel{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;cursor:pointer;}
#cr-sel-count{font-size:12px;color:var(--gray-500);flex:1;}
.cr-batch-btn{font-size:12px;padding:6px 14px;border:none;border-radius:6px;cursor:pointer;font-weight:700;font-family:inherit;}
.cr-batch-archive{background:var(--teal);color:#fff;}
.cr-batch-delete{background:var(--accent);color:#fff;}
.cr-file-grid{display:flex;flex-direction:column;gap:4px;}
.cr-file{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--gray-200);border-radius:8px;background:var(--white);transition:all .15s;}
.cr-file:hover{background:var(--gray-50);border-color:var(--primary-light);}
.cr-file-check{flex-shrink:0;}
.cr-file-check input{width:16px;height:16px;cursor:pointer;}
.cr-file-icon{font-size:20px;flex-shrink:0;width:28px;text-align:center;}
.cr-file-info{flex:1;min-width:0;cursor:pointer;}
.cr-file-title{font-size:14px;font-weight:700;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cr-file-meta{font-size:11px;color:var(--gray-500);}
.cr-file-status{font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;white-space:nowrap;flex-shrink:0;}
.cr-st-ok{background:var(--green);color:#fff;}
.cr-st-done{background:var(--teal);color:#fff;}
.cr-st-todo{background:var(--gray-200);color:var(--gray-600);}
.cr-file-actions{display:flex;gap:4px;flex-shrink:0;}
.cr-act-btn{width:28px;height:28px;border:1px solid var(--gray-200);border-radius:6px;background:var(--white);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.cr-act-btn:hover{background:var(--gray-50);border-color:var(--primary);}
.cr-act-approve{background:var(--green);color:#fff;border-color:var(--green);}
.cr-act-approve:hover{opacity:.85;}

/* ========== CHALLENGE PLATFORM ========== */
.ch-header{margin-bottom:20px;}
.ch-header h3{color:var(--primary);font-weight:900;margin:0 0 4px;}
.ch-phase-label{font-size:13px;color:var(--gray-500);}
.ch-phase-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:4px;background:var(--teal);color:#fff;margin-right:4px;}

/* Timeline */
.ch-timeline{display:flex;align-items:flex-start;gap:0;margin-bottom:24px;overflow-x:auto;padding:8px 0;}
.ch-tl-step{display:flex;flex-direction:column;align-items:center;min-width:80px;flex:1;position:relative;}
.ch-tl-dot{width:32px;height:32px;border-radius:50%;background:var(--gray-200);color:var(--gray-500);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;z-index:1;transition:all .3s;}
.ch-tl-done .ch-tl-dot{background:var(--green);color:#fff;}
.ch-tl-active .ch-tl-dot{background:var(--primary);color:#fff;box-shadow:0 0 0 4px rgba(26,60,110,.2);}
.ch-tl-label{font-size:11px;font-weight:700;margin-top:6px;text-align:center;color:var(--gray-600);}
.ch-tl-dates{font-size:9px;color:var(--gray-400);text-align:center;}
.ch-tl-line{flex:1;height:3px;background:var(--gray-200);margin-top:15px;min-width:20px;}
.ch-tl-done + .ch-tl-line{background:var(--green);}

/* Tabs */
.ch-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:2px solid var(--gray-100);padding-bottom:0;}
.ch-tab{padding:8px 16px;font-size:13px;font-weight:700;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--gray-500);font-family:inherit;transition:all .15s;}
.ch-tab.active{color:var(--primary);border-bottom-color:var(--primary);}
.ch-tab:hover{color:var(--primary);}

/* Team cards grid */
.ch-team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;}
.ch-team-card{border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .2s;background:var(--white);}
.ch-team-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.ch-tc-top{padding:12px 16px;border-bottom:1px solid var(--gray-100);}
.ch-tc-phase{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--gray-400);letter-spacing:1px;}
.ch-tc-name{font-size:16px;font-weight:800;color:var(--gray-900);}
.ch-tc-school{font-size:12px;color:var(--gray-500);}
.ch-tc-body{padding:10px 16px;}
.ch-tc-subject{font-size:13px;font-weight:600;color:var(--primary);}
.ch-tc-company{font-size:12px;color:var(--gray-500);}
.ch-tc-meta{display:flex;gap:12px;font-size:11px;margin-top:8px;color:var(--gray-400);}

/* Dashboard */
.ch-back-btn{background:none;border:none;color:var(--primary);font-size:13px;font-weight:700;cursor:pointer;padding:0;margin-bottom:12px;font-family:inherit;}
.ch-dash-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap;}
.ch-dash-name{font-size:20px;font-weight:900;color:var(--primary);margin:0;}
.ch-dash-sub{font-size:13px;color:var(--gray-500);margin:2px 0 8px;}
.ch-dash-progress{text-align:right;}
.ch-dash-progress span{font-size:12px;color:var(--gray-500);}
.ch-progress-bar{width:160px;height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden;}
.ch-progress-fill{height:100%;background:var(--green);border-radius:4px;transition:width .5s;}

/* Panels grid */
.ch-dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.ch-panel{background:var(--white);border:1px solid var(--gray-200);border-radius:10px;padding:16px;}
.ch-panel h4{font-size:14px;font-weight:800;color:var(--primary);margin:0 0 12px;border-bottom:1px solid var(--gray-100);padding-bottom:8px;}

/* Members */
.ch-member-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;}
.ch-member-role{font-size:11px;color:var(--gray-400);}
.ch-li-link{font-size:11px;font-weight:900;color:#0077b5;text-decoration:none;}
.ch-team-bio{font-size:12px;color:var(--gray-500);margin-top:8px;font-style:italic;}

/* Milestones */
.ch-milestone{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--gray-50);}
.ch-ms-icon{font-size:16px;flex-shrink:0;}
.ch-ms-info{flex:1;min-width:0;}
.ch-ms-title{font-size:13px;font-weight:600;}
.ch-ms-date{font-size:11px;color:var(--gray-400);}
.ch-ms-btn{width:24px;height:24px;border:1px solid var(--green);border-radius:4px;background:var(--white);color:var(--green);cursor:pointer;font-size:12px;}
.ch-milestone.completed .ch-ms-title{text-decoration:line-through;color:var(--gray-400);}

/* Files */
.ch-file-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--gray-50);}
.ch-file-icon{font-size:18px;flex-shrink:0;}
.ch-file-info{flex:1;min-width:0;}
.ch-file-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ch-file-meta{font-size:10px;color:var(--gray-400);}
.ch-add-btn{display:block;width:100%;margin-top:8px;padding:8px;border:1px dashed var(--gray-300);border-radius:6px;background:none;font-size:12px;color:var(--primary);cursor:pointer;font-family:inherit;font-weight:600;}

/* Messages */
.ch-panel-messages{display:flex;flex-direction:column;}
.ch-msg-list{flex:1;max-height:300px;overflow-y:auto;margin-bottom:8px;display:flex;flex-direction:column;gap:6px;}
.ch-msg{padding:8px 12px;border-radius:8px;background:var(--gray-50);max-width:85%;}
.ch-msg-mine{align-self:flex-end;background:var(--primary);color:#fff;}
.ch-msg-sender{font-size:11px;font-weight:700;margin-bottom:2px;}
.ch-msg-mine .ch-msg-sender{color:rgba(255,255,255,.7);}
.ch-msg-text{font-size:13px;line-height:1.4;}
.ch-msg-time{font-size:9px;color:var(--gray-400);margin-top:2px;}
.ch-msg-mine .ch-msg-time{color:rgba(255,255,255,.5);}
.ch-msg-input{display:flex;gap:6px;}
.ch-msg-input input{flex:1;padding:8px 12px;border:1px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:13px;}
.ch-msg-input button{padding:8px 14px;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;}

/* Notes */
.ch-notes-area{width:100%;min-height:120px;padding:10px;border:1px solid var(--gray-200);border-radius:6px;font-family:monospace;font-size:13px;resize:vertical;}
.ch-notes-meta{font-size:10px;color:var(--gray-400);margin-top:4px;}

/* Evaluations */
.ch-eval-card{border:1px solid var(--gray-100);border-radius:8px;padding:10px;margin-bottom:8px;}
.ch-eval-by{font-size:12px;font-weight:700;color:var(--primary);margin-bottom:4px;}
.ch-eval-scores{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;}
.ch-eval-scores span{background:var(--gray-50);padding:2px 8px;border-radius:4px;}
.ch-eval-comment{font-size:12px;color:var(--gray-500);font-style:italic;margin:6px 0 0;}
.ch-eval-form label{display:flex;align-items:center;gap:8px;font-size:13px;margin-bottom:8px;}
.ch-eval-form input[type=range]{flex:1;}
.ch-eval-form span{font-weight:800;min-width:16px;text-align:center;}

/* Jury table */
.ch-jury-table-wrap{overflow-x:auto;}
.ch-jury-table{width:100%;border-collapse:collapse;font-size:12px;}
.ch-jury-table th{background:var(--gray-50);padding:8px;text-align:left;font-weight:700;border-bottom:2px solid var(--gray-200);white-space:nowrap;}
.ch-jury-table td{padding:8px;border-bottom:1px solid var(--gray-100);}
.ch-score{text-align:center;font-weight:600;}
.ch-score-avg{font-size:14px;color:var(--primary);font-weight:900;}
.ch-act-btn{font-size:11px;padding:4px 8px;border:1px solid var(--gray-200);border-radius:4px;background:var(--white);cursor:pointer;margin:1px;white-space:nowrap;}
.ch-jury-note{font-size:12px;color:var(--gray-500);padding:4px 0;border-bottom:1px solid var(--gray-50);}

/* Funnel */
.ch-funnel{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;}
.ch-funnel-col{min-width:0;}
.ch-funnel-header{font-size:12px;font-weight:800;padding:8px;text-align:center;border-bottom:3px solid;margin-bottom:8px;}
.ch-funnel-body{min-height:120px;background:var(--gray-50);border-radius:8px;padding:8px;}
.ch-funnel-card{background:var(--white);border:1px solid var(--gray-200);border-radius:6px;padding:8px;margin-bottom:6px;cursor:grab;font-size:12px;transition:all .15s;}
.ch-funnel-card:active{opacity:.7;cursor:grabbing;}

/* My teams highlight */
.ch-my-teams{background:linear-gradient(135deg,#e8f5e9,#e3f2fd);border:1px solid var(--teal);border-radius:10px;padding:16px;margin-bottom:20px;}
.ch-tc-mine{border-color:var(--teal)!important;}
body.dark-mode .ch-my-teams{background:linear-gradient(135deg,#0d2818,#0d1b2a);border-color:#1a6b3a;}

/* Support tickets */
.tk-list{display:flex;flex-direction:column;gap:4px;}
.tk-row{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;transition:all .15s;background:var(--white);}
.tk-row:hover{background:var(--gray-50);border-color:var(--primary-light);}
.tk-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.tk-info{flex:1;min-width:0;}
.tk-subject{font-size:14px;font-weight:700;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tk-meta{font-size:11px;color:var(--gray-500);}
.tk-date{font-size:12px;color:var(--gray-400);flex-shrink:0;}
.tk-messages{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.tk-msg{padding:12px 16px;border-radius:10px;background:var(--gray-50);max-width:85%;}
.tk-msg-admin{background:linear-gradient(135deg,#eef2ff,#f0f4f8);align-self:flex-end;border:1px solid #c7d2fe;}
.tk-msg-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;gap:8px;}
.tk-msg-body{font-size:13px;line-height:1.6;color:var(--gray-700);}
body.dark-mode .tk-row{background:#161b22;border-color:#30363d;}
body.dark-mode .tk-row:hover{background:#21262d;}
body.dark-mode .tk-subject{color:#f0f6fc;}
body.dark-mode .tk-msg{background:#21262d;}
body.dark-mode .tk-msg-admin{background:#161b22;border-color:#30363d;}

/* Legal page */
.legal-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid var(--gray-200);}
.legal-tab{padding:10px 20px;font-size:14px;font-weight:700;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--gray-500);font-family:inherit;transition:all .15s;white-space:nowrap;}
.legal-tab.active{color:var(--primary);border-bottom-color:var(--primary);}
.legal-tab:hover{color:var(--primary);}
.legal-content h3{color:var(--primary);font-size:16px;margin:28px 0 10px;font-weight:800;padding-bottom:6px;border-bottom:1px solid var(--gray-100);}
.legal-content h3:first-child{margin-top:0;}
.legal-content p,.legal-content li{font-size:14px;line-height:1.8;color:var(--gray-600);}
.legal-content ul{padding-left:24px;margin:8px 0;}
.legal-content li{margin-bottom:4px;}
.legal-box{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;padding:16px;margin:12px 0;font-size:14px;line-height:1.8;color:var(--gray-700);}
.legal-update{font-size:12px;color:var(--gray-400);font-style:italic;margin-top:32px;padding-top:16px;border-top:1px solid var(--gray-200);}
body.dark-mode .legal-box{background:#161b22;border-color:#30363d;color:#c9d1d9;}
body.dark-mode .legal-tab{color:#6e7681;}
body.dark-mode .legal-tab.active{color:#58a6ff;border-bottom-color:#58a6ff;}
@media(max-width:768px){
    .legal-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;}
    .legal-tab{padding:8px 14px;font-size:12px;}
}

/* Student registration banner */
.ch-register-banner{display:flex;align-items:center;gap:16px;padding:16px 24px;background:linear-gradient(135deg,#e8f5e9,#e3f2fd);border:2px solid var(--teal);border-radius:12px;margin-bottom:24px;max-width:900px;margin-left:auto;margin-right:auto;}
.ch-reg-icon{font-size:32px;flex-shrink:0;}
.ch-reg-text{flex:1;font-size:14px;color:var(--gray-700);line-height:1.5;}
body.dark-mode .ch-register-banner{background:linear-gradient(135deg,#0d2818,#0d1b2a);border-color:#1a6b3a;}
body.dark-mode .ch-reg-text{color:#c9d1d9;}
@media(max-width:768px){
    .ch-register-banner{flex-direction:column;text-align:center;padding:12px 16px;gap:8px;}
    #challenge-forms .card{margin-bottom:0;}
    #challenge-forms > .container > div:first-of-type{grid-template-columns:1fr!important;}
}

/* Stats row */
.ch-stats-row{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap;}
.ch-stat{background:var(--white);border:1px solid var(--gray-200);border-radius:8px;padding:10px 16px;font-size:13px;color:var(--gray-500);}
.ch-stat strong{font-size:20px;color:var(--primary);display:block;}

/* Subject cards */
.ch-subjects-list{display:flex;flex-direction:column;gap:12px;}
.ch-subject-card{background:var(--white);border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;}
.ch-subj-header{padding:14px 16px;border-bottom:1px solid var(--gray-100);}
.ch-subj-company{font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:1px;}
.ch-subj-title{font-size:16px;font-weight:800;color:var(--gray-900);margin-top:2px;}
.ch-subj-meta{font-size:12px;color:var(--gray-400);margin-top:4px;}
.ch-subj-teams{padding:8px 16px;}
.ch-subj-team-row{padding:4px 0;font-size:13px;border-bottom:1px solid var(--gray-50);}

/* Full team cards (accordion) */
.ch-teams-list{display:flex;flex-direction:column;gap:8px;}
.ch-team-full{background:var(--white);border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;transition:all .2s;}
.ch-tf-header{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;}
.ch-tf-header:hover{background:var(--gray-50);}
.ch-tf-color{width:4px;height:40px;border-radius:2px;flex-shrink:0;}
.ch-tf-main{flex:1;min-width:0;}
.ch-tf-name{font-size:15px;font-weight:800;color:var(--gray-900);}
.ch-tf-sub{font-size:12px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ch-tf-badges{display:flex;gap:6px;align-items:center;flex-shrink:0;}
.ch-tf-count{font-size:14px;font-weight:800;color:var(--primary);text-align:center;flex-shrink:0;min-width:40px;}
.ch-tf-count small{font-size:10px;font-weight:600;color:var(--gray-400);display:block;}
.ch-tf-chevron{color:var(--gray-400);flex-shrink:0;transition:transform .2s;}
.ch-tf-open .ch-tf-chevron{transform:rotate(180deg);}
.ch-tf-body{display:none;padding:0 16px 16px;border-top:1px solid var(--gray-100);}
.ch-tf-open .ch-tf-body{display:block;}
.ch-tf-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:12px;}
.ch-tf-table th{text-align:left;font-size:11px;color:var(--gray-400);text-transform:uppercase;padding:6px 8px;border-bottom:1px solid var(--gray-200);}
.ch-tf-table td{padding:8px;border-bottom:1px solid var(--gray-50);}
.ch-tf-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}

/* Mentor list */
.ch-mentor-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;}
.ch-mentor-card{background:var(--white);border:1px solid var(--gray-200);border-radius:10px;padding:16px;}
.ch-mentor-header{display:flex;gap:12px;align-items:center;margin-bottom:8px;}
.ch-mentor-avatar{width:44px;height:44px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0;overflow:hidden;}
.ch-mentor-avatar img{width:100%;height:100%;object-fit:cover;}
.ch-mentor-name{font-size:15px;font-weight:800;color:var(--gray-900);}
.ch-mentor-job{font-size:12px;color:var(--gray-500);}
.ch-mentor-email{font-size:12px;color:var(--primary);text-decoration:none;}
.ch-mentor-expertise{font-size:12px;color:var(--gray-600);margin-bottom:4px;}
.ch-mentor-assigned{font-size:12px;color:var(--green);font-weight:600;}
.ch-mentor-available{font-size:12px;color:var(--orange);font-weight:600;}
.ch-mentor-teams{display:flex;gap:4px;flex-wrap:wrap;}
.ch-unassigned-list{display:flex;flex-direction:column;gap:6px;}
.ch-unassigned-row{font-size:13px;padding:8px 12px;background:var(--gray-50);border-radius:6px;display:flex;align-items:center;flex-wrap:wrap;gap:4px;}

/* Activity feed */
.ch-activity-feed{display:flex;flex-direction:column;gap:0;}
.ch-activity-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--gray-100);font-size:13px;}
.ch-act-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center;}
.ch-act-content{flex:1;min-width:0;}
.ch-act-date{font-size:11px;color:var(--gray-400);flex-shrink:0;}

/* Dark mode challenge */
body.dark-mode .ch-team-card{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-team-full{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-tf-header:hover{background:#21262d;}
body.dark-mode .ch-tf-name{color:#f0f6fc;}
body.dark-mode .ch-tf-body{border-color:#21262d;}
body.dark-mode .ch-tf-table th{border-color:#21262d;}
body.dark-mode .ch-tf-table td{border-color:#161b22;}
body.dark-mode .ch-subject-card{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-subj-title{color:#f0f6fc;}
body.dark-mode .ch-stat{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-mentor-card{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-unassigned-row{background:#0d1117;}
body.dark-mode .ch-activity-item{border-color:#21262d;}
body.dark-mode .ch-tc-name{color:#f0f6fc;}
body.dark-mode .ch-panel{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-msg{background:#21262d;}
body.dark-mode .ch-jury-table th{background:#0d1117;}
body.dark-mode .ch-jury-table td{border-color:#21262d;}
body.dark-mode .ch-funnel-body{background:#0d1117;}
body.dark-mode .ch-funnel-card{background:#161b22;border-color:#30363d;}
body.dark-mode .ch-notes-area{background:#0d1117;border-color:#30363d;color:#c9d1d9;}

/* Mobile challenge */
@media(max-width:768px){
    .ch-dash-grid{grid-template-columns:1fr;}
    .ch-team-grid{grid-template-columns:1fr;}
    .ch-funnel{grid-template-columns:1fr;gap:12px;}
    .ch-timeline{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;}
    .ch-tl-step{min-width:60px;}
    .ch-tl-dot{width:26px;height:26px;font-size:11px;}
    .ch-jury-table{font-size:11px;}
    .ch-jury-table th,.ch-jury-table td{padding:4px;}
    .ch-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;}
    .ch-tab{white-space:nowrap;font-size:11px;padding:6px 10px;}
    .ch-tf-badges{display:none;}
    .ch-tf-table{font-size:11px;}
    .ch-tf-name{font-size:13px;}
    .ch-tf-sub{font-size:11px;}
    .ch-stats-row{gap:8px;}
    .ch-stat{padding:8px 12px;font-size:12px;}
    .ch-stat strong{font-size:16px;}
    .ch-mentor-list{grid-template-columns:1fr;}
    .ch-subj-title{font-size:14px;}
}
body.dark-mode .cr-batch-bar{background:#161b22;border-color:#30363d;}
body.dark-mode .cr-file{background:#161b22;border-color:#30363d;}
body.dark-mode .cr-file:hover{background:#21262d;}
body.dark-mode .cr-file-title{color:#f0f6fc;}
body.dark-mode .cr-act-btn{background:#0d1117;border-color:#30363d;color:#c9d1d9;}
@media(max-width:768px){
    .cr-file-actions{display:none;}
    .cr-file{padding:8px;gap:8px;}
    .cr-file-title{font-size:13px;}
    .cr-file-icon{font-size:16px;width:22px;}
}

.bureau-kanban{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
.bureau-kanban-col{background:var(--gray-50);border-radius:var(--radius);padding:12px;min-height:200px;}
.bureau-kanban-header{font-size:14px;font-weight:800;padding-bottom:8px;margin-bottom:8px;border-bottom:3px solid;display:flex;justify-content:space-between;align-items:center;}
.bureau-kanban-count{background:var(--gray-200);color:var(--gray-600);font-size:11px;padding:2px 8px;border-radius:10px;}
.bureau-action-card{background:var(--white);border:1px solid var(--gray-200);border-radius:8px;padding:12px;margin-bottom:8px;transition:all .15s;}
.bureau-action-card:hover{box-shadow:var(--shadow-md);}
.bureau-action-overdue{border-left:3px solid var(--accent);}
.bureau-action-title{font-size:14px;font-weight:700;color:var(--gray-900);margin-bottom:4px;}
.bureau-action-desc{font-size:12px;color:var(--gray-500);margin-bottom:6px;line-height:1.4;}
.bureau-action-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--gray-400);}
.bureau-action-assignee{font-weight:600;}
.bureau-overdue{color:var(--accent);font-weight:700;}
.bureau-action-btns{display:flex;gap:4px;margin-top:6px;}
.kanban-drag-over{background:rgba(26,60,110,.08)!important;border:2px dashed var(--primary)!important;}
.bureau-action-card[draggable]{cursor:grab;}
.bureau-action-card[draggable]:active{cursor:grabbing;opacity:.7;}
.bureau-sm-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--gray-200);background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;}
.bureau-sm-btn:hover{background:var(--gray-100);}
.bureau-sm-ok{color:var(--green);border-color:var(--green);}
.bureau-sm-ok:hover{background:var(--green);color:#fff;}
/* Bureau Meetings */
.bureau-meeting-card{display:flex;gap:14px;align-items:center;padding:12px;border:1px solid var(--gray-200);border-radius:8px;margin-bottom:8px;background:var(--white);transition:all .15s;}
.bureau-meeting-card:hover{box-shadow:var(--shadow);}
.bureau-meeting-past{opacity:.7;}
.bureau-meeting-date{width:52px;text-align:center;flex-shrink:0;}
.bureau-meeting-day{font-size:24px;font-weight:900;color:var(--primary);line-height:1;}
.bureau-meeting-month{font-size:11px;color:var(--gray-500);text-transform:uppercase;font-weight:700;}
.bureau-meeting-info{flex:1;min-width:0;}
.bureau-meeting-title{font-size:15px;font-weight:700;color:var(--gray-900);}
.bureau-meeting-meta{font-size:12px;color:var(--gray-500);}
.bureau-meeting-agenda{font-size:12px;color:var(--gray-600);margin-top:4px;line-height:1.4;}
.bureau-meeting-actions{flex-shrink:0;display:flex;gap:6px;align-items:center;}
/* Bureau Docs */
.bureau-doc-row{display:flex;gap:12px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--gray-100);transition:background .1s;}
.bureau-doc-row:hover{background:var(--gray-50);}
.bureau-doc-icon{font-size:24px;width:40px;text-align:center;flex-shrink:0;}
.bureau-doc-info{flex:1;min-width:0;}
.bureau-doc-title{font-size:14px;font-weight:700;color:var(--gray-900);}
.bureau-doc-meta{font-size:11px;color:var(--gray-400);}
@media(max-width:768px){.bureau-kanban{grid-template-columns:1fr;}}
body.dark-mode .bureau-kanban-col{background:#21262d;}
body.dark-mode .bureau-action-card,body.dark-mode .bureau-meeting-card{background:#161b22;border-color:#30363d;}
body.dark-mode .bureau-sm-btn{background:#21262d;border-color:#30363d;color:#c9d1d9;}
/* Actions Table */
.act-table{width:100%;border-collapse:collapse;font-size:14px;}
.act-table th{text-align:left;padding:10px 12px;font-size:12px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--gray-200);}
.act-row{transition:background .1s;}
.act-row:hover{background:var(--gray-50);}
.act-row td{padding:10px 12px;border-bottom:1px solid var(--gray-100);vertical-align:middle;}
.act-row-overdue{background:rgba(200,16,46,.03);}
.act-row-overdue:hover{background:rgba(200,16,46,.06);}
.act-status-dot{display:inline-block;width:12px;height:12px;border-radius:50%;}
.act-title{font-weight:700;color:var(--gray-900);font-size:14px;}
.act-who{font-size:12px;color:var(--gray-500);}
.act-overdue{color:var(--accent);font-weight:700;}
.act-move-btns{display:flex;gap:4px;}
.act-move-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--gray-200);background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .15s;color:var(--gray-600);}
.act-move-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
body.dark-mode .act-table th{border-color:#30363d;color:#8b949e;}
body.dark-mode .act-row:hover{background:#21262d;}
body.dark-mode .act-row td{border-color:#21262d;}
body.dark-mode .act-move-btn{background:#21262d;border-color:#30363d;color:#8b949e;}
body.dark-mode .bureau-doc-row:hover{background:#21262d;}
/* Wiki Full-screen */
.wiki-full{display:grid;grid-template-columns:220px 1fr;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;min-height:600px;}
.wiki-sidebar{background:var(--gray-50);border-right:1px solid var(--gray-200);overflow-y:auto;}
.wiki-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--gray-200);font-size:14px;}
.wiki-tab{display:block;width:100%;padding:10px 14px;background:none;border:none;border-left:3px solid transparent;cursor:pointer;font-family:inherit;text-align:left;transition:all .1s;}
.wiki-tab:hover{background:var(--gray-100);}
.wiki-tab-active{background:var(--white);border-left-color:var(--primary);}
.wiki-tab-date{font-size:12px;font-weight:700;color:var(--primary);}
.wiki-tab-title{font-size:12px;color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wiki-tab-status{font-size:10px;color:var(--gray-400);margin-top:2px;}
.wiki-tab-has-cr{color:var(--green);font-weight:700;}
.wiki-editor-area{display:flex;flex-direction:column;background:var(--white);}
.wiki-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--gray-200);background:var(--gray-50);flex-shrink:0;flex-wrap:wrap;gap:8px;}
.wiki-toolbar-left{min-width:0;}
.wiki-title{font-size:16px;font-weight:800;color:var(--primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wiki-date{font-size:12px;color:var(--gray-500);}
.wiki-toolbar-right{display:flex;gap:6px;align-items:center;flex-shrink:0;}
.wiki-toolbar-btn{padding:5px 12px;border:1px solid var(--gray-200);border-radius:6px;background:var(--white);font-size:11px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;}
.wiki-toolbar-btn:hover{background:var(--gray-100);}
.wiki-save-status{font-size:11px;color:var(--green);font-weight:600;}
.wiki-agenda{padding:8px 16px;background:rgba(26,60,110,.03);border-bottom:1px solid var(--gray-100);font-size:12px;color:var(--gray-600);}
.wiki-split{display:grid;grid-template-columns:1fr 1fr;flex:1;overflow:hidden;}
.wiki-edit-pane{border-right:1px solid var(--gray-100);display:flex;flex-direction:column;}
.wiki-textarea{flex:1;width:100%;border:none;padding:16px;font-family:'Courier New',monospace;font-size:13px;line-height:1.8;resize:none;outline:none;background:transparent;}
.wiki-preview-pane{padding:16px;font-size:14px;line-height:1.7;overflow-y:auto;}
.wiki-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--gray-400);}
.md-check{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:14px;}
.md-checked{text-decoration:line-through;color:var(--gray-400);}
.md-check-box{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:2px solid var(--gray-300);border-radius:4px;font-size:12px;flex-shrink:0;}
.md-checked .md-check-box{background:var(--green);border-color:var(--green);color:#fff;}
@media(max-width:768px){.wiki-full{grid-template-columns:1fr;}.wiki-sidebar{max-height:150px;border-right:none;border-bottom:1px solid var(--gray-200);}.wiki-split{grid-template-columns:1fr;}.wiki-preview-pane{display:none;}}
body.dark-mode .wiki-sidebar{background:#21262d;}
body.dark-mode .wiki-editor-area{background:#161b22;}
body.dark-mode .wiki-tab-active{background:#161b22;}
body.dark-mode .wiki-toolbar{background:#21262d;}
body.dark-mode .wiki-textarea{color:#e6edf3;}
body.dark-mode .wiki-toolbar-btn{background:#21262d;border-color:#30363d;color:#c9d1d9;}
body.dark-mode .md-check-box{border-color:#30363d;}
/* Wiki Fullscreen Overlay */
.wiki-fs{position:fixed;inset:0;z-index:2000;background:var(--white);display:flex;flex-direction:column;}
.wiki-fs-toolbar{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-bottom:1px solid var(--gray-200);background:var(--primary);color:#fff;flex-shrink:0;gap:8px;flex-wrap:wrap;}
.wiki-fs-toolbar-left{display:flex;align-items:center;gap:12px;min-width:0;}
.wiki-fs-close{background:rgba(255,255,255,.15);border:none;color:#fff;width:36px;height:36px;border-radius:8px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0;}
.wiki-fs-close:hover{background:rgba(255,255,255,.3);}
.wiki-fs-title{font-size:16px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;}
.wiki-fs-meta{font-size:11px;opacity:.7;color:#fff;}
.wiki-fs-toolbar-right{display:flex;gap:6px;align-items:center;flex-shrink:0;}
.wiki-fs-btn{padding:6px 14px;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:rgba(255,255,255,.1);color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;}
.wiki-fs-btn:hover{background:rgba(255,255,255,.25);}
.wiki-fs-btn-accent{background:var(--teal);border-color:var(--teal);}
.wiki-fs-btn-accent:hover{background:#0abfbf;}
.wiki-fs-agenda{padding:6px 16px;background:rgba(26,60,110,.04);border-bottom:1px solid var(--gray-100);font-size:12px;color:var(--gray-600);flex-shrink:0;}
/* OneNote-style format bar */
.on-format-bar{display:flex;flex-direction:column;gap:4px;padding:6px 16px;background:var(--gray-50);border-bottom:1px solid var(--gray-200);flex-shrink:0;}
.on-fmt-row{display:flex;gap:2px;align-items:center;flex-wrap:wrap;}
.on-fmt-btn{width:32px;height:32px;border:none;background:var(--white);border-radius:6px;cursor:pointer;font-size:14px;font-family:inherit;display:flex;align-items:center;justify-content:center;transition:all .1s;color:var(--gray-700);}
.on-fmt-btn:hover{background:var(--primary);color:#fff;}
.on-fmt-btn-wide{width:auto;padding:4px 10px;font-size:11px;gap:4px;}
.on-fmt-sep{width:1px;height:24px;background:var(--gray-200);margin:0 4px;}
.on-word-count{font-size:11px;color:var(--gray-400);font-weight:600;margin-left:auto;}
.wiki-callout{page-break-inside:avoid;}
.on-editor-wrap{flex:1;overflow-y:auto;background:var(--white);}
.on-editor{max-width:800px;margin:0 auto;padding:32px 48px;min-height:100%;font-family:'Source Sans 3','Segoe UI',sans-serif;font-size:15px;line-height:1.8;color:var(--gray-800);outline:none;}
.on-editor:focus{outline:none;}
.on-editor h2{color:var(--primary);font-size:22px;font-weight:900;margin:24px 0 12px;padding-bottom:6px;border-bottom:2px solid var(--gray-200);}
.on-editor h3{color:var(--primary);font-size:18px;font-weight:800;margin:20px 0 8px;}
.on-editor h4{color:var(--gray-700);font-size:15px;font-weight:700;margin:16px 0 6px;}
.on-editor ul,.on-editor ol{margin:8px 0;padding-left:24px;}
.on-editor li{margin-bottom:4px;}
.on-editor blockquote{border-left:3px solid var(--primary);padding:8px 16px;margin:12px 0;background:rgba(26,60,110,.03);border-radius:0 6px 6px 0;color:var(--gray-600);}
.on-editor hr{border:none;border-top:1px solid var(--gray-200);margin:20px 0;}
.on-editor label{display:flex;align-items:center;gap:8px;padding:4px 0;}
.wiki-fs-footer{padding:4px 16px;background:var(--gray-50);border-top:1px solid var(--gray-200);font-size:10px;color:var(--gray-400);flex-shrink:0;text-align:center;}
body.dark-mode .wiki-fs{background:#0d1117;}
body.dark-mode .wiki-fs-toolbar{background:#161b22;}
body.dark-mode .wiki-fs-footer{background:#21262d;}
body.dark-mode .on-format-bar{background:#21262d;}
body.dark-mode .on-fmt-btn{background:#161b22;color:#c9d1d9;}
body.dark-mode .on-fmt-btn:hover{background:#388bfd;color:#fff;}
body.dark-mode .on-fmt-row .on-fmt-btn[style*="background:#fef3cd"]{background:#3d3200!important;color:#ffd600;}
body.dark-mode .on-fmt-row .on-fmt-btn[style*="background:#d4edda"]{background:#1b3a1b!important;color:#4caf50;}
body.dark-mode .on-fmt-row .on-fmt-btn[style*="background:#f8d7da"]{background:#3a1b1b!important;color:#f44336;}
body.dark-mode .on-editor-wrap{background:#0d1117;}
body.dark-mode .on-editor{color:#e6edf3;}
body.dark-mode .on-editor h2{color:#58a6ff;border-color:#30363d;}
body.dark-mode .on-editor h3{color:#58a6ff;}
body.dark-mode .on-editor blockquote{background:rgba(56,139,253,.05);border-color:#388bfd;}
/* Wiki Read mode (Wikipedia-style) */
.wiki-read-wrap{flex:1;overflow-y:auto;background:var(--white);}
.wiki-article{max-width:800px;margin:0 auto;padding:32px 48px;font-size:15px;line-height:1.8;color:var(--gray-800);}
.wiki-article h2{color:var(--primary);font-size:22px;font-weight:900;margin:28px 0 12px;padding-bottom:6px;border-bottom:2px solid var(--gray-200);}
.wiki-article h3{color:var(--primary);font-size:18px;font-weight:800;margin:24px 0 8px;}
.wiki-article h4{color:var(--gray-700);font-size:15px;font-weight:700;margin:16px 0 6px;}
.wiki-article ul,.wiki-article ol{margin:8px 0;padding-left:24px;}
.wiki-article li{margin-bottom:6px;}
.wiki-article blockquote{border-left:3px solid var(--primary);padding:12px 20px;margin:16px 0;background:rgba(26,60,110,.03);border-radius:0 8px 8px 0;color:var(--gray-600);font-style:italic;}
.wiki-article hr{border:none;border-top:1px solid var(--gray-200);margin:24px 0;}
.wiki-article label{display:flex;align-items:center;gap:8px;padding:4px 0;}
.wiki-article strong{color:var(--gray-900);}
.wiki-empty-article{text-align:center;padding:60px 20px;}
body.dark-mode .wiki-read-wrap{background:#0d1117;}
body.dark-mode .wiki-article{color:#c9d1d9;}
body.dark-mode .wiki-article h2{color:#58a6ff;border-color:#30363d;}
body.dark-mode .wiki-article h3{color:#58a6ff;}
body.dark-mode .wiki-article strong{color:#e6edf3;}
/* Bureau action buttons (#1) */
.bureau-action-btn{padding:3px 8px;border:1px solid var(--gray-200);border-radius:4px;background:var(--white);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .1s;color:var(--gray-600);}
.bureau-action-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
.bureau-action-btn-warn:hover{background:var(--orange);border-color:var(--orange);}
.bureau-action-btn-danger:hover{background:var(--accent);border-color:var(--accent);}
body.dark-mode .bureau-action-btn{background:#21262d;border-color:#30363d;color:#8b949e;}
/* Kanban filter buttons (#6) */
.bureau-filter-btn{padding:3px 10px;border:1px solid var(--gray-200);border-radius:12px;background:var(--white);cursor:pointer;font-family:inherit;font-size:11px;font-weight:600;transition:all .1s;}
.bureau-filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);}
.bureau-filter-btn:hover{border-color:var(--primary);}
body.dark-mode .bureau-filter-btn{background:#21262d;border-color:#30363d;color:#8b949e;}
body.dark-mode .bureau-filter-btn.active{background:var(--primary);color:#fff;}
/* Wiki timer (#4) */
.wiki-timer{font-family:monospace;font-size:14px;font-weight:700;color:rgba(255,255,255,.8);background:rgba(0,0,0,.2);padding:4px 10px;border-radius:4px;}

/* ========== COMPACT LIST (mobile annuaire) ========== */
.clist-wrap{display:flex;gap:0;position:relative;}
.clist-alpha{position:sticky;top:56px;align-self:flex-start;display:flex;flex-direction:column;align-items:center;gap:1px;padding:4px 2px;z-index:3;background:var(--white);border-radius:4px;}
.clist-alpha a{width:20px;height:16px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:var(--primary);text-decoration:none;border-radius:2px;transition:all .1s;}
.clist-alpha a:hover,.clist-alpha a:active{background:var(--primary);color:#fff;}
.clist-body{flex:1;min-width:0;}
.clist-letter{font-size:12px;font-weight:800;color:var(--primary);padding:6px 8px 2px;border-bottom:1px solid var(--gray-100);position:sticky;top:56px;background:var(--white);z-index:2;}
.clist-row{display:flex;align-items:center;gap:10px;padding:8px;border-bottom:1px solid var(--gray-50);cursor:pointer;transition:background .1s;border-radius:6px;}
.clist-row:active{background:var(--gray-50);}
.clist-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;overflow:hidden;}
.clist-avatar img{width:100%;height:100%;object-fit:cover;}
.clist-avatar-locked{background:var(--gray-300);}
.clist-info{flex:1;min-width:0;}
.clist-name{font-size:14px;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.clist-name strong{font-weight:800;}
.clist-sub{font-size:11px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.clist-badge{display:inline-block;width:16px;height:16px;border-radius:50%;font-size:8px;font-weight:900;text-align:center;line-height:16px;vertical-align:middle;margin-left:2px;color:#fff;}
.cb-board{background:var(--primary);}
.cb-mentor{background:var(--teal);}
.clist-chevron{color:var(--gray-300);flex-shrink:0;}
.clist-row-locked{opacity:.8;}

/* Dark mode compact list */
body.dark-mode .clist-alpha{background:#0d1117;}
body.dark-mode .clist-letter{background:#0d1117;border-color:#21262d;color:#58a6ff;}
body.dark-mode .clist-row{border-color:#161b22;}
body.dark-mode .clist-row:active{background:#161b22;}
body.dark-mode .clist-avatar{background:#30363d;}
body.dark-mode .clist-name{color:#f0f6fc;}
body.dark-mode .clist-sub{color:#6e7681;}
body.dark-mode .clist-chevron{color:#30363d;}

/* ========== ANNUAIRE SEARCH & FILTERS ========== */
.ann-search-bar{display:flex;gap:8px;margin-bottom:12px;align-items:center;}
.ann-search-input{flex:1;padding:10px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:14px;background:var(--white);transition:border-color .2s;}
.ann-search-input:focus{border-color:var(--primary);outline:none;}
.ann-filter-toggle{display:none;width:40px;height:40px;border:2px solid var(--gray-200);border-radius:var(--radius);background:var(--white);cursor:pointer;color:var(--gray-500);flex-shrink:0;transition:all .2s;}
.ann-filter-toggle:hover{border-color:var(--primary);color:var(--primary);}
.ann-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;align-items:center;}
.ann-filter-select{padding:10px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-family:inherit;font-size:14px;background:var(--white);}
.rgpd-banner-compact{font-size:12px;padding:8px 14px;margin-bottom:12px;gap:8px;line-height:1.4;}
body.dark-mode .ann-search-input{background:#0d1117;border-color:#30363d;color:#c9d1d9;}
body.dark-mode .ann-filter-toggle{background:#0d1117;border-color:#30363d;color:#6e7681;}
body.dark-mode .ann-filter-select{background:#0d1117;border-color:#30363d;color:#c9d1d9;}

/* ========== MOBILE APP-LIKE ========== */
.mobile-nav{display:none;}

@media (max-width: 768px) {
    /* Base */
    body{font-size:14px;line-height:1.6;padding-bottom:56px;}

    /* Annuaire compact on mobile */
    .ann-filter-toggle{display:flex;align-items:center;justify-content:center;}
    .ann-filters{display:none;gap:8px;margin-bottom:12px;}
    .ann-filters.open{display:flex;}
    .ann-filter-select{flex:1;min-width:0;padding:8px 10px;font-size:13px;}
    .ann-search-input{padding:8px 12px;font-size:13px;}
    .rgpd-banner-compact{font-size:11px;padding:6px 10px;margin-bottom:8px;}
    #page-annuaire .section-title{font-size:18px;margin-bottom:4px;}
    #page-annuaire .section-sub{font-size:12px;margin-bottom:8px;}
    #page-annuaire .section-line{display:none;}

    /* Bottom navigation — always visible, compact */
    .mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--gray-200);z-index:100;padding:4px 0;padding-bottom:env(safe-area-inset-bottom,4px);box-shadow:0 -1px 8px rgba(0,0,0,.06);justify-content:space-around;}
    .mnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 0;background:none;border:none;color:var(--gray-400);cursor:pointer;font-family:inherit;transition:color .15s;}
    .mnav-btn svg{width:20px;height:20px;stroke:currentColor;}
    .mnav-btn span{font-size:9px;font-weight:600;}
    .mnav-btn.active{color:var(--primary);}

    /* Navbar */
    .navbar{display:flex;flex-direction:column;}
    .nav-inner{height:44px;padding:0 12px;}
    .nav-logo img{height:28px!important;}
    .nav-links,.nav-hamburger,.nav-search,.nav-sub{display:none!important;}
    .lang-current{font-size:11px;padding:2px 8px;min-height:28px;}
    .dark-mode-btn{width:28px;height:28px;}
    .nav-member-btn{font-size:12px;padding:4px 12px;min-height:32px;border-radius:6px;}
    .nav-bell{width:32px;height:32px;}
    .nav-bell-icon{font-size:16px;}
    .tricolor-bar{height:2px;}
    .tricolor-bar::after{transition:width .1s linear;}

    /* Hero */
    .hero-slider{height:240px;}
    .slide-content{padding:0 16px;}
    .slide-content h1{font-size:20px;line-height:1.3;}
    .slide-content p{font-size:12px;line-height:1.5;margin-bottom:12px;}
    .slide-content .btn{font-size:12px;padding:8px 16px;min-height:36px;}
    .slide-dots{bottom:8px;}
    .slide-dot{width:8px;height:8px;}

    /* Sections */
    section{padding:24px 0;}
    .container{padding:0 14px;}
    .section-title{font-size:20px;margin-bottom:6px;}
    .section-sub{font-size:13px;margin-bottom:20px;}
    .section-line{width:40px;height:3px;margin-bottom:12px;}

    /* Welcome */
    .hw-layout{grid-template-columns:1fr;gap:16px;}
    .hw-badge{font-size:10px;padding:3px 10px;margin-bottom:10px;}
    .hw-title{font-size:22px;}
    .hw-desc{font-size:14px;margin-bottom:16px;}
    .hw-visual{display:none;}
    .hw-stats{gap:12px;margin-bottom:16px;}
    .hw-stat-val{font-size:22px;}
    .hw-stat-label{font-size:10px;}
    .hw-actions .btn{font-size:13px;padding:10px 16px;}

    /* News carousel */
    .news-carousel-wrap{padding:0 32px;}
    .news-carousel-card{min-width:220px;max-width:220px;}
    .ncc-img{height:120px;}
    .ncc-body{padding:12px;}
    .ncc-title{font-size:14px;}
    .ncc-excerpt{font-size:12px;-webkit-line-clamp:2;}
    .nc-arrow{width:28px;height:28px;font-size:12px;}

    /* Cards */
    .cards-grid{grid-template-columns:1fr!important;gap:12px;}
    .card-body{padding:16px;}
    .card-title{font-size:16px;}
    .card-text{font-size:13px;}
    .card-tag{font-size:10px;padding:2px 8px;}

    /* KPI */
    .kpi-row{grid-template-columns:repeat(2,1fr)!important;gap:10px;margin-bottom:24px;}
    .kpi-card{padding:16px 10px;}
    .kpi-val{font-size:24px;}
    .kpi-label{font-size:11px;}

    /* Events */
    .evt-card{flex-direction:column;margin-bottom:12px;}
    .evt-date-col{flex-direction:row;gap:6px;min-width:auto;padding:8px 14px;}
    .evt-date-day{font-size:20px;}
    .evt-date-month,.evt-date-year{font-size:10px;}
    .evt-body{padding:12px;}
    .evt-title{font-size:15px;}
    .evt-desc{font-size:12px;-webkit-line-clamp:2;}
    .evt-meta{font-size:11px;}
    .evt-reg-btn{font-size:11px;padding:6px 12px;min-height:36px;}
    .evt-gauge{margin:4px 0;}

    /* Agenda */
    .agenda-layout{grid-template-columns:1fr;gap:12px;}
    .agenda-calendar{position:static;}
    .cal-header{padding:10px 12px;}
    .cal-header h3{font-size:14px;}
    .cal-grid{padding:4px;}
    .cal-day{padding:5px 2px;font-size:11px;}
    .cal-dow{font-size:9px;padding:4px 0;}

    /* Directory */
    .dir-alpha-bar{gap:1px;padding:4px 0;position:static;}
    .dir-alpha-link{width:22px;height:22px;font-size:9px;border-radius:3px;}
    .dir-member-card{padding:8px;gap:8px;}
    .dir-mc-avatar{width:36px;height:36px;font-size:12px;}
    .dir-mc-name{font-size:13px;}
    .dir-mc-title{font-size:11px;}
    .dir-mc-company{font-size:11px;}
    .dir-mc-tags{display:none;}
    .dir-mc-li{width:26px;height:26px;font-size:11px;}
    .dir-letter-anchor{font-size:12px;padding:8px 0 2px;}

    /* Member tabs — icons only on mobile */
    .member-tabs-unified{display:flex;flex-wrap:nowrap;gap:0;margin-bottom:12px;justify-content:space-around;overflow:visible;}
    .mtab-u{flex-shrink:0;padding:8px 6px;font-size:0;min-width:0;display:flex;align-items:center;justify-content:center;position:relative;}
    .mtab-u svg{width:20px;height:20px;}
    .mtab-u::after{content:attr(data-tab);position:absolute;bottom:-14px;left:50%;transform:translateX(-50%);font-size:8px;font-weight:700;color:var(--gray-400);white-space:nowrap;opacity:0;transition:opacity .15s;}
    .mtab-u.active::after{opacity:1;color:var(--primary);}

    /* LinkedIn annuaire mobile */
    .ln-grid{grid-template-columns:1fr!important;gap:12px;}
    .ln-card{border-radius:10px;}
    .ln-cover{height:44px;}
    .ln-avatar{width:60px;height:60px;margin-top:-30px;}
    .ln-initials{font-size:18px;}
    .ln-name{font-size:15px;}
    .ln-headline{font-size:12px;}
    .ln-company{font-size:12px;}
    .ln-body{padding:8px 14px 0;}
    .ln-tags{padding:8px 14px 0;gap:4px;}
    .ln-tag{font-size:10px;padding:2px 8px;}
    .ln-bio{font-size:11px;padding:6px 14px 0;}
    .ln-footer{padding:8px 14px;}
    .ln-lock-msg{font-size:11px;padding:6px 12px;}
    .ln-modal{max-width:100%;width:100%;border-radius:0;max-height:100vh;overflow-y:auto;}
    .ln-modal-cover{height:80px;}
    .ln-modal-header{padding:12px 16px;gap:12px;}
    .ln-modal-avatar{width:64px;height:64px;font-size:22px;margin-top:-48px;}
    .ln-modal-info h2{font-size:18px;}
    .ln-modal-details{grid-template-columns:1fr;padding:12px 16px 0;}
    .ln-modal-section{padding:0 16px;}
    .ln-modal-actions{padding:16px;}
    .ln-modal-badges{padding:12px 16px 0;}

    /* Profile form */
    #mtab-profile > div{grid-template-columns:1fr!important;}
    .form-group label{font-size:12px;}
    .form-group input,.form-group select,.form-group textarea{font-size:14px;padding:8px 12px;min-height:40px;}

    /* Auth modal full screen */
    .auth-overlay{padding:0;align-items:stretch;}
    .auth-card{max-width:100%;border-radius:0;min-height:100vh;overflow-y:auto;}
    .auth-header{padding:24px 20px 0;}
    .auth-title{font-size:20px;}
    .auth-form{padding:16px 20px 0;}
    .auth-input{font-size:14px;padding:10px 14px;}

    /* Admin modals full screen */
    .adm-modal-bg{padding:0;}
    .adm-modal{max-width:100%!important;width:100%!important;border-radius:0;max-height:100vh;overflow-y:auto;}

    /* DataTable */
    .dt-wrapper{border-radius:8px;}
    .dt-toolbar{flex-direction:column;gap:6px;padding:8px 10px;}
    .dt-toolbar-left,.dt-toolbar-right{width:100%;}
    .dt-search-input{width:100%;}
    .dt-table{font-size:11px;}
    .dt-th,.dt-td{padding:6px 6px;}
    .dt-footer{flex-direction:column;gap:4px;padding:6px 10px;font-size:11px;}
    .dt-page-size{font-size:11px;}

    /* Bureau */
    .bureau-kanban{grid-template-columns:1fr;gap:10px;}
    .bureau-kanban-col{padding:8px;min-height:auto;}
    .bureau-kanban-header{font-size:13px;}
    .bureau-action-card{padding:10px;}
    .bureau-action-title{font-size:13px;}

    /* Wiki fullscreen */
    .wiki-fs-toolbar{padding:6px 10px;}
    .wiki-fs-title{font-size:13px;}
    .wiki-fs-meta{font-size:10px;}
    .wiki-fs-btn{font-size:10px;padding:4px 8px;}
    .on-format-bar{padding:4px 6px;gap:1px;}
    .on-fmt-btn{width:26px;height:26px;font-size:11px;}
    .on-fmt-btn-wide{padding:2px 5px;font-size:9px;}
    .on-fmt-sep{height:18px;}
    .on-editor{padding:12px;font-size:14px;line-height:1.7;}
    .wiki-article{padding:16px;font-size:14px;}

    /* Org chart */
    .org-branches{grid-template-columns:1fr!important;}
    .org-tiles{gap:4px;}
    .org-tile{min-width:auto;padding:6px 8px;}
    .org-tile-name{font-size:12px;}
    .org-section-label{font-size:10px;}
    .org-photo{width:60px;height:60px;font-size:20px;}
    .org-photo-sm{width:40px;height:40px;font-size:14px;}

    /* Partners */
    .partners-grid{gap:12px;}
    .partner-tile{width:80px;height:50px;padding:6px;}
    .partner-tile-logo{max-width:60px;max-height:35px;}
    .partner-tile-text{font-size:10px;}

    /* Challenge */
    .challenge-timeline::before{left:18px;}
    .ct-number{width:36px;height:36px;font-size:16px;}
    .ct-title{font-size:15px;}
    .ct-desc{font-size:12px;}
    .ct-content{padding:14px;}

    /* Adhesion */
    #page-adhesion .kpi-row{grid-template-columns:1fr!important;}
    .adh-choice{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 12px;}
    .adh-pay-choice{padding:10px 8px;}
    .adh-pay-choice strong{font-size:12px;}
    .form-card{padding:16px!important;}

    /* Footer */
    .footer{padding:20px 0 72px;}
    .footer h4{font-size:12px;margin-bottom:4px;}
    .footer-links a{font-size:12px;}
    .footer-links li{margin-bottom:1px;}
    .footer-bar{font-size:11px;padding:12px 0;}

    /* Buttons */
    .btn{min-height:40px;font-size:13px;}
    .form-submit{min-height:44px;font-size:14px;}

    /* Partner banner hidden */
    .partner-banner{display:none!important;}

    /* Dark mode mobile nav */
    body.dark-mode .mobile-nav{background:#161b22;border-color:#30363d;}
    body.dark-mode .mobile-nav{background:#161b22;border-color:#30363d;}
    body.dark-mode .mnav-btn{color:#6e7681;}
    body.dark-mode .mnav-btn.active{color:#58a6ff;}
}

@media (max-width: 380px) {
    .hero-slider{height:200px;}
    .slide-content h1{font-size:18px;}
    .hw-title{font-size:20px;}
    .section-title{font-size:18px;}
    .clist-alpha a{width:18px;height:14px;font-size:8px;}
}
