:root {
  --sv-green: #1E3A2B;
  --sv-green-mid: #2D5241;
  --sv-green-light: #3B6250;
  --sv-gold: #C9A84C;
  --sv-gold-light: #DFC07A;
  --sv-gold-pale: rgba(201,168,76,0.12);
  --sv-cream: #F8F7F5;
  --sv-cream-dark: #EEECE8;
  --sv-white: #FFFFFF;
  --sv-text: #1A2E22;
  --sv-text-muted: #6B7E72;
  --sv-text-light: #9BAA9F;
  --sv-border: rgba(30,58,43,0.1);
  --sv-border-gold: rgba(201,168,76,0.3);
  --sv-red: #C0392B;
  --sv-sidebar-w: 272px;
  --sv-header-h: 60px;
  --sv-bottom-h: 64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:'Inter',sans-serif;font-size:15px;color:var(--sv-text);background:#dbd5c8;-webkit-font-smoothing:antialiased}
button{cursor:pointer;border:none;background:none;font-family:'Inter',sans-serif}
input,select,textarea{font-family:'Inter',sans-serif}
a{text-decoration:none;color:inherit}
img{max-width:100%}

/* ───── LOGIN ───── */
#login-screen{position:fixed;inset:0;background:var(--sv-green);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;padding:32px 28px;overflow-y:auto}
#login-screen .login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:44px}
#login-screen .login-logo-icon{width:min(300px,85vw);height:auto}
#login-screen .login-box{width:100%;max-width:380px}
#login-screen .login-title{color:var(--sv-white);font-size:18px;font-weight:600;margin-bottom:20px;letter-spacing:0.2px}
#login-screen .form-field{margin-bottom:12px}
#login-screen .form-field input{width:100%;padding:14px 16px;background:rgba(245,240,232,0.12);border:1px solid rgba(245,240,232,0.18);border-radius:10px;color:var(--sv-white);font-size:14px;outline:none;transition:.2s;font-family:'Inter',sans-serif}
#login-screen .form-field input::placeholder{color:rgba(255,255,255,0.45)}
#login-screen .form-field input:focus{border-color:rgba(201,168,76,0.6);background:rgba(245,240,232,0.18)}
.forgot{text-align:right;margin-bottom:22px}
.forgot a{color:rgba(255,255,255,0.7);font-size:13px;text-decoration:none}
.forgot a:hover{color:var(--sv-white)}
.btn-login{width:100%;padding:15px;background:linear-gradient(135deg,#C9A84C 0%,#E2C06A 50%,#C9A84C 100%);color:#1A1A1A;border-radius:10px;font-size:15px;font-weight:600;letter-spacing:0.3px;transition:.2s;cursor:pointer;border:none;font-family:'Inter',sans-serif}
.btn-login:hover{background:linear-gradient(135deg,#DFC07A 0%,#EDD080 50%,#DFC07A 100%)}
.login-divider{display:flex;align-items:center;gap:14px;margin:22px 0;color:rgba(255,255,255,0.35);font-size:13px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.15)}
.login-social{display:flex;gap:14px;justify-content:center}
.social-btn{width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.5);color:rgba(255,255,255,0.85);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;transition:.2s;cursor:pointer}
.social-btn:hover{border-color:var(--sv-white);color:var(--sv-white)}
.login-signup{text-align:center;margin-top:24px;font-size:14px;color:rgba(255,255,255,0.55)}
.login-signup a{color:var(--sv-gold);font-weight:500}

/* ───── APP SHELL ───── */
#app{display:none;height:100vh;overflow:hidden}
#app.visible{display:flex}

/* SIDEBAR (desktop) */
#sidebar{width:var(--sv-sidebar-w);background:linear-gradient(180deg,#1A3326 0%,#1E3A2B 25%,#2A4A38 60%,#3B5C4A 100%);display:flex;flex-direction:column;height:100vh;flex-shrink:0;overflow-y:auto;transition:.3s;position:relative}
#sidebar::before{content:'';position:absolute;inset:0;background-image:radial-gradient(ellipse at 50% 20%,rgba(255,255,255,0.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(201,168,76,0.05) 0%,transparent 60%);pointer-events:none;z-index:0}
#sidebar > *{position:relative;z-index:1}
.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,0.07);display:flex;justify-content:center;align-items:center}
.sidebar-logo-icon{width:160px;height:auto;flex-shrink:0}
.sidebar-logo-text{font-family:'Inter',sans-serif;color:var(--sv-gold);font-size:14px;letter-spacing:3px;font-weight:600;line-height:1.2}
.sidebar-logo-sub{color:rgba(201,168,76,0.45);font-size:7px;letter-spacing:2px;font-weight:300}
.sidebar-profile{padding:16px 16px 10px}
.profile-switcher{background:rgba(255,255,255,0.07);border:1px solid rgba(201,168,76,0.15);border-radius:10px;padding:10px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;width:100%;transition:.2s}
.profile-switcher:hover{border-color:rgba(201,168,76,0.35)}
.profile-avatar{width:30px;height:30px;border-radius:50%;background:var(--sv-gold);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--sv-green);flex-shrink:0}
.profile-info{flex:1;text-align:left}
.profile-role{font-size:10px;color:rgba(201,168,76,0.6);letter-spacing:1.5px;text-transform:uppercase;font-weight:400}
.profile-name{font-size:13px;color:var(--sv-white);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.profile-chevron{color:rgba(201,168,76,0.5);font-size:11px}
.profile-dropdown{background:var(--sv-green-mid);border:1px solid rgba(201,168,76,0.2);border-radius:10px;margin:4px 16px 0;overflow:hidden;display:none}
.profile-dropdown.open{display:block}
.profile-option{padding:10px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:.15s;border-bottom:1px solid rgba(255,255,255,0.05)}
.profile-option:last-child{border:none}
.profile-option:hover{background:rgba(255,255,255,0.05)}
.profile-option .po-dot{width:8px;height:8px;border-radius:50%;background:var(--sv-gold);opacity:0.4;flex-shrink:0}
.profile-option.active .po-dot{opacity:1}
.profile-option .po-label{font-size:12px;color:rgba(255,255,255,0.75)}
.sidebar-nav{padding:8px 12px;flex:1}
.nav-section-label{font-size:10px;color:rgba(255,255,255,0.25);letter-spacing:2px;text-transform:uppercase;padding:12px 8px 6px;font-weight:400}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:.15s;margin-bottom:2px;position:relative}
.nav-item:hover{background:rgba(255,255,255,0.07)}
.nav-item.active{background:rgba(201,168,76,0.15);border:1px solid rgba(201,168,76,0.2)}
.nav-item .nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-item .nav-label{font-size:14px;color:rgba(255,255,255,0.7);font-weight:400;white-space:nowrap}
.nav-item.active .nav-label{color:var(--sv-white);font-weight:500}
.nav-item .nav-badge{margin-left:auto;background:var(--sv-red);color:#fff;font-size:10px;font-weight:500;padding:2px 6px;border-radius:10px}
.nav-item .nav-badge.nav-badge-gold{background:var(--sv-gold);color:var(--sv-green)}
.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,0.07);margin-top:auto}
.sidebar-support{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;opacity:0.6;transition:.2s;border-radius:8px}
.sidebar-support:hover{opacity:1;background:rgba(255,255,255,0.05)}
.sidebar-support span{font-size:14px;color:var(--sv-white)}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;margin-top:6px;border-radius:10px;cursor:pointer;transition:.15s;position:relative;background:rgba(255,255,255,0.04)}
.sidebar-user:hover{background:rgba(255,255,255,0.08)}
.sidebar-user-avatar{width:34px;height:34px;border-radius:50%;background:var(--sv-gold);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:var(--sv-green);flex-shrink:0}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-name{font-size:13px;font-weight:500;color:var(--sv-white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:11px;color:rgba(201,168,76,0.7);margin-top:1px;letter-spacing:0.5px}
.sidebar-user-chevron{flex-shrink:0;transition:.2s}
.sidebar-user.dropdown-open .sidebar-user-chevron{transform:rotate(180deg)}
.sidebar-user-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--sv-border);border-radius:10px;box-shadow:0 -4px 20px rgba(0,0,0,0.25);overflow:hidden;display:none;z-index:500}
.sidebar-user-dropdown.open{display:block}
.sud-item{padding:11px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:var(--sv-text);transition:.12s;border:none;background:none;width:100%;text-align:left;font-family:'Inter',sans-serif}
.sud-item:hover{background:var(--sv-cream)}
.sud-item.sud-danger{color:var(--sv-red);border-top:1px solid var(--sv-border)}
.sud-item.sud-danger:hover{background:rgba(192,57,43,0.06)}
.sud-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--sv-text-muted)}
.sud-item.sud-danger .sud-icon{color:var(--sv-red)}

