:root{
  --navy:#0b1628;--navy2:#0f1e38;--navy3:#152540;--navy4:#1a2d4e;--navy5:#1e3258;
  --gold:#f0a500;--gold2:#ffc233;--gold-bg:rgba(240,165,0,.1);--gold-border:rgba(240,165,0,.25);
  --green:#10b981;--green-bg:rgba(16,185,129,.1);--green-border:rgba(16,185,129,.25);
  --red:#ef4444;--red-bg:rgba(239,68,68,.1);--red-border:rgba(239,68,68,.25);
  --blue:#3b82f6;--blue-bg:rgba(59,130,246,.1);--blue-border:rgba(59,130,246,.25);
  --purple:#8b5cf6;--purple-bg:rgba(139,92,246,.1);--cyan:#06b6d4;--cyan-bg:rgba(6,182,212,.1);
  --text:#e2eaf5;--text2:#94a8c0;--border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.13);
  --r:12px;--r-sm:8px;--sidebar:242px;--topbar:60px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:'Inter',system-ui,sans-serif;background:var(--navy);color:var(--text);font-size:14px;line-height:1.5}
button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}
.app{display:flex;height:100vh}
/* RTL overrides */
[dir=rtl] .nav-item{border-left:none;border-right:3px solid transparent}
[dir=rtl] .nav-item.active{border-right-color:var(--gold)}
[dir=rtl] .sb-footer .user-card{flex-direction:row-reverse}
[dir=rtl] .topbar-title{text-align:right}
[dir=rtl] .td-avatar{flex-direction:row-reverse}
[dir=rtl] .form-row{direction:rtl}
[dir=rtl] th,[dir=rtl] td{text-align:right}
[dir=rtl] .badge{direction:ltr}
[dir=rtl] .card-header{flex-direction:row-reverse}
[dir=rtl] .modal-head{flex-direction:row-reverse}

/* ── SIDEBAR ── */
.sidebar{width:var(--sidebar);min-width:var(--sidebar);background:var(--navy2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.sb-brand{padding:14px 16px 13px;border-bottom:1px solid var(--border)}
.brand-logo{display:flex;align-items:center;gap:10px;min-width:0}
.brand-icon{
  width:40px;height:40px;flex-shrink:0;
  background:var(--gold);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;overflow:hidden;
  box-shadow:0 2px 10px rgba(0,0,0,.25)}
.brand-name{
  font-size:12px;font-weight:700;color:var(--text);
  line-height:1.4;letter-spacing:-.1px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;min-width:0;word-break:break-word;cursor:default}
.brand-name span{color:var(--gold)}
.brand-school{display:none}
.nav{flex:1;overflow-y:auto;padding:8px 0 12px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
/* Collapsible nav groups */
.nav-group{}
.nav-section{display:flex;align-items:center;justify-content:space-between;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.3px;color:var(--text2);opacity:.45;padding:16px 18px 5px;cursor:pointer;user-select:none;transition:opacity .15s}
.nav-section:hover{opacity:.7}
.nav-chevron{width:14px;height:14px;flex-shrink:0;opacity:.7;background:none;display:inline-block;position:relative}
.nav-chevron::before{content:'';display:block;width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin:2px auto;transition:transform .2s ease}
.nav-group.collapsed .nav-chevron::before{transform:rotate(-45deg)}
.nav-group-items{overflow:hidden;max-height:600px;transition:max-height .25s ease,opacity .2s ease;opacity:1}
.nav-group.collapsed .nav-group-items{max-height:0;opacity:0;pointer-events:none}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 18px;cursor:pointer;transition:background .15s,color .15s,border-color .15s;color:var(--text2);font-size:13px;font-weight:500;border-left:3px solid transparent;margin:1px 0;border-radius:0}
.nav-item:hover{background:rgba(255,255,255,.05);color:var(--text)}
.nav-item.active{background:var(--gold-bg);color:var(--gold);border-left-color:var(--gold);font-weight:600}
.nav-item .ni{font-size:15px;width:22px;text-align:center;flex-shrink:0;opacity:.85}
.nav-item.active .ni{opacity:1}
.nav-ext{font-size:9px;opacity:.5;margin-left:auto}
.sb-footer{padding:14px 16px;border-top:1px solid var(--border)}
.user-card{display:flex;align-items:center;gap:10px}
.user-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.5px}
.user-info{flex:1;min-width:0}
.user-name{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10.5px;color:var(--text2);text-transform:capitalize;margin-top:1px}
.btn-logout{background:none;border:none;color:var(--text2);font-size:17px;padding:4px 6px;transition:color .2s;border-radius:6px}
.btn-logout:hover{color:var(--red);background:var(--red-bg)}

/* ── TOPBAR ── */
.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:var(--topbar);min-height:var(--topbar);background:var(--navy2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px}
.topbar-title{font-size:17px;font-weight:700;flex:1;letter-spacing:-.2px}
.topbar-date{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:6px}
.topbar-actions{display:flex;align-items:center;gap:10px}
.content{flex:1;overflow-y:auto;padding:26px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:600;border:none;transition:all .18s;cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--gold);color:#0b1628}
.btn-primary:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(240,165,0,.35)}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover{opacity:.9;transform:translateY(-1px)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.btn-danger:hover{background:rgba(239,68,68,.18)}
.btn-ghost{background:transparent;color:var(--text2);border:1.5px solid var(--border2)}
.btn-ghost:hover{color:var(--text);border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.04)}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}
.btn-icon{padding:7px;border-radius:7px;font-size:14px}

