/* ═══════════════════════════════════════════
   ListingPanel — Complete Styles
   ═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
    --bg:#f4f5f9;--card-bg:#fff;--card-border:rgba(0,0,0,.05);--card-shadow:0 1px 3px rgba(0,0,0,.03);
    --sidebar-bg:#fff;--sidebar-border:rgba(0,0,0,.06);--header-bg:#fff;--header-border:rgba(0,0,0,.06);
    --text:#1a1a2e;--text-secondary:#5a5a72;--text-muted:#8e8ea0;--text-faint:#b0b0c0;
    --input-bg:#fafafe;--input-border:#e5e5ee;--input-focus-bg:#fff;
    --search-bg:#f8f8fc;--search-border:#eeeef4;--kbd-bg:#f0f0f8;--kbd-border:#e8e8f0;--kbd-text:#a0a0b8;
    --clock-bg:#f8f8fc;--clock-border:#eeeef4;--divider:#e0e0ea;--divider-light:rgba(0,0,0,.04);
    --nav-text:#6b6b80;--section-label:#b0b0c0;--badge-bg:#ef4444;
    --logout-bg:rgba(239,68,68,.06);--logout-text:#ef4444;
    --scroll-thumb:#d8d8e8;--scroll-thumb-hover:#b8b8cc;
    --login-bg:linear-gradient(145deg,#f8f9fc,#eef0f5 40%,#e8eaf0);
    --login-deco-a:rgba(99,102,241,.06);--login-deco-b:rgba(16,185,129,.05);
    --announce-bg:rgba(99,102,241,.04);--announce-border:rgba(99,102,241,.08);
    --announce-new:rgba(99,102,241,.1);--announce-new-text:#6366f1;
    --stat-up-bg:rgba(16,185,129,.08);--stat-down-bg:rgba(239,68,68,.08);
    --notif-bg:#f8f8fc;--notif-border:#eeeef4;--toggle-bg:#f0f0f8;--toggle-border:#e0e0ea;
    --primary:#6366f1;--primary-dark:#4f46e5;--modal-overlay:rgba(0,0,0,.45);
}
[data-theme="dark"] {
    --bg:#0f1117;--card-bg:#181a23;--card-border:rgba(255,255,255,.06);--card-shadow:0 1px 4px rgba(0,0,0,.3);
    --sidebar-bg:#14161f;--sidebar-border:rgba(255,255,255,.06);--header-bg:#14161f;--header-border:rgba(255,255,255,.06);
    --text:#e8e8f0;--text-secondary:#a0a0b8;--text-muted:#6e6e88;--text-faint:#4e4e66;
    --input-bg:#1e2030;--input-border:#2a2c3e;--input-focus-bg:#22243a;
    --search-bg:#1a1c2a;--search-border:#262840;--kbd-bg:#22243a;--kbd-border:#2e3048;--kbd-text:#6e6e88;
    --clock-bg:#1a1c2a;--clock-border:#262840;--divider:#2a2c3e;--divider-light:rgba(255,255,255,.04);
    --nav-text:#7e7e98;--section-label:#4e4e66;
    --logout-bg:rgba(239,68,68,.1);--logout-text:#f87171;
    --scroll-thumb:#2a2c3e;--scroll-thumb-hover:#3a3c52;
    --login-bg:linear-gradient(145deg,#0f1117,#141620 40%,#181a28);
    --login-deco-a:rgba(99,102,241,.08);--login-deco-b:rgba(16,185,129,.06);
    --announce-bg:rgba(99,102,241,.06);--announce-border:rgba(99,102,241,.12);
    --announce-new:rgba(99,102,241,.15);--announce-new-text:#818cf8;
    --stat-up-bg:rgba(16,185,129,.12);--stat-down-bg:rgba(239,68,68,.12);
    --notif-bg:#1a1c2a;--notif-border:#262840;--toggle-bg:#1e2030;--toggle-border:#2a2c3e;
    --modal-overlay:rgba(0,0,0,.7);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
img{max-width:100%;height:auto}
body{background:var(--bg);font-family:'Plus Jakarta Sans',sans-serif;color:var(--text);transition:background .4s,color .4s;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--scroll-thumb-hover)}
input::placeholder{color:var(--text-faint)!important}button{font-family:inherit}button:hover{filter:brightness(.97)}a{text-decoration:none;color:inherit}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238e8ea0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}50%{transform:translateX(6px)}75%{transform:translateX(-4px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeUp .5s cubic-bezier(.16,1,.3,1) both}.shake{animation:shake .4s ease-in-out}

/* ═══ LOGIN ═══ */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--login-bg);position:relative;overflow:hidden;transition:background .4s}
.login-deco{position:absolute;border-radius:50%;pointer-events:none}
.login-deco--a{top:-120px;right:-120px;width:400px;height:400px;background:radial-gradient(circle,var(--login-deco-a),transparent 70%)}
.login-deco--b{bottom:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle,var(--login-deco-b),transparent 70%)}
.login-deco--square{position:absolute;top:40%;right:10%;width:80px;height:80px;border:1px solid var(--login-deco-a);border-radius:20px;transform:rotate(45deg);pointer-events:none}
.login-wrapper{width:420px;max-width:92vw;padding:0 20px}
.login-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 8px 32px rgba(99,102,241,.25);margin-bottom:20px}
.login-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:26px;color:var(--text);letter-spacing:-.5px}
.login-subtitle{color:var(--text-muted);font-size:14px;margin-top:8px}
.login-card{background:var(--card-bg);border-radius:20px;padding:36px 32px 32px;box-shadow:var(--card-shadow);border:1px solid var(--card-border);transition:background .4s,border .4s}
.login-card h2{font-family:'Outfit',sans-serif;font-weight:700;font-size:20px;color:var(--text);margin-bottom:4px}
.login-card .login-desc{color:var(--text-muted);font-size:13px;margin-bottom:28px}

