/* ============================================================================
   STOA GRAPPLING - Progress Platform  |  premium dark theme
   ============================================================================ */
:root{
  --bg:#0a0b0e; --bg2:#0f1115; --panel:#14161c; --panel2:#1a1d25; --panel3:#21252f;
  --line:#272b36; --line2:#333845;
  --text:#eceef2; --muted:#9aa1ad; --muted2:#6b7280;
  --gold:#c9a24b; --gold2:#e3c074; --steel:#5b8cff;
  --green:#36c08a; --amber:#e0a13a; --red:#e0564a;
  --white-belt:#e9ecf1; --blue-belt:#2f6fed; --purple-belt:#8a4fe0; --brown-belt:#8a5a36; --black-belt:#0c0d10;
  --radius:14px; --shadow:0 12px 40px rgba(0,0,0,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:'Inter',system-ui,sans-serif;background:radial-gradient(1200px 700px at 80% -10%,#15171f 0%,var(--bg) 55%);color:var(--text);-webkit-font-smoothing:antialiased}
.brand-font{font-family:'Oswald',Impact,sans-serif;letter-spacing:.04em;text-transform:uppercase}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
.hide{display:none!important}
.gold{color:var(--gold2)}
.mut{color:var(--muted)}

/* ---------- LOGIN ---------- */
#login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(900px 500px at 50% -10%,#1a1d27,#080a0d 60%);z-index:10}
.login-card{width:100%;max-width:560px;text-align:center}
.login-mark{font-size:13px;font-weight:600;letter-spacing:.42em;color:var(--gold2);margin-bottom:10px}
.login-logo{font-size:62px;line-height:1;font-weight:700;margin-bottom:6px}
.login-logo .dot{color:var(--gold)}
.login-tag{font-size:14px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}
.login-sub{font-size:14px;color:var(--muted2);margin-bottom:30px}
.qa-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2);margin-bottom:14px}
.qa-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:18px}
@media(max-width:560px){.qa-grid{grid-template-columns:1fr}}
.qa{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px 16px;text-align:left;transition:.18s;display:flex;flex-direction:column;gap:8px}
.qa:hover{border-color:var(--gold);transform:translateY(-2px);background:var(--panel2)}
.qa .av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:#0a0b0e}
.qa .nm{font-weight:700;font-size:15px}
.qa .rl{font-size:12px;color:var(--muted)}
.qa .badge{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold2);font-weight:600}
.qa-note{font-size:12px;color:var(--muted2);margin-top:6px}
.qa-students{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:4px}
.chip{background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:7px 13px;font-size:12.5px;color:var(--muted);transition:.16s;display:flex;align-items:center;gap:7px}
.chip:hover{border-color:var(--gold);color:var(--text)}
.chip .pip{width:9px;height:9px;border-radius:50%}

