:root{--sb:#0f0f0f;--blue:#2563eb;--blue-lt:#eff6ff;--blue-dk:#1d4ed8;--brand:#b70100;--green:#16a34a;--green-lt:#ecfdf5;--amber-lt:#fffbeb;--red:#dc2626;--red-lt:#fef2f2;--text:#1a1a1a;--muted:#6b7280;--border:#e5e7eb;--bg:#f8f9fb;--white:#fff;--tbh:68px;--sbw:256px;--r:11px}
    *{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}
    body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--text);line-height:1.6;font-size:15px;background:var(--bg);-webkit-font-smoothing:antialiased}
    button,select,textarea{font:inherit}a{color:var(--blue);text-decoration:none}
    /* ══ TOPBAR ══ */
    .topbar{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--tbh);background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:2px solid var(--border);display:flex;align-items:center}
    .tb-logo{width:var(--sbw);flex-shrink:0;padding:0 20px;height:100%;display:flex;align-items:center;border-right:2px solid var(--border)}
    .logo-img{height:40px;width:auto;max-width:195px;display:block;object-fit:contain;object-position:left center}
    .tb-center{flex:1;padding:0 18px;display:flex;align-items:center;gap:14px}
    .tb-ring-wrap{position:relative;width:40px;height:40px;flex-shrink:0}
    .tb-ring-svg{width:40px;height:40px}
    .tb-ring-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--text)}
    .tb-prog-block{display:flex;flex-direction:column;gap:4px;min-width:130px}
    .tb-step-lbl{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap}
    .tb-rail{height:6px;background:#e5e7eb;border-radius:99px;overflow:hidden;min-width:100px}
    .tb-bar{height:100%;background:linear-gradient(90deg,var(--blue),#4f46e5);border-radius:99px;transition:width .6s cubic-bezier(.4,.2,.2,1)}
    .tb-dv{width:1px;height:28px;background:var(--border);flex-shrink:0}
    .tb-xp-block{display:flex;flex-direction:column;gap:3px;min-width:100px}
    .tb-xp-top{display:flex;align-items:center;gap:6px}
    .tb-lv-badge{padding:2px 7px;border-radius:99px;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
    .tb-xp-val{font-size:11.5px;font-weight:700;color:var(--text)}
    .tb-lv-name{font-size:10px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden}
    .tb-xp-bar-bg{height:4px;background:#e5e7eb;border-radius:99px;overflow:hidden;width:90px}
    .tb-xp-bar{height:100%;background:linear-gradient(90deg,#8b5cf6,#ec4899);border-radius:99px;transition:width .5s cubic-bezier(.4,.2,.2,1)}
    .tb-cd{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:var(--r);border:1.5px solid var(--border);background:var(--bg);min-width:90px;transition:.15s}
    .tb-cd.cd-ok{border-color:rgba(22,163,74,.3);background:rgba(22,163,74,.06)}
    .tb-cd.cd-warn{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.06)}
    @keyframes urgentPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}50%{box-shadow:0 0 0 5px rgba(239,68,68,0)}}
    .tb-cd.cd-urgent{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.06);animation:urgentPulse 1.8s ease-in-out infinite}
    .tb-cd.cd-overdue{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.06)}
    .tb-cd-icon{font-size:16px;flex-shrink:0;line-height:1}
    .tb-cd-val{font-size:14px;font-weight:800;letter-spacing:-.03em;line-height:1}
    .tb-cd.cd-ok .tb-cd-val{color:#16a34a}.tb-cd.cd-warn .tb-cd-val{color:#d97706}
    .tb-cd.cd-urgent .tb-cd-val,.tb-cd.cd-overdue .tb-cd-val{color:#dc2626}
    .tb-cd-sub{font-size:9.5px;color:var(--muted);font-weight:500}
    .tb-right{margin-left:auto;padding:0 14px;display:flex;gap:7px;align-items:center;flex-shrink:0}
    .tb-btn{padding:7px 14px;border-radius:var(--r);font-size:12.5px;font-weight:600;cursor:pointer;border:2px solid var(--border);background:var(--white);color:var(--text);transition:.15s;display:inline-flex;align-items:center;gap:5px;text-decoration:none;white-space:nowrap}
    .tb-btn:hover{background:var(--bg);text-decoration:none;transform:translateY(-1px)}
    .tb-btn.p{background:var(--blue);color:#fff;border-color:var(--blue)}.tb-btn.p:hover{background:var(--blue-dk)}
    .tb-btn.danger{color:#dc2626;border-color:rgba(220,38,38,.22)}.tb-btn.danger:hover{background:var(--red-lt)}
    .mob-btn{display:none;padding:6px 10px;border:2px solid var(--border);border-radius:var(--r);background:var(--white);font-size:12.5px;font-weight:600;cursor:pointer;color:var(--text)}
    .screen{display:none;}.screen.active{display:block}

    /* ══ SETUP ══ */
    .setup-split{display:grid;grid-template-columns:44fr 56fr;min-height:calc(100vh - var(--tbh))}
    .sl{background:var(--sb);padding:56px 52px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
    .sr{background:var(--bg);padding:52px 58px;display:flex;flex-direction:column;justify-content:center;overflow-y:auto}
    .sl-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden}
    .sl-blob{position:absolute;border-radius:50%}
    @keyframes floatA{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-24px) rotate(14deg)}}
    @keyframes floatB{0%,100%{transform:translateY(0) rotate(45deg)}50%{transform:translateY(20px) rotate(59deg)}}
    @keyframes floatC{0%,100%{transform:scale(1) rotate(0)}50%{transform:scale(1.08) rotate(-12deg)}}
    .s-tag{display:inline-block;padding:5px 14px;border-radius:99px;border:2px solid rgba(255,255,255,.1);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:18px}
    /* Typing cursor */
    @keyframes blinkCursor{0%,100%{opacity:1}50%{opacity:0}}
    .type-cursor{display:inline-block;width:3px;height:.82em;background:var(--brand);margin-left:2px;vertical-align:text-bottom;animation:blinkCursor .7s step-end infinite}
    /* H1 with First time larger */
    .s-h1{margin-bottom:16px; text-align: left;}
    .s-h1:after{display:none;}
    .s-h1-l1{display:block;font-size:clamp(44px,5.2vw,72px);font-weight:800;letter-spacing:-.05em;line-height:1.04;color:var(--brand)}
    .s-h1-l2{display:block;font-size:clamp(26px,3vw,42px);font-weight:800;letter-spacing:-.04em;line-height:1.08;color:#fff;margin-top:4px}
    .s-h1-l3{display:block;font-size:clamp(20px,2.2vw,30px);font-weight:600;letter-spacing:-.03em;line-height:1.12;color:rgba(255,255,255,.25);margin-top:6px}
    /* Subtitle — no max-width restriction */
    .s-sub{font-size:15px;color:rgba(255,255,255,.42);line-height:1.7;margin-bottom:36px;max-width:520px}
    .phases{display:flex;flex-direction:column;gap:12px}
    .ph{display:flex;align-items:flex-start;gap:12px}
    .ph-n{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.12);display:grid;place-items:center;font-size:11px;font-weight:700;color:rgba(255,255,255,.35);flex-shrink:0;margin-top:2px}
    .ph-t strong{display:block;font-size:14px;font-weight:600;color:rgba(255,255,255,.8)}.ph-t span{font-size:12px;color:rgba(255,255,255,.28)}
    .sr h2{font-size:22px;font-weight:700;letter-spacing:-.025em;margin:15px 0;}
    .fg{margin-bottom:10px}.fg>label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
    select{width:100%;padding:10px 34px 10px 13px;border:2px solid var(--border);border-radius:var(--r);background:var(--white);color:var(--text);outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%236b7280' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;font-size:14px;transition:.15s}
    select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
    .buyer-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
    .bc{border:2px solid var(--border);border-radius:var(--r);padding:12px 14px;cursor:pointer;background:var(--white);transition:.15s;text-align:left}
    .bc:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 4px 12px rgba(37,99,235,.1)}
    .bc.on{border-color:var(--blue);background:var(--blue-lt)}
    .bc strong{display:block;font-size:13.5px;font-weight:700;margin-bottom:2px}.bc span{font-size:11.5px;color:var(--muted);line-height:1.35}
    /* Slider timeline */
    .tl-slider-cont{padding:10px;border:2px solid var(--border);border-radius:var(--r);background:var(--white);transition:.2s}
    .tl-slider-cont.disabled{opacity:.4;pointer-events:none}
    .tl-val-row{display:flex;align-items:baseline;gap:8px;margin-bottom:12px}
    .tl-m-num{font-size:40px;font-weight:800;letter-spacing:-.05em;color:var(--blue);line-height:1}
    .tl-m-lbl{font-size:14px;color:var(--muted)}
    .tl-sep{font-size:18px;color:var(--border)}
    .tl-d-num{font-size:26px;font-weight:700;letter-spacing:-.04em;color:var(--text);line-height:1}
    .tl-d-lbl{font-size:12.5px;color:var(--muted)}
    input[type=range].tl-range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:99px;outline:none;cursor:pointer;margin-bottom:5px;background:linear-gradient(to right,var(--blue) 0%,var(--blue) 45%,#e5e7eb 45%)}
    input[type=range].tl-range::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 2px 6px rgba(37,99,235,.35);cursor:pointer;transition:transform .15s}
    input[type=range].tl-range::-webkit-slider-thumb:hover{transform:scale(1.2)}
    input[type=range].tl-range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--blue);border:3px solid #fff;cursor:pointer}
    .tl-ticks{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);padding:0 1px;margin-bottom:8px}
    .tl-note{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:4px}
    .tl-ns-check{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:13px;color:var(--muted);cursor:pointer}
    .tl-ns-check input{accent-color:var(--blue);width:16px;height:16px;cursor:pointer;flex-shrink:0}
    .start-btn{width:100%;padding:14px;border-radius:var(--r);background:var(--blue);color:#fff;border:none;font-size:16px;font-weight:700;cursor:pointer;margin-top:18px;transition:.15s;box-shadow:0 4px 0 #1d4ed8}
    .start-btn:hover{background:var(--blue-dk);transform:translateY(-2px);box-shadow:0 6px 0 #1e40af}
    .start-btn:active{transform:translateY(2px);box-shadow:0 2px 0 #1d4ed8}
    .s-note{font-size:11.5px;color:var(--muted);margin-top:12px;line-height:1.55}

    /* ══ TRACKER ══ */
    .tracker{display:flex;height:calc(100vh - var(--tbh)); padding-bottom: 35px;}
    .sidebar{width:var(--sbw);flex-shrink:0;background:var(--sb);display:flex;flex-direction:column;overflow:hidden}
    .sb-info-box{padding:16px 16px 12px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.07)}
    .sb-info-lbl{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:9px;display:flex;align-items:center;justify-content:space-between}
    .sb-edit{font-size:10.5px;color:rgba(255,255,255,.25);cursor:pointer;text-decoration:underline;background:none;border:none;padding:0;transition:.12s;font-weight:500}
    .sb-edit:hover{color:rgba(255,255,255,.6)}
    .sb-info-row{font-size:13px;color:rgba(255,255,255,.65);font-weight:500;margin-bottom:6px;line-height:1.35}
    .sb-info-row:last-child{margin-bottom:0}
    .sb-nav{flex:1;overflow-y:auto;padding:6px 8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.07) transparent}
    .ph-sep{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.2);padding:12px 8px 4px;display:block}
    .s-tab{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 10px;border-radius:10px;border:none;background:none;cursor:pointer;color:rgba(255,255,255,.42);font-size:12.5px;font-weight:400;transition:.15s;line-height:1.3}
    .s-tab:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.82);transform:translateX(3px)}
    .s-tab.cur{background:rgba(37,99,235,.22);color:#fff;font-weight:600}
    .s-tab-t{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .sn{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-size:10.5px;font-weight:700;background:rgba(255,255,255,.08);color:rgba(255,255,255,.35);transition:.2s}
    .sn.g{background:var(--green);color:#fff;transform:scale(1.1)}.sn.r{background:var(--red);color:#fff}.sn.c{background:var(--blue);color:#fff}
    .step-wrap{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0}
    .step-body{flex:1;padding:36px 44px 48px;position:relative}
    .step-deco-bg{position:absolute;top:0;right:0;bottom:0;width:45%;pointer-events:none;z-index:0;overflow:hidden}
    .deco-blob{position:absolute;border-radius:50%}

    /* ══ STEP GRID ══ */
    @keyframes stpIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
    .step-content-inner{animation:stpIn .22s cubic-bezier(.2,.8,.3,1) both;position:relative;z-index:1}
    .step-grid{display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:start}
    .step-aside{display:flex;flex-direction:column;gap:10px;position:sticky;top:calc(var(--tbh)+16px)}
    .step-ph-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
    .ph-badge{padding:4px 12px;border-radius:99px;font-size:10.5px;font-weight:700;background:var(--blue-lt);color:var(--blue);letter-spacing:.04em;text-transform:uppercase;border:1.5px solid rgba(37,99,235,.15)}
    .step-of{font-size:12px;color:var(--muted);font-weight:500}
    .step-title{font-size:clamp(26px,2.8vw,40px);font-weight:800;letter-spacing:-.04em;line-height:1.08;margin-bottom:14px}
    .step-intro{font-size:15px;color:#4b5563;line-height:1.78;margin-bottom:20px}
    .buyer-tip{border-radius:var(--r);margin-bottom:20px;border:2px solid;overflow:hidden}
    .buyer-tip[data-bt="gymOwner"]{border-color:rgba(37,99,235,.2);background:var(--blue-lt)}
    .buyer-tip[data-bt="distributor"]{border-color:rgba(22,163,74,.2);background:var(--green-lt)}
    .bt-head{display:flex;align-items:center;gap:8px;padding:10px 14px 8px}
    .bt-icon{font-size:18px;line-height:1;flex-shrink:0}
    .bt-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 9px;border-radius:99px}
    .buyer-tip[data-bt="gymOwner"] .bt-tag{background:rgba(37,99,235,.12);color:var(--blue)}
    .buyer-tip[data-bt="distributor"] .bt-tag{background:rgba(22,163,74,.12);color:var(--green)}
    .buyer-tip p{padding:0 14px 12px;font-size:13.5px;line-height:1.65;margin:0}
    .buyer-tip[data-bt="gymOwner"] p{color:#1e3a8a}.buyer-tip[data-bt="distributor"] p{color:#14532d}
    .c-note{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;border-radius:var(--r);background:var(--amber-lt);border:2px solid rgba(180,120,20,.22);margin-bottom:20px}
    .c-flag{font-size:32px;line-height:1;flex-shrink:0;margin-top:1px}
    .c-note-body{flex:1;min-width:0}
    .c-note-hd{font-size:11px;font-weight:700;color:#92400e;letter-spacing:.05em;text-transform:uppercase;margin-bottom:5px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.c-note-type{font-size:10px;font-weight:500;text-transform:none;letter-spacing:0;opacity:.65;font-style:italic}
    .c-note-body p{font-size:13.5px;color:#78350f;line-height:1.65;margin:0}
    .sec-lbl{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
    .ck-progress-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
    .ck-prog-bar{flex:1;height:8px;background:#e5e7eb;border-radius:99px;overflow:hidden;border:2px solid #e5e7eb}
    .ck-prog-fill{height:100%;background:linear-gradient(90deg,var(--green),#4ade80);border-radius:99px;transition:width .4s cubic-bezier(.4,.2,.2,1)}
    .ck-prog-txt{font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap;min-width:36px;text-align:right}
    .checklist{display:grid;gap:7px;margin-bottom:16px}
    @keyframes ckPop{0%{transform:scale(1)}35%{transform:scale(1.04)}70%{transform:scale(0.98)}100%{transform:scale(1)}}
    @keyframes ckGlow{0%{box-shadow:0 0 0 0 rgba(22,163,74,.45)}100%{box-shadow:0 0 0 9px rgba(22,163,74,0)}}
    .cl-it{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;border-radius:var(--r);border:2px solid var(--border);background:var(--white);cursor:pointer;transition:border-color .15s,background .15s,transform .15s;user-select:none}
    .cl-it:hover{border-color:#9ca3af;background:#fafafa;transform:translateY(-1px)}
    .cl-it.ck{background:var(--green-lt);border-color:rgba(22,163,74,.35);animation:ckPop .3s cubic-bezier(.2,.8,.3,1.3) both,ckGlow .5s ease-out both}
    .cl-cb{width:18px;height:18px;border-radius:5px;border:2px solid var(--border);flex-shrink:0;display:grid;place-items:center;transition:.15s}
    .cl-it.ck .cl-cb{background:var(--green);border-color:var(--green)}
    .cl-it:hover:not(.ck) .cl-cb{border-color:var(--green)}
    .cl-lbl{font-size:13.5px;color:#374151;line-height:1.45;flex:1}
    .cl-it.ck .cl-lbl{color:#6b7280;text-decoration:line-through;text-decoration-color:rgba(0,0,0,.2)}
    .step-tip{display:flex;gap:9px;align-items:flex-start;padding:13px 15px;border-radius:var(--r);background:var(--blue-lt);border:2px solid rgba(37,99,235,.15);font-size:13.5px;color:#1e3a8a;line-height:1.65;margin-top:16px}
    .step-tip svg{flex-shrink:0;margin-top:2px}
    /* ══ ASIDE ══ */
    .aside-widget{background:var(--white);border:2px solid var(--border);border-radius:16px;overflow:hidden}
    .aw-ring-row{display:flex;align-items:center;gap:14px;padding:16px 16px 12px}
    .aw-ring-wrap{position:relative;width:80px;height:80px;flex-shrink:0}
    .aw-ring{width:80px;height:80px}
    .prog-circle{transition:stroke-dashoffset .6s cubic-bezier(.4,.2,.2,1)}
    .aw-ring-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}
    .aw-step-n{font-size:24px;font-weight:800;letter-spacing:-.04em;color:var(--text)}
    .aw-step-of{font-size:9.5px;font-weight:600;color:var(--muted);margin-top:1px}
    .aw-meta{flex:1;min-width:0}
    .aw-phase-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--blue);margin-bottom:4px}
    .aw-done-ct{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
    .aw-est{font-size:12px;color:var(--muted)}
    .aw-ck-section{padding:0 16px 14px}
    .aw-ck-label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
    .aw-ck-bar-bg{height:6px;background:var(--border);border-radius:99px;overflow:hidden;margin-bottom:5px;border:2px solid var(--border)}
    .aw-ck-bar-fill{height:100%;background:linear-gradient(90deg,var(--green),#4ade80);border-radius:99px;transition:width .4s cubic-bezier(.4,.2,.2,1)}
    .aw-ck-nums{font-size:12px;font-weight:600;color:var(--muted)}
    .aside-det{background:var(--white);border:2px solid var(--border);border-radius:var(--r);overflow:hidden}
    .aside-det summary{padding:11px 14px;cursor:pointer;font-size:13px;font-weight:700;list-style:none;user-select:none;display:flex;align-items:center;gap:7px;transition:.12s}
    .aside-det summary:hover{background:var(--bg)}.aside-det[open] summary{border-bottom:2px solid var(--border);background:var(--bg)}
    .terms-det summary{color:var(--muted)}
    .yr-det{border-color:rgba(37,99,235,.2)}.yr-det summary{color:var(--blue)}
    .broker-det{border-color:rgba(22,163,74,.2)}.broker-det summary{color:var(--green)}
    .aside-det .tn{font-size:12.5px;font-weight:700;color:var(--text);padding:10px 14px 0}
    .aside-det .td{font-size:12.5px;color:var(--muted);line-height:1.55;padding:2px 14px 10px;margin:0}
    .aside-det ul{padding:10px 14px 12px;list-style:none;display:grid;gap:5px}
    .aside-det li{font-size:13px;color:#374151;padding-left:14px;position:relative;line-height:1.5}
    .aside-det li::before{content:"\2192";position:absolute;left:0;color:inherit;opacity:.6}
    .yr-det li{color:#1e3a8a}.broker-det li{color:#14532d}
    /* ══ ACTIONS ══ */
    .aside-actions{display:flex;flex-direction:column;gap:8px}
    @keyframes donePulse{0%,100%{transform:scale(1);box-shadow:0 4px 0 rgba(0,0,0,.1)}50%{transform:scale(1.02);box-shadow:0 4px 0 rgba(0,0,0,.1),0 0 18px rgba(22,163,74,.28)}}
    @keyframes doneAppear{0%{transform:scale(1)}40%{transform:scale(1.08)}70%{transform:scale(0.97)}100%{transform:scale(1)}}
    .done-btn{width:100%;padding:14px 16px;border-radius:var(--r);font-size:15px;font-weight:700;cursor:pointer;border:2px solid var(--border);background:var(--bg);color:var(--muted);display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 0 rgba(0,0,0,.1);transition:border-color .15s,background .15s,color .15s;animation:donePulse 2.5s ease-in-out infinite}
    .done-btn:hover{border-color:var(--green);color:var(--green);background:var(--green-lt);animation:none;transform:translateY(-2px);box-shadow:0 6px 0 rgba(22,163,74,.2)}
    .done-btn.active{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 4px 0 #15803d;animation:doneAppear .4s cubic-bezier(.2,.8,.3,1.3) both}
    .done-btn.active:hover{transform:translateY(-2px);box-shadow:0 6px 0 #15803d}
    /* Help button — i as superscript badge top-right */
    .help-wrap{position:relative}
    .help-btn{width:100%;padding:12px 16px;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;border:2px solid rgba(37,99,235,.2);background:var(--blue-lt);color:var(--blue);display:flex;align-items:center;justify-content:center;gap:7px;transition:.15s;box-shadow:0 3px 0 rgba(37,99,235,.12)}
    .help-btn:hover{background:#dbeafe;transform:translateY(-2px);box-shadow:0 5px 0 rgba(37,99,235,.18)}
    .help-i-anchor{position:absolute;top:-8px;right:-8px;z-index:20}
    .help-i-dot{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;background:var(--blue);color:#fff;font-size:10px;font-weight:800;font-style:italic;cursor:default;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2);line-height:1}
    .help-tt{display:none;position:absolute;bottom:calc(100% + 8px);right:-4px;width:220px;background:#111;color:#fff;font-size:12px;padding:9px 13px;border-radius:9px;line-height:1.55;z-index:100;box-shadow:0 4px 16px rgba(0,0,0,.3);font-style:normal;font-weight:500;pointer-events:none;text-align:left}
    .help-tt::after{content:'';position:absolute;top:100%;right:11px;border:6px solid transparent;border-top-color:#111}
    .help-i-anchor:hover .help-tt{display:block}
    /* Final step */
    .final-cta{padding:18px 16px;border-radius:14px;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);color:#fff;border:2px solid rgba(255,255,255,.08)}
    .final-title{font-size:17px;font-weight:800;margin-bottom:6px}
    .final-sub{font-size:12.5px;opacity:.75;line-height:1.55;margin-bottom:14px}
    .summary-btn{width:100%;padding:11px;border-radius:var(--r);font-size:14px;font-weight:700;cursor:pointer;background:#fff;color:var(--blue);border:none;transition:.15s;box-shadow:0 4px 0 rgba(0,0,0,.12)}
    .summary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 0 rgba(0,0,0,.16)}
    /* Nav bar */
    .step-nav{padding:14px 44px;border-top:2px solid var(--border);background:var(--white);flex-shrink:0;display:flex;align-items:center;gap:10px}
    .nav-b{padding:10px 18px;border-radius:var(--r);font-size:13.5px;font-weight:600;cursor:pointer;border:2px solid var(--border);background:var(--white);color:var(--text);transition:.15s;box-shadow:0 3px 0 rgba(0,0,0,.07)}
    .nav-b:hover:not(:disabled){background:var(--bg);transform:translateY(-1px);box-shadow:0 5px 0 rgba(0,0,0,.08)}
    .nav-b:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 0 rgba(0,0,0,.07)}
    .nav-b:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}
    .nav-b.nx{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 3px 0 #1d4ed8;margin-left:auto}
    .nav-b.nx:hover{background:var(--blue-dk);box-shadow:0 5px 0 #1e40af}
    .nav-step-txt{font-size:13px;font-weight:600;color:var(--muted)}
    /* ══ MODAL ══ */
    .modal-bg{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;padding:20px}.modal-bg.on{display:flex}
    @keyframes modalIn{from{opacity:0;transform:scale(.92) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
    .modal-box{background:var(--white);border-radius:20px;width:100%;max-width:580px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 80px rgba(0,0,0,.25);animation:modalIn .22s cubic-bezier(.2,.8,.3,1) both}
    .m-hd{padding:18px 22px;border-bottom:2px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
    .m-hd h3{font-size:17px;font-weight:700;letter-spacing:-.02em}.m-hd p{font-size:12.5px;color:var(--muted);margin-top:3px;line-height:1.5}
    .m-x{width:28px;height:28px;border:2px solid var(--border);background:var(--bg);border-radius:50%;cursor:pointer;font-size:9px;display:grid;place-items:center;color:var(--muted);flex-shrink:0;transition:.12s}
    .m-x:hover{background:var(--border)}.m-bd{flex:1;overflow-y:auto;padding:16px 22px}
    .m-how{background:var(--blue-lt);border:1.5px solid rgba(37,99,235,.15);border-radius:var(--r);padding:12px 14px;margin-bottom:14px;font-size:13px;color:#1e3a8a;line-height:1.6}
    .m-how strong{display:block;margin-bottom:4px;font-size:13.5px}
    .m-to{font-size:13px;color:var(--muted);margin-bottom:5px}.m-to strong{color:var(--text)}
    .m-subj{font-size:12px;color:var(--muted);margin-bottom:12px;word-break:break-word}.m-subj span{color:var(--text);font-weight:500}
    .m-ta{width:100%;border:2px solid var(--border);border-radius:var(--r);padding:12px 14px;font-size:13px;line-height:1.7;color:var(--text);resize:vertical;min-height:240px;outline:none;background:#fafafa;transition:.12s}
    .m-ta:focus{border-color:var(--blue);background:var(--white)}
    .m-ft{padding:14px 22px;border-top:2px solid var(--border);display:flex;gap:9px;align-items:center}
    .m-copy{padding:10px 18px;border-radius:var(--r);font-size:13.5px;font-weight:700;cursor:pointer;background:var(--blue);color:#fff;border:none;transition:.15s;box-shadow:0 3px 0 #1d4ed8}
    .m-copy:hover{background:var(--blue-dk);transform:translateY(-1px)}
    .m-note{margin-left:auto;font-size:11.5px;color:var(--muted)}
    /* ══ TOAST ══ */
    @keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
    .toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(10px);background:#111;color:#fff;padding:11px 18px;border-radius:12px;font-size:13.5px;font-weight:600;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;z-index:2000;white-space:nowrap;max-width:90vw;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(0,0,0,.25)}
    .toast.on{opacity:1;transform:translateX(-50%) translateY(0);animation:toastIn .25s cubic-bezier(.2,.8,.3,1) both}
    /* ══ DRAWER ══ */
    .ov{display:none;position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.5)}.ov.on{display:block}
    .drawer{position:fixed;left:0;top:0;bottom:0;width:260px;z-index:701;transform:translateX(-100%);transition:transform .24s;background:var(--sb);overflow-y:auto}.drawer.on{transform:translateX(0)}
    .dr-hd{display:flex;align-items:center;justify-content:space-between;padding:15px;border-bottom:1px solid rgba(255,255,255,.07)}
    .dr-hd strong{font-size:14.5px;font-weight:700;color:#fff}
    .dr-x{width:28px;height:28px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);border-radius:50%;cursor:pointer;font-size:15px;color:rgba(255,255,255,.5);display:grid;place-items:center;transition:.12s}
    .dr-x:hover{background:rgba(255,255,255,.15)}
    /* ══ SUMMARY ══ */
    .sum-page{padding:40px 52px 80px}
    .sum-hero{margin-bottom:28px}
    .sum-ey{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
    .sum-h{font-size:clamp(28px,3.5vw,42px);font-weight:800;letter-spacing:-.04em;margin-bottom:12px}
    .sum-meta{display:flex;flex-wrap:wrap;gap:8px}
    .sum-chip{padding:5px 13px;border-radius:99px;font-size:13px;font-weight:600;background:var(--bg);border:2px solid var(--border);color:var(--text)}
    .sum-chip.gn{background:var(--green-lt);border-color:rgba(22,163,74,.3);color:#14532d}
    .sum-chip.rd{background:var(--red-lt);border-color:rgba(220,38,38,.2);color:#991b1b}
    .sum-grid{display:grid;grid-template-columns:1fr 280px;gap:18px;align-items:start}
    .sum-main{display:flex;flex-direction:column;gap:16px}
    .sum-card{background:var(--white);border:2px solid var(--border);border-radius:16px;overflow:hidden}
    .sc-hd{padding:16px 22px;border-bottom:2px solid var(--border)}.sc-hd h3{font-size:15.5px;font-weight:700;letter-spacing:-.02em}.sc-hd p{font-size:12.5px;color:var(--muted);margin-top:3px}
    .sc-bd{padding:16px 22px}
    .sum-side{display:flex;flex-direction:column;gap:14px;position:sticky;top:20px}
    .sum-cta-card{background:var(--white);border:2px solid var(--border);border-radius:16px;overflow:hidden}
    .s-rows{display:grid;gap:7px}
    .sum-phase-hd{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);padding:8px 0 4px;margin-top:4px}
    .sum-phase-hd:first-child{margin-top:0;padding-top:0}
    .s-row{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:10px;border:2px solid var(--border);background:var(--bg);transition:.12s}
    .s-row:hover{border-color:#9ca3af;transform:translateY(-1px)}
    .rn{width:25px;height:25px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;background:#e5e7eb;color:var(--muted);flex-shrink:0}
    .rn.g{background:var(--green);color:#fff}.rn.r{background:var(--red);color:#fff}
    .rt{flex:1;font-size:13px;font-weight:500}
    .rb{font-size:12px;font-weight:700;padding:3px 9px;border-radius:6px;white-space:nowrap}
    .rb.g{background:var(--green-lt);color:#14532d}.rb.r{background:var(--red-lt);color:#991b1b}.rb.n{background:#f3f4f6;color:var(--muted)}
    .sum-content{display:grid;gap:2px}
    .bq-step{font-size:12.5px;font-weight:700;color:var(--text);padding:10px 0 4px;border-top:2px solid var(--border);margin-top:8px}
    .bq-step:first-child{border-top:none;margin-top:0;padding-top:0}
    .bq-item{font-size:13px;color:#4b5563;padding:4px 0 4px 16px;line-height:1.5}
    .sa{padding:10px 16px;border-radius:var(--r);font-size:13.5px;font-weight:600;cursor:pointer;border:2px solid var(--border);background:var(--white);color:var(--text);transition:.15s;display:inline-flex;align-items:center;text-decoration:none;box-shadow:0 3px 0 rgba(0,0,0,.06)}
    .sa:hover{background:var(--bg);text-decoration:none;transform:translateY(-1px)}.sa.p{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 3px 0 #1d4ed8}.sa.p:hover{background:var(--blue-dk)}
    /* ══ RESPONSIVE ══ */
    @media(max-width:1100px){.step-grid{grid-template-columns:1fr 260px;gap:28px}}
    @media(max-width:960px){.step-grid{grid-template-columns:1fr}.step-aside{position:static}.sidebar{display:none}.mob-btn{display:inline-flex}.tb-logo{width:auto;border-right:none}.step-body{padding:22px 20px 40px}.step-nav{padding:12px 20px}.tracker{height:auto}.step-wrap{overflow-y:visible}.sum-grid{grid-template-columns:1fr}.sum-side{position:static}.tb-center{display:none!important}}
    @media(max-width:640px){.setup-split{grid-template-columns:1fr}.sl{padding:44px 24px;min-height:45vh}.sr{padding:36px 20px}.buyer-row{grid-template-columns:1fr}.sum-page{padding:22px 16px 60px}}
    /* ══ PRINT: summary page only ══ */
    @media print{
        #setupScreen,#trackerScreen{display:none!important}
        #summaryScreen{display:block!important;padding-top:0!important}
        .topbar,.sidebar,.drawer,.ov,.step-nav,.modal-bg,.sum-side{display:none!important}
        .sum-page{padding:0;max-width:none}
        @page{margin:1.5cm}
    }
    .plan-note{font-size:12px;color:#6b7280;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;padding:9px 13px;margin-bottom:16px;font-style:italic;line-height:1.6}
    .setup-disclaimer{font-size:12px;color:#6b7280;line-height:1.65;padding:12px 14px;border-radius:var(--r);background:#f9fafb;border:1.5px solid #e5e7eb;}

    .seo-summary{background:#fff;border-top:1px solid #e5e7eb;padding:40px 52px;color:#374151}
    .seo-summary h2{font-size:24px;font-weight:700;line-height:1.25;margin-bottom:12px;color:#111827;letter-spacing:-.02em}
    .seo-summary h3{font-size:17px;font-weight:600;margin:22px 0 10px;color:#111827}
    .seo-summary p{max-width:900px;font-size:14px;line-height:1.7;margin-bottom:12px;color:#4b5563}
    .seo-summary ol{max-width:900px;padding-left:22px;display:grid;gap:6px}
    .seo-summary li{font-size:14px;line-height:1.6;color:#4b5563}
    @media(max-width:640px){.seo-summary{padding:28px 20px}}

    /* ══ MOBILE IMPROVEMENTS ══ */

    /* ── Tablet (≤960px): topbar when sidebar is hidden ── */
    @media(max-width:960px){
        .tb-right{gap:6px;padding:0 12px}
        .tb-btn{padding:7px 12px;font-size:12.5px}
        .mob-btn{display:inline-flex;padding:7px 11px;font-size:12.5px}
    }

    /* ── Phone (≤640px): major layout fixes ── */
    @media(max-width:640px){
        /* Topbar: compact buttons, avoid overflow */
        .tb-right{gap:5px;padding:0 10px}
        .tb-btn{padding:7px 10px;font-size:12px;white-space:nowrap}
        .mob-btn{padding:7px 9px;font-size:12px}

        /* Step title: readable on phone */
        .step-title{font-size:clamp(22px,6vw,32px);letter-spacing:-.03em}
        .step-intro{font-size:14px;line-height:1.7}

        /* Step nav: truncate long "Next:" title, hide middle label */
        .nav-step-txt{display:none}
        .nav-b{padding:9px 14px;font-size:13px}
        .nav-b.nx{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:54vw;font-size:13px}

        /* Checklist: min touch target 44px */
        .cl-it{padding:13px 14px;min-height:44px}
        .cl-cb{width:20px;height:20px}

        /* Done/Help buttons: min 48px touch target */
        .done-btn,.help-btn{min-height:48px;font-size:14px}

        /* Help tooltip: open to the left so it doesn't go off-screen */
        .help-i-anchor{top:-9px;right:-5px}
        .help-tt{right:auto;left:0;width:min(240px,85vw)}
        .help-tt::after{right:auto;left:14px}

        /* Aside widget: slightly more compact */
        .aw-ring-row{gap:10px;padding:14px 14px 10px}
        .aw-ck-section{padding:0 14px 12px}

        /* Aside details (terms/broker): full readable size */
        .aside-det summary{padding:12px 14px;font-size:13.5px;min-height:44px;align-items:center}
        .aside-det ul{padding:10px 14px 14px}
        .aside-det li{font-size:13.5px;line-height:1.55}

        /* Country note: smaller flag on phone */
        .c-flag{font-size:26px}
        .c-note-body p{font-size:13px}

        /* Buyer tip: compact */
        .buyer-tip p{font-size:13px;padding:0 12px 12px}

        /* Plan note */
        .plan-note{font-size:11.5px;padding:8px 12px}

        /* Setup form */
        .sr h2{font-size:20px}
        .tl-val-row{gap:6px}
        .tl-m-num{font-size:34px}
        .tl-d-num{font-size:22px}
        .setup-disclaimer{font-size:11.5px}

        /* Modal: full-screen friendly */
        .modal-bg{padding:8px}
        .modal-box{border-radius:16px;max-height:96vh}
        .m-hd{padding:14px 16px}
        .m-bd{padding:12px 16px}
        .m-ft{padding:12px 16px}
        .m-ta{min-height:200px;font-size:13px}

        /* Summary */
        .sum-h{font-size:clamp(24px,6vw,36px)}
        .sum-meta{gap:6px}
        .sum-chip{font-size:12px;padding:4px 10px}
        .sc-hd{padding:14px 16px}
        .sc-bd{padding:14px 16px}
        .s-row{padding:10px 12px;gap:8px}
        .rt{font-size:12.5px}

        /* SEO summary on mobile already handled, reinforce */
        .seo-summary h2{font-size:20px}
        .seo-summary h3{font-size:15px}
    }

    /* ── Very small phones (≤400px) ── */
    @media(max-width:400px){
        /* Topbar: show abbreviated Start Over */
        .tb-so-full{display:none}
        .tb-so-short{display:inline}

        /* Bigger touch on tiny screens */
        .cl-it{min-height:48px}
        .done-btn,.help-btn{min-height:52px}

        /* First screen title */
        .s-h1-l1{font-size:clamp(36px,10vw,48px)}
        .s-h1-l2{font-size:clamp(20px,5.5vw,28px)}
        .s-h1-l3{font-size:clamp(17px,4.5vw,24px)}

        /* Step nav: even shorter */
        .nav-b.nx{max-width:50vw}
        .nav-b{padding:8px 12px;font-size:12.5px}

        /* Summary chips: smaller */
        .sum-chip{font-size:11px;padding:3px 9px}
    }

    /* ── Range slider: larger thumb on all touch devices ── */
    @media(hover:none) and (pointer:coarse){
        input[type=range].tl-range{height:8px}
        input[type=range].tl-range::-webkit-slider-thumb{width:28px;height:28px;box-shadow:0 2px 8px rgba(37,99,235,.4)}
        input[type=range].tl-range::-moz-range-thumb{width:28px;height:28px}
        .cl-it{min-height:46px}
        .done-btn,.help-btn,.nav-b,.tb-btn,.mob-btn,.start-btn{min-height:44px}
    }