/* ── STAT CARDS ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px;margin-bottom:24px}
/* Base card */
.stat-card{
  background:var(--navy2);border:1px solid var(--border);border-radius:var(--r);
  padding:20px 18px;position:relative;overflow:hidden;
  transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s,border-color .25s;
  cursor:pointer;
}
/* Left accent stripe */
.stat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;transition:width .25s}
.stat-card:hover::before{width:4px}
/* Bottom-right ambient glow orb */
.stat-card::after{content:'';position:absolute;right:-28px;bottom:-28px;width:100px;height:100px;
  border-radius:50%;opacity:.07;transition:opacity .3s,transform .3s;pointer-events:none}
.stat-card:hover::after{opacity:.18;transform:scale(1.25)}
/* Color mappings — stripe + orb + hover glow */
.sc-blue::before{background:var(--blue)}.sc-blue::after{background:var(--blue)}
.sc-blue:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(59,130,246,.25),0 14px 36px -4px rgba(59,130,246,.22);border-color:rgba(59,130,246,.35)}
.sc-purple::before{background:var(--purple)}.sc-purple::after{background:var(--purple)}
.sc-purple:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(139,92,246,.25),0 14px 36px -4px rgba(139,92,246,.22);border-color:rgba(139,92,246,.35)}
.sc-cyan::before{background:var(--cyan)}.sc-cyan::after{background:var(--cyan)}
.sc-cyan:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(6,182,212,.25),0 14px 36px -4px rgba(6,182,212,.22);border-color:rgba(6,182,212,.35)}
.sc-green::before{background:var(--green)}.sc-green::after{background:var(--green)}
.sc-green:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(16,185,129,.25),0 14px 36px -4px rgba(16,185,129,.22);border-color:rgba(16,185,129,.35)}
.sc-red::before{background:var(--red)}.sc-red::after{background:var(--red)}
.sc-red:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(239,68,68,.25),0 14px 36px -4px rgba(239,68,68,.22);border-color:rgba(239,68,68,.35)}
.sc-gold::before{background:var(--gold)}.sc-gold::after{background:var(--gold)}
.sc-gold:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(245,158,11,.25),0 14px 36px -4px rgba(245,158,11,.22);border-color:rgba(245,158,11,.35)}
/* Icon */
.stat-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.stat-icon-wrap{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;transition:transform .25s,box-shadow .25s}
.stat-card:hover .stat-icon-wrap{transform:scale(1.12) rotate(-6deg)}
.sc-blue .stat-icon-wrap{background:var(--blue-bg);box-shadow:0 0 0 0 rgba(59,130,246,0)}
.sc-purple .stat-icon-wrap{background:var(--purple-bg)}
.sc-cyan .stat-icon-wrap{background:var(--cyan-bg)}
.sc-green .stat-icon-wrap{background:var(--green-bg)}
.sc-red .stat-icon-wrap{background:var(--red-bg)}
.sc-gold .stat-icon-wrap{background:var(--gold-bg)}
/* Sparkline */
.sc-spark{opacity:.45;transition:opacity .25s;flex-shrink:0}
.stat-card:hover .sc-spark{opacity:1}
/* Value + label */
.stat-val{font-size:28px;font-weight:800;line-height:1;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.stat-label{font-size:11.5px;color:var(--text2);margin-top:4px;font-weight:500}

/* ── CARDS ── */
.card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--r)}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.card-body{padding:20px}
.card-body.p0{padding:0}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ── TABLES ── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text2);padding:11px 16px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--navy3)}
td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.025)}
.td-avatar{display:flex;align-items:center;gap:10px}
.av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}
.badge-gold{background:var(--gold-bg);color:var(--gold)}.badge-blue{background:var(--blue-bg);color:var(--blue)}
.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-cyan{background:var(--cyan-bg);color:var(--cyan)}
.badge-muted{background:rgba(148,168,192,.1);color:var(--text2)}