.form-label{display:block;font-family:'Outfit',sans-serif;font-weight:600;font-size:12.5px;color:var(--text-secondary);margin-bottom:8px;letter-spacing:.3px}
.form-input{width:100%;padding:13px 16px;border-radius:12px;border:1.5px solid var(--input-border);background:var(--input-bg);font-size:14px;font-family:'Plus Jakarta Sans',sans-serif;color:var(--text);outline:none;transition:all .2s}
.form-input:focus{border-color:#6366f1;background:var(--input-focus-bg);box-shadow:0 0 0 3px rgba(99,102,241,.08)}
.form-input--pw{padding-right:48px}
.form-textarea{resize:vertical;min-height:60px;line-height:1.6}
.form-group{margin-bottom:16px}
.pw-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-faint);padding:0;display:flex}
.btn-login{width:100%;padding:14px 24px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;box-shadow:0 4px 16px rgba(99,102,241,.3);transition:all .25s;display:flex;align-items:center;justify-content:center;gap:10px}
.btn-login:disabled{background:linear-gradient(135deg,#a5a6f6,#8b8bf0);cursor:default}
.btn-login .spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.theme-toggle-login{position:absolute;top:24px;right:28px;z-index:10}

.alert{padding:12px 16px;border-radius:10px;font-size:13px;margin-bottom:20px;font-weight:500}
.alert--error{background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.15)}
.alert--success{background:rgba(16,185,129,.08);color:#10b981;border:1px solid rgba(16,185,129,.15)}

/* ═══ THEME TOGGLE ═══ */
.theme-toggle{position:relative;width:52px;height:28px;border-radius:14px;background:var(--toggle-bg);border:1px solid var(--toggle-border);cursor:pointer;padding:0;transition:all .3s;flex-shrink:0}
[data-theme="dark"] .theme-toggle{background:linear-gradient(135deg,#4f46e5,#6366f1);border-color:rgba(99,102,241,.3)}
.theme-toggle__knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.1);transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;color:#f59e0b}
[data-theme="dark"] .theme-toggle__knob{left:26px;background:#1a1a2e;box-shadow:0 1px 4px rgba(0,0,0,.4);color:#fbbf24}

/* ═══ PANEL LAYOUT ═══ */
.panel-layout{display:flex;height:100vh;overflow:hidden;background:var(--bg);transition:background .4s}

/* ─── Sidebar ─── */
.sidebar{width:280px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;transition:width .3s cubic-bezier(.16,1,.3,1),background .4s;flex-shrink:0;overflow:hidden;z-index:20}
.sidebar.collapsed{width:84px}
.sidebar__logo{padding:22px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--divider-light);flex-shrink:0}
.sidebar.collapsed .sidebar__logo{padding:22px 12px;justify-content:center}
.sidebar__logo-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#4f46e5);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar__logo-text{font-family:'Outfit',sans-serif;font-weight:800;font-size:20px;color:var(--text)}
.sidebar__logo-sub{font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;color:var(--text-faint);font-weight:500;letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.sidebar.collapsed .sidebar__logo-info{display:none}

.sidebar__nav{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:3px;overflow-y:auto}
.sidebar.collapsed .sidebar__nav{padding:16px 10px}
.sidebar__section-label{font-family:'Outfit',sans-serif;font-weight:600;font-size:12px;color:var(--section-label);letter-spacing:1.2px;text-transform:uppercase;padding:8px 14px;margin-bottom:4px}
.sidebar.collapsed .sidebar__section-label{display:none}

.nav-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:12px;border:none;cursor:pointer;background:transparent;color:var(--nav-text);font-family:'Outfit',sans-serif;font-weight:600;font-size:15.5px;width:100%;text-align:left;transition:all .2s}
.sidebar.collapsed .nav-item{padding:11px;justify-content:center}
.nav-item.active{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:600;box-shadow:0 4px 12px rgba(99,102,241,.2)}
.nav-item__label{flex:1}.sidebar.collapsed .nav-item__label{display:none}
.nav-item__badge{background:#ef4444;color:#fff;border-radius:8px;padding:2px 8px;font-size:11px;font-weight:700;font-family:'Outfit',sans-serif}
.nav-item.active .nav-item__badge{background:rgba(255,255,255,.25)}
.sidebar.collapsed .nav-item__badge{display:none}
.sidebar__spacer{height:16px}
.sidebar__bottom{padding:16px 14px;border-top:1px solid var(--divider-light)}
.sidebar.collapsed .sidebar__bottom{padding:16px 10px}
.nav-item--logout{background:var(--logout-bg);color:var(--logout-text);font-weight:600}
.nav-item--logout .nav-item__label{color:var(--logout-text)}
.sidebar.collapsed .nav-item--logout .nav-item__label{display:none}

/* ─── Sidebar Dropdown ─── */
.nav-dropdown__trigger{justify-content:flex-start}
.nav-dropdown__arrow{margin-left:auto;transition:transform .25s ease;display:flex}
.nav-dropdown.open .nav-dropdown__arrow{transform:rotate(90deg)}
.nav-dropdown__menu{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.16,1,.3,1);padding-left:10px;margin-top:2px}
.nav-dropdown.open .nav-dropdown__menu{max-height:400px;padding-bottom:4px}
.sidebar.collapsed .nav-dropdown__menu{display:none}
.sidebar.collapsed .nav-dropdown__arrow{display:none}

.nav-dropdown__item{display:flex;align-items:center;gap:11px;padding:7px 12px;border-radius:9px;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:500;color:var(--nav-text);transition:all .15s;cursor:pointer}
.nav-dropdown__item:hover{background:rgba(99,102,241,.06);color:var(--text)}
.nav-dropdown__item.active{background:rgba(99,102,241,.1);color:#6366f1;font-weight:600}
.nav-dropdown__icon-circle{width:34px;height:34px;min-width:34px;min-height:34px;max-width:34px;max-height:34px;border-radius:50%;background:var(--input-bg);border:1.5px solid var(--input-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;position:relative}
.nav-dropdown__icon-circle img{width:26px;height:26px;max-width:26px;max-height:26px;object-fit:cover;display:block;flex-shrink:0;border-radius:50%}

/* ─── Header ─── */
.header{height:68px;background:var(--header-bg);border-bottom:1px solid var(--header-border);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:15;transition:background .4s,border .4s}
.header__menu-btn{background:none;border:none;cursor:pointer;color:var(--nav-text);padding:6px;border-radius:8px;display:flex;align-items:center}
.header__search{flex:1;max-width:400px;position:relative}
.header__search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-faint);display:flex}
.header__search-input{width:100%;padding:10px 16px 10px 42px;border-radius:11px;border:1.5px solid var(--search-border);background:var(--search-bg);font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;color:var(--text);outline:none;transition:all .2s}
.header__search-input:focus{border-color:#6366f1;background:var(--input-focus-bg)}
.header__kbd{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:var(--kbd-bg);border-radius:6px;padding:3px 8px;font-family:'Outfit',sans-serif;font-size:10.5px;font-weight:600;color:var(--kbd-text);border:1px solid var(--kbd-border)}
.header__right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.header__divider{width:1px;height:24px;background:var(--divider);margin:0 4px}
.header__divider--tall{height:32px;margin:0 6px}
.header__clock{padding:8px 14px;border-radius:10px;background:var(--clock-bg);border:1px solid var(--clock-border);display:flex;align-items:center;gap:10px;transition:all .4s}
.header__clock-time{font-family:'Outfit',sans-serif;font-weight:700;font-size:13.5px;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:.5px}
.header__clock-sep{width:1px;height:16px;background:var(--divider)}
.header__clock-date{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:var(--text-muted);font-weight:500}
.header__notif{position:relative;background:var(--notif-bg);border:1px solid var(--notif-border);border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--nav-text);transition:all .4s}
.header__notif-dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:#ef4444;border:2px solid var(--header-bg)}
.header__profile{display:flex;align-items:center;gap:10px;padding:6px 10px 6px 6px;border-radius:12px;cursor:pointer}
.header__avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;color:#fff;font-size:14px}
.header__user-name{font-family:'Outfit',sans-serif;font-weight:700;font-size:13px;color:var(--text)}
.header__user-role{font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;color:var(--text-muted);font-weight:500}
.header__profile-chevron{color:var(--text-faint);display:flex}

/* ─── Notification Dropdown ─── */
.notif-wrapper{position:relative;display:flex;align-items:center}
.notif-dropdown{display:none;position:absolute;top:calc(100% + 12px);right:-10px;width:360px;max-height:420px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.15);z-index:50;overflow:hidden;opacity:0;transform:translateY(-8px);transition:opacity .2s,transform .2s}
.notif-dropdown.show{display:block;opacity:1;transform:translateY(0)}
.notif-dropdown__header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--divider-light)}
.notif-dropdown__title{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;color:var(--text)}
.notif-dropdown__mark-read{background:none;border:none;cursor:pointer;font-size:12px;color:#6366f1;font-weight:600;font-family:'Plus Jakarta Sans',sans-serif}
.notif-dropdown__list{overflow-y:auto;max-height:340px}
.notif-dropdown__empty{padding:32px;text-align:center;color:var(--text-muted);font-size:13px}
.notif-item{display:flex;gap:12px;padding:14px 18px;border-bottom:1px solid var(--divider-light);transition:background .15s}
.notif-item:hover{background:rgba(99,102,241,.03)}
.notif-item:last-child{border-bottom:none}
.notif-item__dot{width:8px;height:8px;border-radius:50%;background:#6366f1;flex-shrink:0;margin-top:5px}
.notif-item__dot--read{background:var(--divider)}
.notif-item__title{font-family:'Outfit',sans-serif;font-weight:600;font-size:13px;color:var(--text);margin-bottom:2px}
.notif-item__msg{font-size:12px;color:var(--text-muted);line-height:1.5}
.notif-item__time{font-size:11px;color:var(--text-faint);margin-top:3px}

/* ─── Main Content ─── */
.main-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}
.main-content{flex:1;overflow-y:auto}
.dashboard{padding:28px 32px;max-width:1200px;margin:0 auto}
/* ─── Greeting Card ─── */
.greeting-card{
    background:var(--card-bg);border-radius:18px;padding:28px 32px;margin-bottom:28px;
    border:1px solid var(--card-border);
    display:flex;align-items:center;justify-content:space-between;gap:20px;
    transition:background .4s,border .4s;
    position:relative;overflow:hidden;
}
.greeting-card__content{display:flex;align-items:center;gap:18px}
.greeting-card__emoji{font-size:40px;line-height:1}
.greeting__title{font-family:'Outfit',sans-serif;font-weight:800;font-size:24px;color:var(--text);letter-spacing:-.5px;margin-bottom:4px}
.greeting__sub{font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;color:var(--text-muted)}
.greeting-card__meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.greeting-card__date{font-family:'Outfit',sans-serif;font-weight:600;font-size:13px;color:var(--text-muted)}
.greeting-card__role{
    font-family:'Outfit',sans-serif;font-weight:700;font-size:11px;
    padding:4px 12px;border-radius:8px;letter-spacing:.4px;
    background:rgba(99,102,241,.1);color:#6366f1;
}

/* ─── Floating Marquee Background ─── */
@keyframes marqueeScroll{
    0%{transform:translateX(0)}
    100%{transform:translateX(-50%)}
}
@keyframes marqueeScrollReverse{
    0%{transform:translateX(-50%)}
    100%{transform:translateX(0)}
}
.marquee-bg{
    position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none;
    opacity:.06;
}
[data-theme="dark"] .marquee-bg{opacity:.04}
.marquee-track{
    display:flex;align-items:center;gap:40px;white-space:nowrap;
    width:max-content;
}
.marquee-track--1{
    animation:marqueeScroll 35s linear infinite;
    position:absolute;top:8px;left:0;
}
.marquee-track--2{
    animation:marqueeScrollReverse 28s linear infinite;
    position:absolute;bottom:8px;left:0;
}
.marquee-img{
    width:48px;height:48px;object-fit:contain;flex-shrink:0;
    filter:grayscale(100%);
    opacity:.7;
}

/* Banner marquee */
.marquee-bg--banner{opacity:.1}
[data-theme="dark"] .marquee-bg--banner{opacity:.08}
.marquee-track--banner{
    animation:marqueeScroll 22s linear infinite;
    position:absolute;top:50%;left:0;transform:translateY(-50%);
    gap:60px;
}
.marquee-img--banner{
    width:40px;height:40px;
    filter:grayscale(100%) brightness(3);
    opacity:.5;
}

/* ─── Dashboard Cards ─── */
.dash-cards{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:24px;
}
.dash-card{
    background:var(--card-bg);border-radius:16px;padding:24px;
    border:none;box-shadow:0 1px 4px rgba(0,0,0,.04);
    display:flex;flex-direction:column;gap:16px;
    transition:background .4s,box-shadow .3s,transform .2s;position:relative;
}
.dash-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.08)}
[data-theme="dark"] .dash-card{box-shadow:0 1px 6px rgba(0,0,0,.25);border:1px solid var(--card-border)}
[data-theme="dark"] .dash-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.35)}

