﻿:root {
  --p1: #0b5fa5; --p2: #0e7fcb; --p3: #13a0f5;
  --accent: #00d4aa; --accent2: #f59e0b;
  --bg: #f1f6fc; --bg2: #e4edf8; --card: #ffffff;
  --text: #0d1f35; --text2: #3a5370; --text3: #7a95b0;
  --border: #ccd9ea; --success: #10b981; --danger: #ef4444;
  --grad: linear-gradient(135deg, var(--p1) 0%, var(--p3) 100%);
  --grad2: linear-gradient(135deg, var(--accent) 0%, var(--p2) 100%);
  --shadow: 0 8px 28px rgba(11,95,165,0.13);
  --shadow-lg: 0 20px 60px rgba(11,95,165,0.18);
  --shadow-xl: 0 32px 80px rgba(11,95,165,0.22);
  --font-body: 'Tajawal', sans-serif;
  --font-head: 'Cairo', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
.bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.10;animation:blobFloat 12s ease-in-out infinite}
.bg-blob:nth-child(1){width:600px;height:600px;background:var(--p1);top:-200px;right:-100px}
.bg-blob:nth-child(2){width:400px;height:400px;background:var(--accent);bottom:-100px;left:-100px;animation-delay:4s}
.bg-blob:nth-child(3){width:300px;height:300px;background:var(--p3);top:40%;left:30%;animation-delay:8s}
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}
#main-nav{position:fixed;top:0;left:0;right:0;z-index:200;height:64px;background:rgba(255,255,255,.93);backdrop-filter:blur(20px);border-bottom:1px solid rgba(11,95,165,.1);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;box-shadow:0 2px 20px rgba(11,95,165,.06)}
.nav-brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-head);font-weight:900;font-size:1.1rem;color:var(--p1)}
.nav-brand-icon{width:40px;height:40px;background:var(--grad);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:transform .3s}
.nav-brand-icon:hover{transform:rotate(10deg) scale(1.1)}
.nav-actions{display:flex;gap:.6rem;align-items:center}
.nbtn{padding:.45rem 1.1rem;border-radius:10px;font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .2s;display:flex;align-items:center;gap:.4rem}
.nbtn-ghost{background:transparent;color:var(--p1);border:1.5px solid var(--p1)}
.nbtn-ghost:hover{background:var(--p1);color:white}
.nbtn-solid{background:var(--grad);color:white;box-shadow:0 4px 12px rgba(11,95,165,.2)}
.nbtn-solid:hover{transform:translateY(-1px)}
.pg{display:none;min-height:100vh;padding-top:64px;position:relative;z-index:1}
.pg.on{display:block}
.pgc{display:none;min-height:100vh;padding-top:64px;position:relative;z-index:1;align-items:center;justify-content:center;padding-bottom:2rem}
.pgc.on{display:flex}
@keyframes slideUp{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:slideUp .7s cubic-bezier(.16,1,.3,1) both}
.htbadge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;border-radius:100px;font-size:.8rem;font-weight:600}
.htbadge-teal{background:rgba(0,212,170,.12);color:#00a88a;border:1px solid rgba(0,212,170,.25)}
.htbadge-blue{background:rgba(11,95,165,.1);color:var(--p1);border:1px solid rgba(11,95,165,.2)}
.htbadge-gold{background:rgba(245,158,11,.1);color:#b45309;border:1px solid rgba(245,158,11,.2)}
.hero-card{background:white;border-radius:32px;padding:4rem;box-shadow:var(--shadow-xl);border:1px solid rgba(11,95,165,.08);text-align:center;position:relative;overflow:hidden;max-width:900px;width:100%;margin:2rem auto}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:var(--grad)}
.hero-icon{width:100px;height:100px;background:var(--grad);border-radius:28px;display:flex;align-items:center;justify-content:center;font-size:3rem;box-shadow:0 16px 40px rgba(11,95,165,.3);margin:0 auto 2rem;animation:ipulse 3s ease-in-out infinite;overflow:hidden;position:relative}
.hero-icon.has-image{background:transparent;box-shadow:none;}
@keyframes ipulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.hero-title{font-family:var(--font-head);font-size:2.2rem;font-weight:900;color:var(--text);line-height:1.3;margin-bottom:1.2rem}
.hero-title span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:1.05rem;color:var(--text2);line-height:1.9;max-width:560px;margin:0 auto 2.5rem}
.hero-feats{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.hfeat{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--bg);border-radius:100px;border:1px solid var(--border);font-size:.85rem;color:var(--text2);transition:all .2s;cursor:default}
.hfeat:hover{background:var(--p1);color:white;border-color:var(--p1);transform:translateY(-2px)}
.hero-stats{display:flex;border-radius:16px;overflow:hidden;border:1px solid var(--border);margin-bottom:2.5rem;background:var(--bg)}
.hstat{flex:1;padding:1.2rem;text-align:center;border-left:1px solid var(--border);transition:background .2s}
.hstat:last-child{border-left:none}
.hstat:hover{background:white}
.hstat-num{font-family:var(--font-head);font-size:2rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hstat-lbl{font-size:.78rem;color:var(--text3);margin-top:.2rem}
.hero-cta{display:inline-flex;align-items:center;gap:.8rem;background:var(--grad);color:white;padding:1.1rem 3.5rem;border-radius:16px;font-family:var(--font-head);font-size:1.15rem;font-weight:800;border:none;cursor:pointer;box-shadow:0 12px 35px rgba(11,95,165,.35);transition:all .3s}
.hero-cta:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(11,95,165,.4)}
.arrow{transition:transform .3s}
.hero-cta:hover .arrow{transform:translateX(-6px)}
.form-card{background:white;border-radius:28px;padding:3rem;box-shadow:var(--shadow-xl);border:1px solid rgba(11,95,165,.08);position:relative;overflow:hidden;max-width:520px;width:100%}
.form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad)}
.fc-icon{width:60px;height:60px;background:rgba(11,95,165,.08);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:1.5rem}
.fc-title{font-family:var(--font-head);font-size:1.6rem;font-weight:900;margin-bottom:.4rem}
.fc-sub{font-size:.92rem;color:var(--text3);margin-bottom:2.2rem;line-height:1.6}
.fgrp{margin-bottom:1.4rem}
.flbl{display:flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:700;color:var(--text2);margin-bottom:.5rem}
.req{color:var(--danger);font-size:.8rem}
.fin{width:100%;padding:.85rem 1.1rem;border:2px solid var(--border);border-radius:12px;font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--bg);outline:none;transition:all .25s}
.fin::placeholder{color:var(--text3)}
.fin:hover{border-color:var(--p2);background:white}
.fin:focus{border-color:var(--p1);background:white;box-shadow:0 0 0 4px rgba(11,95,165,.08)}
.fin.err{border-color:var(--danger);background:#fff5f5}
.ferr{display:none;align-items:center;gap:.35rem;color:var(--danger);font-size:.8rem;margin-top:.4rem;font-weight:500}
.ferr.on{display:flex}
.btn-p{width:100%;padding:1rem;border-radius:14px;border:none;background:var(--grad);color:white;font-family:var(--font-head);font-size:1.05rem;font-weight:800;cursor:pointer;box-shadow:0 8px 25px rgba(11,95,165,.3);transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.6rem}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 14px 35px rgba(11,95,165,.38)}
.prog-widget{background:white;border-radius:20px;padding:1.3rem 1.8rem;box-shadow:var(--shadow);border:1px solid rgba(11,95,165,.08);margin-bottom:1.8rem;display:flex;align-items:center;gap:1.2rem}
.prog-info{flex:1}
.prog-lbl{font-size:.85rem;color:var(--text3);margin-bottom:.6rem;display:flex;justify-content:space-between}
.prog-lbl strong{color:var(--p1);font-weight:700}
.prog-track{height:10px;background:var(--bg2);border-radius:10px;overflow:hidden}
.prog-fill{height:100%;background:var(--grad);border-radius:10px;transition:width .6s cubic-bezier(.34,1.56,.64,1);width:0%}
.prog-circ{width:56px;height:56px;flex-shrink:0;position:relative}
.prog-circ svg{transform:rotate(-90deg)}
.pcirc-bg{fill:none;stroke:var(--bg2);stroke-width:6}
.pcirc-fill{fill:none;stroke:var(--p1);stroke-width:6;stroke-linecap:round;stroke-dasharray:126;stroke-dashoffset:126;transition:stroke-dashoffset .6s cubic-bezier(.34,1.56,.64,1)}
.pcirc-txt{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.75rem;font-weight:800;color:var(--p1)}
.sec-div{display:flex;align-items:center;gap:1rem;margin:2rem 0 1.2rem;padding:1.4rem 1.8rem;border-radius:18px;background:var(--grad);color:white;overflow:hidden}
.sd-icon{font-size:2.2rem}
.sd-title{font-family:var(--font-head);font-size:1.1rem;font-weight:900}
.sd-desc{font-size:.83rem;opacity:.85;margin-top:.15rem}
.qcard{background:white;border-radius:20px;padding:2rem;box-shadow:var(--shadow);border:1px solid rgba(11,95,165,.07);margin-bottom:1.2rem;animation:slideUp .4s ease both;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.qcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.qcard::after{content:'';position:absolute;right:0;top:0;bottom:0;width:4px;background:var(--grad)}
.qhdr{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.4rem}
.qnum{min-width:38px;height:38px;background:var(--grad);border-radius:12px;display:flex;align-items:center;justify-content:center;color:white;font-family:var(--font-head);font-weight:800;font-size:.92rem;flex-shrink:0;box-shadow:0 4px 12px rgba(11,95,165,.25)}
.qtxt{font-size:1rem;font-weight:600;color:var(--text);line-height:1.55}
.qmeta{display:flex;align-items:center;gap:.5rem;margin-top:.35rem;flex-wrap:wrap}
.qtag{font-size:.72rem;color:var(--text3);background:var(--bg);padding:.2rem .55rem;border-radius:6px;border:1px solid var(--border)}
.qimg{width:100%;border-radius:12px;margin-bottom:1rem;max-height:200px;object-fit:cover}
.yn-wrap{display:flex;gap:1rem}
.yn-btn{flex:1;padding:.9rem;border:2px solid var(--border);border-radius:14px;background:var(--bg);cursor:pointer;font-family:var(--font-body);font-size:1rem;font-weight:700;color:var(--text2);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.yn-btn:hover{border-color:var(--p1);color:var(--p1)}
.yn-y{background:rgba(16,185,129,.1)!important;border-color:var(--success)!important;color:#065f46!important}
.yn-n{background:rgba(239,68,68,.08)!important;border-color:var(--danger)!important;color:#991b1b!important}
.scale-wrap{display:flex;gap:.6rem;flex-wrap:wrap}
.sc-btn{flex:1;min-width:48px;height:56px;border:2px solid var(--border);border-radius:14px;background:var(--bg);cursor:pointer;font-family:var(--font-head);font-size:1.15rem;font-weight:800;color:var(--text2);transition:all .2s;display:flex;align-items:center;justify-content:center}
.sc-btn:hover{border-color:var(--p1);color:var(--p1);transform:scale(1.05)}
.sc-btn.sel{background:var(--grad);border-color:transparent;color:white;box-shadow:0 6px 16px rgba(11,95,165,.25)}
.sc-lbls{display:flex;justify-content:space-between;margin-top:.6rem;font-size:.75rem;color:var(--text3)}
.mc-wrap{display:flex;flex-direction:column;gap:.7rem}
.mc-opt{display:flex;align-items:center;gap:.9rem;padding:.85rem 1.1rem;border:2px solid var(--border);border-radius:14px;background:var(--bg);cursor:pointer;transition:all .2s}
.mc-opt:hover{border-color:var(--p2)}
.mc-opt.chk{border-color:var(--p1);background:rgba(11,95,165,.06)}
.mc-box{width:20px;height:20px;border:2px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:white;transition:all .2s}
.mc-opt.chk .mc-box{background:var(--p1);border-color:var(--p1)}
.mc-ck{color:white;font-size:.75rem;display:none}
.mc-opt.chk .mc-ck{display:block}
.mc-lbl{font-size:.95rem;color:var(--text)}
.qta{width:100%;min-height:120px;padding:1rem 1.1rem;border:2px solid var(--border);border-radius:14px;font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--bg);resize:vertical;outline:none;line-height:1.7;transition:all .25s}
.qta:hover{border-color:var(--p2);background:white}
.qta:focus{border-color:var(--p1);background:white;box-shadow:0 0 0 4px rgba(11,95,165,.08)}
.qta::placeholder{color:var(--text3)}
.charcnt{text-align:left;font-size:.75rem;color:var(--text3);margin-top:.4rem}
.btn-submit{width:100%;padding:1.2rem;border-radius:16px;border:none;background:var(--grad);color:white;font-family:var(--font-head);font-size:1.15rem;font-weight:800;cursor:pointer;box-shadow:0 12px 35px rgba(11,95,165,.35);transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.8rem;margin-top:1.5rem}
.btn-submit:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(11,95,165,.45)}
.success-card{background:white;border-radius:32px;padding:4.5rem 3rem;box-shadow:var(--shadow-xl);max-width:520px;width:100%;text-align:center;animation:slideUp .8s cubic-bezier(.16,1,.3,1);border:1px solid rgba(11,95,165,.08);position:relative;overflow:hidden}
.success-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:var(--grad2)}
.success-anim{width:110px;height:110px;margin:0 auto 2rem;background:linear-gradient(135deg,#10b981,#34d399);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;box-shadow:0 16px 40px rgba(16,185,129,.35);animation:spop .6s .2s cubic-bezier(.34,1.56,.64,1) both}
@keyframes spop{from{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0)}}
.success-title{font-family:var(--font-head);font-size:1.9rem;font-weight:900;color:var(--text);margin-bottom:1rem}
.success-desc{color:var(--text2);font-size:1rem;line-height:1.85;margin-bottom:2.5rem}
.success-stats{display:flex;gap:1rem;justify-content:center;margin-bottom:2.5rem;flex-wrap:wrap}
.ss-item{flex:1;min-width:100px;padding:1rem;background:var(--bg);border-radius:14px;border:1px solid var(--border);text-align:center}
.ss-num{font-family:var(--font-head);font-size:1.6rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ss-lbl{font-size:.75rem;color:var(--text3);margin-top:.15rem}
.btn-return{background:var(--grad);color:white;border:none;padding:.9rem 2.5rem;border-radius:14px;font-family:var(--font-head);font-size:1rem;font-weight:800;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}
.btn-return:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.login-card{background:white;border-radius:28px;padding:3rem;box-shadow:var(--shadow-xl);border:1px solid rgba(11,95,165,.08);position:relative;overflow:hidden;max-width:460px;width:100%}
.login-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad)}
#page-admin{padding:64px 0 0}
.admin-shell{display:flex;min-height:calc(100vh - 64px)}
.adm-sidebar{width:268px;background:var(--text);flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto}
.sl-brand{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:.8rem}
.sl-icon{width:40px;height:40px;background:var(--grad);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.sl-txt{color:white;font-family:var(--font-head);font-weight:800;font-size:1rem}
.sl-sub{color:rgba(255,255,255,.4);font-size:.72rem}
.adm-nav{flex:1;padding:.75rem 0}
.sng{padding:.25rem 1rem;margin-bottom:.2rem}
.sngl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.3);padding:.5rem .75rem}
.snav{display:flex;align-items:center;gap:.75rem;padding:.75rem .9rem;border-radius:12px;cursor:pointer;color:rgba(255,255,255,.6);font-size:.9rem;font-weight:500;transition:all .2s;position:relative}
.snav:hover{background:rgba(255,255,255,.07);color:white}
.snav.on{background:rgba(11,95,165,.35);color:white}
.snav.on::before{content:'';position:absolute;right:-1rem;top:50%;transform:translateY(-50%);width:4px;height:28px;background:var(--accent);border-radius:4px 0 0 4px}
.sn-ico{font-size:1.1rem;width:24px;text-align:center}
.sn-bdg{margin-right:auto;background:var(--p2);color:white;padding:.15rem .5rem;border-radius:100px;font-size:.7rem;font-weight:700}
.sl-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.08)}
.sl-logout{display:flex;align-items:center;gap:.7rem;padding:.75rem .9rem;border-radius:12px;cursor:pointer;color:rgba(255,255,255,.4);font-size:.88rem;transition:all .2s}
.sl-logout:hover{color:var(--danger);background:rgba(239,68,68,.1)}
.adm-main{flex:1;padding:2rem;overflow-y:auto;min-width:0}
.atab{display:none}
.atab.on{display:block;animation:slideUp .4s ease}
.apttl{font-family:var(--font-head);font-size:1.6rem;font-weight:900;color:var(--text);margin-bottom:.4rem;display:flex;align-items:center;gap:.7rem}
.aptsub{color:var(--text3);font-size:.9rem;margin-bottom:2rem}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.2rem;margin-bottom:2rem}
.sc{background:white;border-radius:20px;padding:1.6rem;box-shadow:var(--shadow);border:1px solid rgba(11,95,165,.07);display:flex;align-items:center;gap:1.1rem;transition:all .25s}
.sc:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.sc-ico{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0}
.ico-g{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.2))}
.ico-b{background:linear-gradient(135deg,rgba(11,95,165,.1),rgba(19,160,245,.18))}
.ico-t{background:linear-gradient(135deg,rgba(0,212,170,.1),rgba(0,212,170,.2))}
.ico-o{background:linear-gradient(135deg,rgba(245,158,11,.1),rgba(245,158,11,.2))}
.sc-val{font-family:var(--font-head);font-size:2.1rem;font-weight:900;color:var(--text);line-height:1}
.sc-lbl{font-size:.8rem;color:var(--text3);margin-top:.3rem}
.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}
.cc{background:white;border-radius:20px;padding:1.8rem;box-shadow:var(--shadow);border:1px solid rgba(11,95,165,.07)}
.cc-ttl{font-family:var(--font-head);font-size:1rem;font-weight:800;color:var(--text);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}
.blist{display:flex;flex-direction:column;gap:1rem}
.br{display:flex;align-items:center;gap:.8rem}
.blbl{font-size:.82rem;color:var(--text2);min-width:100px;text-align:right}
.bouter{flex:1;height:24px;background:var(--bg2);border-radius:6px;overflow:hidden}
.binner{height:100%;background:var(--grad);border-radius:6px;transition:width 1.2s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:flex-end;padding-left:.4rem}
.binner-v{font-size:.7rem;font-weight:700;color:white;min-width:20px}
.bnum{font-size:.82rem;font-weight:700;color:var(--p1);min-width:28px;text-align:center}
.donut-wrap{display:flex;align-items:center;gap:2rem}
.dleg{flex:1}
.dleg-item{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem;font-size:.85rem;color:var(--text2)}
.dleg-dot{width:12px;height:12px;border-radius:4px;flex-shrink:0}
.tbl-cont{background:white;border-radius:20px;padding:1.8rem;box-shadow:var(--shadow);border:1px solid rgba(11,95,165,.07);overflow:hidden}
.tbl-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.srchbox{flex:1;min-width:200px;display:flex;align-items:center;gap:.5rem;background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:.6rem 1rem;transition:all .2s}
.srchbox:focus-within{border-color:var(--p1);background:white}
.srchbox input{flex:1;border:none;background:transparent;font-family:var(--font-body);font-size:.9rem;color:var(--text);outline:none}
.srchbox input::placeholder{color:var(--text3)}
.expgrp{display:flex;gap:.5rem}
.expbtn{padding:.6rem 1rem;border-radius:10px;border:none;cursor:pointer;font-family:var(--font-body);font-size:.83rem;font-weight:700;transition:all .2s;display:flex;align-items:center;gap:.4rem}
.ex-xl{background:#dcfce7;color:#15803d}
.ex-xl:hover{background:#bbf7d0}
.ex-csv{background:#dbeafe;color:#1d4ed8}
.ex-csv:hover{background:#bfdbfe}
.dtbl{width:100%;border-collapse:collapse}
.dtbl thead tr{background:var(--bg)}
.dtbl th{padding:.8rem 1rem;text-align:right;font-size:.79rem;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}
.dtbl td{padding:.9rem 1rem;font-size:.88rem;color:var(--text);border-bottom:1px solid rgba(11,95,165,.05);vertical-align:middle}
.dtbl tr:last-child td{border-bottom:none}
.dtbl tbody tr{transition:background .15s;cursor:pointer}
.dtbl tbody tr:hover td{background:rgba(11,95,165,.025)}
.tdbdg{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:100px;font-size:.75rem;font-weight:700;white-space:nowrap}
.tdb-b{background:#dbeafe;color:#1d4ed8}
.vbtn{padding:.35rem .8rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-family:var(--font-body);font-size:.8rem;font-weight:600;color:var(--p1);cursor:pointer;transition:all .2s;white-space:nowrap}
.vbtn:hover{background:var(--p1);color:white;border-color:var(--p1)}
.qed-list{margin-bottom:1.2rem}
.qed-item{background:white;border-radius:14px;padding:1.2rem 1.5rem;box-shadow:0 2px 8px rgba(11,95,165,.08);border:1.5px solid rgba(11,95,165,.08);margin-bottom:.8rem;display:flex;align-items:center;gap:1rem;transition:all .2s;cursor:grab}
.qed-item:hover{border-color:var(--p2);box-shadow:var(--shadow)}
.qed-drag{color:var(--text3);font-size:1.3rem;user-select:none}
.qed-body{flex:1;min-width:0}
.qed-txt{font-size:.92rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qed-meta{display:flex;align-items:center;gap:.5rem;margin-top:.3rem;flex-wrap:wrap}
.qtype-tag{font-size:.72rem;background:var(--bg2);color:var(--text3);padding:.2rem .6rem;border-radius:6px}
.qsec-tag{font-size:.72rem;background:rgba(11,95,165,.08);color:var(--p1);padding:.2rem .6rem;border-radius:6px}
.qvis-tag{font-size:.72rem;padding:.2rem .6rem;border-radius:6px}
.qvis-v{background:#dcfce7;color:#15803d}
.qvis-h{background:#fee2e2;color:#991b1b}
.qed-acts{display:flex;gap:.4rem;flex-shrink:0}
.qa-btn{width:34px;height:34px;border-radius:10px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s}
.qa-edit{background:#fef3c7;color:#b45309}
.qa-edit:hover{background:#fde68a}
.qa-del{background:#fee2e2;color:#991b1b}
.qa-del:hover{background:#fecaca}
.qa-vis{background:#dbeafe;color:#1d4ed8}
.qa-vis:hover{background:#bfdbfe}
.qadd-btn{width:100%;padding:1rem;background:white;border:2px dashed var(--border);border-radius:14px;font-family:var(--font-body);font-size:.93rem;font-weight:700;color:var(--text3);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.qadd-btn:hover{border-color:var(--p1);color:var(--p1);background:rgba(11,95,165,.03)}
.sblk{margin-bottom:2rem}
.sblk-ttl{font-family:var(--font-head);font-size:1rem;font-weight:800;color:var(--text);margin-bottom:1rem;padding:.6rem 1rem;background:var(--bg);border-radius:10px;border-right:4px solid var(--p1);display:flex;align-items:center;gap:.5rem}
.scard{background:white;border-radius:16px;padding:1.8rem;box-shadow:0 2px 8px rgba(11,95,165,.08);border:1px solid rgba(11,95,165,.07);margin-bottom:1rem}
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem}
.sitem{display:flex;flex-direction:column;gap:.45rem}
.slbl{font-size:.87rem;font-weight:700;color:var(--text2)}
.slbl-sub{font-size:.75rem;color:var(--text3);margin-top:-.2rem}
.sin{padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:10px;font-family:var(--font-body);font-size:.9rem;color:var(--text);background:var(--bg);outline:none;transition:all .2s}
.sin:focus{border-color:var(--p1);background:white}
input[type=color].sin{padding:.3rem .5rem;height:46px;cursor:pointer}
.sin-full{grid-column:1/-1}
.tog-w{display:flex;align-items:center;gap:.7rem;cursor:pointer;padding:.5rem 0}
.tog-track{width:46px;height:26px;background:var(--border);border-radius:13px;position:relative;transition:background .3s;flex-shrink:0}
.tog-track.on{background:var(--p1)}
.tog-knob{width:20px;height:20px;background:white;border-radius:50%;position:absolute;top:3px;right:3px;box-shadow:0 2px 6px rgba(0,0,0,.15);transition:transform .3s}
.tog-track.on .tog-knob{transform:translateX(-20px)}
.tog-lbl{font-size:.88rem;color:var(--text)}
.btn-save{background:var(--grad);color:white;border:none;padding:.8rem 2.2rem;border-radius:12px;font-family:var(--font-head);font-size:.95rem;font-weight:800;cursor:pointer;transition:all .2s;margin-top:.5rem;display:inline-flex;align-items:center;gap:.5rem}
.btn-save:hover{opacity:.88;transform:translateY(-2px)}
.btn-danger{background:linear-gradient(135deg,#ef4444,#b91c1c);color:white;border:none;padding:.8rem 2.2rem;border-radius:12px;font-family:var(--font-head);font-size:.95rem;font-weight:800;cursor:pointer;transition:all .2s;margin-top:.5rem;margin-right:.8rem;display:inline-flex;align-items:center;gap:.5rem}
.btn-danger:hover{opacity:.88;transform:translateY(-2px)}
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
.tc{border:2px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .2s}
.tc:hover{border-color:var(--p1);transform:translateY(-2px);box-shadow:var(--shadow)}
.tc.sel{border-color:var(--p1);box-shadow:0 0 0 3px rgba(11,95,165,.15)}
.tc-prev{height:80px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.tc-name{padding:.5rem;text-align:center;font-size:.82rem;font-weight:700;color:var(--text2);background:var(--bg)}
.tc.sel .tc-name{color:var(--p1)}
.modal-ov{position:fixed;inset:0;z-index:1000;background:rgba(13,31,53,.6);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:1.5rem}
.modal-ov.on{display:flex}
.modal-box{background:white;border-radius:28px;padding:2.2rem;max-width:540px;width:100%;box-shadow:0 40px 100px rgba(0,0,0,.25);animation:slideUp .4s cubic-bezier(.16,1,.3,1);max-height:90vh;overflow-y:auto}
.mhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.8rem}
.mttl{font-family:var(--font-head);font-size:1.3rem;font-weight:900;color:var(--text)}
.mclose{width:36px;height:36px;border-radius:10px;border:none;background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text3);transition:all .2s}
.mclose:hover{background:var(--danger);color:white}
.mfoot{display:flex;gap:.8rem;margin-top:2rem;justify-content:flex-end}
.mbtn-c{padding:.7rem 1.5rem;border-radius:10px;background:var(--bg);border:1.5px solid var(--border);font-family:var(--font-body);font-size:.9rem;font-weight:700;color:var(--text2);cursor:pointer;transition:all .2s}
.mbtn-c:hover{border-color:var(--danger);color:var(--danger)}
.mbtn-s{padding:.7rem 2rem;border-radius:10px;background:var(--grad);border:none;font-family:var(--font-head);font-size:.95rem;font-weight:800;color:white;cursor:pointer;transition:all .2s}
.mbtn-s:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.rd-emp{background:var(--bg);border-radius:14px;padding:1.2rem;margin-bottom:1.5rem;display:flex;gap:1rem;align-items:center}
.rd-av{width:50px;height:50px;background:var(--grad);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:900;color:white;font-family:var(--font-head);flex-shrink:0}
.rd-nm{font-weight:800;font-size:1rem;color:var(--text)}
.rd-mt{font-size:.83rem;color:var(--text3);margin-top:.2rem}
.rd-ans{padding:.9rem 1rem;border:1px solid var(--border);border-radius:12px;margin-bottom:.7rem}
.rd-q{font-size:.83rem;font-weight:700;color:var(--text3);margin-bottom:.4rem}
.rd-a{font-size:.92rem;color:var(--text)}
.toast{position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);background:white;border-radius:14px;padding:.9rem 1.6rem;box-shadow:0 10px 40px rgba(0,0,0,.15);z-index:2000;font-size:.92rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:.6rem;opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(11,95,165,.1);pointer-events:none;white-space:nowrap}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
.empty-st{text-align:center;padding:4rem 2rem;color:var(--text3)}
.empty-ico{font-size:3rem;margin-bottom:1rem;opacity:.4}
.empty-ttl{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--text2);margin-bottom:.5rem}
@media(max-width:900px){.adm-sidebar{display:none}.adm-main{padding:1.2rem}}
@media(max-width:640px){.hero-card{padding:2.5rem 1.5rem}.hero-title{font-size:1.6rem}#main-nav{padding:0 1rem}.hero-stats{flex-direction:column}.hstat{border-left:none;border-bottom:1px solid var(--border)}.hstat:last-child{border-bottom:none}}

/* Banner upload */
.banner-upload-label{display:flex;align-items:center;justify-content:center;gap:.7rem;padding:1.1rem;background:var(--bg);border:2px dashed var(--border);border-radius:14px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text3);transition:all .2s;width:100%}
.banner-upload-label:hover{border-color:var(--p1);color:var(--p1);background:rgba(11,95,165,.03)}
.banner-upload-label span:first-child{font-size:1.4rem}

/* UI appearance CSS vars */
:root{
  --ui-radius:20px;
  --ui-shadow:0 8px 28px rgba(11,95,165,.13);
  --ui-fontsize:16px;
}
body{font-size:var(--ui-fontsize)}


.an-section-title{font-family:var(--font-head);font-size:.95rem;font-weight:800;color:var(--text);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.an-empty{text-align:center;padding:3rem 1rem;color:var(--text3);font-size:.9rem}
.an-bar-chart{display:flex;flex-direction:column;gap:.7rem}
.an-heatmap-table{border-collapse:collapse;min-width:100%}
.an-heatmap-table th,.an-heatmap-table td{padding:.4rem .8rem;border:1px solid var(--border);font-size:.78rem}
.an-heatmap-table thead th{background:var(--bg2);font-weight:700;color:var(--text2)}
.an-pill{display:inline-flex;align-items:center;padding:.25rem .7rem;border-radius:100px;font-size:.72rem;font-weight:700;gap:.3rem}
.an-pill-g{background:#dcfce7;color:#15803d}
.an-pill-r{background:#fee2e2;color:#991b1b}
.an-pill-b{background:#dbeafe;color:#1d4ed8}

/* Question image upload styles */
.qimg-upload-wrap{display:flex;flex-direction:column;gap:.6rem}
.qimg-file-label{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text2);transition:all .2s;width:fit-content}
.qimg-file-label:hover{border-color:var(--p1);color:var(--p1)}
.qimg-preview-wrap{border-radius:12px;overflow:hidden;border:1.5px solid var(--border);position:relative;display:none}
.qimg-preview-wrap img{width:100%;max-height:150px;object-fit:cover;display:block}
.qimg-clear{position:absolute;top:.4rem;left:.4rem;width:28px;height:28px;border-radius:50%;border:none;background:rgba(0,0,0,.55);color:white;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .2s}
.qimg-clear:hover{background:var(--danger)}

/* Paragraph block styles */
.para-block{background:var(--bg);border-radius:12px;padding:1rem;border:1.5px solid var(--border);position:relative;transition:border-color .2s}
.para-block:hover{border-color:var(--p2)}
.para-block-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}
.para-block-label{font-size:.78rem;font-weight:700;color:var(--p1)}
.para-block-actions{display:flex;gap:.3rem}
.para-action-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:white;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .2s}
.para-action-btn:hover{border-color:var(--p1);color:var(--p1)}
.para-action-del{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.para-action-del:hover{background:#fecaca}
.para-textarea{width:100%;min-height:72px;padding:.6rem .8rem;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font-body);font-size:.88rem;color:var(--text);background:white;resize:vertical;outline:none;transition:border-color .2s}
.para-textarea:focus{border-color:var(--p1)}
.para-meta{margin-top:.6rem;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}
.para-meta-label{font-size:.75rem;font-weight:600;color:var(--text2);display:flex;align-items:center;gap:.4rem}
.para-meta-select{padding:.28rem .5rem;border:1.5px solid var(--border);border-radius:7px;font-family:var(--font-body);font-size:.75rem;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s}
.para-meta-select:focus{border-color:var(--p1)}