/* ── FORMS ── */
.form-field{margin-bottom:16px}
.form-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text2);margin-bottom:7px}
.form-field input,.form-field select,.form-field textarea{width:100%;padding:10px 13px;background:var(--navy3);border:1.5px solid var(--border2);border-radius:var(--r-sm);color:var(--text);font-size:13px;outline:none;transition:border-color .18s,box-shadow .18s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(240,165,0,.1)}
.form-field input::placeholder{color:var(--text2);opacity:.4}
.form-field textarea{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);z-index:200;align-items:center;justify-content:center;padding:24px}
.modal-bg.open{display:flex;animation:fadeIn .18s ease}
.modal{background:var(--navy2);border:1px solid var(--border2);border-radius:16px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.7);animation:slideUp .22s ease}
.modal.modal-lg{max-width:780px}
.modal-head{padding:20px 24px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--navy2);z-index:1}
.modal-title{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}
.modal-close{background:none;border:none;color:var(--text2);font-size:18px;line-height:1;padding:4px 8px;transition:color .2s;border-radius:6px}
.modal-close:hover{color:var(--text);background:rgba(255,255,255,.06)}
.modal-body{padding:24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:var(--navy3);border-radius:0 0 16px 16px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ── SEARCH & FILTERS ── */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:200px}
.search-wrap::before{content:'🔍';position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.35;pointer-events:none}
.search-inp{width:100%;padding:9px 13px 9px 34px;background:var(--navy2);border:1.5px solid var(--border2);border-radius:var(--r-sm);color:var(--text);font-size:13px;outline:none;transition:border-color .18s}
.search-inp:focus{border-color:var(--gold)}
.search-inp::placeholder{color:var(--text2);opacity:.4}
.filter-sel{padding:9px 12px;background:var(--navy2);border:1.5px solid var(--border2);border-radius:var(--r-sm);color:var(--text);font-size:13px;outline:none;cursor:pointer;transition:border-color .18s}
.filter-sel:focus{border-color:var(--gold)}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:56px 24px}
.empty .ei{font-size:52px;margin-bottom:14px;display:block;opacity:.7}
.empty .et{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.empty .es{font-size:13px;color:var(--text2);margin-bottom:22px;line-height:1.6}

/* ── PAGE HEADER ── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.page-header h2{font-size:20px;font-weight:800;letter-spacing:-.3px}
.page-sub{font-size:12.5px;color:var(--text2);margin-top:2px;font-weight:400}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;right:24px;border-radius:var(--r);padding:13px 18px;font-size:13px;font-weight:500;z-index:9999;display:none;box-shadow:0 8px 32px rgba(0,0,0,.5);max-width:340px;display:flex;align-items:center;gap:10px;pointer-events:none}
#toast.show{display:flex;animation:slideInR .25s ease}
#toast.success{background:#0f2d1f;border:1px solid var(--green-border);color:var(--green)}
#toast.error{background:#2d0f0f;border:1px solid var(--red-border);color:var(--red)}
#toast.info{background:var(--navy3);border:1px solid var(--border2);color:var(--text)}
@keyframes slideInR{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ── CONFIRM ── */
#confirm-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:300;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#confirm-bg.open{display:flex}
#confirm-box{background:var(--navy2);border:1px solid var(--border2);border-radius:16px;padding:28px 24px;max-width:360px;width:100%;box-shadow:0 24px 60px rgba(0,0,0,.6);text-align:center}
#confirm-icon{font-size:40px;margin-bottom:12px}
#confirm-msg{font-size:14px;margin-bottom:6px;font-weight:600;line-height:1.6}
#confirm-sub{font-size:12.5px;color:var(--text2);margin-bottom:22px;line-height:1.5}
#confirm-actions{display:flex;gap:10px;justify-content:center}

/* ── NOTICE CARDS ── */
.notice-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;margin-bottom:12px;border-left:4px solid transparent;transition:transform .18s}
.notice-card:hover{transform:translateX(3px)}
.notice-card.high{border-left-color:var(--red)}.notice-card.normal{border-left-color:var(--gold)}.notice-card.low{border-left-color:var(--blue)}
.notice-title{font-size:14.5px;font-weight:700;margin-bottom:7px}
.notice-body{font-size:13px;color:var(--text2);line-height:1.65;margin-bottom:12px;white-space:pre-wrap}
.notice-meta{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--text2);flex-wrap:wrap;gap:8px}

/* ── ATTENDANCE ── */
.att-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}
.att-row:last-child{border-bottom:none}
.att-name{font-size:13px;font-weight:500;display:flex;align-items:center;gap:9px}
.att-toggle{display:flex;gap:6px}
.att-btn{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:none;color:var(--text2);transition:all .15s}
.att-btn.present{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}
.att-btn.absent{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}
.att-btn.late{background:var(--gold-bg);color:var(--gold);border-color:var(--gold-border)}