/* MAIN AREA */
#main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}
#top-bar{height:auto;min-height:72px;background:transparent;border-bottom:none;display:flex;align-items:center;padding:24px 32px 0;gap:16px;flex-shrink:0}
.mobile-menu-btn{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:8px;cursor:pointer}
.mobile-menu-btn:hover{background:var(--sv-cream)}
#top-bar .page-title{font-family:'Inter',sans-serif;font-size:24px;font-weight:600;color:var(--sv-text);flex-shrink:0}
.topbar-search{display:flex;align-items:center;gap:10px;background:var(--sv-white);border:1px solid var(--sv-border);border-radius:24px;padding:11px 20px;max-width:560px;flex:1;margin:0 auto}
.topbar-search input{background:none;border:none;outline:none;font-size:14px;color:var(--sv-text);width:100%;font-family:'Inter',sans-serif}
.topbar-search input::placeholder{color:var(--sv-text-muted)}
.topbar-actions{display:flex;align-items:center;gap:8px;position:relative}
.topbar-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:.15s}
.topbar-btn:hover{background:var(--sv-cream-dark)}
.topbar-badge{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--sv-red);border-radius:50%;border:1.5px solid var(--sv-cream)}
.topbar-user{display:flex;align-items:center;gap:8px;padding:4px;border-radius:24px;cursor:pointer;transition:.15s;position:relative}
.topbar-user:hover{background:var(--sv-cream-dark)}
.topbar-avatar{width:36px;height:36px;border-radius:50%;background:var(--sv-green);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:var(--sv-gold);transition:.15s}
.topbar-user:hover .topbar-avatar{box-shadow:0 0 0 3px rgba(201,168,76,0.2)}
.topbar-user-name{display:none}
.topbar-user-role{display:none}
.topbar-user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--sv-white);border:1px solid var(--sv-border);border-radius:12px;box-shadow:0 8px 24px rgba(30,58,43,0.12);min-width:220px;z-index:300;display:none;overflow:hidden}
.topbar-user-dropdown.open{display:block}
.topbar-user-dropdown .tud-header{padding:14px 16px;border-bottom:1px solid var(--sv-border);background:var(--sv-cream)}
.topbar-user-dropdown .tud-name{font-size:14px;font-weight:600;color:var(--sv-text)}
.topbar-user-dropdown .tud-email{font-size:12px;color:var(--sv-text-muted);margin-top:2px}
.topbar-user-dropdown .tud-item{padding:11px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--sv-text);transition:.12s;border:none;background:none;width:100%;text-align:left;font-family:'Inter',sans-serif}
.topbar-user-dropdown .tud-item:hover{background:var(--sv-cream)}
.topbar-user-dropdown .tud-item.tud-danger{color:var(--sv-red);border-top:1px solid var(--sv-border)}
.topbar-user-dropdown .tud-item.tud-danger:hover{background:rgba(192,57,43,0.06)}
.topbar-user-dropdown .tud-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--sv-text-muted)}
.topbar-user-dropdown .tud-item.tud-danger .tud-icon{color:var(--sv-red)}

#content{flex:1;overflow-y:auto;padding:20px 32px 32px;background:#dbd5c8}

