@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700;800;900&display=swap');

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overscroll-behavior:none;-webkit-font-smoothing:antialiased}

/* ── DARK (default) ──────────────────────────────────── */
:root{
  --orange:#E8895A;--orange-l:rgba(232,137,90,0.13);--orange-d:#D97757;--orange-b:rgba(232,137,90,0.28);
  --bg:#111110;--bg2:#1C1B1A;--bg3:#252422;
  --border:#2E2C29;--border-l:#222120;
  --text:#F0EDE8;--t2:#A09890;--t3:#605A55;
  --red:#E05555;--green:#5CAD7A;
  --sh:0 2px 12px rgba(0,0,0,0.35);--sh-md:0 6px 24px rgba(0,0,0,0.45);
  --lvlup-bg:rgba(17,17,16,0.96);
  --success-bg:rgba(92,173,122,0.1);--success-border:rgba(92,173,122,0.3);
  --gold:#E8895A;--gl:#D97757;--dark:#111110;--d2:#1C1B1A;--d3:#252422;--b:#2E2C29;
}

/* ── LIGHT ───────────────────────────────────────────── */
[data-theme="light"]{
  --orange:#D97757;--orange-l:#F5EDE7;--orange-d:#C0654A;--orange-b:#E8C4B0;
  --bg:#FAFAF8;--bg2:#FFFFFF;--bg3:#F0EAE3;
  --border:#E8E0D5;--border-l:#F5F0EB;
  --text:#1A1A1A;--t2:#6B6560;--t3:#9B948E;
  --red:#D95252;--green:#4A9B6F;
  --sh:0 2px 12px rgba(0,0,0,0.06);--sh-md:0 6px 24px rgba(0,0,0,0.10);
  --lvlup-bg:rgba(250,250,248,0.96);
  --success-bg:#F0FAF5;--success-border:#B8DCCA;
  --gold:#D97757;--gl:#E8976A;--dark:#FAFAF8;--d2:#FFFFFF;--d3:#F0EAE3;--b:#E8E0D5;
}

.app{max-width:430px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative}

