/* =====================================================================
   Forgeflow — style.css
   Ember-gold forge theme · neon accents · lesson engine classes included
   ===================================================================== */

/* ── Variables ── */
:root{
  --bg:        #0a0a0f;
  --surface:   #13131a;
  --surface2:  #1c1c28;
  --border:    #2a2a3d;
  --gold:      #f97316;
  --gold-soft: #fb923c;
  --red:       #ef4444;
  --blue:      #3b82f6;
  --green:     #22c55e;
  --muted:     #6b7280;
  --text:      #e5e7eb;
  --text-soft: #9ca3af;
  --radius:    10px;
  --shadow:    0 4px 24px rgba(0,0,0,0.4);
}

/* ── Reset ── */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ font-size:16px; }
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  line-height:1.65; min-height:100vh;
}
a{ color:var(--gold); text-decoration:none; }
a:hover{ text-decoration:underline; }
code,pre{ font-family:'JetBrains Mono',monospace; }
code{ background:var(--surface2); border:1px solid var(--border); border-radius:4px; padding:2px 6px; font-size:.85em; }

/* ── Buttons ── */
.btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 20px; border-radius:var(--radius); border:none;
  font-size:.9rem; font-weight:600; cursor:pointer;
  transition:all .15s; font-family:inherit; white-space:nowrap;
}
.btn-primary{ background:var(--gold); color:#000; }
.btn-primary:hover{ background:var(--gold-soft); }
.btn-secondary{ background:var(--surface2); color:var(--text); border:1px solid var(--border); }
.btn-secondary:hover{ border-color:var(--gold); color:var(--gold); }
.btn-ghost{ background:transparent; color:var(--text-soft); border:1px solid var(--border); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); }
.btn-forge{ background:linear-gradient(135deg,#f97316,#ef4444); color:#fff; }
.btn-forge:hover{ opacity:.9; }
.btn-forge.done{ background:var(--surface2); color:var(--green); border:1px solid var(--green); }
.btn-lg{ padding:14px 32px; font-size:1rem; border-radius:12px; }
.btn-sm{ padding:6px 12px; font-size:.8rem; }
.btn-icon{ padding:8px 12px; }
.btn-full{ width:100%; justify-content:center; }
.btn-google{
  width:100%; display:flex; align-items:center; justify-content:center; gap:10px;
  padding:12px; background:var(--surface2); border:1px solid var(--border);
  border-radius:var(--radius); color:var(--text); font-size:.9rem; font-weight:500;
  cursor:pointer; font-family:inherit; transition:all .15s;
}
.btn-google:hover{ border-color:var(--gold); }
.link-btn{ background:none; border:none; color:var(--gold); cursor:pointer; font-size:inherit; text-decoration:underline; }

/* ── Inputs ── */
.inp{
  width:100%; padding:11px 14px; background:var(--surface2); border:1px solid var(--border);
  border-radius:var(--radius); color:var(--text); font-size:.9rem; font-family:inherit;
  transition:border-color .15s; outline:none;
}
.inp:focus{ border-color:var(--gold); }

/* ── Toast ── */
.toast{
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--surface2); border:1px solid var(--border); border-radius:var(--radius);
  padding:12px 24px; font-size:.9rem; opacity:0; transition:all .2s; pointer-events:none; z-index:9999;
}
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ══════════════════════════════════════════
   LANDING
══════════════════════════════════════════ */
#viewLanding{ min-height:100vh; }

.land-nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 48px; border-bottom:1px solid var(--border); position:sticky; top:0;
  background:rgba(10,10,15,0.95); backdrop-filter:blur(12px); z-index:100;
}
.land-logo{ display:flex; align-items:center; gap:10px; font-size:1.2rem; font-weight:700; color:var(--gold); }
.land-nav-btns{ display:flex; gap:10px; }