/* MOBILE BOTTOM NAV */
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--sv-cream);border-top:1px solid var(--sv-cream-dark);z-index:200;height:var(--sv-bottom-h)}
#bottom-nav .bn-inner{display:flex;height:100%;padding-bottom:4px}
#bottom-nav .bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;padding-top:4px;position:relative}
#bottom-nav .bn-item .bn-label{font-size:10px;color:var(--sv-text-muted);font-weight:400}
#bottom-nav .bn-item.active .bn-label{color:var(--sv-gold);font-weight:500}
#bottom-nav .bn-item .bn-dot{display:none}
.bn-badge{position:absolute;top:4px;right:calc(50% - 18px);width:7px;height:7px;background:var(--sv-red);border-radius:50%;border:1.5px solid var(--sv-cream)}

/* MOBILE SIDEBAR OVERLAY */
#mobile-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:300}
#mobile-sidebar-overlay.open{display:block}
#sidebar.mobile-open{transform:translateX(0)!important}

/* ───── COMPONENTS ───── */
.page-header{margin-bottom:28px;display:none}
.page-header h1{font-family:'Inter',sans-serif;font-size:24px;font-weight:600;color:var(--sv-text)}
.page-header p{font-size:14px;color:var(--sv-text-muted);margin-top:4px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

.card{background:var(--sv-white);border-radius:14px;border:1px solid var(--sv-border);padding:20px;transition:.2s}
.card-sm{background:var(--sv-white);border-radius:12px;border:1px solid var(--sv-border);padding:16px}
.card-green{background:var(--sv-green);border-radius:14px;padding:20px;position:relative;overflow:hidden}
.card-label{font-size:11px;color:var(--sv-text-muted);letter-spacing:1.5px;text-transform:uppercase;font-weight:400;margin-bottom:8px}
.card-label-white{font-size:11px;color:rgba(201,168,76,0.6);letter-spacing:1.5px;text-transform:uppercase;font-weight:400;margin-bottom:6px}
.card-value{font-family:'Inter',sans-serif;font-size:36px;font-weight:600;color:var(--sv-text);line-height:1}
.card-value-white{font-family:'Inter',sans-serif;font-size:36px;font-weight:600;color:var(--sv-white);line-height:1}
.card-sub{font-size:12px;color:var(--sv-text-muted);margin-top:6px}
.card-sub-gold{font-size:12px;color:rgba(201,168,76,0.7);margin-top:4px}
.card-icon-bg{position:absolute;right:-16px;bottom:-16px;width:80px;height:80px;border-radius:50%;border:1px solid rgba(201,168,76,0.1)}

.stat-up{color:#2D8653;font-size:12px;font-weight:500}
.stat-down{color:var(--sv-red);font-size:12px}

.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500;letter-spacing:0.5px}
.badge-gold{background:rgba(201,168,76,0.12);color:#8B6A1A;border:1px solid rgba(201,168,76,0.3)}
.badge-green{background:rgba(45,82,65,0.1);color:var(--sv-green-mid);border:1px solid rgba(45,82,65,0.2)}
.badge-red{background:rgba(192,57,43,0.08);color:var(--sv-red);border:1px solid rgba(192,57,43,0.2)}
.badge-gray{background:rgba(107,126,114,0.1);color:var(--sv-text-muted);border:1px solid rgba(107,126,114,0.2)}
.badge-blue{background:rgba(44,82,130,0.08);color:#2C5282;border:1px solid rgba(44,82,130,0.2)}

.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.section-title{font-family:'Inter',sans-serif;font-size:18px;font-weight:600;color:var(--sv-text)}
.section-link{font-size:13px;color:var(--sv-text);cursor:pointer;font-weight:500}

.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:.2s;letter-spacing:0.3px}
.btn-primary{background:var(--sv-green);color:var(--sv-white)}
.btn-primary:hover{background:var(--sv-green-mid)}
.btn-gold{background:rgba(201,168,76,0.08);color:#8B6A1A;border:1.5px solid var(--sv-gold)}
.btn-gold:hover{background:rgba(201,168,76,0.15)}
.btn-gold-outline{background:rgba(201,168,76,0.08);color:#8B6A1A;border:1.5px solid var(--sv-gold)}
.btn-gold-outline:hover{background:rgba(201,168,76,0.15)}
.btn-outline{background:var(--sv-white);color:var(--sv-text);border:1px solid var(--sv-border)}
.btn-outline:hover{border-color:var(--sv-text-muted)}
.btn-voir-ag{background:var(--sv-green);color:var(--sv-gold);border:1.5px solid var(--sv-green);padding:9px 28px;font-size:13px;font-weight:600}
.btn-voir-ag:hover{background:#2A4A38;border-color:#2A4A38}
.btn-voir-ag svg{stroke:var(--sv-gold)}
.btn-repondre{background:var(--sv-green);color:var(--sv-gold);border:1.5px solid var(--sv-green);padding:10px 28px;font-size:14px;font-weight:600}
.btn-repondre:hover{background:#2A4A38;border-color:#2A4A38}
.btn-repondre svg{stroke:var(--sv-gold)}
.btn-green-gold{background:var(--sv-green);color:var(--sv-gold);border:1.5px solid var(--sv-green);font-weight:600}
.btn-green-gold:hover{background:#2A4A38;border-color:#2A4A38}
.btn-green-gold svg{stroke:var(--sv-gold)}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-danger{background:rgba(192,57,43,0.08);color:var(--sv-red);border:1px solid rgba(192,57,43,0.2)}

.table-wrap{background:var(--sv-white);border-radius:12px;border:1px solid var(--sv-border);overflow:hidden}
table.sv-table{width:100%;border-collapse:collapse}
table.sv-table th{padding:12px 16px;font-size:11px;font-weight:600;color:var(--sv-text-muted);letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid var(--sv-border);text-align:left;background:var(--sv-cream)}
table.sv-table td{padding:14px 16px;font-size:14px;color:var(--sv-text);border-bottom:1px solid rgba(30,58,43,0.05)}
table.sv-table tr:last-child td{border:none}
table.sv-table tr:hover td{background:rgba(248,247,245,0.7)}

.form-group{margin-bottom:18px}
.form-label{display:block;font-size:12px;font-weight:500;color:var(--sv-text-muted);letter-spacing:0.5px;margin-bottom:6px;text-transform:uppercase}
.form-input{width:100%;padding:11px 14px;background:var(--sv-white);border:1px solid var(--sv-border);border-radius:8px;font-size:14px;color:var(--sv-text);outline:none;transition:.2s}
.form-input:focus{border-color:var(--sv-green);box-shadow:0 0 0 3px rgba(30,58,43,0.08)}
.form-select{width:100%;padding:11px 38px 11px 14px;background:var(--sv-white) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%236B7E72' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 14px center;border:1px solid var(--sv-border);border-radius:8px;font-size:14px;color:var(--sv-text);outline:none;appearance:none;cursor:pointer}
.form-textarea{width:100%;padding:11px 14px;background:var(--sv-white);border:1px solid var(--sv-border);border-radius:8px;font-size:14px;color:var(--sv-text);outline:none;resize:vertical;min-height:90px}
.radio-group{display:flex;flex-direction:column;gap:10px}
.radio-option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid var(--sv-border);border-radius:8px;cursor:pointer;transition:.15s}
.radio-option:hover,.radio-option.selected{border-color:var(--sv-green);background:rgba(30,58,43,0.03)}
.radio-option input[type=radio]{margin-top:1px;accent-color:var(--sv-green)}
.radio-option .ro-label{font-size:14px;color:var(--sv-text);font-weight:400}
.radio-option .ro-sub{font-size:12px;color:var(--sv-text-muted);margin-top:2px}

.upload-zone{display:block;border:2px dashed rgba(30,58,43,0.2);border-radius:10px;padding:28px;text-align:center;cursor:pointer;transition:.2s;position:relative}
.upload-zone:hover{border-color:var(--sv-gold);background:var(--sv-gold-pale)}
.upload-zone input[type=file]{position:absolute;width:0.1px;height:0.1px;opacity:0;overflow:hidden;z-index:-1}
.upload-zone.has-file{border-style:solid;border-color:var(--sv-gold);background:var(--sv-gold-pale)}
.upload-zone .uz-icon{font-size:24px;margin-bottom:8px}
.upload-zone .uz-label{font-size:14px;color:var(--sv-text-muted);font-weight:400}
.upload-zone .uz-sub{font-size:12px;color:var(--sv-text-light);margin-top:4px}
.upload-zone .uz-filename{font-size:13px;color:var(--sv-gold);font-weight:500;margin-top:6px;display:none}
.upload-zone.has-file .uz-filename{display:block}
.upload-zone.has-file .uz-sub{display:none}

.alert-banner{border-radius:10px;padding:14px 16px;display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}
.alert-warning{background:rgba(201,168,76,0.1);border:1px solid rgba(201,168,76,0.25)}
.alert-info{background:rgba(44,82,130,0.06);border:1px solid rgba(44,82,130,0.15)}
.alert-danger{background:rgba(192,57,43,0.07);border:1px solid rgba(192,57,43,0.2)}

.divider{height:1px;background:var(--sv-border);margin:20px 0}

.tag-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:500}

.progress-bar{height:6px;background:rgba(30,58,43,0.08);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:var(--sv-gold);border-radius:3px;transition:.4s}

/* Chart cards */
.chart-card{background:var(--sv-white);border-radius:14px;border:1px solid var(--sv-border);padding:20px;display:flex;flex-direction:column;min-width:0}
.chart-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.chart-card-title{font-size:14px;font-weight:600;color:var(--sv-text)}
.chart-card-sub{font-size:12px;color:var(--sv-text-muted);margin-top:2px;font-weight:300}
.chart-period{font-size:12px;color:var(--sv-text-muted);background:var(--sv-cream);padding:4px 10px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.chart-period:hover{color:var(--sv-text);background:var(--sv-cream-dark)}
.chart-canvas-wrap{position:relative;height:220px;width:100%;margin-top:14px;min-width:0}
.chart-canvas-wrap canvas{max-width:100%!important}
.chart-legend{display:flex;gap:14px;margin-top:12px;flex-wrap:wrap;font-size:12px;color:var(--sv-text-muted)}
.chart-legend-item{display:flex;align-items:center;gap:6px}
.chart-legend-dot{width:8px;height:8px;border-radius:2px}
.chart-legend-dot.line{height:3px;border-radius:2px;width:14px}
.chart-legend-dot.donut{border-radius:50%}
.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}
.donut-center-val{font-size:24px;font-weight:600;color:var(--sv-text);line-height:1}
.donut-center-lbl{font-size:11px;color:var(--sv-text-muted);margin-top:4px;line-height:1.2}

/* ── Mes GFV : bloc distinct + header vert foncé ── */
.gfv-block{border:1px solid var(--sv-border);box-shadow:0 1px 3px rgba(30,58,43,0.05)}
.gfv-block-header{background:var(--sv-green);border-bottom:none;align-items:flex-start;padding:16px 20px}
.gbt-region{font-size:12px;color:var(--sv-gold);letter-spacing:2px;text-transform:uppercase;font-weight:600}
.gbt-aoc{font-size:13px;color:var(--sv-text-muted);margin-top:3px}
.gbt-name{font-family:'Inter',sans-serif;font-size:16px;color:var(--sv-gold);font-weight:600;margin-top:3px;line-height:1.3}
.gfv-next-ag{text-align:right;flex-shrink:0;background:rgba(201,168,76,0.18);border:1px solid rgba(201,168,76,0.4);border-radius:10px;padding:8px 12px}
.gfv-next-ag .gna-label{font-size:10px;color:var(--sv-gold-light);text-transform:uppercase;letter-spacing:1px}
.gfv-next-ag .gna-date{font-size:14px;color:#8B6A1A;font-weight:600;margin-top:2px}
.parts-block{margin-top:16px}
.parts-title{font-size:13px;font-weight:600;color:var(--sv-text);margin-bottom:8px}
.parts-table th {text-align:right} !important
.parts-table td{text-align:right} !important
.parts-table td.pc-name{font-weight:500}
.gfv-docs{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.doc-family{display:inline-flex;align-items:center;gap:6px;background:var(--sv-cream);border:1px solid var(--sv-border);border-radius:8px;padding:4px 6px 4px 10px}
.doc-family .df-label{font-size:12px;color:var(--sv-text-muted);font-weight:500}
.doc-family .df-select{width:auto;padding:5px 8px;font-size:13px;border:none;background:transparent}
.doc-family .df-dl{padding:5px 8px}

/* ── Documents : filtres latéraux ── */
.docs-layout{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:start}
.docs-filters{display:flex;flex-direction:column;gap:18px;background:var(--sv-white);border:1px solid var(--sv-border);border-radius:14px;padding:18px}
.df-group-label{font-size:11px;font-weight:600;color:var(--sv-text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.docs-cat{display:block;width:100%;text-align:left;background:transparent;border:1px solid transparent;border-radius:8px;padding:8px 12px;font-size:14px;color:var(--sv-text-muted);cursor:pointer;transition:.15s;margin-bottom:2px}
.docs-cat:hover{background:var(--sv-cream-dark)}
.docs-cat.active{background:var(--sv-gold-pale);border-color:rgba(201,168,76,0.3);color:var(--sv-text);font-weight:500}
.docs-empty{padding:24px;text-align:center;font-size:14px;color:var(--sv-text-muted)}

/* ── AG à venir ── */
.ag-block{padding:0;overflow:hidden}
.ag-block-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px 14px;background:var(--sv-white);border-bottom:1px solid var(--sv-border);flex-wrap:wrap}
.ag-block-top .gbt-aoc{color:var(--sv-text-muted)}
.ag-block-top h2{color:var(--sv-text);font-size:16px}
.ag-status{display:inline-flex;align-items:center;gap:6px;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;white-space:nowrap}
.ag-status .as-dot{width:7px;height:7px;border-radius:50%}
.ag-status-req{background:rgba(192,57,43,0.15);color:#ff9d92;border:1px solid rgba(192,57,43,0.4)}
.ag-status-req .as-dot{background:#ff6b5b}
.ag-status-ok{background:rgba(45,134,83,0.18);color:#7fd1a3;border:1px solid rgba(45,134,83,0.4)}
.ag-status-ok .as-dot{background:#2D8653}
.ag-when{display:flex;gap:14px;flex-wrap:wrap;padding:16px 20px;background:var(--sv-cream)}
.aw-item{flex:1;min-width:120px}
.aw-item.aw-lieu{flex:2;min-width:200px}
.aw-label{font-size:11px;color:var(--sv-text-muted);text-transform:uppercase;letter-spacing:1px}
.aw-value{font-family:'Inter',sans-serif;font-size:20px;font-weight:600;color:var(--sv-text);margin-top:3px;line-height:1.2}
.aw-item.aw-lieu .aw-value{font-size:15px;font-weight:500}
.ag-contacts{padding:14px 20px 0;display:flex;flex-direction:column;gap:6px}
.ag-contact{font-size:13px;color:var(--sv-text-muted)}
.ag-contact .ac-title{font-weight:600;color:var(--sv-text)}
.ag-deadline{font-size:13px;color:var(--sv-red);font-weight:500;margin-top:2px}
.ag-action{padding:14px 20px 20px}
.ag-replied{font-size:14px;color:var(--sv-text)}
.ag-replied-date{font-size:12px;color:var(--sv-text-light);margin-top:4px}
.ag-form-slot{padding:0 20px}
.ag-form-slot:not(:empty){padding-bottom:8px}

/* ── La Société ── */
.schema-gfv{display:flex;flex-direction:column;gap:12px}
.schema-step{display:flex;gap:12px;align-items:flex-start}
.schema-num{width:28px;height:28px;border-radius:50%;background:var(--sv-gold-pale);border:1px solid rgba(201,168,76,0.4);color:#8B6A1A;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
.schema-t{font-size:14px;font-weight:600;color:var(--sv-text)}
.schema-d{font-size:13px;color:var(--sv-text-muted);margin-top:2px}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(26,46,34,0.55);backdrop-filter:blur(2px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-box{background:#fff;border-radius:16px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.3);animation:modalIn .2s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--sv-border)}
.modal-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--sv-text)}
.modal-title svg{color:var(--sv-gold)}
.modal-close{background:none;border:none;font-size:26px;line-height:1;color:var(--sv-text-muted);cursor:pointer;padding:0 4px;transition:.15s}
.modal-close:hover{color:var(--sv-text)}
.modal-body{padding:20px 24px}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--sv-border);background:var(--sv-cream)}

/* ── FAQ ── */
.faq-intro{background:linear-gradient(135deg,var(--sv-green) 0%,#2A4A38 100%);border-radius:14px;padding:24px 26px;margin-bottom:24px;color:#fff;position:relative;overflow:hidden}
.faq-intro::after{content:'';position:absolute;top:-30px;right:-20px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,0.18) 0%,transparent 70%)}
.faq-intro h3{font-size:22px;font-weight:600;margin-bottom:6px;position:relative}
.faq-intro p{font-size:14px;color:rgba(255,255,255,0.75);position:relative;max-width:520px}
.faq-cat{margin-bottom:24px}
.faq-cat-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--sv-gold);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;padding-left:2px}
.faq-cat-title svg{width:16px;height:16px}
.faq-item{background:var(--sv-white);border:1px solid var(--sv-border);border-radius:10px;margin-bottom:10px;overflow:hidden;transition:.2s}
.faq-item:hover{border-color:rgba(201,168,76,0.4)}
.faq-item[open]{border-color:rgba(201,168,76,0.5);box-shadow:0 2px 12px rgba(30,58,43,0.06)}
.faq-item summary{padding:16px 18px;cursor:pointer;font-size:15px;font-weight:500;color:var(--sv-text);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item[open] summary{color:var(--sv-gold)}
.faq-plus{color:var(--sv-gold);font-size:20px;transition:.25s;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--sv-gold-pale);border-radius:50%}
.faq-item[open] .faq-plus{transform:rotate(45deg)}
.faq-answer{padding:0 18px 16px;font-size:14px;color:var(--sv-text-muted);border-top:1px solid var(--sv-border);padding-top:14px;line-height:1.6}
.faq-contact{background:var(--sv-cream);border:1px solid var(--sv-border);border-radius:14px;padding:24px;text-align:center;margin-top:8px}
.faq-contact-icon{width:48px;height:48px;border-radius:50%;background:var(--sv-gold-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.faq-contact h4{font-size:16px;font-weight:600;color:var(--sv-text);margin-bottom:4px}
.faq-contact p{font-size:14px;color:var(--sv-text-muted);margin-bottom:14px}

/* ── Offres ── */
.offer-card{padding:0;overflow:hidden;margin-bottom:16px;display:flex;align-items:stretch}
.offer-video{width:320px;flex-shrink:0;align-self:stretch;min-height:180px;background:linear-gradient(135deg,var(--sv-green),var(--sv-green-light));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:rgba(255,255,255,0.85);font-size:13px}
.offer-video-play{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.4);display:flex;align-items:center;justify-content:center}
.offer-video-play svg path{stroke:#fff}
.offer-body{padding:20px 24px;flex:1;display:flex;flex-direction:column;justify-content:center}
.offer-title{font-family:'Inter',sans-serif;font-size:16px;font-weight:600;color:var(--sv-text);margin-bottom:8px}
.offer-desc{font-size:14px;color:var(--sv-text-muted);line-height:1.6;margin-bottom:16px}

/* ── Rencontres Saint-Vincent ── */
.sv-event-card{border-left:4px solid var(--sv-gold)}
.sv-event-badge{display:inline-flex;align-items:center;gap:6px;background:var(--sv-gold-pale);border:1px solid rgba(201,168,76,0.4);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;color:#8B6A1A;margin-bottom:12px}
.sv-event-badge svg path{stroke:#8B6A1A}
.sv-event-title{font-family:'Inter',sans-serif;font-size:20px;font-weight:600;color:var(--sv-text);margin-bottom:8px}
.sv-event-desc{font-size:14px;color:var(--sv-text-muted);line-height:1.6;max-width:640px}

/* ── Profil : photo ── */
.photo-block{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--sv-border)}
.photo-block.has-photo .photo-avatar{width:56px;height:56px;border-radius:50%;background:var(--sv-green);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:22px;font-weight:600;color:var(--sv-gold);flex-shrink:0}
.photo-placeholder{width:56px;height:56px;border-radius:50%;border:2px dashed rgba(30,58,43,0.25);display:flex;align-items:center;justify-content:center;color:var(--sv-text-light);cursor:pointer;flex-shrink:0}
.photo-placeholder:hover{border-color:var(--sv-gold);color:var(--sv-gold)}
.photo-pitch .pp-title{font-size:14px;font-weight:600;color:var(--sv-text)}
.photo-pitch .pp-sub{font-size:13px;color:var(--sv-text-muted);margin-top:3px;line-height:1.5}

@media(max-width:900px){
  .offer-card{flex-direction:column}
  .offer-video{width:100%;align-self:auto;min-height:150px;order:-1}
  .docs-layout{grid-template-columns:1fr}
  .docs-filters{flex-direction:column;gap:16px}
  .docs-filters .df-group{flex:1;min-width:0}
  .docs-cat{display:inline-block;width:auto}
  .chart-canvas-wrap{height:200px}
  .chart-card{padding:16px}
  /* Catégorie en select sur mobile (les boutons sont masqués au profit du select) */
  .df-group-cat-buttons{display:none}
  .df-group-cat-select{display:block}
  /* Document item : nom en haut pleine largeur, puis icône + infos + téléchargement */
  .doc-item{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"name name name" "icon meta dl";column-gap:12px;row-gap:6px;align-items:center}
  .doc-item .doc-name{grid-area:name;margin-bottom:0;font-size:15px;line-height:1.35;word-break:break-space;white-space:normal;}
  .doc-item .doc-icon{grid-area:icon;width:36px;height:36px}
  .doc-item .doc-info{grid-area:meta;min-width:0}
  .doc-item .doc-meta{white-space:normal;word-break:break-word}
  .doc-item .badge{display:none}
  .doc-item .doc-year{display:none}
  .doc-item .doc-dl{grid-area:dl}
}
@media(min-width:901px){
  .df-group-cat-select{display:none}
}
@media(max-width:520px){
  .chart-canvas-wrap{height:180px}
}
.gfv-card{background:var(--sv-white);border-radius:14px;border:1px solid var(--sv-border);overflow:hidden;margin-bottom:14px}
.gfv-card-header{background:var(--sv-white);padding:18px 20px 14px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--sv-border)}
.gfv-card-header .gch-tag{font-size:12px;color:var(--sv-text-muted);margin-bottom:4px;font-weight:400;letter-spacing:0}
.gfv-card-header .gch-name{font-family:'Inter',sans-serif;font-size:15px;color:var(--sv-text);font-weight:600;max-width:300px;line-height:1.3}
.gfv-chip{background:transparent;border:1.5px solid var(--sv-text);border-radius:30px;padding:6px 14px;text-align:right;flex-shrink:0;white-space:nowrap}
.gfv-chip .gc-val{font-size:14px;font-weight:600;color:var(--sv-text);display:inline}
.gfv-chip .gc-lbl{font-size:13px;color:var(--sv-text);font-weight:400;display:inline;margin-left:4px}
.gfv-card-body{padding:16px 20px}
.gfv-stats{display:flex;gap:0;margin-bottom:14px}
.gfv-stat{flex:1;text-align:center;padding:12px 8px;background:var(--sv-cream);border:1px solid var(--sv-border);position:relative}
.gfv-stat:first-child{border-radius:8px 0 0 8px}
.gfv-stat:last-child{border-radius:0 8px 8px 0}
.gfv-stat+.gfv-stat{border-left:none}
.gfv-stat .gs-label{font-size:11px;color:var(--sv-text-muted);display:block;margin-bottom:4px;font-weight:400}
.gfv-stat .gs-val{font-size:14px;font-weight:600;color:var(--sv-text)}
.gfv-stat .gs-val.gold{color:var(--sv-gold)}
.gfv-stat .gs-val.red{color:var(--sv-red)}
.gfv-contacts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gfv-contact{background:var(--sv-cream);border-radius:8px;padding:12px}
.gfv-contact .gc-title{font-size:10px;color:var(--sv-text-muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;font-weight:500}
.gfv-contact .gc-name{font-size:17px;font-weight:600;color:var(--sv-text);margin-bottom:2px}
.gfv-contact .gc-detail{font-size:15px;color:var(--sv-text-muted)}

/* Doc item */
.doc-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid rgba(30,58,43,0.06)}
.doc-item:last-child{border:none}
.doc-icon{width:40px;height:40px;border-radius:10px;background:var(--sv-gold-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.doc-info{flex:1}
.doc-name{font-size:14px;font-weight:500;color:var(--sv-text);margin-bottom:2px}
.doc-meta{font-size:12px;color:var(--sv-text-muted)}
.doc-year{font-size:11px;color:var(--sv-gold);font-weight:500;background:var(--sv-gold-pale);padding:3px 8px;border-radius:20px}
.doc-dl{width:32px;height:32px;border-radius:8px;border:1px solid var(--sv-border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:.15s}
.doc-dl:hover{background:var(--sv-cream);border-color:var(--sv-gold)}

/* AG card */
.ag-upcoming{background:var(--sv-white);border-radius:14px;padding:20px;margin-bottom:20px;position:relative;border:1px solid var(--sv-border);border-left:4px solid var(--sv-gold)}
.ag-upcoming::after{display:none}
.ag-upcoming .au-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(201,168,76,0.12);border:1px solid rgba(201,168,76,0.35);border-radius:20px;padding:4px 12px;margin-bottom:12px}
.au-badge .ab-dot{width:6px;height:6px;border-radius:50%;background:var(--sv-gold)}
.au-badge span{font-size:10px;color:#8B6A1A;letter-spacing:1.5px;text-transform:uppercase}
.ag-upcoming h2{font-family:'Inter',sans-serif;font-size:18px;color:var(--sv-gold);font-weight:600;margin-bottom:4px}
.ag-upcoming p{font-size:13px;color:var(--sv-text-muted);margin-bottom:14px}
.ag-meta{display:flex;gap:20px;margin-bottom:16px;flex-wrap:wrap}
.ag-meta-item .am-label{font-size:10px;color:var(--sv-text-muted);text-transform:uppercase;letter-spacing:1px}
.ag-meta-item .am-value{font-size:13px;color:var(--sv-text);margin-top:2px;font-weight:500}

/* Status indicators */
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.status-green{background:#2D8653}
.status-orange{background:#E08631}
.status-red{background:var(--sv-red)}
.status-gray{background:var(--sv-text-light)}

/* Toggle switch */
.toggle{display:flex;align-items:center;gap:8px}
.toggle input{display:none}
.toggle-track{width:36px;height:20px;background:var(--sv-border);border-radius:10px;position:relative;cursor:pointer;transition:.2s}
.toggle input:checked+.toggle-track{background:var(--sv-green)}
.toggle-track::after{content:'';width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:.2s}
.toggle input:checked+.toggle-track::after{left:18px}

/* Trombinoscope */
.trombi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.trombi-card{background:var(--sv-white);border-radius:12px;border:1px solid var(--sv-border);padding:16px;text-align:center;transition:.2s}
.trombi-card:hover{border-color:var(--sv-gold);box-shadow:0 2px 12px rgba(201,168,76,0.1)}
.trombi-avatar{width:48px;height:48px;border-radius:50%;background:var(--sv-green);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:18px;font-weight:600;color:var(--sv-gold);margin:0 auto 10px}
.trombi-name{font-size:13px;font-weight:500;color:var(--sv-text);margin-bottom:2px}
.trombi-parts{font-size:11px;color:var(--sv-text-muted)}
.trombi-type{font-size:11px;color:var(--sv-gold);margin-top:4px}

/* Audit log */
.log-item{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid rgba(30,58,43,0.05)}
.log-item:last-child{border:none}
.log-time{font-size:12px;color:var(--sv-text-muted);white-space:nowrap;width:80px;flex-shrink:0;padding-top:1px}
.log-dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex-shrink:0}
.log-text{font-size:13px;color:var(--sv-text)}
.log-sub{font-size:12px;color:var(--sv-text-muted);margin-top:2px}

/* Responsive */
@media(max-width:900px){
  /* Lighter background on mobile to match graphiste reference */
  html,body{background:#dbd5c8}
  #content{background:#dbd5c8}
  #bottom-nav{background:#F8F7F5;border-top:1px solid #EEECE8;box-shadow:0 -20px 24px -8px rgba(255,255,255,0.95),0 -4px 12px rgba(255,255,255,0.6)}
  #sidebar{position:fixed;left:0;top:0;bottom:0;z-index:400;transform:translateX(-100%);transition:.3s}
  .mobile-menu-btn{display:flex}
  #bottom-nav{display:block}
  #content{padding:20px 16px;padding-bottom:calc(var(--sv-bottom-h) + 20px)}
  .grid-3{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .topbar-search{display:none}
  .topbar-user-name,.topbar-user-role{display:none}
  /* Hide entire topbar on mobile */
  #top-bar{display:none}
  /* Remove top padding since no topbar */
  #main-area{padding-top:0}
  /* Mobile page title bar removed — each screen has its own page-header h1 */
  .mob-page-title{display:none}
  /* Dashboard: green header starts flush from top */
  .mob-dash-header{margin-top:-20px}
  table.sv-table th:nth-child(n+4),table.sv-table td:nth-child(n+4){display:none}
  .gfv-contacts{grid-template-columns:1fr}
  /* Mobile green dashboard header */
  .mob-dash-header{display:flex;flex-direction:column;background:var(--sv-green);margin:-20px -16px 24px;padding:16px 16px 24px;border-radius:0 0 20px 20px}
  .mob-dash-logo{display:flex;justify-content:center;margin-bottom:18px}
  .mob-dash-logo svg{width:200px;height:auto}
  .mob-dash-user{display:flex;align-items:center;gap:10px}
  .mob-dash-avatar{width:38px;height:38px;border-radius:50%;background:var(--sv-gold);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:var(--sv-green);flex-shrink:0}
  .mob-dash-hello{font-size:11px;color:rgba(255,255,255,0.5);font-weight:300;margin-bottom:2px}
  .mob-dash-name{font-size:15px;font-weight:600;color:var(--sv-white)}
  .mob-dash-bell{margin-left:auto;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer}
  .mob-dash-bell-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;background:var(--sv-gold);border-radius:50%;border:1.5px solid var(--sv-green)}
  /* Mobile search bar */
  .mob-search{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.15);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:8px;margin-top:14px}
  .mob-search input{background:none;border:none;outline:none;font-size:14px;color:rgba(255,255,255,0.8);width:100%;font-family:'Inter',sans-serif}
  .mob-search input::placeholder{color:rgba(255,255,255,0.45)}
  .mob-page-search{display:flex;align-items:center;gap:8px;background:var(--sv-white);border:1px solid var(--sv-border);border-radius:24px;padding:11px 16px;margin-bottom:18px}
  .mob-page-search input{background:none;border:none;outline:none;font-size:14px;color:var(--sv-text);width:100%;font-family:'Inter',sans-serif}
  .mob-page-search input::placeholder{color:var(--sv-text-muted)}
  /* GFV stats 2×2 on mobile */
  .gfv-stats{flex-wrap:wrap}
  .gfv-stat{width:50%!important;min-width:50%!important;flex:none!important}
  .gfv-stat:first-child{border-radius:8px 0 0 0!important}
  .gfv-stat:nth-child(2){border-radius:0 8px 0 0!important;border-left:none!important}
  .gfv-stat:nth-child(3){border-radius:0 0 0 8px!important;border-top:none!important}
  .gfv-stat:nth-child(4){border-radius:0 0 8px 0!important;border-top:none!important;border-left:none!important}
  /* Mobile menu screen */
  .mob-menu-screen{padding:0}
  .mob-menu-header{background:var(--sv-green);padding:24px 20px 20px;border-radius:0 0 20px 20px;margin:-20px -16px 0}
  .mob-menu-logo{display:flex;justify-content:center;margin-bottom:20px}
  .mob-menu-logo svg{width:130px;height:auto}
  .mob-menu-profile{background:rgba(255,255,255,0.08);border:1px solid rgba(201,168,76,0.2);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:10px}
  .mob-menu-av{width:36px;height:36px;border-radius:50%;background:var(--sv-gold);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--sv-green);flex-shrink:0}
  .mob-menu-role{font-size:10px;color:rgba(201,168,76,0.6);letter-spacing:1.5px;text-transform:uppercase}
  .mob-menu-name{font-size:14px;color:var(--sv-white);font-weight:500}
  .mob-menu-nav{padding:20px 0 0}
  .mob-menu-nav-label{font-size:10px;color:var(--sv-text-muted);letter-spacing:2px;text-transform:uppercase;padding:0 4px 10px;font-weight:400}
  .mob-menu-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:10px;cursor:pointer;transition:.15s;margin-bottom:4px}
  .mob-menu-item:hover{background:var(--sv-cream-dark)}
  .mob-menu-item.active{background:rgba(201,168,76,0.1);border:1px solid rgba(201,168,76,0.2)}
  .mob-menu-item .mmi-icon{color:var(--sv-text-muted)}
  .mob-menu-item.active .mmi-icon{color:var(--sv-gold)}
  .mob-menu-item .mmi-label{font-size:14px;color:var(--sv-text);font-weight:400}
  .mob-menu-item.active .mmi-label{color:var(--sv-text);font-weight:500}
  .mob-menu-item .mmi-badge{margin-left:auto;background:var(--sv-red);color:#fff;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px}
  .mob-menu-item .mmi-badge.mmi-badge-gold{background:var(--sv-gold);color:var(--sv-green)}
  .mob-menu-logout{margin-top:8px;border-top:1px solid var(--sv-border);padding-top:16px!important;border-radius:0!important}
  .mob-menu-logout .mmi-icon{color:var(--sv-red)!important}
  .mob-menu-logout .mmi-label{color:var(--sv-red)!important}
  .mob-menu-logout:hover{background:rgba(192,57,43,0.06)!important}
  .mob-menu-support{display:flex;align-items:center;gap:10px;padding:14px;border-top:1px solid var(--sv-border);margin-top:8px;color:var(--sv-text-muted);font-size:14px;cursor:pointer}
}
@media(max-width:520px){
  .grid-4{grid-template-columns:1fr 1fr!important}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .ag-meta{flex-direction:column;gap:10px}
}
/* Hide mobile-only elements on desktop */
@media(min-width:901px){
  .mob-dash-header,.mob-menu-screen,.mob-page-title,.mob-search,.mob-page-search{display:none!important}
}
/* Hide desktop page-header on mobile dashboard (green header replaces it) */
@media(max-width:900px){
  .page-header{display:block}
  .mob-dash-header + .page-header{display:none}
  /* Hide page-header subtitles on mobile - title only */
  .page-header p{display:none}
  .page-header{margin-bottom:20px}