/* ── REPORT CARDS ── */
.rc-header{display:grid;grid-template-columns:1fr 90px 72px 90px;gap:10px;margin-bottom:8px;padding:0 4px}
.rc-lbl{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text2);letter-spacing:.5px}
.rc-row{display:grid;grid-template-columns:1fr 90px 72px 90px;gap:10px;margin-bottom:8px;align-items:center}
.rc-row input{padding:8px 10px;background:var(--navy3);border:1.5px solid var(--border2);border-radius:7px;color:var(--text);font-size:13px;outline:none;transition:border-color .18s;width:100%}
.rc-row input:focus{border-color:var(--gold)}
.rc-row input::placeholder{color:var(--text2);opacity:.4}

/* ── TIMETABLE ── */
.tt-grid{overflow-x:auto;margin-top:4px}
.tt-table{width:100%;border-collapse:collapse;min-width:650px}
.tt-table th{background:var(--navy3);padding:10px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text2);text-align:center;border:1px solid var(--border)}
.tt-table td{border:1px solid var(--border);padding:0;vertical-align:top;min-width:120px}
.tt-cell{padding:10px 12px;cursor:pointer;min-height:62px;transition:background .15s;position:relative}
.tt-cell:hover{background:rgba(255,255,255,.04)}
.tt-cell.filled{background:var(--navy4)}
.tt-cell.filled:hover{background:var(--navy5)}
.tt-subj{font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:2px}
.tt-tchr{font-size:11px;color:var(--text2)}
.tt-empty{font-size:11px;color:var(--text2);opacity:.35;text-align:center;margin-top:10px}
.tt-period{background:var(--navy3);padding:10px 14px;font-size:11.5px;font-weight:600;color:var(--text2);text-align:center;white-space:nowrap;border:1px solid var(--border);min-width:70px}

/* ── EXAM CARDS ── */
.exam-card{background:var(--navy2);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;display:flex;align-items:center;gap:16px;margin-bottom:12px;transition:transform .18s,box-shadow .18s}
.exam-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.exam-date-box{background:var(--navy3);border-radius:10px;padding:10px 14px;text-align:center;min-width:58px;flex-shrink:0}
.exam-day{font-size:22px;font-weight:800;line-height:1;color:var(--gold)}
.exam-mon{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--text2);margin-top:2px;letter-spacing:.5px}
.exam-info{flex:1;min-width:0}
.exam-name{font-size:14.5px;font-weight:700;margin-bottom:4px}
.exam-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text2)}
.exam-actions{display:flex;gap:8px;flex-shrink:0}

/* ── SETTINGS ── */
.settings-section{background:var(--navy2);border:1px solid var(--border);border-radius:var(--r);padding:22px;margin-bottom:16px}
.settings-section-title{font-size:13.5px;font-weight:700;margin-bottom:18px;display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--border)}

/* ── CHARTS ── */
.chart-wrap{position:relative;padding:20px;height:240px}
.chart-wrap canvas{max-height:200px}

/* ── LOADING ── */
.spin{display:inline-block;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.1);border-top-color:var(--gold);border-radius:50%;animation:rot .6s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.loading-center{display:flex;align-items:center;justify-content:center;padding:60px;gap:12px;color:var(--text2);font-size:13px}

/* ── HELPERS ── */
.text-muted{color:var(--text2)}.text-gold{color:var(--gold)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-blue{color:var(--blue)}
.fw600{font-weight:600}.fw700{font-weight:700}.fw800{font-weight:800}
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}
.mb0{margin-bottom:0}