.hero{
  text-align:center; padding:100px 24px 80px;
  background:radial-gradient(ellipse 80% 50% at 50% -20%, rgba(249,115,22,0.12), transparent);
}
.hero-kicker{ color:var(--gold); font-size:.85rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; margin-bottom:16px; }
.hero-title{ font-size:clamp(2.4rem,5vw,4rem); font-weight:800; line-height:1.1; margin-bottom:20px; }
.hero-sub{ max-width:600px; margin:0 auto 36px; color:var(--text-soft); font-size:1.1rem; }
.hero-actions{ display:flex; flex-direction:column; align-items:center; gap:12px; margin-bottom:24px; }
.hero-price{ color:var(--muted); font-size:.85rem; }
.hero-badges{ display:flex; flex-wrap:wrap; justify-content:center; gap:12px; }
.badge{ background:var(--surface2); border:1px solid var(--border); border-radius:100px; padding:6px 14px; font-size:.8rem; color:var(--text-soft); }

.features{ padding:80px 24px; max-width:1100px; margin:0 auto; }
.feat-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:24px; }
.feat-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:28px 24px; transition:border-color .15s; }
.feat-card:hover{ border-color:var(--gold); }
.feat-icon{ font-size:2rem; margin-bottom:12px; }
.feat-card h3{ font-size:1rem; font-weight:700; margin-bottom:8px; }
.feat-card p{ color:var(--text-soft); font-size:.9rem; }