/* ---------- APP SHELL ---------- */
#app{display:flex;min-height:100vh}
.sidebar{width:236px;flex-shrink:0;background:linear-gradient(180deg,var(--bg2),#0b0d11);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sb-logo{padding:22px 22px 16px;font-size:26px;font-weight:700}
.sb-logo .dot{color:var(--gold)}
.sb-logo small{display:block;font-size:9.5px;letter-spacing:.32em;color:var(--muted2);font-weight:600;margin-top:2px}
.sb-nav{flex:1;padding:8px 12px;display:flex;flex-direction:column;gap:3px}
.sb-link{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;color:var(--muted);font-size:14px;font-weight:500;transition:.14s}
.sb-link:hover{background:var(--panel);color:var(--text)}
.sb-link.active{background:var(--panel2);color:var(--text)}
.sb-link.active .ic{color:var(--gold2)}
.sb-link .ic{width:18px;height:18px;flex-shrink:0;color:var(--muted2)}
.sb-foot{padding:14px;border-top:1px solid var(--line)}
.sb-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px}
.sb-user .av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#0a0b0e}
.sb-user .nm{font-size:13px;font-weight:600}.sb-user .rl{font-size:11px;color:var(--muted)}
.sb-logout{width:100%;margin-top:8px;padding:9px;border:1px solid var(--line);border-radius:9px;color:var(--muted);font-size:12.5px;transition:.15s}
.sb-logout:hover{border-color:var(--red);color:var(--red)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:62px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;background:rgba(10,11,14,.82);backdrop-filter:blur(10px);z-index:5}
.topbar h1{font-size:19px;font-weight:700}
.topbar .sub{font-size:12.5px;color:var(--muted)}
.demo-tag{font-size:11px;color:var(--gold2);border:1px solid var(--line2);border-radius:20px;padding:5px 12px;letter-spacing:.04em}
.content{padding:26px 28px 80px;max-width:1180px;width:100%}

/* ---------- GENERIC ---------- */
.grid{display:grid;gap:16px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g2,.g3,.g4{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.card h3{font-size:15px;font-weight:700;margin-bottom:4px}
.card .lbl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted2);margin-bottom:12px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.stat .n{font-size:30px;font-weight:800;font-family:'Oswald',sans-serif}
.stat .n.gold{color:var(--gold2)}.stat .n.green{color:var(--green)}.stat .n.steel{color:var(--steel)}
.stat .l{font-size:12px;color:var(--muted);margin-top:3px}
.section-title{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted2);margin:30px 0 14px;font-weight:600}
.section-title:first-child{margin-top:0}

/* belt bar */
.belt-bar{height:26px;border-radius:6px;display:flex;align-items:center;padding:0 8px;position:relative;border:1px solid rgba(255,255,255,.12)}
.belt-bar .stripes{position:absolute;right:10px;display:flex;gap:3px}
.belt-bar .stripes i{width:5px;height:16px;background:#fff;border-radius:1px;display:block;opacity:.95}
.belt-name{font-size:12px;font-weight:700}

/* progress */
.pbar{height:9px;background:var(--panel3);border-radius:6px;overflow:hidden}
.pbar > i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:6px}
.pbar.green > i{background:linear-gradient(90deg,#26a06f,var(--green))}

/* skill tree */
.cat{margin-bottom:18px}
.cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cat-head .nm{font-size:14.5px;font-weight:700;display:flex;align-items:center;gap:9px}
.cat-head .ct{font-size:11.5px;color:var(--muted2)}
.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:9px}
.tech{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:11px 13px;transition:.14s}
.tech:hover{border-color:var(--line2)}
.tech .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.tech .nm{font-size:13px;font-weight:500;flex:1}
.tech .tag{font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);font-weight:600}
.dot.mastered{background:var(--green);box-shadow:0 0 10px rgba(54,192,138,.5)}
.dot.drilled{background:var(--gold)}
.dot.learning{background:var(--steel)}
.dot.locked{background:#3a3f4b}
.tech.locked{opacity:.5}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin-bottom:6px}
.legend span{display:flex;align-items:center;gap:7px}
.legend i{width:10px;height:10px;border-radius:50%;display:inline-block}

/* drill-next cards */
.drill{display:flex;align-items:center;gap:13px;padding:14px 16px;background:linear-gradient(120deg,var(--panel2),var(--panel));border:1px solid var(--line2);border-radius:12px}
.drill .num{width:30px;height:30px;border-radius:8px;background:var(--gold);color:#0a0b0e;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.drill .nm{font-weight:600;font-size:14px}.drill .meta{font-size:12px;color:var(--muted)}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;padding:11px 12px;color:var(--muted2);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--line);font-weight:600}
.tbl td{padding:12px;border-bottom:1px solid var(--line)}
.tbl tr:hover td{background:var(--bg2)}
.pill{font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;display:inline-block}
.pill.green{background:rgba(54,192,138,.14);color:var(--green)}
.pill.amber{background:rgba(224,161,58,.14);color:var(--amber)}
.pill.red{background:rgba(224,86,74,.15);color:var(--red)}
.pill.steel{background:rgba(91,140,255,.14);color:var(--steel)}
.mini-belt{display:inline-flex;align-items:center;gap:6px;font-size:12px}
.mini-belt .sw{width:22px;height:11px;border-radius:3px;border:1px solid rgba(255,255,255,.18)}
.spark{display:flex;align-items:flex-end;gap:3px;height:30px}
.spark i{width:6px;background:var(--steel);border-radius:2px;opacity:.85}

/* week bars */
.weekbars{display:flex;align-items:flex-end;gap:8px;height:80px;margin-top:6px}
.weekbars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}
.weekbars .b i{width:100%;background:linear-gradient(180deg,var(--gold2),var(--gold));border-radius:5px 5px 0 0;display:block}
.weekbars .b span{font-size:10px;color:var(--muted2)}

/* ---------- AI COACH (Lily-style) ---------- */
#ai-btn{position:fixed;bottom:24px;right:24px;z-index:40;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0b0e;box-shadow:0 10px 30px rgba(201,162,75,.4);display:flex;align-items:center;justify-content:center;transition:.18s}
#ai-btn:hover{transform:scale(1.06)}
#ai-btn svg{width:24px;height:24px}
#ai-panel{position:fixed;bottom:92px;right:24px;z-index:40;width:380px;max-width:calc(100vw - 36px);height:560px;max-height:calc(100vh - 130px);background:var(--panel);border:1px solid var(--line2);border-radius:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}
.ai-head{padding:15px 16px;background:linear-gradient(135deg,#1a1d25,#14161c);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:11px}
.ai-head .av{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;color:#0a0b0e}
.ai-head .t{font-size:14px;font-weight:700}.ai-head .s{font-size:11px;color:var(--muted)}
.ai-head .demo{margin-left:auto;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold2);border:1px solid var(--line2);padding:3px 7px;border-radius:20px}
.ai-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.ai-row{display:flex;gap:9px;max-width:90%}
.ai-row.user{align-self:flex-end;flex-direction:row-reverse}
.ai-av{width:27px;height:27px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px}
.ai-av.bot{background:rgba(201,162,75,.16);color:var(--gold2)}
.ai-av.me{background:rgba(91,140,255,.16);color:var(--steel)}
.ai-av svg{width:15px;height:15px}
.ai-bubble{padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.55}
.ai-row.bot .ai-bubble{background:var(--panel2);border:1px solid var(--line);border-bottom-left-radius:5px}
.ai-row.user .ai-bubble{background:var(--steel);color:#fff;border-bottom-right-radius:5px}
.ai-bubble p{margin:.25em 0}.ai-bubble ul{margin:.3em 0;padding-left:1.1em}.ai-bubble li{margin:.15em 0}
.ai-bubble strong{font-weight:700}
.ai-sugg{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px}
.ai-sugg button{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:18px;padding:6px 11px;transition:.15s}
.ai-sugg button:hover{border-color:var(--gold);color:var(--text)}
.ai-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.ai-input input{flex:1;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:11px 13px;color:var(--text);font-size:13.5px;outline:none}
.ai-input input:focus{border-color:var(--gold)}
.ai-input button{width:42px;border-radius:11px;background:var(--gold);color:#0a0b0e;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-input button svg{width:18px;height:18px}
.typing{display:flex;gap:4px;padding:4px 2px}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--muted2);animation:tp 1s infinite}
.typing i:nth-child(2){animation-delay:.15s}.typing i:nth-child(3){animation-delay:.3s}
@keyframes tp{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
::-webkit-scrollbar{width:9px}::-webkit-scrollbar-thumb{background:var(--line2);border-radius:6px}::-webkit-scrollbar-track{background:transparent}

/* ---------- FUNDAMENTALS / MACH ---------- */
.mach{display:inline-flex;gap:4px;vertical-align:middle}
.mach i{width:18px;height:6px;border-radius:3px;background:var(--panel3);display:block}
.mach i.on{background:linear-gradient(90deg,var(--gold),var(--gold2))}

.ring{--p:0;width:88px;height:88px;border-radius:50%;flex-shrink:0;background:conic-gradient(var(--gold2) calc(var(--p)*1%),var(--panel3) 0);display:flex;align-items:center;justify-content:center}
.ring span{width:66px;height:66px;border-radius:50%;background:var(--panel);display:flex;align-items:center;justify-content:center;font-weight:800;font-family:'Oswald',sans-serif;font-size:19px;color:var(--gold2)}
.ring.sm{width:62px;height:62px}.ring.sm span{width:46px;height:46px;font-size:14px}

.fund-head{display:flex;align-items:center;justify-content:space-between;gap:20px}
.fund-head.grad{border-color:var(--gold)}
.fh-big{font-size:15px;color:var(--muted);margin-top:8px}
.fh-big .brand-font{font-size:40px;color:var(--gold2);font-weight:800;line-height:1}
.fh-tot{font-size:21px;color:var(--muted)}
.fh-cap{font-size:13px}
.fh-grad{margin-top:10px;color:var(--gold2);font-weight:600;font-size:13px}
.fh-next{margin-top:10px;color:var(--muted);font-size:13px}
.mach-legend{font-size:13px;color:var(--muted);margin:14px 2px 4px;line-height:1.55}

.lesson-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(234px,1fr));gap:12px}
.lesson{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:7px;transition:.15s}
.lesson:hover{border-color:var(--line2)}
.lesson.done{border-color:rgba(201,162,75,.5);background:linear-gradient(160deg,rgba(201,162,75,.09),var(--panel))}
.lesson.fresh{opacity:.66}
.lh{display:flex;align-items:center;gap:8px}
.ln{width:24px;height:24px;border-radius:7px;background:var(--panel3);color:var(--text);font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;flex-shrink:0}
.lesson.done .ln{background:var(--gold);color:#0a0b0e}
.lcat{font-size:10px;letter-spacing:.07em;text-transform:uppercase;font-weight:700}
.lmaster{margin-left:auto;font-size:10px;color:var(--gold2);font-weight:700}
.lname{font-size:13.5px;font-weight:600;line-height:1.3}
.lfocus{font-size:12px;color:var(--muted);line-height:1.4;flex:1}
.lbtm{display:flex;align-items:center;gap:9px;margin-top:2px}
.llvl{font-size:11px;color:var(--muted2)}
.lesson.done .llvl{color:var(--gold2)}

/* training log timeline */
.timeline{display:flex;flex-direction:column}
.tl-item{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.tl-item:last-child{border-bottom:none}
.tl-dot{width:10px;height:10px;border-radius:50%;margin-top:5px;flex-shrink:0}
.tl-body{flex:1}
.tl-top{display:flex;justify-content:space-between;gap:10px}
.tl-les{font-size:13.5px;font-weight:600}
.tl-date{font-size:12px;color:var(--muted2);white-space:nowrap}
.tl-note{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.45}

/* dashboard fundamentals banner */
.fund-banner{cursor:pointer;display:flex;align-items:center;gap:18px;transition:.15s;margin-bottom:6px}
.fund-banner:hover{border-color:var(--gold);transform:translateY(-1px)}
.fund-banner .fb-main{flex:1}
.fund-banner .fb-go{font-size:12.5px;color:var(--gold2);font-weight:600;white-space:nowrap}

/* check-in kiosk */
.lesson-pick{width:100%;background:var(--bg2);border:1px solid var(--line2);border-radius:10px;padding:12px 13px;color:var(--text);font-size:14px;font-family:inherit;outline:none;margin-bottom:9px}
.lesson-pick:focus{border-color:var(--gold)}
.kiosk-cat{font-size:12.5px;color:var(--muted);margin-bottom:16px}
.ci-list{display:flex;flex-direction:column;gap:9px}
.ci-row{display:flex;align-items:center;gap:13px;background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:11px 13px}
.ci-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.ci-main{flex:1;min-width:0}
.ci-nm{font-weight:600;font-size:14px}
.ci-sub{font-size:11.5px;color:var(--muted)}
.ci-mach{display:flex;flex-direction:column;align-items:flex-end;gap:5px;margin-right:2px}
.ci-mach span{font-size:10.5px;color:var(--muted2);white-space:nowrap}
.ci-btn{background:var(--gold);color:#0a0b0e;font-weight:700;font-size:13px;padding:9px 16px;border-radius:9px;transition:.15s;flex-shrink:0}
.ci-btn:hover{background:var(--gold2)}
.ci-btn.done{background:rgba(54,192,138,.16);color:var(--green);cursor:default}
.ci-help{font-size:12.5px;color:var(--muted);margin-top:15px;line-height:1.55}
@media(max-width:560px){.ci-mach{display:none}}

/* cohort board */
.cohort{display:flex;flex-direction:column;gap:12px}
.co-row{display:flex;align-items:center;gap:14px}
.co-nm{width:140px;font-size:13px;font-weight:500;flex-shrink:0}
.co-x{width:46px;text-align:right;font-size:12.5px;color:var(--muted);font-family:'Oswald',sans-serif}
@media(max-width:560px){.co-nm{width:96px}}

/* ---------- THEME TOGGLE + LIGHT THEME ---------- */
.theme-toggle{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);border:1px solid var(--line2);border-radius:20px;padding:6px 12px;background:transparent;transition:.15s}
.theme-toggle:hover{border-color:var(--gold);color:var(--text)}
.theme-toggle svg{width:15px;height:15px}
.top-right{display:flex;align-items:center;gap:12px}
.login-theme{position:fixed;top:18px;right:18px;z-index:20}

[data-theme="light"]{
  --bg:#eef1f5;--bg2:#e7eaf0;--panel:#ffffff;--panel2:#f5f7fa;--panel3:#e9edf2;
  --line:#e3e7ee;--line2:#cfd5df;
  --text:#1b1f27;--muted:#5a626f;--muted2:#8b93a1;
  --gold:#c9a24b;--gold2:#9a6b14;--steel:#2f6fed;
  --green:#138a5a;--amber:#b67d18;--red:#d0392b;
  --shadow:0 14px 40px rgba(20,30,60,.14);
}
[data-theme="light"] body{background:radial-gradient(1200px 700px at 80% -10%,#ffffff 0%,var(--bg) 55%)}
[data-theme="light"] #login{background:radial-gradient(900px 500px at 50% -10%,#ffffff,#e7ecf3 62%)}
[data-theme="light"] .sidebar{background:linear-gradient(180deg,#ffffff,#f2f5f9)}
[data-theme="light"] .topbar{background:rgba(255,255,255,.85)}
[data-theme="light"] .ai-head{background:linear-gradient(135deg,#f5f7fa,#ffffff)}
[data-theme="light"] .belt-bar{border-color:rgba(0,0,0,.14)}
[data-theme="light"] .mini-belt .sw{border-color:rgba(0,0,0,.18)}
[data-theme="light"] .qa .av,[data-theme="light"] .sb-user .av,[data-theme="light"] .drill .num,[data-theme="light"] .ci-av,[data-theme="light"] .num{box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
[data-theme="light"] .ci-btn:hover{background:#d8b257}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:#cdd3dd}

/* ---------- CRUD: toolbar, buttons, forms, modal, toast ---------- */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line2);border-radius:10px;padding:10px 16px;font-size:13.5px;font-weight:600;color:var(--text);background:var(--panel2);transition:.15s}
.btn:hover{border-color:var(--gold)}
.btn.sm{padding:8px 13px;font-size:13px}
.btn.gold{background:var(--gold);color:#0a0b0e;border-color:var(--gold)}
.btn.gold:hover{background:var(--gold2)}
.btn.ghost{background:transparent}
.btn svg{width:15px;height:15px}
.btn .i14{width:14px;height:14px}
.ibtn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);color:var(--muted);transition:.14s;margin-left:4px;vertical-align:middle}
.ibtn:hover{border-color:var(--gold);color:var(--gold2);background:var(--panel2)}
.ibtn.danger:hover{border-color:var(--red);color:var(--red)}
.ibtn .i14{width:14px;height:14px}
.i14{width:14px;height:14px}
.dot.editable{cursor:pointer;transition:transform .12s}
.dot.editable:hover{transform:scale(1.45)}

.form{display:flex;flex-direction:column;gap:13px}
.form label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.02em}
.form label.check{flex-direction:row;align-items:center;gap:9px;font-size:13px;color:var(--text);font-weight:500}
.form input,.form select,.form textarea{font-family:inherit;background:var(--bg2);border:1px solid var(--line2);border-radius:10px;padding:11px 13px;color:var(--text);font-size:14px;outline:none;transition:.14s}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--gold)}
.form input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}

#modalWrap{position:fixed;inset:0;z-index:60}
.modal-backdrop{position:fixed;inset:0;background:rgba(5,6,9,.6);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .15s ease}
.modal{width:100%;max-width:480px;background:var(--panel);border:1px solid var(--line2);border-radius:16px;box-shadow:var(--shadow);max-height:90vh;overflow:auto;animation:pop .16s ease}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 6px}
.modal-head h3{font-size:17px;font-weight:700}
.modal-x{font-size:24px;line-height:1;color:var(--muted2);width:32px;height:32px;border-radius:8px;transition:.14s}
.modal-x:hover{background:var(--panel2);color:var(--text)}
.modal-body{padding:8px 20px 4px}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px 20px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}

#toastWrap{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:70;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--panel3);color:var(--text);border:1px solid var(--line2);border-radius:10px;padding:11px 18px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow);opacity:0;transform:translateY(10px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast.ok{border-color:rgba(54,192,138,.5)}
.toast.ok::before{content:"\2713  ";color:var(--green);font-weight:800}
.toast.err{border-color:rgba(224,86,74,.5)}
.toast.err::before{content:"!  ";color:var(--red);font-weight:800}

/* ---------- embed mode (showcase iframes) ---------- */
.embed .top-right{display:none}
.embed #ai-btn{bottom:14px;right:14px;width:48px;height:48px}
.embed .content{padding-bottom:30px}