/* ── CALENDAR ── */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cal-month-title{font-size:17px;font-weight:800;letter-spacing:-.3px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border-radius:var(--r);overflow:hidden}
.cal-dow{background:var(--navy3);padding:10px 4px;text-align:center;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text2)}
.cal-cell{background:var(--navy2);min-height:90px;padding:8px;position:relative;cursor:pointer;transition:background .15s}
.cal-cell:hover{background:var(--navy4)}
.cal-cell.today{background:var(--navy4)}
.cal-cell.today .cal-day{background:var(--gold);color:#0b1628;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px}
.cal-cell.other-month{opacity:.3}
.cal-day{font-size:12.5px;font-weight:600;margin-bottom:4px;width:24px;text-align:center}
.cal-event-chip{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:20px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.ev-holiday{background:rgba(239,68,68,.2);color:var(--red)}
.ev-exam{background:rgba(59,130,246,.2);color:var(--blue)}
.ev-activity{background:rgba(16,185,129,.2);color:var(--green)}
.ev-meeting{background:rgba(240,165,0,.2);color:var(--gold)}
.ev-other{background:rgba(139,92,246,.2);color:var(--purple)}
.cal-empty{background:var(--navy);opacity:.4}

/* ── ID CARDS ── */
.id-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:16px}
.id-card-item{cursor:zoom-in!important;transition:transform .14s ease,box-shadow .14s ease;border-radius:6px;}
.id-card-item:hover{transform:scale(1.06) translateY(-3px)!important;box-shadow:0 12px 36px rgba(0,0,0,.45);z-index:2;position:relative;}
.id-card{background:var(--navy2);border:1px solid var(--border2);border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s}
.id-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.35)}
.id-card-head{background:linear-gradient(135deg,var(--navy3),var(--navy4));padding:14px 16px;border-bottom:1px solid var(--border)}
.id-card-school{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--gold);margin-bottom:2px}
.id-card-body{padding:14px 16px;display:flex;gap:12px;align-items:center}
.id-photo{width:52px;height:62px;background:var(--navy3);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border:2px solid var(--border2)}
.id-info{flex:1;min-width:0}
.id-name{font-size:13.5px;font-weight:800;line-height:1.2;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.id-class{font-size:11px;color:var(--text2);margin-bottom:6px}
.id-adm{font-size:10px;font-weight:700;background:var(--navy3);padding:2px 8px;border-radius:20px;display:inline-block;color:var(--gold);letter-spacing:.5px}
.id-card-foot{padding:8px 16px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.id-barcode{font-size:18px;letter-spacing:-1px;color:var(--border2);font-family:monospace}

/* ── STAFF ATTENDANCE ── */
.staff-att-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}
.staff-att-row:last-child{border-bottom:none}
.staff-att-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.staff-att-toggle{display:flex;gap:6px;flex-wrap:wrap}
.satt-btn{padding:4px 11px;border-radius:20px;font-size:11.5px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:none;color:var(--text2);transition:all .15s;white-space:nowrap}
.satt-btn.present{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}
.satt-btn.absent{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}
.satt-btn.late{background:var(--gold-bg);color:var(--gold);border-color:var(--gold-border)}
.satt-btn.on_leave{background:var(--purple-bg);color:var(--purple);border-color:rgba(139,92,246,.25)}

/* ── LIBRARY / HOSTEL ── */
.room-chip{display:inline-flex;align-items:center;gap:6px;background:var(--navy3);border:1px solid var(--border2);border-radius:8px;padding:7px 13px;font-size:12px;font-weight:600;margin:3px;cursor:pointer;transition:border-color .15s,background .15s}
.room-chip:hover{background:var(--navy4)}
.room-chip.full{border-color:var(--red-border);color:var(--red)}
.room-chip.available{border-color:var(--green-border)}

/* ── MARKS ENTRY GRID ── */
.marks-grid-wrap { overflow-x: auto; }
.marks-grid-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.marks-grid-table th { background: var(--navy3); padding: 10px 12px; text-align: left;
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .7px;
  color: var(--text2); position: sticky; top: 0; z-index: 2; }
.marks-grid-table td { padding: 7px 10px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.marks-grid-table tbody tr:hover { background: rgba(255,255,255,.03); }
.marks-grid-table tbody tr.row-focus { background: rgba(240,165,0,.06); }
input.mark-inp {
  width: 72px; padding: 6px 8px; background: var(--navy3); border: 1.5px solid var(--border2);
  border-radius: 6px; color: var(--text); font-size: 13px; font-weight: 600; text-align: center;
  outline: none; transition: border-color .15s;
}
input.mark-inp:focus { border-color: var(--gold); background: var(--navy4); }
input.mark-inp.grade-A { border-color: var(--green); }
input.mark-inp.grade-B { border-color: var(--blue); }
input.mark-inp.grade-C { border-color: var(--gold); }
input.mark-inp.grade-D { border-color: rgba(240,165,0,.4); }
input.mark-inp.grade-F { border-color: var(--red); }
input.remark-inp {
  width: 100%; padding: 6px 8px; background: var(--navy3); border: 1.5px solid var(--border2);
  border-radius: 6px; color: var(--text); font-size: 12px; outline: none;
  transition: border-color .15s;
}
input.remark-inp:focus { border-color: var(--gold); }
.grade-chip {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 30px; height: 26px; padding: 0 8px; border-radius: 20px;
  font-size: 11px; font-weight: 700; transition: background .15s;
}
.chip-A { background: var(--green-bg); color: var(--green); border: 1px solid var(--green-border); }
.chip-B { background: var(--blue-bg); color: var(--blue); border: 1px solid var(--blue-border); }
.chip-C { background: var(--gold-bg); color: var(--gold); border: 1px solid var(--gold-border); }
.chip-D { background: rgba(249,115,22,.1); color: #f97316; border: 1px solid rgba(249,115,22,.25); }
.chip-F { background: var(--red-bg); color: var(--red); border: 1px solid var(--red-border); }
.marks-stat-bar { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.marks-stat { background: var(--navy3); border-radius: 8px; padding: 8px 14px; text-align: center; }
.marks-stat-val { font-size: 18px; font-weight: 700; }
.marks-stat-lbl { font-size: 10px; color: var(--text2); text-transform: uppercase; letter-spacing: .7px; margin-top: 2px; }

/* ── PHOTO UPLOAD PREVIEW ── */
.photo-preview-wrap { display: flex; align-items: center; gap: 14px; margin-bottom: 4px; }
.photo-preview { width: 68px; height: 80px; border-radius: 8px; object-fit: cover;
  border: 2px solid var(--border2); background: var(--navy3);
  display: flex; align-items: center; justify-content: center; font-size: 26px; flex-shrink: 0; overflow: hidden; }
.photo-preview img { width: 100%; height: 100%; object-fit: cover; border-radius: 6px; }
.photo-upload-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px;
  border: 1.5px dashed var(--border2); border-radius: 8px; cursor: pointer;
  font-size: 12.5px; color: var(--text2); transition: all .15s; }
.photo-upload-btn:hover { border-color: var(--gold); color: var(--gold); }

/* ── PRINT ── */
@media print{
  .sidebar,.topbar,#toast,#confirm-bg,.modal-bg,.btn-logout,.topbar-actions{display:none!important}
  .main{margin:0}.content{padding:0;overflow:visible}
  body{background:#fff;color:#000}
  .print-doc{display:block!important}
  .no-print{display:none!important}
}
.print-doc{display:none}

/* ═══════════════════════════════════════════════════════
   PAGINATION
═══════════════════════════════════════════════════════ */
.pagination{display:flex;align-items:center;gap:6px;padding:14px 0;flex-wrap:wrap}
.pagination button{min-width:34px;height:34px;border-radius:6px;border:1px solid var(--border2);background:var(--navy3);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;padding:0 10px}
.pagination button:hover{background:var(--navy4);color:var(--text)}
.pagination button.active{background:var(--gold);color:var(--navy);border-color:var(--gold);font-weight:700}
.pagination button:disabled{opacity:.35;cursor:default}
.pagination .pg-info{font-size:12px;color:var(--text2);margin-left:6px}
.table-search{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.table-search input{flex:1;max-width:320px;background:var(--navy3);border:1px solid var(--border2);color:var(--text);border-radius:8px;padding:8px 12px;font-size:13px}
.table-search input:focus{outline:none;border-color:var(--gold)}

/* ═══════════════════════════════════════════════════════
   MOBILE / RESPONSIVE
═══════════════════════════════════════════════════════ */
.menu-toggle{display:none;background:none;border:none;color:var(--text);font-size:22px;padding:4px 8px;cursor:pointer;line-height:1}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:199}
.sidebar-overlay.open{display:block}

@media (max-width: 768px) {
  html, body { overflow: auto; height: auto; }
  .app { flex-direction: column; height: auto; min-height: 100vh; }

  /* Sidebar becomes a slide-in drawer */
  .sidebar {
    position: fixed; top: 0; left: -260px; height: 100vh; z-index: 200;
    width: var(--sidebar); transition: left .25s ease; overflow-y: auto;
    box-shadow: 4px 0 24px rgba(0,0,0,.5);
  }
  .sidebar.open { left: 0; }
  .main { flex: 1; min-width: 0; overflow: visible; }

  /* Topbar */
  .topbar { padding: 0 14px; gap: 8px; height: auto; min-height: 56px; flex-wrap: wrap; }
  .topbar-title { font-size: 14px; }
  .topbar-date { display: none; }
  .menu-toggle { display: block; }
  .topbar-actions { flex-wrap: wrap; gap: 6px; }
  .topbar-actions .btn { padding: 6px 10px; font-size: 11.5px; }
  /* Hide language select text label on mobile to save space */
  .topbar select { max-width: 70px; font-size: 11px; padding: 4px 6px; }

  /* Content */
  .content { padding: 12px; overflow: visible; }

  /* Tables � ALL tables get horizontal scroll */
  .table-wrap, .tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }
  table { min-width: 520px; }

  /* Grids collapse */
  .grid2, .grid3 { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: 1fr 1fr !important; gap: 10px; }

  /* Modals: slide up from bottom */
  .modal {
    width: 100vw; max-width: 100%; margin: 0;
    max-height: 88vh; border-radius: 16px 16px 0 0;
  }
  .modal-bg { align-items: flex-end; padding: 0; }

  /* Forms single column */
  .form-row { flex-direction: column; gap: 8px; }
  .form-row3 { flex-direction: column; gap: 8px; }

  /* Toolbar wraps */
  .toolbar { flex-wrap: wrap; gap: 8px; }
  .toolbar .filter-sel { min-width: 0; flex: 1; }

  /* Card header stacks */
  .card-header { flex-wrap: wrap; gap: 8px; }
  .card-header .topbar-actions { width: 100%; }

  /* Exam cards */
  .exam-card { flex-direction: column; gap: 10px; }
  .exam-actions { flex-direction: row; flex-wrap: wrap; }

  /* Pagination wraps */
  .pagination { gap: 4px; }
  .pagination button { min-width: 30px; height: 30px; font-size: 12px; }

  /* Hide sidebar footer user info text */
  .user-info { display: none; }

  /* Marks grid: compact on mobile */
  .marks-grid-table th, .marks-grid-table td { padding: 6px 8px; font-size: 12px; }
  .marks-grid-table input.mark-inp { width: 54px !important; }
}

@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr 1fr !important; gap: 8px; }
  .topbar-actions .btn span.btn-label { display: none; }
  .content { padding: 10px; }
  table { min-width: 380px; font-size: 12px; }
  .modal { max-height: 94vh; }
  /* Touch-friendly minimum tap target */
  .btn, button, .nav-item { min-height: 40px; }
  /* Stat cards smaller on very small screens */
  .stat-card { padding: 12px 14px; }
  .stat-val { font-size: 22px; }
  /* Student/fee cards single col */
  .grid2, .grid3, .grid4 { grid-template-columns: 1fr !important; }
  /* Topbar actions wrap cleanly */
  .topbar { padding: 0 10px; min-height: 52px; }
  .topbar-title { font-size: 13px; max-width: 140px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  /* Demo banner compact */
  #demo-banner { font-size: .72rem !important; padding: 5px 10px !important; flex-wrap: wrap; gap: 4px; }
  #demo-banner a { font-size: .68rem !important; padding: 2px 7px !important; }
}

/* ═══════════════════════════════════════════════════════
   TABLET BREAKPOINT
═══════════════════════════════════════════════════════ */
@media (max-width: 1024px) and (min-width: 769px) {
  :root { --sidebar: 200px; }
  .stats-grid { grid-template-columns: repeat(3, 1fr); }
  .grid3 { grid-template-columns: 1fr 1fr; }
  .grid4 { grid-template-columns: 1fr 1fr; }
  .content { padding: 18px; }
  .nav-item { padding: 8px 14px; font-size: 12.5px; }
}

/* ═══════════════════════════════════════════════════════
   TV / LARGE SCREEN (1440px+)
═══════════════════════════════════════════════════════ */
@media (min-width: 1440px) {
  :root { --sidebar: 260px; }
  .content { padding: 28px; }
  .stats-grid { grid-template-columns: repeat(5, 1fr); }
  .grid3 { grid-template-columns: repeat(3, 1fr); }
  .grid4 { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 1920px) {
  :root { --sidebar: 280px; }
  body { font-size: 15px; }
}

/* ═══════════════════════════════════════════════════════
   IMPROVED MOBILE TABLE EXPERIENCE
═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Table wrapper scroll indicator */
  .table-wrap::after {
    content: '← scroll →';
    display: block;
    text-align: center;
    font-size: 10px;
    color: var(--text2);
    padding: 4px;
    opacity: .6;
  }
  /* Bigger touch targets for table actions */
  td .btn { padding: 5px 10px; font-size: 11px; }
  /* Better spacing for stat cards on mobile */
  .stats-grid { gap: 8px; }
  .stat-card { padding: 14px 16px; border-radius: 10px; }
  .stat-val { font-size: 24px; }
  /* ID cards grid on mobile: 1 per row */
  .id-cards-grid { grid-template-columns: 1fr !important; }
  /* Finance cards */
  .fee-summary-grid { grid-template-columns: 1fr 1fr !important; }
  /* Calendar cells smaller */
  .cal-cell { min-height: 60px; padding: 4px; }
  .cal-event-chip { font-size: 9px; padding: 1px 4px; }
  /* Nav items bigger tap areas */
  .nav-item { padding: 10px 16px; font-size: 13px; }
  .nav-group-label { font-size: 10px; padding: 10px 16px 4px; }
  /* Search inputs full width */
  .search-inp { width: 100%; max-width: 100%; }
  /* Report card on mobile */
  .rc-table th, .rc-table td { font-size: 11px; padding: 5px 6px; }
  /* Topbar date hidden */
  .topbar-date { display: none; }
  /* Demo banner compact on mobile */
  #demo-banner { font-size: .75rem !important; line-height: 1.4; }
}

/* ═══════════════════════════════════════════════════════
   DARK MODE TOGGLE
   Controlled by: data-theme="dark|light" on <html>
   Default is dark. Light mode overrides CSS vars.
═══════════════════════════════════════════════════════ */
[data-theme="light"] {
  --navy:  #f1f5f9;
  --navy2: #ffffff;
  --navy3: #f8fafc;
  --navy4: #e2e8f0;
  --navy5: #cbd5e1;
  --text:  #0f172a;
  --text2: #475569;
  --border: rgba(0,0,0,.08);
  --border2: rgba(0,0,0,.15);
  --gold-bg: rgba(234,179,8,.12);
  --gold-border: rgba(234,179,8,.35);
  --green-bg: rgba(16,185,129,.12);
  --green-border: rgba(16,185,129,.3);
  --red-bg: rgba(239,68,68,.1);
  --red-border: rgba(239,68,68,.25);
  --blue-bg: rgba(59,130,246,.1);
  --blue-border: rgba(59,130,246,.25);
  --purple-bg: rgba(139,92,246,.1);
  --cyan-bg: rgba(6,182,212,.1);
}
[data-theme="light"] .sidebar { border-right-color: var(--border); box-shadow: 2px 0 8px rgba(0,0,0,.06); }
[data-theme="light"] .modal-bg { background: rgba(0,0,0,.4); }
[data-theme="light"] tr:hover td { background: rgba(0,0,0,.02); }
[data-theme="light"] .nav-item:hover { background: rgba(0,0,0,.04); }
[data-theme="light"] .nav-item.active { background: var(--gold-bg); }
[data-theme="light"] .btn-ghost { border-color: var(--border2); }
[data-theme="light"] .search-inp,
[data-theme="light"] .filter-sel { background: var(--navy2); color: var(--text); }
[data-theme="light"] #toast.info { background: var(--navy3); }
[data-theme="light"] .stat-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.1); }