.tiers-preview{ padding:60px 24px; max-width:1100px; margin:0 auto; }
.tiers-preview h2{ text-align:center; font-size:1.8rem; font-weight:800; margin-bottom:32px; }
.tier-cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.tier-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:28px 24px; }
.tier-card.featured{ border-color:var(--gold); background:linear-gradient(135deg,var(--surface),#1a1208); }
.tc-pill{ background:var(--gold); color:#000; border-radius:100px; padding:3px 10px; font-size:.75rem; font-weight:700; display:inline-block; margin-bottom:10px; }
.tier-card h3{ font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.tier-card p{ color:var(--text-soft); font-size:.9rem; }

.cta-section{ text-align:center; padding:80px 24px; background:linear-gradient(180deg,transparent,rgba(249,115,22,0.06)); }
.cta-section h2{ font-size:2rem; font-weight:800; margin-bottom:12px; }
.cta-section p{ color:var(--text-soft); margin-bottom:28px; }

.land-footer{ text-align:center; padding:32px; color:var(--muted); font-size:.85rem; border-top:1px solid var(--border); }

/* ══════════════════════════════════════════
   AUTH / PAYWALL
══════════════════════════════════════════ */
.auth-wrap{
  min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px;
  background:radial-gradient(ellipse 60% 60% at 50% 0%, rgba(249,115,22,0.08),transparent);
}
.auth-card{
  width:100%; max-width:420px; background:var(--surface); border:1px solid var(--border);
  border-radius:16px; padding:40px 36px; display:flex; flex-direction:column; gap:16px;
}
.auth-logo{ display:flex; align-items:center; justify-content:center; gap:10px; font-size:1.3rem; font-weight:800; color:var(--gold); }
.auth-card h2{ text-align:center; font-size:1.5rem; font-weight:800; }
.auth-divider{ display:flex; align-items:center; gap:12px; color:var(--muted); font-size:.8rem; }
.auth-divider::before,.auth-divider::after{ content:""; flex:1; height:1px; background:var(--border); }
.auth-switch{ color:var(--muted); font-size:.85rem; text-align:center; }

.price-card{ background:var(--surface2); border:1px solid var(--gold); border-radius:var(--radius); padding:28px; text-align:center; }
.price-amount{ font-size:3rem; font-weight:800; color:var(--gold); }
.price-amount span{ font-size:1.2rem; color:var(--muted); }
.price-list{ list-style:none; margin:16px 0 24px; display:flex; flex-direction:column; gap:8px; }
.price-list li{ color:var(--text-soft); font-size:.9rem; }

/* ══════════════════════════════════════════
   WORKSPACE
══════════════════════════════════════════ */
.workspace{ display:flex; height:100vh; overflow:hidden; }

.ws-sidebar{
  width:280px; flex-shrink:0; background:var(--surface); border-right:1px solid var(--border);
  display:flex; flex-direction:column; height:100vh; overflow:hidden;
}
.sidebar-top{ padding:16px; border-bottom:1px solid var(--border); }
.sb-logo{ display:flex; align-items:center; gap:8px; font-weight:700; color:var(--gold); font-size:1rem; margin-bottom:8px; }
.sb-user{ display:flex; align-items:center; gap:8px; font-size:.8rem; color:var(--muted); flex-wrap:wrap; }
.sidebar-scroll{ flex:1; overflow-y:auto; padding:8px; }
.sidebar-bottom{ padding:12px 16px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.support-link{ font-size:.8rem; color:var(--muted); }

.side-nav{ display:flex; flex-direction:column; gap:2px; margin-bottom:8px; }
.palette-h{ font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); padding:8px 12px 4px; }
.side-tier{ border-radius:var(--radius); overflow:hidden; margin-bottom:4px; }
.tier-label{ list-style:none; padding:10px 12px; cursor:pointer; font-size:.85rem; font-weight:600; color:var(--text-soft); user-select:none; display:flex; align-items:center; gap:8px; }
.tier-label:hover{ color:var(--text); }
.tier-pill{ background:var(--gold); color:#000; border-radius:100px; padding:2px 8px; font-size:.7rem; font-weight:700; }
.tier-count{ color:var(--muted); font-size:.75rem; }
.side-module{
  width:100%; background:none; border:none; color:var(--text-soft); text-align:left;
  padding:8px 12px; border-radius:8px; cursor:pointer; font-size:.82rem;
  display:flex; align-items:center; gap:8px; transition:all .1s; font-family:inherit;
}
.side-module:hover{ background:var(--surface2); color:var(--text); }
.side-module.active{ background:rgba(249,115,22,0.12); color:var(--gold); }
.side-module.done{ color:var(--green); }
.dot{ width:6px; height:6px; border-radius:50%; background:currentColor; flex-shrink:0; }
.mnum{ margin-left:auto; font-size:.72rem; color:var(--muted); }

.ws-main{ flex:1; display:flex; flex-direction:column; overflow:hidden; }
.ws-topbar{
  display:flex; align-items:center; gap:12px; padding:12px 24px;
  border-bottom:1px solid var(--border); background:var(--surface); flex-shrink:0;
}
.ws-crumbs{ font-size:.85rem; color:var(--muted); }
.ws-body{ flex:1; overflow-y:auto; padding:32px 40px; }

/* ══════════════════════════════════════════
   APP VIEWS
══════════════════════════════════════════ */
.dash-head{ margin-bottom:28px; }
.dash-head h1{ font-size:1.8rem; font-weight:800; margin-bottom:6px; }
.dash-head p{ color:var(--text-soft); }

.plan-widget{ margin-bottom:20px; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.plan-tag{ border-radius:100px; padding:4px 12px; font-size:.8rem; font-weight:600; }
.plan-tag.trial{ background:rgba(249,115,22,0.15); color:var(--gold); border:1px solid rgba(249,115,22,0.3); }
.plan-tag.pro{ background:rgba(34,197,94,0.12); color:var(--green); border:1px solid rgba(34,197,94,0.3); }

.stat-row{ display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:16px; margin-bottom:28px; }
.stat{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:20px; text-align:center; }
.num{ font-size:2rem; font-weight:800; color:var(--gold); }
.lbl{ font-size:.8rem; color:var(--muted); margin-top:4px; }

.continue-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:24px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.cc-kick{ font-size:.8rem; color:var(--gold); font-weight:600; margin-bottom:4px; }
.continue-card h3{ font-size:1.1rem; font-weight:700; margin-bottom:6px; }
.continue-card p{ color:var(--text-soft); font-size:.9rem; }

.module-view{ max-width:860px; }
.mv-kicker{ font-size:.8rem; color:var(--gold); font-weight:600; text-transform:uppercase; letter-spacing:.08em; margin-bottom:8px; }
.mv-title{ font-size:2rem; font-weight:800; margin-bottom:12px; }
.mv-intro{ color:var(--text-soft); margin-bottom:32px; max-width:600px; }

.lesson-list{ display:flex; flex-direction:column; gap:4px; margin-bottom:32px; }
.lesson-row{
  display:flex; align-items:center; gap:12px; padding:12px 16px;
  background:var(--surface); border:1px solid var(--border); border-radius:8px;
  cursor:pointer; transition:all .1s;
}
.lesson-row:hover{ border-color:var(--gold); }
.lesson-row.done{ border-color:var(--green); opacity:.8; }
.ls-num{ width:24px; text-align:right; color:var(--muted); font-size:.85rem; flex-shrink:0; }
.ls-name{ flex:1; font-size:.9rem; }
.ls-tick{ color:var(--green); font-size:.85rem; }

.quiz-row,.build-challenge{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:24px; margin-bottom:20px;
}
.quiz-row h3,.build-challenge h3{ font-size:1rem; font-weight:700; margin-bottom:8px; }
.quiz-row p,.build-challenge p{ color:var(--text-soft); font-size:.9rem; margin-bottom:16px; }
.done-badge{ background:rgba(34,197,94,0.12); color:var(--green); border-radius:100px; padding:2px 10px; font-size:.8rem; font-weight:600; }

.quiz-q{ margin-bottom:24px; }
.qtext{ font-weight:600; margin-bottom:10px; }
.opt-group{ display:flex; flex-direction:column; gap:8px; }
.opt-label{ display:flex; align-items:flex-start; gap:10px; cursor:pointer; color:var(--text-soft); font-size:.9rem; }
.opt-label input{ margin-top:3px; accent-color:var(--gold); }
.opt-label:hover{ color:var(--text); }

/* ══════════════════════════════════════════
   LESSON READER  (content engine classes)
══════════════════════════════════════════ */
.reader{ max-width:780px; }
.reader-body{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:32px 36px; margin:24px 0 28px; line-height:1.75;
}
.reader-body h2,.ls-h{
  font-size:1.15rem; font-weight:700; color:var(--gold);
  margin:28px 0 10px; padding-bottom:6px; border-bottom:1px solid var(--border);
}
.reader-body h2:first-child,.ls-h:first-child{ margin-top:0; }
.reader-body p{ margin-bottom:14px; color:var(--text); font-size:.95rem; }
.reader-body strong{ color:var(--gold-soft); }
.reader-body em{ color:var(--text-soft); font-style:italic; }
.reader-body code{ background:var(--surface2); border:1px solid var(--border); border-radius:4px; padding:2px 7px; font-size:.85em; color:#86efac; }

.ls-ul,.ls-ol{
  margin:10px 0 16px 20px; display:flex; flex-direction:column; gap:8px;
}
.ls-ul li,.ls-ol li{ font-size:.93rem; color:var(--text); }
.ls-ul li strong,.ls-ol li strong{ color:var(--gold-soft); }

.callout{
  background:rgba(249,115,22,0.08); border-left:3px solid var(--gold);
  border-radius:0 var(--radius) var(--radius) 0; padding:14px 18px; margin:18px 0;
  font-size:.9rem; color:var(--text);
}
.callout strong{ color:var(--gold); }

.reader-nav{ display:flex; gap:10px; flex-wrap:wrap; }

/* ── AI Tutor button (in lesson content) ── */
.ls-tutor{
  margin-top:32px; padding:20px 24px; background:linear-gradient(135deg,rgba(249,115,22,0.08),rgba(239,68,68,0.06));
  border:1px solid rgba(249,115,22,0.25); border-radius:var(--radius);
  display:flex; flex-direction:column; align-items:flex-start; gap:8px;
}
.ls-tutor-hint{ font-size:.8rem; color:var(--muted); }
.ff-tutor-btn{ font-size:.85rem; }

/* ══════════════════════════════════════════
   AI TUTOR MODAL
══════════════════════════════════════════ */
.tutor-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,0.75); backdrop-filter:blur(6px);
  z-index:1000; display:flex; align-items:flex-end; justify-content:center;
  padding:0 0 0 0;
}
.tutor-modal{
  width:100%; max-width:760px; height:80vh; background:var(--surface);
  border:1px solid var(--border); border-radius:16px 16px 0 0;
  display:flex; flex-direction:column; overflow:hidden;
}
.tutor-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.tutor-header h2{ font-size:1rem; font-weight:700; }
.tutor-close{ background:none; border:none; color:var(--muted); cursor:pointer; font-size:1.1rem; }
.tutor-close:hover{ color:var(--text); }
.tutor-subhead{ padding:10px 24px; background:var(--surface2); font-size:.82rem; color:var(--muted); flex-shrink:0; }
.tutor-body{
  flex:1; overflow-y:auto; padding:24px;
  font-size:.92rem; line-height:1.75;
}
.tutor-loading{ color:var(--muted); display:flex; align-items:center; gap:10px; }
.tutor-spinner{
  width:16px; height:16px; border:2px solid var(--border); border-top-color:var(--gold);
  border-radius:50%; animation:spin .6s linear infinite; flex-shrink:0;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.tutor-response{ white-space:pre-wrap; }
.tutor-response h2,.tutor-response h3{ color:var(--gold); margin:16px 0 8px; font-size:1rem; }
.tutor-response p{ margin-bottom:12px; }
.tutor-response ul,.tutor-response ol{ margin:8px 0 14px 20px; }
.tutor-response li{ margin-bottom:6px; }
.tutor-response code{ background:var(--surface2); border:1px solid var(--border); border-radius:4px; padding:2px 6px; font-size:.85em; color:#86efac; }
.tutor-response strong{ color:var(--gold-soft); }
.tutor-error{ color:var(--muted); }
.tutor-footer{
  padding:12px 16px; border-top:1px solid var(--border); flex-shrink:0;
  display:flex; gap:10px; align-items:flex-end;
}
.tutor-input{
  flex:1; padding:10px 14px; background:var(--surface2); border:1px solid var(--border);
  border-radius:8px; color:var(--text); font-family:inherit; font-size:.88rem; resize:none; outline:none;
}
.tutor-input:focus{ border-color:var(--gold); }

/* ══════════════════════════════════════════
   PLAN BADGES
══════════════════════════════════════════ */
.plan-badge{ border-radius:100px; padding:3px 10px; font-size:.72rem; font-weight:700; }
.plan-badge.trial{ background:rgba(249,115,22,0.15); color:var(--gold); border:1px solid rgba(249,115,22,0.3); }
.plan-badge.pro  { background:rgba(34,197,94,0.12); color:var(--green); border:1px solid rgba(34,197,94,0.3); }
.plan-badge.owner{ background:rgba(239,68,68,0.12); color:var(--red);   border:1px solid rgba(239,68,68,0.3); }

/* ══════════════════════════════════════════
   FORGE
══════════════════════════════════════════ */
.forge-panel{
  position:fixed; inset:0; background:var(--bg); z-index:500;
  display:flex; flex-direction:column;
}
.forge-panel[hidden]{
  display:none !important;
}
.forge-topbar{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;
  padding:10px 16px; background:var(--surface); border-bottom:1px solid var(--border); flex-shrink:0; gap:8px;
}
.forge-title{ font-size:.95rem; font-weight:700; color:var(--gold); }
.forge-toolbar{ display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.zoom-label{ font-size:.8rem; color:var(--muted); min-width:40px; text-align:center; }
.forge-layout{ display:flex; flex:1; overflow:hidden; }

.forge-palette{
  width:190px; flex-shrink:0; background:var(--surface); border-right:1px solid var(--border);
  overflow-y:auto; padding:8px;
}
.palette-chip{
  padding:8px 10px; border-radius:8px; cursor:pointer; font-size:.8rem; color:var(--text-soft);
  user-select:none; transition:all .1s; display:flex; align-items:center; gap:8px;
  border:1px solid transparent;
}
.palette-chip:hover{ background:var(--surface2); color:var(--text); border-color:var(--border); }

.forge-canvas-wrap{
  flex:1; position:relative; overflow:hidden; background:
    radial-gradient(circle,rgba(249,115,22,.04) 1px,transparent 1px);
  background-size:32px 32px; cursor:default;
}
.forge-svg{
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; transform-origin:0 0; overflow:visible;
}
.forge-world{ position:absolute; top:0; left:0; transform-origin:0 0; }

.forge-node{
  position:absolute; width:160px; background:var(--surface);
  border:2px solid var(--nc,var(--border)); border-radius:10px;
  cursor:move; user-select:none; box-shadow:0 2px 12px rgba(0,0,0,0.3);
  transition:box-shadow .1s;
}
.forge-node:hover{ box-shadow:0 4px 20px rgba(0,0,0,0.5); }
.forge-node.running{ box-shadow:0 0 20px var(--nc,var(--gold)); animation:pulse .4s ease; }
.forge-node.ran{ opacity:.7; }
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.6; } }

.fn-header{
  display:flex; align-items:center; gap:6px; padding:8px 10px;
  background:color-mix(in srgb,var(--nc,var(--border)) 15%,var(--surface));
  border-bottom:1px solid var(--border); border-radius:8px 8px 0 0;
}
.fn-icon{ font-size:1rem; flex-shrink:0; }
.fn-label{ font-size:.78rem; font-weight:600; flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.fn-del{ background:none; border:none; color:var(--muted); cursor:pointer; font-size:.8rem; padding:0; line-height:1; }
.fn-del:hover{ color:var(--red); }

.fn-ports{ display:flex; justify-content:space-between; padding:10px 10px 10px; }
.fn-in-port,.fn-out-port{
  width:12px; height:12px; border-radius:50%; border:2px solid var(--nc,var(--border));
  background:var(--bg); cursor:crosshair; transition:all .1s;
}
.fn-in-port:hover,.fn-out-port:hover{ background:var(--nc,var(--gold)); transform:scale(1.3); }

.forge-wire{
  fill:none; stroke:rgba(249,115,22,0.5); stroke-width:2;
  stroke-dasharray:0; marker-end:none;
}

.forge-log{
  width:220px; flex-shrink:0; background:var(--surface); border-left:1px solid var(--border);
  overflow-y:auto; padding:8px; font-size:.78rem;
}
.log-row{ padding:4px 6px; border-radius:4px; color:var(--text-soft); }
.log-row.ok{ color:var(--green); }
.log-row.warn{ color:var(--gold); }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:768px){
  .land-nav{ padding:12px 20px; }
  .hero{ padding:60px 20px 50px; }
  .ws-sidebar{
    position:fixed; left:-280px; top:0; height:100vh; z-index:200;
    transition:left .25s; box-shadow:none;
  }
  .ws-sidebar.open{ left:0; box-shadow:4px 0 24px rgba(0,0,0,0.5); }
  .ws-body{ padding:20px; }
  .tutor-modal{ height:90vh; }
  .forge-palette{ display:none; }
  .reader-body{ padding:20px; }
  .auth-card{ padding:28px 20px; }
}
