:root{
  --bg:#0f1420; --panel:#182030; --card:#1b2436; --card2:#212c44;
  --ink:#e8edf7; --muted:#94a3b8; --line:#2c3852;
  --green:#34d399; --red:#f87171; --amber:#fbbf24; --blue:#60a5fa; --violet:#a78bfa;
  --accent:#4f86f7; --gold:#F4B740; --teal:#2DD4A7;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;background:
  radial-gradient(1200px 600px at 80% -10%, #1b2a4a55, transparent), var(--bg);color:var(--ink)}
#topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#0f1420ee;backdrop-filter:blur(6px);z-index:5}
.brand{font-weight:800;letter-spacing:.3px}
.brand span{background:linear-gradient(135deg,var(--gold),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent}
#userbox{font-size:13px;color:var(--muted);display:flex;gap:10px;align-items:center}
.lang-sel{width:auto;padding:5px 8px;font-size:12px;background:#0d1422}
.auth-lang{position:absolute;top:14px;right:16px;z-index:6}

/* USER MENU */
.usermenu{position:relative}
.user-btn{display:flex;align-items:center;gap:8px;background:var(--card2);border:1px solid var(--line);color:var(--ink);padding:7px 12px;border-radius:9px;font-weight:600;font-size:13px}
.user-btn:hover{border-color:var(--accent)}
.user-btn .chev{color:var(--muted)}
.user-dd{position:absolute;right:0;top:calc(100% + 6px);min-width:170px;background:var(--card);border:1px solid var(--line);border-radius:11px;overflow:hidden;box-shadow:0 16px 36px -16px #000;z-index:30}
.user-item{display:block;width:100%;text-align:left;background:transparent;border:none;border-radius:0;color:var(--ink);padding:11px 14px;font-size:13px}
.user-item:hover{background:var(--card2)}

/* MODAL (Profile) */
.modal-backdrop{position:fixed;inset:0;background:rgba(4,8,18,.62);display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}
.modal{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 40px 90px -30px #000}
.modal-h{font-size:18px;font-weight:800;margin-bottom:14px}
.modal .auth-field{margin-bottom:12px}
.modal input,.modal select{padding:11px 12px;font-size:14px;border-radius:10px}
.modal input:focus,.modal select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #2dd4a733}
.pf-err{color:var(--red);font-size:13px;min-height:16px;margin-top:4px}
#app{padding:18px;max-width:1320px;margin:0 auto}
button{cursor:pointer;border:1px solid var(--line);background:var(--card2);color:var(--ink);padding:7px 12px;border-radius:8px;font-size:13px}
button:hover{border-color:var(--accent)}
button.primary{background:var(--accent);border-color:var(--accent);color:#04102b;font-weight:700}
button.ghost{background:transparent}
button.danger{border-color:#7f1d1d;color:#fca5a5}
button:disabled{opacity:.45;cursor:not-allowed}
input,select{background:#0d1422;border:1px solid var(--line);color:var(--ink);padding:7px 9px;border-radius:8px;font-size:13px;width:100%}
label{font-size:12px;color:var(--muted);display:block;margin:8px 0 3px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px}
.row{display:flex;gap:10px;flex-wrap:wrap}
.muted{color:var(--muted)}
.pos{color:var(--green)} .neg{color:var(--red)}
h1,h2,h3{margin:.2em 0}
.center{max-width:420px;margin:6vh auto}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.tabs button.active{background:var(--accent);color:#04102b;border-color:var(--accent)}

/* GAME LAYOUT */
.game-grid{display:grid;grid-template-columns:300px 1fr 360px;gap:14px;align-items:start}
.col h3{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:8px}
.pnl-line{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;border-bottom:1px dashed #ffffff10}
.pnl-line b{font-variant-numeric:tabular-nums}
.section{margin-bottom:14px}
.news-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.badge{font-size:11px;padding:2px 8px;border-radius:20px;border:1px solid var(--line)}
.badge.expansion{color:var(--green);border-color:#14532d}
.badge.peak{color:var(--amber);border-color:#78350f}
.badge.recession{color:var(--red);border-color:#7f1d1d}
.badge.recovery{color:var(--blue);border-color:#1e3a8a}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:right;padding:5px 6px;border-bottom:1px solid #ffffff0d}
th:first-child,td:first-child{text-align:left}
.market input{width:64px;display:inline-block}
.stat{display:flex;justify-content:space-between;font-size:13px;padding:2px 0}
.bar{height:7px;border-radius:6px;background:#0d1422;overflow:hidden;margin-top:2px}
.bar > i{display:block;height:100%;background:var(--accent)}
.panel-table td,.panel-table th{font-size:12px;padding:4px 5px}
.you-row{outline:1px solid var(--accent);outline-offset:-1px}
.finished{color:var(--amber);font-weight:700}
.note{font-size:12px;color:var(--muted);margin-top:6px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.kpi{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:8px 10px}
.kpi .v{font-size:18px;font-weight:800}
.kpi .l{font-size:11px;color:var(--muted)}
.endturn{position:sticky;bottom:0;padding:10px 0;margin-top:14px;background:var(--bg);border-top:1px solid var(--line);z-index:4}
#toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#04102b;border:1px solid var(--accent);padding:9px 16px;border-radius:10px;opacity:0;transition:.2s;pointer-events:none;font-size:13px;z-index:9}
#toast.show{opacity:1}
.gamecard{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--card2);margin-bottom:8px}
.spin{width:46px;height:46px;border:4px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:s 1s linear infinite;margin:18px auto}
@keyframes s{to{transform:rotate(360deg)}}
.scrollers{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:1100px){.game-grid{grid-template-columns:1fr}}
.game-grid2{display:grid;grid-template-columns:360px 1fr;gap:14px;align-items:start}
@media(max-width:1000px){.game-grid2{grid-template-columns:1fr}}
.mini{padding:1px 8px;font-size:14px;border-radius:6px;line-height:1.2}
.cmp-sel{width:auto;display:inline-block;padding:2px 6px;font-size:12px}

/* FINISH-YEAR PROGRESS BAR */
.finish-bar{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.finish-prog{flex:1;min-width:0}
.finish-track{height:9px;border-radius:6px;background:#0d1422;overflow:hidden}
.finish-track>i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--teal));transition:width .4s}
.finish-label{margin-top:6px;font-size:12px}
.finish-bar button.primary{flex:none;font-size:15px;padding:11px 22px}

/* NEWS BANNER */
.news-card{border-left:4px solid var(--line)}
.news-card.expansion{border-left-color:var(--green)}
.news-card.peak{border-left-color:var(--amber)}
.news-card.recession{border-left-color:var(--red)}
.news-card.recovery{border-left-color:var(--blue)}
.news-banner{display:flex;align-items:center;gap:13px}
.news-emoji{font-size:30px;width:50px;height:50px;flex:none;display:grid;place-items:center;background:#ffffff0d;border:1px solid var(--line);border-radius:13px}
.news-headline{min-width:0}
.news-phase{font-size:19px;font-weight:800}
.news-chips{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.news-chip{font-size:12px;font-weight:600;padding:4px 9px;border-radius:20px;border:1px solid var(--line);white-space:nowrap}
.news-chip.pos{color:var(--green);border-color:#14532d;background:#14532d22}
.news-chip.neg{color:var(--red);border-color:#7f1d1d;background:#7f1d1d22}
.news-story{margin-top:11px;line-height:1.55}

/* YEAR-BY-YEAR REPLAY */
.year-row{border:1px solid var(--line);border-radius:12px;padding:11px 13px;margin-bottom:8px;background:var(--card2)}
.year-head{display:flex;align-items:center;gap:8px}
.year-head b{font-size:15px}
.year-result{margin-left:auto;font-weight:800;font-variant-numeric:tabular-nums}
.year-stats{font-size:12px;margin-top:6px}
.year-time{font-size:12px;margin-top:5px;color:var(--blue)}
.year-acts{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.act-chip{font-size:12px;padding:3px 9px;border-radius:8px;border:1px solid var(--line);background:#0d1422}

/* REPLAY: P&L + Balance side by side */
.detail-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
@media(max-width:900px){.detail-2col{grid-template-columns:1fr}}
.yearnav{display:inline-flex;align-items:center;gap:8px}
.yearnav-lbl{font-weight:600;min-width:128px;text-align:center;font-size:13px}

/* 3-COLUMN GAME LAYOUT */
.game-grid3{display:grid;grid-template-columns:300px 1fr 300px;gap:14px;align-items:start}
@media(max-width:1200px){.game-grid3{grid-template-columns:1fr}}

/* ACTIONS ACCORDION */
.subcard{border:1px solid var(--line);border-radius:10px;margin-bottom:8px;overflow:hidden;background:#0d1422}
.subcard-head{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--card2);border:none;border-radius:0;padding:11px 13px;font-weight:600;color:var(--ink);font-size:14px}
.subcard-head:hover{background:#26324c}
.subcard.open .subcard-head{border-bottom:1px solid var(--line)}
.subcard .chev{color:var(--muted)}
.subcard-body{padding:12px 13px}
.sub-always{background:var(--card2)!important}

/* NEWS — THREE PARTS */
.news-part{padding:12px 0;border-top:1px solid var(--line)}
.news-part:first-child{padding-top:0;border-top:none}
.news-part-h{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:8px}
.news-rates{display:flex;flex-wrap:wrap;gap:6px 14px;margin-top:10px;font-size:12px;color:var(--muted)}
.news-rates b{color:var(--ink)}
.news-prices{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:560px){.news-prices{grid-template-columns:1fr}}
.price-block{background:#0d1422;border:1px solid var(--line);border-radius:9px;padding:8px}
.price-title{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;margin-bottom:4px}
.mini-prices{width:100%;border-collapse:collapse;font-size:12px}
.mini-prices td{padding:2px 3px;border-bottom:1px solid #ffffff08;text-align:right}
.mini-prices td:first-child{text-align:left}
.news-impact{margin:0;padding-left:18px;line-height:1.7;font-size:13px}
.news-impact li{margin-bottom:2px}

/* REGION PICKER (main page) */
.region-pick{display:inline-flex;align-items:center;gap:8px;margin-top:18px;background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:8px 14px}
.region-pick label{margin:0;font-size:13px;color:var(--muted)}
.region-pick select{width:auto;padding:8px 10px}

/* PROGRESS BARS */
.bar-label{font-size:12px;margin-bottom:5px;display:flex;gap:6px;align-items:center}
.year-track>i{background:linear-gradient(90deg,var(--blue),var(--violet))}

/* PROFESSION CARD */
.prof-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.prof-emoji{font-size:30px;width:46px;height:46px;display:grid;place-items:center;background:#ffffff0d;border:1px solid var(--line);border-radius:12px;flex:none}
.prof-name{font-size:17px;font-weight:800}
#prof-card .stat{padding:4px 0;border-bottom:1px dashed #ffffff10}
#prof-card .stat:last-child{border-bottom:none}

/* ---------- AUTH / LANDING ---------- */
body.auth-mode #topbar{display:none}
body.auth-mode #app{padding:0;max-width:none;margin:0}
.auth-wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}
.auth-hero{position:relative;display:flex;flex-direction:column;justify-content:center;padding:7vh 6vw;overflow:hidden;
  background:
    radial-gradient(760px 520px at 10% 18%, #F4B74024, transparent 60%),
    radial-gradient(760px 520px at 26% 96%, #2DD4A722, transparent 60%),
    linear-gradient(160deg,#0f1420,#0b0f18)}
.coins-badge{width:124px;margin-bottom:22px;animation:float 5s ease-in-out infinite}
.coins-badge svg{width:100%;height:auto;display:block;filter:drop-shadow(0 14px 26px #2dd4a74d)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.auth-title{font-size:clamp(34px,5vw,50px);font-weight:800;margin:0;letter-spacing:.5px}
.auth-title span{background:linear-gradient(135deg,var(--gold),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent}
.auth-tag{margin-top:8px;font-size:13px;font-weight:600;letter-spacing:4px;color:var(--muted)}
.auth-pitch{margin-top:20px;max-width:480px;color:#c7d2e3;line-height:1.65;font-size:15px}
.auth-feats{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:11px;max-width:480px}
.auth-feats li{display:flex;align-items:center;gap:12px;color:#c7d2e3;font-size:14px}
.auth-feats li span{flex:none;font-size:17px;width:30px;height:30px;display:grid;place-items:center;background:#ffffff10;border:1px solid var(--line);border-radius:9px}

.auth-panel{display:flex;align-items:center;justify-content:center;padding:6vh 5vw;background:var(--bg)}
.auth-card{width:100%;max-width:404px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:0 40px 80px -40px #000}
.seg{display:flex;gap:4px;background:#0d1422;border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:20px}
.seg button{flex:1;background:transparent;border:none;padding:10px;border-radius:9px;color:var(--muted);font-weight:600;font-size:13px}
.seg button:hover{color:var(--ink)}
.seg button.on{background:linear-gradient(135deg,var(--gold),var(--teal));color:#04102b}
.auth-h{font-size:20px;font-weight:800;margin:0 0 18px}
.auth-field{margin-bottom:13px}
.auth-field label{margin:0 0 6px}
.auth-card input,.auth-card select{padding:12px;font-size:14px;border-radius:10px}
.auth-card input:focus,.auth-card select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #2dd4a733}
.auth-go{width:100%;margin-top:8px;padding:14px;border:none;border-radius:12px;font-size:15px;font-weight:800;color:#04102b;
  background:linear-gradient(135deg,var(--gold),var(--teal));cursor:pointer;transition:transform .08s,box-shadow .2s;box-shadow:0 10px 28px -12px #2dd4a7cc}
.auth-go:hover{transform:translateY(-1px);box-shadow:0 16px 34px -12px #2dd4a7dd}
.auth-go:active{transform:translateY(0)}
.auth-go.loading,.auth-go:disabled{opacity:.7;cursor:progress;transform:none}
.auth-err{min-height:17px;margin-top:11px;font-size:13px;color:var(--red);opacity:0;transition:.15s}
.auth-err.show{opacity:1}
.auth-alt{margin-top:16px;text-align:center;font-size:13px;color:var(--muted)}
.auth-alt a{color:var(--teal);cursor:pointer;font-weight:600}
.auth-alt a:hover{text-decoration:underline}
@media(max-width:900px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-hero{padding:7vh 8vw 3vh;align-items:center;text-align:center}
  .auth-feats{display:none}
  .auth-pitch{font-size:14px}
  .auth-panel{padding:3vh 7vw 9vh}
}

/* ---- teaching mode ---- */
.teach-banner{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:linear-gradient(90deg,#21304a,#1b2436);border:1px solid var(--accent);border-radius:12px;padding:9px 14px;margin-bottom:12px;font-size:13px;font-weight:600;color:var(--ink)}
.link-btn{margin-left:auto;background:none;border:none;color:var(--blue);cursor:pointer;font-size:12px;padding:2px 4px;text-decoration:underline}
.su-toggle{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;cursor:pointer}
.su-toggle input{width:auto}
.lesson-modal{max-width:440px;text-align:left;border-color:var(--accent)}
.lesson-badge{display:inline-block;background:var(--accent);color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-bottom:12px}
.lesson-title{font-size:21px;font-weight:800;margin-bottom:10px;line-height:1.25}
.lesson-body{font-size:14px;line-height:1.6;color:var(--ink)}

/* ---- info icons + hover tooltips on P&L / Balance-Sheet lines ---- */
.info-i{position:relative;display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;margin-left:5px;border:1px solid var(--muted);color:var(--muted);border-radius:50%;font-size:9px;font-style:italic;font-weight:700;line-height:1;cursor:help;vertical-align:middle;font-family:Georgia,'Times New Roman',serif}
.info-i:hover,.info-i:focus{border-color:var(--blue);color:var(--blue);outline:none}
.info-i:hover::after,.info-i:focus::after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translateX(-50%);width:230px;background:#0b1322;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-size:12px;font-style:normal;font-weight:400;line-height:1.45;text-align:left;white-space:normal;box-shadow:0 14px 34px -12px #000;z-index:90;pointer-events:none}
.info-i:hover::before,.info-i:focus::before{content:'';position:absolute;left:50%;bottom:calc(100% + 2px);transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--line);z-index:90}

/* ---- inline action error + work-row job buttons ---- */
.inline-err{color:var(--red);font-size:12px;margin-left:4px}
.work-row{align-items:center}
.jobbtns{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
button.small{padding:5px 9px;font-size:12px}

/* ---- longer lesson cards: scroll + paragraph spacing ---- */
.lesson-modal{max-height:84vh;overflow-y:auto}
.lesson-body p{margin:0 0 9px}
.lesson-body p:last-child{margin-bottom:0}

/* ---- profession card living-cost breakdown ---- */
.stat.sub{padding:1px 0 1px 12px;font-size:12px;color:var(--muted)}
.stat.sub span:last-child{color:var(--ink)}

/* ================= Landing page ================= */
body.landing-mode #topbar{display:none}
body.landing-mode #app{padding:0;max-width:none;margin:0}
.lp{color:var(--ink)}
.lp a{cursor:pointer}
.lp-nav{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 28px;background:rgba(15,20,32,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.lp-brand{display:flex;align-items:center;gap:10px;font-size:19px}
.lp-brand b span{color:var(--gold)}
.lp-logo{width:34px;height:26px;display:inline-flex}
.lp-logo svg{width:100%;height:100%}
.lp-navlinks{display:flex;align-items:center;gap:18px}
.lp-navlinks a{color:var(--muted);font-size:14px;text-decoration:none}
.lp-navlinks a:hover{color:var(--ink)}
.lp-btn{border:1px solid var(--line);background:var(--card2);color:var(--ink);border-radius:10px;padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer}
.lp-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.lp-btn.ghost{background:transparent}
.lp-btn.big{padding:14px 26px;font-size:16px}
.lp-btn:hover{filter:brightness(1.08)}
.lp-lang select{padding:7px 8px;font-size:13px;border-radius:8px;background:var(--card2);color:var(--ink);border:1px solid var(--line)}

.lp-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;max-width:1140px;margin:0 auto;padding:64px 28px 40px}
.lp-eyebrow{color:var(--teal);font-weight:800;font-size:12px;letter-spacing:.12em;margin-bottom:14px}
.lp-hero h1{font-size:46px;line-height:1.08;margin:0 0 18px;font-weight:850;letter-spacing:-.01em}
.lp-hero p{color:#c7d2e3;font-size:17px;line-height:1.6;max-width:540px}
.lp-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.lp-trustline{margin-top:16px;color:var(--muted);font-size:13px}
.lp-hero-art{position:relative;min-height:300px}
.lp-card-float{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:0 40px 80px -40px #000;width:280px}
.lp-card-float.two{position:absolute;right:0;bottom:-26px;width:230px;border-color:var(--accent)}
.lp-mini-h{font-weight:800;font-size:13px;margin-bottom:10px;color:var(--muted)}
.lp-mini-row{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}
.lp-mini-row.tot{border-top:1px solid var(--line);margin-top:6px;padding-top:8px;font-weight:800}
.lp-bignum{font-size:30px;font-weight:850;color:var(--teal)}
.lp-spark{height:38px;margin:8px 0;border-radius:8px;background:linear-gradient(90deg,#1d2b46,#214a3e);position:relative;overflow:hidden}
.lp-spark::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:100%;background:linear-gradient(120deg,transparent 60%,#2dd4a755);clip-path:polygon(0 100%,15% 80%,35% 88%,55% 55%,75% 62%,100% 25%,100% 100%)}
.pos{color:var(--green)} .neg{color:var(--red)}

.lp-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 34px;padding:18px 28px;background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);color:var(--muted);font-size:14px;font-weight:600}
.lp-section{max-width:1080px;margin:0 auto;padding:58px 28px}
.lp-section.alt{background:var(--panel);max-width:none}
.lp-section.alt>*{max-width:1080px;margin-left:auto;margin-right:auto}
.lp-section h2{font-size:30px;font-weight:850;text-align:center;margin:0 0 8px}
.lp-sub{text-align:center;color:var(--muted);margin:0 0 26px}
.lp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:26px}
.lp-grid.two{grid-template-columns:repeat(2,1fr);max-width:760px;margin-left:auto;margin-right:auto}
.lp-feat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px}
.lp-ico{font-size:26px;margin-bottom:8px}
.lp-feat h3{margin:0 0 6px;font-size:16px}
.lp-feat p{margin:0;color:#b9c4d6;font-size:14px;line-height:1.55}
.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.lp-step{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;position:relative}
.lp-num{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;margin-bottom:10px}
.lp-step h3{margin:0 0 6px}.lp-step p{margin:0;color:#b9c4d6;font-size:14px;line-height:1.55}

.lp-prices{display:grid;grid-template-columns:repeat(2,minmax(0,340px));gap:20px;justify-content:center;margin-top:8px}
.lp-price{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;position:relative;display:flex;flex-direction:column}
.lp-price.feat{border-color:var(--gold);box-shadow:0 30px 70px -40px var(--gold)}
.lp-badge{position:absolute;top:-12px;right:18px;background:var(--gold);color:#1a1206;font-size:11px;font-weight:800;padding:4px 10px;border-radius:999px}
.lp-price-name{font-weight:800;font-size:15px;color:var(--muted)}
.lp-price-amt{font-size:34px;font-weight:850;margin:6px 0 14px}
.lp-price-amt span{font-size:15px;color:var(--muted);font-weight:600}
.lp-price-amt small{display:block;font-size:13px;color:var(--muted);font-weight:600}
.lp-price ul{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:9px;flex:1}
.lp-price li{padding-left:22px;position:relative;font-size:14px;color:#cdd8e8}
.lp-price li::before{content:'✓';position:absolute;left:0;color:var(--green);font-weight:800}
.lp-fineprint{margin-top:10px;color:var(--muted);font-size:12px;text-align:center}
.lp-final{text-align:center;padding:60px 28px}
.lp-final h2{font-size:28px;font-weight:850;margin:0 0 20px}
.lp-foot{border-top:1px solid var(--line);padding:26px 28px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 22px;color:var(--muted);font-size:13px;text-align:center}
.lp-foot-links{display:flex;gap:18px}
.lp-foot-links a{color:var(--muted);text-decoration:underline;cursor:pointer}
.lp-foot-note{flex-basis:100%;text-align:center;color:#6b7894;font-size:12px}

@media(max-width:860px){
  .lp-hero{grid-template-columns:1fr;padding-top:40px}
  .lp-hero h1{font-size:34px}
  .lp-hero-art{min-height:260px;margin-top:10px}
  .lp-navlinks a[href]{display:none}
  .lp-grid,.lp-grid.two,.lp-steps,.lp-prices{grid-template-columns:1fr}
}

/* auth consent + back link + legal modal */
.auth-check{display:flex;gap:9px;align-items:flex-start;font-size:12.5px;color:#c7d2e3;line-height:1.45;margin:2px 0 4px;cursor:pointer}
.auth-check input{width:auto;margin-top:2px}
.auth-check a{color:var(--blue);text-decoration:underline;cursor:pointer}
.auth-back{color:var(--muted);text-decoration:none;font-size:14px;margin-right:auto;cursor:pointer}
.auth-back:hover{color:var(--ink)}
.auth-lang{display:flex;align-items:center;gap:12px}
.legal-modal{max-width:600px;max-height:84vh;overflow-y:auto;text-align:left}
.legal-body{font-size:13.5px;line-height:1.6;color:#cdd8e8}
.legal-body h4{margin:16px 0 4px;font-size:14px;color:var(--ink)}
.legal-body p{margin:0 0 8px}
.legal-body a{color:var(--blue)}

/* ===== subscription / support / admin dialogs ===== */
.badge-prem{display:inline-block;background:var(--gold);color:#1a1206;font-size:10px;font-weight:800;padding:1px 7px;border-radius:999px;vertical-align:middle}
.user-item.admin{color:var(--gold)}
.badge-open{display:inline-block;background:#1f3a2e;color:var(--green);font-size:10px;font-weight:800;padding:1px 7px;border-radius:999px}
.badge-closed{display:inline-block;background:#3a2330;color:var(--muted);font-size:10px;font-weight:800;padding:1px 7px;border-radius:999px}

.sub-modal,.support-modal,.admin-modal{max-width:560px;max-height:86vh;overflow-y:auto;text-align:left}
.sub-status{font-size:16px;font-weight:800}
.sub-status.on{color:var(--gold)}
.sub-plans{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.sub-h{font-weight:800;font-size:13px;color:var(--muted);margin:18px 0 6px;border-top:1px solid var(--line);padding-top:12px}
.pay-table{width:100%;border-collapse:collapse;font-size:13px}
.pay-table td{padding:5px 4px;border-bottom:1px solid var(--line)}
.pay-table a{color:var(--blue)}

.sp-switches{display:flex;gap:16px;margin-bottom:12px;flex-wrap:wrap}
.sp-switches .sw{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}
.sp-switches input{width:auto}
.sp-new{display:grid;gap:8px;margin-bottom:14px}
.sp-new input,.sp-new textarea,.sp-reply textarea{width:100%;background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 11px;font-size:14px;font-family:inherit;box-sizing:border-box}
.sp-h{font-weight:800;font-size:13px;color:var(--muted);margin:6px 0}
.sp-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin-bottom:7px;cursor:pointer;color:var(--ink)}
.sp-item:hover{border-color:var(--accent)}
.sp-item-subj{font-weight:600;flex:1}
.sp-item-who{font-size:11px}
.sp-item-date{font-size:11px}
.sp-subj{font-size:16px;font-weight:800;margin:6px 0}
.sp-thread{display:grid;gap:8px;margin:10px 0;max-height:40vh;overflow-y:auto}
.sp-msg{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:14px}
.sp-msg.admin{border-color:var(--accent);background:#16233c}
.sp-msg b{font-size:12px;color:var(--muted)}
.sp-msg span{display:block;font-size:11px;margin-top:3px}
.sp-reply{display:flex;gap:8px;align-items:flex-start;margin-top:8px}
.sp-reply textarea{flex:1}

.seg2{display:flex;gap:6px;margin:12px 0}
.seg2 button{flex:1;background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:8px;font-weight:600;cursor:pointer}
.seg2 button.on{background:var(--accent);border-color:var(--accent);color:#fff}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{text-align:left;color:var(--muted);font-size:11px;border-bottom:1px solid var(--line);padding:5px 4px}
.admin-table td{padding:6px 4px;border-bottom:1px solid var(--line);vertical-align:top}
.admin-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.admin-filters select,.admin-filters input{background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:7px 9px;font-size:13px}
.admin-total{font-size:14px;margin-bottom:8px}
button.mini{background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:4px 9px;font-size:12px;cursor:pointer}
button.mini:hover{border-color:var(--accent)}

/* email-verification banner */
.verify-banner{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;background:#3a3320;border:1px solid var(--amber);color:#f4e3b0;border-radius:10px;padding:9px 14px;margin:14px auto 0;max-width:560px;font-size:13.5px}
.verify-banner .link-btn{color:var(--amber)}

/* admin email-test block */
.admin-mailtest{border-top:1px solid var(--line);margin-top:14px;padding-top:6px}
.admin-mailtest input{background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:8px 10px;font-size:13px}