.dash-card__icon{
    width:44px;height:44px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.dash-card__icon--purple{background:rgba(99,102,241,.1);color:#6366f1}
.dash-card__icon--green{background:rgba(16,185,129,.1);color:#10b981}
.dash-card__icon--amber{background:rgba(245,158,11,.1);color:#f59e0b}
.dash-card__icon--blue{background:rgba(59,130,246,.1);color:#3b82f6}

.dash-card__body{display:flex;flex-direction:column;gap:4px}
.dash-card__label{font-family:'Plus Jakarta Sans',sans-serif;font-size:12.5px;color:var(--text-muted);font-weight:500;letter-spacing:.2px}
.dash-card__value{font-family:'Outfit',sans-serif;font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.5px;line-height:1.1}

.dash-card__footer{margin-top:auto}
.dash-card__hint{font-family:'Plus Jakarta Sans',sans-serif;font-size:11.5px;color:var(--text-faint);font-weight:500}

/* IBAN card specifics */
.dash-card--iban .dash-card__body{gap:6px}
.dash-card__iban-name{font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;color:var(--text)}
.dash-card__iban-row{display:flex;align-items:center;gap:8px}
.dash-card__iban-number{
    font-family:'Outfit',sans-serif;font-weight:600;font-size:13px;color:var(--text-secondary);
    letter-spacing:.6px;word-break:break-all;
}
.dash-card__iban-empty{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--text-faint);font-style:italic}
.dash-card__copy{
    width:30px;height:30px;border-radius:8px;border:1px solid var(--input-border);
    background:var(--input-bg);display:flex;align-items:center;justify-content:center;
    cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0;
}
.dash-card__copy:hover{border-color:#6366f1;color:#6366f1}
.dash-card__copy.copied{border-color:#10b981;color:#10b981}

/* ─── Announcements ─── */
.announcements-card{background:var(--card-bg);border-radius:14px;padding:22px 24px;border:none;box-shadow:0 1px 4px rgba(0,0,0,.04);margin-bottom:20px;transition:background .4s}
[data-theme="dark"] .announcements-card{box-shadow:0 1px 6px rgba(0,0,0,.2);border:1px solid var(--card-border)}
.announcements-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.announcements-card__icon{width:34px;height:34px;border-radius:9px;background:rgba(99,102,241,.1);display:flex;align-items:center;justify-content:center;color:#6366f1}
.announcements-card__title{font-family:'Outfit',sans-serif;font-weight:700;font-size:17px;color:var(--text)}
.announce-row{display:flex;align-items:flex-start;gap:14px;padding:16px 14px;border-bottom:1px solid var(--divider-light);border-radius:10px;margin:2px 0;background:transparent;border:1px solid transparent;transition:background .2s}
.announce-row:last-child{border-bottom:none}
.announce-row--pinned{background:var(--announce-bg);border-color:var(--announce-border)}
.announce-row__badge{display:inline-flex;align-items:center;gap:3px;background:rgba(99,102,241,.12);color:#6366f1;border-radius:6px;padding:2px 8px;font-family:'Outfit',sans-serif;font-size:10.5px;font-weight:700}
.announce-row__new{background:var(--announce-new);color:var(--announce-new-text);border-radius:6px;padding:2px 8px;font-family:'Outfit',sans-serif;font-size:10.5px;font-weight:700}
.announce-row__title{font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;color:var(--text)}
.announce-row__desc{font-family:'Plus Jakarta Sans',sans-serif;font-size:12.5px;color:var(--text-muted);line-height:1.6;margin-top:4px}
.announce-row__time{font-family:'Plus Jakarta Sans',sans-serif;font-size:11.5px;color:var(--text-faint);white-space:nowrap;flex-shrink:0;margin-top:2px}

/* ─── Telegram ─── */
.telegram-banner{background:linear-gradient(135deg,#0088cc,#0077b5 40%,#005f99);border-radius:16px;padding:22px 32px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden;cursor:pointer}
.telegram-banner__deco{position:absolute;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.telegram-banner__deco--a{top:-40px;right:80px;width:120px;height:120px}
.telegram-banner__deco--b{bottom:-30px;right:200px;width:80px;height:80px;background:rgba(255,255,255,.04)}
.telegram-banner__deco--c{top:-20px;left:40%;width:60px;height:60px;background:rgba(255,255,255,.03)}
.telegram-banner__icon{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.telegram-banner__title{font-family:'Outfit',sans-serif;font-weight:700;font-size:16.5px;color:#fff;margin-bottom:3px}
.telegram-banner__desc{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:rgba(255,255,255,.75)}
.telegram-banner__btn{background:#fff;color:#0088cc;border:none;padding:11px 28px;border-radius:11px;cursor:pointer;font-family:'Outfit',sans-serif;font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:8px;box-shadow:0 2px 12px rgba(0,0,0,.15);position:relative;z-index:1;flex-shrink:0}

/* ═══ ADMIN COMPONENTS ═══ */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-weight:600;font-size:13.5px;box-shadow:0 2px 10px rgba(99,102,241,.2);transition:all .2s}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;background:var(--input-bg);color:var(--text);border:1px solid var(--input-border);cursor:pointer;font-family:'Outfit',sans-serif;font-weight:600;font-size:13.5px;transition:all .2s}
.btn-icon{width:32px;height:32px;border-radius:8px;border:1px solid var(--input-border);background:var(--input-bg);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all .15s}
.btn-icon:hover{border-color:#6366f1;color:#6366f1}
.btn-icon--danger:hover{border-color:#ef4444;color:#ef4444}

.admin-card{background:var(--card-bg);border-radius:16px;padding:24px;border:1px solid var(--card-border);box-shadow:var(--card-shadow);transition:background .4s,border .4s}
.table-wrap{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{font-family:'Outfit',sans-serif;font-weight:600;font-size:11.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--divider-light)}
.admin-table td{padding:12px 14px;border-bottom:1px solid var(--divider-light);color:var(--text);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.role-badge{padding:3px 10px;border-radius:6px;font-family:'Outfit',sans-serif;font-size:11px;font-weight:700}
.role-badge--admin{background:rgba(99,102,241,.1);color:#6366f1}
.role-badge--user{background:rgba(16,185,129,.1);color:#10b981}
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
.status-dot--active{background:#10b981}.status-dot--banned{background:#ef4444}.status-dot--suspended{background:#f59e0b}

.form-feedback{font-size:12.5px;padding:8px 0;min-height:24px}
.form-feedback.error{color:#ef4444}.form-feedback.success{color:#10b981}

.yorum-row{padding:16px;border:1px solid var(--divider-light);border-radius:12px;margin-bottom:10px;background:var(--input-bg);transition:background .3s}
.yorum-row:hover{background:var(--card-bg)}

/* ─── Modal ─── */
.modal-overlay{display:none;position:fixed;inset:0;background:var(--modal-overlay);z-index:100;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.active{display:flex}
.modal{background:var(--card-bg);border-radius:18px;width:460px;max-width:94vw;max-height:90vh;overflow-y:auto;box-shadow:0 12px 48px rgba(0,0,0,.2);border:1px solid var(--card-border)}
.modal__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--divider-light)}
.modal__header h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:17px;color:var(--text)}
.modal__close{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;padding:4px}
.modal__body{padding:20px 24px}
.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--divider-light)}

/* ═══ MOBILE OVERLAY ═══ */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:19;backdrop-filter:blur(2px);opacity:0;transition:opacity .3s}
.sidebar-overlay.active{display:block;opacity:1}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){.header__clock-date,.header__clock-sep,.header__kbd{display:none}.dashboard{padding:24px 20px}.dash-cards{grid-template-columns:repeat(2,1fr);gap:14px}}
@media(max-width:768px){
    .sidebar{position:fixed;left:-280px;top:0;bottom:0;width:280px!important;z-index:25;transition:left .3s cubic-bezier(.16,1,.3,1),background .4s;box-shadow:none}
    .sidebar.mobile-open{left:0;box-shadow:4px 0 24px rgba(0,0,0,.12)}
    .sidebar.collapsed{width:280px!important;left:-280px}
    .sidebar.collapsed.mobile-open{left:0}
    .sidebar.collapsed .sidebar__logo-info,.sidebar.collapsed .sidebar__section-label{display:block}
    .sidebar.collapsed .nav-item{padding:11px 14px;justify-content:flex-start}
    .sidebar.collapsed .nav-item__label,.sidebar.collapsed .nav-item__badge,.sidebar.collapsed .nav-item--logout .nav-item__label{display:inline}
    .sidebar.collapsed .sidebar__nav,.sidebar.collapsed .sidebar__bottom{padding:16px 14px}
    .sidebar.collapsed .sidebar__logo{padding:22px 20px;justify-content:flex-start}
    .sidebar.collapsed .nav-dropdown__menu{display:block}
    .sidebar.collapsed .nav-dropdown__arrow{display:flex}
    .header{padding:0 16px;gap:10px;height:60px}
    .header__search{max-width:none}
    .header__search-input{font-size:13px;padding:9px 14px 9px 38px}
    .header__clock,.header__divider,.header__divider--tall{display:none}
    .header__right{gap:6px}
    .header__profile{padding:4px;gap:0}
    .header__profile>div:not(.header__avatar){display:none}
    .header__profile-chevron{display:none!important}
    .header__avatar{width:34px;height:34px;font-size:13px}
    .notif-dropdown{width:calc(100vw - 32px);right:-60px}
    .dashboard{padding:20px 16px}
    .greeting-card{flex-direction:column;align-items:flex-start;padding:20px;gap:14px}
    .greeting-card__meta{flex-direction:row;align-items:center}
    .greeting-card__emoji{font-size:32px}
    .greeting__title{font-size:20px}
    .greeting__sub{font-size:12.5px}
    .dash-cards{grid-template-columns:repeat(2,1fr);gap:12px}
    .dash-card{padding:18px;border-radius:14px}
    .dash-card__value{font-size:24px}
    .dash-card__icon{width:38px;height:38px;border-radius:10px}
    .announcements-card{padding:18px 16px;border-radius:14px}
    .announce-row{padding:14px 10px;gap:10px;flex-wrap:wrap}
    .announce-row__time{width:100%;margin-top:4px;font-size:11px}
    .telegram-banner{padding:18px 20px;flex-direction:column;align-items:flex-start;gap:16px;border-radius:14px}
    .telegram-banner__btn{align-self:stretch;justify-content:center;padding:12px 20px}
    .login-wrapper{padding:0 16px}
    .login-card{padding:28px 22px 24px;border-radius:16px}
    .login-title{font-size:22px}
    .theme-toggle-login{top:16px;right:16px}
}
@media(max-width:480px){
    .header{padding:0 12px;gap:8px;height:56px}
    .header__search-input{font-size:12px;padding:8px 12px 8px 36px;border-radius:9px}
    .header__notif{width:36px;height:36px;border-radius:9px}
    .header__avatar{width:32px;height:32px;font-size:12px;border-radius:8px}
    .theme-toggle{width:44px;height:24px;border-radius:12px}
    .theme-toggle__knob{width:18px;height:18px;top:2px;left:2px}
    [data-theme="dark"] .theme-toggle__knob{left:22px}
    .dashboard{padding:16px 12px}
    .greeting-card{padding:16px}
    .greeting-card__emoji{font-size:28px}
    .greeting__title{font-size:18px}
    .dash-cards{grid-template-columns:1fr;gap:10px;margin-bottom:20px}
    .dash-card{padding:16px;border-radius:12px;gap:12px}
    .dash-card__value{font-size:22px}
    .announcements-card{padding:14px 12px}
    .telegram-banner{padding:16px}
    .login-card{padding:24px 18px 22px}
    .admin-table{font-size:12px}
    .admin-table th,.admin-table td{padding:8px 10px}
}