/* ── HEADER ─────────────────────────────────────────── */
.hdr{padding:52px 20px 14px;background:var(--bg2);border-bottom:1px solid var(--border)}
.hdr-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.logo{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:3px;text-transform:uppercase}
.lvl-badge{background:var(--orange-l);border:1px solid #E8C4B0;border-radius:20px;padding:6px 14px;display:flex;align-items:center;gap:6px;cursor:pointer;transition:background 0.2s}
.lvl-badge:hover{background:#EEE3D9}
.lvl-num{font-size:16px;font-weight:800;color:var(--orange)}
.lvl-lbl{font-size:9px;color:var(--orange-d);text-transform:uppercase;letter-spacing:1px;font-weight:700}
.name-line{font-size:22px;font-weight:700;letter-spacing:-0.4px;margin-bottom:10px;color:var(--text)}
.xp-bar-wrap{position:relative;margin-bottom:2px}
.xp-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.xp-fill{height:100%;border-radius:2px;background:var(--orange);transition:width 0.8s ease}
.xp-lbl{display:flex;justify-content:space-between;font-size:10px;color:var(--t3);margin-top:5px;font-weight:500}

/* ── TABS ────────────────────────────────────────────── */
.tabs{display:flex;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.tab{flex:1;padding:10px 2px 8px;text-align:center;font-size:8.5px;font-weight:700;color:var(--t3);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s;text-transform:uppercase;letter-spacing:0.5px;display:flex;flex-direction:column;align-items:center;gap:3px}
.tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.tab-ic{font-size:18px}
.content{padding:20px 16px 48px;overflow-y:auto;height:calc(100dvh - 152px);-webkit-overflow-scrolling:touch}

/* ── CARDS ───────────────────────────────────────────── */
.card{background:var(--bg2);border-radius:16px;padding:18px;border:1px solid var(--border);margin-bottom:12px;box-shadow:var(--sh);transition:transform 0.2s ease,box-shadow 0.2s ease}
.card-interactive{cursor:pointer}
.card-interactive:hover{transform:scale(1.01);box-shadow:var(--sh-md)}
.card-interactive:active{transform:scale(0.99)}
.card-ttl{font-size:10px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:14px}
.sec-ttl{font-size:18px;font-weight:700;margin-bottom:18px;color:var(--text);letter-spacing:-0.3px}

/* ── AREA CARDS ──────────────────────────────────────── */
.area-card{border-radius:16px;padding:18px;margin-bottom:10px;border:1px solid var(--border);background:var(--bg2);cursor:pointer;transition:transform 0.2s ease,box-shadow 0.2s ease,border-color 0.2s;box-shadow:var(--sh)}
.area-card:hover{transform:scale(1.02);box-shadow:var(--sh-md)}
.area-card:active{transform:scale(0.98)}
.area-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.area-left{display:flex;align-items:center;gap:12px}
.area-icon{font-size:28px}
.area-name{font-size:15px;font-weight:700;color:var(--text)}
.area-sub{font-size:11px;color:var(--t3);margin-top:2px;font-weight:400}
.area-lvl{text-align:right}
.area-lvl-num{font-size:20px;font-weight:800}
.area-lvl-lbl{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.area-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.area-bar-fill{height:100%;border-radius:2px;transition:width 0.6s ease}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn{background:var(--orange);color:#fff;border:none;border-radius:24px;padding:15px 24px;font-size:15px;font-weight:600;cursor:pointer;width:100%;margin-bottom:10px;transition:background 0.2s,transform 0.1s,box-shadow 0.2s;font-family:inherit;letter-spacing:0.1px;box-shadow:0 2px 10px rgba(217,119,87,0.28)}
.btn:hover{background:var(--orange-d);box-shadow:0 4px 18px rgba(217,119,87,0.38)}
.btn:active{transform:scale(0.98);box-shadow:0 1px 4px rgba(217,119,87,0.2)}
.btn-o{background:transparent;color:var(--orange);border:1.5px solid var(--orange);box-shadow:none}
.btn-o:hover{background:var(--orange-l);box-shadow:none}
.btn-d{background:var(--bg2);color:var(--t2);border:1px solid var(--border);box-shadow:none}
.btn-d:hover{background:var(--bg3);box-shadow:none}
.btn-ghost{background:transparent;color:var(--t3);border:none;box-shadow:none;font-size:14px;padding:10px 24px;font-weight:500}
.btn-ghost:hover{color:var(--t2);box-shadow:none;background:transparent}
.btn-sm{padding:8px 16px;font-size:12px;margin-bottom:0;width:auto;border-radius:20px}
.btn-r{background:#FEF0EF;color:var(--red);border:1px solid #F8CACA;box-shadow:none}
.btn-r:hover{background:#FDE4E4;box-shadow:none}

/* ── TASK ITEMS ──────────────────────────────────────── */
.task-item{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border-l)}
.task-item:last-child{border-bottom:none}
.task-check{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.2s;font-size:12px;min-width:26px}
.task-check.done{background:var(--orange);border-color:var(--orange);color:#fff}
.task-body{flex:1}
.task-name{font-size:14px;font-weight:500;color:var(--text);line-height:1.4}
.task-name.done{text-decoration:line-through;color:var(--t3)}
.task-meta{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}
.task-area{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px}
.task-xp{font-size:11px;color:var(--orange);font-weight:700}

/* ── HABIT ITEMS ─────────────────────────────────────── */
.habit-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-l)}
.habit-row:last-child{border-bottom:none}
.habit-dot{width:32px;height:32px;border-radius:10px;border:1.5px solid var(--border);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all 0.2s;background:var(--bg)}
.habit-dot.done{border-color:var(--orange);background:var(--orange-l)}
.habit-info{flex:1}
.habit-name{font-size:13px;font-weight:600;color:var(--text)}
.habit-streak{font-size:11px;color:var(--t3);margin-top:2px;font-weight:400}
.habit-xp{font-size:11px;color:var(--orange);font-weight:700}

/* ── XP POP ──────────────────────────────────────────── */
.xp-pop{position:fixed;font-size:13px;font-weight:700;color:var(--orange);pointer-events:none;z-index:9999;opacity:0;transition:opacity 0.3s,transform 0.8s;background:var(--bg2);padding:4px 12px;border-radius:20px;border:1px solid var(--orange-b);box-shadow:var(--sh)}
.xp-pop.show{opacity:1;transform:translateY(-44px)}

/* ── LEVEL UP ────────────────────────────────────────── */
.lvlup-ov{position:fixed;inset:0;background:var(--lvlup-bg);z-index:2000;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:40px;backdrop-filter:blur(12px)}
.lvlup-num{font-size:88px;font-weight:900;color:var(--orange);line-height:1}
.lvlup-txt{font-size:26px;font-weight:800;margin:10px 0 4px;letter-spacing:-0.5px;color:var(--text)}
.lvlup-sub{font-size:15px;color:var(--t2);margin-bottom:32px}

/* ── CHECK-IN ────────────────────────────────────────── */
.checkin-ov{position:fixed;inset:0;background:var(--bg);z-index:1500;overflow-y:auto;padding:56px 28px 48px}
.ci-badge{display:inline-block;font-size:11px;font-weight:700;color:var(--orange);letter-spacing:2px;text-transform:uppercase;margin-bottom:28px}
.ci-emoji-big{font-size:56px;margin-bottom:16px;display:block;text-align:center}
.ci-title{font-size:24px;font-weight:700;margin-bottom:8px;letter-spacing:-0.4px;color:var(--text);text-align:center;line-height:1.2}
.ci-sub{font-size:14px;color:var(--t2);line-height:1.6;text-align:center;margin-bottom:24px;font-weight:400}
.ci-section-ttl{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px;letter-spacing:0.1px}
.mood-pills{display:flex;gap:8px;margin-bottom:32px;justify-content:center;flex-wrap:wrap}
.mood-pill{background:var(--bg2);border:1.5px solid var(--border);border-radius:40px;padding:10px 16px;cursor:pointer;text-align:center;transition:all 0.2s;display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--t2);white-space:nowrap;box-shadow:var(--sh)}
.mood-pill .em{font-size:18px}
.mood-pill.sel{border-color:var(--orange);background:var(--orange-l);color:var(--orange)}
.ci-input{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:16px;color:var(--text);font-size:14px;font-family:inherit;margin-bottom:16px;outline:none;resize:none;transition:border-color 0.2s;line-height:1.5}
.ci-input:focus{border-color:var(--orange)}
.ci-input::placeholder{color:var(--t3);font-weight:400}
.focus-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:28px}
.focus-btn{background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:14px 12px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all 0.2s;box-shadow:var(--sh);min-height:52px}
.focus-btn:hover{border-color:var(--orange)}
.focus-btn.sel{border-color:var(--orange);background:var(--orange);box-shadow:0 2px 10px rgba(217,119,87,0.3)}
.focus-btn .ic{font-size:20px;flex-shrink:0}
.focus-btn .nm{font-size:12px;font-weight:600;color:var(--text);line-height:1.2}
.focus-btn.sel .nm{color:#fff}

/* ── ONBOARDING ──────────────────────────────────────── */
.onb{position:fixed;inset:0;background:var(--bg);z-index:3000;overflow-y:auto;padding:56px 28px 48px}
.ob-logo{font-size:11px;font-weight:700;color:var(--orange);letter-spacing:3px;text-transform:uppercase;margin-bottom:32px}
.ob-title{font-size:28px;font-weight:800;margin-bottom:10px;letter-spacing:-0.5px;color:var(--text);line-height:1.15}
.ob-sub{font-size:15px;color:var(--t2);margin-bottom:32px;line-height:1.65;font-weight:400}
.ob-in{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:16px;color:var(--text);font-size:15px;font-family:inherit;margin-bottom:12px;outline:none;transition:border-color 0.2s;font-weight:400}
.ob-in:focus{border-color:var(--orange)}
.ob-in::placeholder{color:var(--t3)}
.ob-prog{display:flex;gap:6px;margin-bottom:36px}
.ob-dot{height:3px;border-radius:2px;flex:1;background:var(--border);transition:background 0.3s}
.ob-dot.act{background:var(--orange)}
.ob-opt{display:flex;align-items:center;justify-content:space-between;background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:10px;cursor:pointer;transition:all 0.2s;gap:12px;box-shadow:var(--sh)}
.ob-opt:hover{border-color:var(--orange);transform:translateX(2px)}
.ob-opt:active{transform:scale(0.98)}
.ob-opt.sel{border-color:var(--orange);background:var(--orange-l)}
.ob-opt strong{font-size:15px;font-weight:700;display:block;margin-bottom:2px;color:var(--text)}
.ob-opt span{font-size:12px;color:var(--t3)}
.ob-assess{display:flex;flex-direction:column}
.ob-q{padding:16px 0;border-bottom:1px solid var(--border-l)}
.ob-q:last-child{border-bottom:none}
.ob-q-text{font-size:14px;font-weight:600;margin-bottom:12px;line-height:1.5;color:var(--text)}
.ob-q-btns{display:flex;gap:8px}
.ob-q-btn{flex:1;padding:12px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg2);color:var(--t2);font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all 0.2s;font-family:inherit;box-shadow:var(--sh)}
.ob-q-btn.sel{border-color:var(--orange);color:var(--orange);background:var(--orange-l)}

/* ── CHAT ────────────────────────────────────────────── */
.chat-wrap{display:flex;flex-direction:column;height:calc(100dvh - 165px)}
.chat-msgs{flex:1;overflow-y:auto;padding:12px 4px;display:flex;flex-direction:column;gap:10px}
.msg{max-width:86%;padding:12px 16px;border-radius:18px;font-size:13px;line-height:1.65;font-weight:400}
.msg.bot{background:var(--bg2);border:1px solid var(--border);color:var(--text);align-self:flex-start;border-radius:4px 18px 18px 18px;box-shadow:var(--sh)}
.msg.user{background:var(--orange);color:#fff;align-self:flex-end;font-weight:500;border-radius:18px 4px 18px 18px}
.msg.bot strong{color:var(--orange)}
.chat-in-row{display:flex;gap:8px;padding:10px 0 6px}
.chat-in{flex:1;background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:12px;color:var(--text);font-size:14px;resize:none;height:46px;font-family:inherit;outline:none;transition:border-color 0.2s}
.chat-in:focus{border-color:var(--orange)}
.chat-in::placeholder{color:var(--t3)}
.chat-send{background:var(--orange);color:#fff;border:none;border-radius:14px;padding:12px 16px;font-weight:700;cursor:pointer;font-size:18px;flex-shrink:0;transition:background 0.2s;box-shadow:0 2px 8px rgba(217,119,87,0.3)}
.chat-send:hover{background:var(--orange-d)}
.chat-send:disabled{opacity:0.4;box-shadow:none}
.qrs{display:flex;gap:7px;flex-wrap:nowrap;margin-bottom:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.qr{background:var(--bg2);border:1.5px solid var(--border);color:var(--t2);border-radius:20px;padding:7px 14px;font-size:11px;cursor:pointer;font-weight:600;white-space:nowrap;flex-shrink:0;transition:all 0.2s}
.qr:hover{border-color:var(--orange);color:var(--orange)}
.typing{display:flex;gap:4px;align-items:center;padding:13px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:4px 18px 18px 18px;width:66px;box-shadow:var(--sh)}
.dot{width:6px;height:6px;background:var(--border);border-radius:50%;animation:bounce 1.2s infinite}
.dot:nth-child(2){animation-delay:0.2s}.dot:nth-child(3){animation-delay:0.4s}

/* ── STATS ───────────────────────────────────────────── */
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-l)}
.stat-row:last-child{border-bottom:none}

/* ── NOTIF ───────────────────────────────────────────── */
.notif{position:fixed;top:60px;left:50%;transform:translateX(-50%);background:var(--text);color:#fff;padding:11px 20px;border-radius:24px;font-size:13px;font-weight:600;z-index:9999;opacity:0;transition:opacity 0.3s;max-width:90vw;text-align:center;pointer-events:none;box-shadow:0 4px 20px rgba(26,26,26,0.18)}
.notif.show{opacity:1}

/* ── ACHIEVEMENT POPUP ───────────────────────────────── */
.ach-pop{position:fixed;bottom:90px;left:16px;right:16px;background:var(--bg2);border:1.5px solid var(--orange);border-radius:16px;padding:16px 18px;z-index:900;transform:translateY(120px);transition:transform 0.4s ease;display:flex;align-items:center;gap:14px;box-shadow:var(--sh-md)}
.ach-pop.show{transform:translateY(0)}

/* ── UTILS ───────────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.flt{display:flex;justify-content:space-between;align-items:center}
.gap8{display:flex;gap:8px}
.mb12{margin-bottom:12px}

/* ── ANIMATIONS ──────────────────────────────────────── */
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
@keyframes fu{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pop{0%{transform:scale(0.5);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.fu{animation:fu 0.4s ease-out}
.pop{animation:pop 0.4s ease}

/* ── LOGIN SCREEN ────────────────────────────────────── */
#loginOv{
  position:fixed;inset:0;z-index:4000;
  background:var(--bg);
  display:flex;align-items:stretch;justify-content:center;
  animation:fu 0.35s ease-out;
}
.login-screen{
  display:flex;flex-direction:column;
  width:100%;max-width:430px;
  padding:56px 32px 48px;
}
.login-top{margin-bottom:auto}
.login-center{flex:1;display:flex;flex-direction:column;justify-content:center;padding:32px 0}
.login-bottom{margin-top:auto}

/* ── AREA LETTER BADGE ───────────────────────────────── */
.area-ltr{border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;letter-spacing:-0.5px}

/* ── ACHIEVEMENT SYMBOL ──────────────────────────────── */
.ach-sym{border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0;letter-spacing:0.5px;text-transform:uppercase}

/* ── THEME TOGGLE ────────────────────────────────────── */
.theme-btn{background:var(--bg3);border:1px solid var(--border);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);flex-shrink:0;transition:background 0.2s,color 0.2s}
.theme-btn:hover{background:var(--border);color:var(--text)}
.theme-btn svg{display:block}

/* ── LEADERBOARD ─────────────────────────────────────── */
.lb-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border-l)}
.lb-row:last-child{border-bottom:none}
.lb-rank{font-size:13px;font-weight:800;width:28px;text-align:center;flex-shrink:0;color:var(--t3)}
.lb-rank.gold{color:#D4A017;font-size:16px}
.lb-rank.silver{color:#888;font-size:15px}
.lb-rank.bronze{color:#A0522D;font-size:14px}
.lb-rank.me{color:var(--orange)}
.lb-info{flex:1;min-width:0}
.lb-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-name.me{color:var(--orange)}
.lb-sub{font-size:10px;color:var(--t3);margin-top:1px}
.lb-xp{font-size:12px;font-weight:700;color:var(--orange);flex-shrink:0}
.lb-podium{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px;text-align:center}
.lb-pod-item{background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:14px 8px}
.lb-pod-item.p1{border-color:#D4A017;background:linear-gradient(135deg,#FFF9EC,#FFFFFF)}
.lb-pod-item.p2{border-color:#C0C0C0;background:linear-gradient(135deg,#F5F5F5,#FFFFFF)}
.lb-pod-item.p3{border-color:#A0522D;background:linear-gradient(135deg,#FDF0E8,#FFFFFF)}
.lb-pod-medal{font-size:24px;margin-bottom:4px}
.lb-pod-name{font-size:11px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-pod-xp{font-size:10px;color:var(--t3);margin-top:2px}
.lb-self-row{background:var(--orange-l);border:1.5px solid #E8C4B0;border-radius:12px;padding:12px 14px;margin-bottom:12px;display:flex;align-items:center;gap:10px}

/* ── LOGIN PROMPT SHEET ──────────────────────────────── */
.lp-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-radius:20px 20px 0 0;border-top:1.5px solid var(--border);padding:28px 24px 52px;z-index:3500;box-shadow:0 -8px 40px rgba(0,0,0,0.10);transform:translateY(100%);transition:transform 0.35s cubic-bezier(0.16,1,0.3,1);max-width:430px;margin:0 auto}
.lp-sheet.show{transform:translateY(0)}
.lp-close{position:absolute;top:16px;right:18px;background:var(--bg3);border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:12px;color:var(--t3);display:flex;align-items:center;justify-content:center}
.lp-emoji{font-size:40px;margin-bottom:12px}
.lp-title{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-0.3px;margin-bottom:8px}
.lp-sub{font-size:14px;color:var(--t2);line-height:1.65}
@media(min-width:640px){
  .lp-sheet{left:50%;right:auto;width:480px;border-radius:20px 20px 0 0;transform:translateX(-50%) translateY(100%)}
  .lp-sheet.show{transform:translateX(-50%) translateY(0)}
}

/* ── INSTALL TUTORIAL POPUP ──────────────────────────── */
.it-wrap{position:fixed;bottom:80px;left:16px;right:16px;background:var(--bg2);border-radius:20px;border:1.5px solid var(--border);padding:22px 20px 18px;z-index:3000;box-shadow:var(--sh-md);opacity:0;transform:translateY(16px);transition:opacity 0.3s,transform 0.3s;max-width:400px}
.it-wrap.show{opacity:1;transform:translateY(0)}
.it-close{position:absolute;top:12px;right:14px;background:var(--bg3);border:none;border-radius:50%;width:26px;height:26px;cursor:pointer;font-size:11px;color:var(--t3);display:flex;align-items:center;justify-content:center}
.it-os{font-size:30px;margin-bottom:6px}
.it-title{font-size:15px;font-weight:800;color:var(--text);margin-bottom:12px;letter-spacing:-0.2px}
.it-step{display:flex;gap:10px;align-items:flex-start;margin-bottom:9px}
.it-step-num{width:20px;height:20px;background:var(--orange-l);border-radius:50%;font-size:10px;font-weight:800;color:var(--orange);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.it-step-txt{font-size:12px;color:var(--t2);line-height:1.5}
.it-step-txt strong{color:var(--text);font-weight:700}
.it-bullet{font-size:12px;color:var(--t2);margin-bottom:7px;line-height:1.4}
.it-dots{display:flex;gap:5px;justify-content:center;margin-top:12px}
.it-dot{width:6px;height:6px;border-radius:50%;background:var(--border);transition:background 0.2s}
.it-dot.act{background:var(--orange)}
.it-btns{display:flex;gap:8px;margin-top:12px}
@media(min-width:640px){.it-wrap{left:auto;right:20px;bottom:20px;max-width:300px;margin:0}}

/* ── DESKTOP ─────────────────────────────────────────── */
@media(min-width:640px){
  body{display:flex;justify-content:center;align-items:flex-start}
  .app{max-width:480px;width:100%;box-shadow:0 0 0 1px var(--border),0 20px 60px rgba(0,0,0,0.06);min-height:100vh}
  .notif{max-width:460px}
  .ach-pop{max-width:460px;left:50%;transform:translateX(-50%) translateY(120px)}
  .ach-pop.show{transform:translateX(-50%) translateY(0)}
}
@media(min-width:900px){
  .app{max-width:520px}
}