/* System dark preference fallback (when no data-theme set and OS is dark) */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    color-scheme: dark;
  }
}

/* ── QUICK ACTIONS ── */
.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
@media(max-width:768px){.quick-actions{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.quick-actions{grid-template-columns:1fr}}
.qa-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--navy3);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:background .18s,border-color .18s,transform .15s,box-shadow .18s;user-select:none;color:inherit}
.qa-card:hover{background:var(--navy4);border-color:var(--border2);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.qa-card:active{transform:translateY(0);box-shadow:none}
.qa-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.qa-icon-blue  {background:var(--blue-bg);  border:1px solid var(--blue-border)}
.qa-icon-green {background:var(--green-bg); border:1px solid var(--green-border)}
.qa-icon-gold  {background:var(--gold-bg);  border:1px solid var(--gold-border)}
.qa-icon-purple{background:var(--purple-bg);border:1px solid rgba(139,92,246,.25)}
.qa-icon-red   {background:var(--red-bg);   border:1px solid var(--red-border)}
.qa-icon-cyan  {background:var(--cyan-bg);  border:1px solid rgba(6,182,212,.25)}
.qa-icon-orange{background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.25)}
.qa-text{min-width:0}
.qa-title{font-size:13.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qa-sub{font-size:11.5px;color:var(--text2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Help tooltips ── */
.help-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(148,163,192,.15);border:1px solid rgba(148,163,192,.25);color:var(--text2);font-size:10px;font-weight:700;cursor:help;position:relative;vertical-align:middle;margin-left:5px;flex-shrink:0;line-height:1;user-select:none}
.help-icon:hover{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue)}
.help-icon::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:#1e3258;color:var(--text);font-size:11.5px;font-weight:400;line-height:1.5;padding:8px 12px;border-radius:8px;border:1px solid var(--border2);white-space:normal;width:220px;pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.help-icon::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1e3258;pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999}
.help-icon:hover::after,.help-icon:hover::before{opacity:1}
.help-icon.tip-right::after{left:auto;right:0;transform:none}
.help-icon.tip-left::after{left:0;right:auto;transform:none}

/* ── WORKFLOW STEPPER ── */
.workflow-bar{background:var(--navy3);border:1px solid var(--border);border-radius:var(--r);padding:14px 20px;margin-bottom:20px;display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none}
.workflow-bar::-webkit-scrollbar{display:none}
.wf-step{display:flex;align-items:center;gap:10px;flex-shrink:0;cursor:pointer;padding:4px 6px;border-radius:8px;transition:background .15s}
.wf-step:hover{background:rgba(255,255,255,.05)}
.wf-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;transition:background .2s,color .2s}
.wf-num.done{background:var(--green);color:#fff}
.wf-num.active{background:var(--gold);color:#000}
.wf-num.pending{background:var(--navy4);color:var(--text2);border:1px solid var(--border2)}
.wf-label{font-size:12.5px;font-weight:600;white-space:nowrap;color:var(--text2)}
.wf-label.done{color:var(--text)}
.wf-label.active{color:var(--gold)}
.wf-connector{flex:1;min-width:20px;max-width:48px;height:2px;background:var(--border);margin:0 4px;flex-shrink:0}
.wf-connector.done{background:var(--green);opacity:.5}
