:root {
  --bg:#f5f4f0;--surface:#ffffff;--border:#e0dfe8;--text:#1a1a2e;--muted:#8888aa;--dim:#c4c4d4;
  --c1:#ff6b6b;--c2:#ffd93d;--c3:#6bcb77;--c4:#4d96ff;--c5:#ff6bbd;--c6:#a06bff;--c7:#ff9f43;--c8:#48dbfb;
  --radius:16px;--font-disp:'Kaisei Decol',serif;--font-body:'Zen Kaku Gothic New',sans-serif;
}
[data-theme="dark"]{--bg:#0e0e12;--surface:#16161e;--border:#2a2a36;--text:#f0eff8;--muted:#6e6e88;--dim:#3a3a50;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:0.5;}
.screen { position:relative; z-index:1; display:none; opacity:0; transition:opacity 0.3s ease; }
.screen.active { display:flex; flex-direction:column; }
:focus-visible{outline:2px solid var(--c4);outline-offset:2px;}

/* ═══ TOP ═══ */
#screen-top{min-height:100vh;align-items:center;justify-content:center;padding:48px 24px;text-align:center;}
.top-badge{font-size:11px;letter-spacing:3px;color:var(--muted);margin-bottom:12px;}
.top-title{font-family:var(--font-disp);font-weight:700;font-size:clamp(28px,8vw,56px);line-height:1.15;background:linear-gradient(135deg,var(--c6) 0%,var(--c4) 50%,var(--c8) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px;}
.top-tagline{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:28px;max-width:340px;}
.btn-primary{font-family:var(--font-disp);font-weight:700;font-size:17px;padding:16px 48px;background:linear-gradient(135deg,var(--c6),var(--c4));border:none;border-radius:50px;color:#fff;cursor:pointer;box-shadow:0 8px 32px #a06bff44;transition:transform 0.15s,box-shadow 0.15s;}
.btn-primary:hover{transform:scale(1.04);box-shadow:0 12px 40px #a06bff66;}
.top-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;max-width:380px;width:100%;margin-bottom:20px;display:flex;flex-direction:column;gap:14px;}
.top-info-item{display:flex;align-items:flex-start;gap:12px;text-align:left;}
.top-info-icon{font-size:20px;flex-shrink:0;width:28px;text-align:center;margin-top:1px;}
.top-info-head{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px;}
.top-info-desc{font-size:11px;color:var(--muted);line-height:1.6;}
.top-how{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;max-width:380px;width:100%;margin-bottom:28px;text-align:left;}
.top-how-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:1px;}
.top-how-desc{font-size:12px;color:var(--muted);line-height:1.8;}
.top-note{font-size:11px;color:var(--dim);margin-top:16px;}
.top-link{display:inline-block;margin-top:20px;font-size:12px;color:var(--muted);text-decoration:none;}
.top-link:hover{color:var(--text);}
.partner-banner{background:linear-gradient(135deg,#ff6bbd18,#4d96ff18);border:1px solid #ff6bbd44;border-radius:var(--radius);padding:14px 20px;font-size:13px;color:var(--text);text-align:center;margin-bottom:24px;max-width:340px;line-height:1.7;}
.partner-banner strong{color:#c0408a;}
[data-theme="dark"] .partner-banner strong{color:#ff8fcc;}

/* ═══ MBTI ═══ */
#screen-mbti{min-height:100vh;align-items:center;justify-content:center;padding:40px 20px;text-align:center;}
.mbti-heading{font-family:var(--font-disp);font-weight:700;font-size:22px;margin-bottom:8px;}
.mbti-sub{font-size:13px;color:var(--muted);margin-bottom:28px;line-height:1.6;}
.mbti-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:380px;width:100%;margin-bottom:28px;}
.mbti-btn{padding:11px 4px;border:1.5px solid var(--border);border-radius:12px;background:var(--surface);cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--text);transition:all 0.15s;text-align:center;}
.mbti-btn:hover{border-color:var(--c6);background:var(--c6)08;}
.mbti-btn.selected{border-color:var(--c6);background:var(--c6)18;color:var(--c6);transform:scale(1.05);}
.mbti-group-label{font-size:10px;color:var(--dim);letter-spacing:1px;grid-column:1/-1;margin-top:8px;text-align:left;}
.mbti-skip{font-size:12px;color:var(--dim);cursor:pointer;background:none;border:none;text-decoration:underline;}

/* ═══ QUIZ ═══ */
#screen-quiz{min-height:100vh;padding:32px 20px 48px;max-width:520px;margin:0 auto;width:100%;}
.quiz-progress-wrap{margin-bottom:24px;}
.quiz-progress-label{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:8px;letter-spacing:1px;}
.quiz-progress-track{height:4px;background:var(--border);border-radius:2px;overflow:hidden;}
.quiz-progress-bar{height:100%;background:linear-gradient(90deg,var(--c6),var(--c4));border-radius:2px;transition:width 0.4s ease;}
.quiz-q-num{font-family:var(--font-disp);font-size:38px;color:var(--dim);line-height:1;margin-bottom:16px;}
.likert-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 22px 20px;margin-bottom:16px;}
.likert-labels{display:flex;justify-content:space-between;gap:16px;margin-bottom:20px;}
.likert-label{font-size:13px;font-weight:700;line-height:1.6;max-width:44%;overflow-wrap:anywhere;}
.likert-label.left{text-align:left;color:var(--c4);}
.likert-label.right{text-align:right;color:var(--c7);}
.likert-scale{display:flex;justify-content:space-between;align-items:center;padding:0 8px;}
.likert-dot{width:44px;height:44px;border-radius:50%;border:2.5px solid var(--border);background:var(--surface);cursor:pointer;transition:all 0.2s;flex-shrink:0;position:relative;}
.likert-dot:nth-child(3){width:34px;height:34px;border-style:dashed;}
.likert-dot:hover{border-color:var(--c6);transform:scale(1.12);box-shadow:0 0 16px var(--c6)22;}
.likert-dot.selected{background:var(--c6);border-color:var(--c6);transform:scale(1.18);box-shadow:0 0 20px var(--c6)44;}
.likert-hint{display:flex;justify-content:space-between;font-size:10px;color:var(--dim);margin-top:10px;padding:0 12px;}
.quiz-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.btn-back{display:flex;align-items:center;gap:6px;padding:6px 14px;background:none;border:1.5px solid var(--border);border-radius:20px;color:var(--muted);font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all 0.15s;}
.btn-back:hover{border-color:var(--text);color:var(--text);}
.btn-back:disabled{opacity:0.2;cursor:not-allowed;}
.quiz-timer-wrap{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:4px;}
.quiz-timer-bar{height:100%;background:linear-gradient(90deg,var(--c6),var(--c4));border-radius:2px;width:100%;transition:width 0.1s linear;}
.quiz-timer-bar.warn{background:linear-gradient(90deg,var(--c1),var(--c7));}
.quiz-timer-num{font-family:var(--font-disp);font-size:14px;font-weight:700;color:var(--dim);text-align:center;margin-bottom:8px;transition:color 0.3s;}
.quiz-timer-num.warn{color:var(--c1);}
.quiz-body{flex:1;display:flex;flex-direction:column;justify-content:center;}
.quiz-anim-enter{animation:slideIn 0.25s ease;}
@keyframes slideIn{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}

/* ═══ RESULT ═══ */
#screen-result{min-height:100vh;padding:0 0 80px;align-items:center;}
.result-hero{width:100%;padding:48px 24px 32px;text-align:center;position:relative;overflow:hidden;}
.result-hero-bg{position:absolute;inset:0;opacity:0.12;background:radial-gradient(circle at 50% 50%,var(--type-color,#a06bff) 0%,transparent 70%);}
.result-badge-text{font-size:11px;letter-spacing:3px;color:var(--muted);margin-bottom:12px;position:relative;}
.result-emoji{font-size:56px;margin-bottom:8px;line-height:1;position:relative;}
.result-type-name{font-family:var(--font-disp);font-weight:700;font-size:clamp(22px,6vw,40px);margin-bottom:6px;position:relative;}
.result-mbti-combo{font-size:15px;font-weight:700;color:var(--muted);margin-bottom:12px;position:relative;}
.result-catch{font-size:14px;color:var(--muted);max-width:320px;margin:0 auto;line-height:1.6;position:relative;}

.result-cards{width:100%;max-width:520px;margin:0 auto;padding:0 20px;}
.result-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;}
.result-card-head{padding:14px 18px 10px;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;letter-spacing:2px;color:var(--muted);}
.result-card-body{padding:16px 18px;font-size:14px;line-height:1.8;color:var(--text);}

/* Combo description */
.combo-desc{padding:18px;font-size:14px;line-height:1.9;color:var(--text);}

/* Aruaru */
.aruaru-list{padding:14px 18px;display:flex;flex-direction:column;gap:10px;}
.aruaru-item{display:flex;gap:10px;font-size:13px;line-height:1.6;color:var(--text);}
.aruaru-icon{font-size:18px;flex-shrink:0;margin-top:1px;}

/* Scatter */
.scatter-body{padding:16px;position:relative;}
.scatter-canvas-wrap{position:relative;width:100%;aspect-ratio:1;}
.scatter-canvas{width:100%;height:100%;}
.scatter-axis-label{position:absolute;font-size:10px;font-weight:700;color:var(--dim);}
.scatter-axis-label.left{left:4px;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:center;}
.scatter-axis-label.right{right:4px;top:50%;transform:translateY(-50%) rotate(90deg);transform-origin:center;}
.scatter-axis-label.top{top:2px;left:50%;transform:translateX(-50%);}
.scatter-axis-label.bottom{bottom:2px;left:50%;transform:translateX(-50%);}
.scatter-quadrant-desc{padding:12px 18px;font-size:13px;color:var(--muted);line-height:1.7;border-top:1px solid var(--border);}

/* Compat */
.compat-section{padding:14px 18px;}
.compat-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--dim);}
.compat-row:last-child{border-bottom:none;}
.compat-emoji{font-size:24px;flex-shrink:0;}
.compat-info{flex:1;}
.compat-name{font-size:13px;font-weight:700;}
.compat-why{font-size:11px;color:var(--muted);line-height:1.5;margin-top:2px;}
.compat-badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;flex-shrink:0;}
.compat-badge.best{background:#6bcb7722;color:#2a9440;}
.compat-badge.good{background:#4d96ff22;color:#4d96ff;}
.compat-badge.spark{background:#ff6b6b22;color:#ff6b6b;}
[data-theme="dark"] .compat-badge.best{color:#3fb950;}
[data-theme="dark"] .compat-badge.good{color:#79b8ff;}
[data-theme="dark"] .compat-badge.spark{color:#f85149;}

/* Weight bars */
.weight-bars{padding:12px 18px 16px;}
.weight-row{margin-bottom:10px;}
.weight-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.weight-label{font-size:12px;font-weight:700;}
.weight-val{font-size:12px;font-weight:700;color:var(--c6);}
.weight-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.weight-fill{height:100%;background:var(--c6);border-radius:3px;transition:width 0.6s ease;}
.dna-desc{padding:12px 16px 4px;font-size:14px;color:var(--muted);line-height:1.7;}
.top4-list{padding:8px 16px 16px;display:flex;flex-direction:column;gap:10px;}
.top4-row{display:flex;align-items:center;gap:10px;animation:fadeInUp 0.4s both;}
.top4-rank{font-size:18px;width:28px;flex-shrink:0;text-align:center;}
.top4-info{flex:1;min-width:0;}
.top4-label{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px;}
.top4-bar-wrap{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.top4-bar{height:100%;border-radius:3px;transition:width 0.7s ease;}
.top4-val{font-size:12px;font-weight:700;color:var(--muted);width:36px;text-align:right;flex-shrink:0;}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Share */
.share-section{padding:16px 18px;display:flex;flex-direction:column;gap:10px;}
.btn-share{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font-disp);font-weight:700;font-size:14px;color:#fff;transition:transform 0.15s;}
.btn-share:hover{transform:scale(1.02);}
.btn-share.compare{background:linear-gradient(135deg,var(--c5),var(--c4));}
.btn-share.x-share{background:#14171A;}
.btn-share.line-share{background:#06C755;}
.btn-retry{width:100%;padding:12px;border-radius:var(--radius);background:none;border:1.5px solid var(--border);cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:700;color:var(--muted);transition:all 0.15s;margin-top:4px;}
.btn-retry:hover{border-color:var(--text);color:var(--text);}
.btn-link{display:inline-block;margin-top:8px;font-size:12px;color:var(--muted);text-decoration:none;text-align:center;}
.btn-link:hover{color:var(--text);}

/* Toast */
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%);background:var(--c6);color:#fff;padding:10px 24px;border-radius:50px;font-weight:700;font-size:13px;opacity:0;transition:opacity 0.3s;z-index:100;pointer-events:none;white-space:nowrap;}
.toast.show{opacity:1;}

/* Theme */
.theme-toggle{position:fixed;top:16px;right:16px;z-index:999;}
.toggle-switch{position:relative;width:44px;height:24px;cursor:pointer;display:block;}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute;}
.toggle-track{position:absolute;inset:0;background:var(--border);border-radius:24px;transition:background 0.25s;}
.toggle-switch input:checked+.toggle-track{background:#6e6e88;}
.toggle-thumb{line-height:1;position:absolute;top:3px;left:3px;width:18px;height:18px;background:var(--surface);border-radius:50%;transition:transform 0.25s;display:flex;align-items:center;justify-content:center;font-size:11px;box-shadow:0 1px 4px rgba(0,0,0,0.2);}
.toggle-switch input:checked~.toggle-thumb{transform:translateX(20px);}

.site-footer{width:100%;max-width:520px;margin:32px auto 0;padding:24px 20px;text-align:center;font-size:11px;color:var(--dim);line-height:2;}
.site-footer a{color:var(--muted);text-decoration:none;}
.site-footer a:hover{color:var(--text);}

/* Fade in stagger */
.fade-in{animation:fadeIn 0.5s ease both;}
@keyframes fadeIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

/* Restore code card */
.code-card{padding:18px;text-align:center;}

/* City stories */
.city-stories{padding:4px 0;}
.city-card{padding:16px 18px;border-bottom:1px solid var(--border);}
.city-card:last-child{border-bottom:none;}
.city-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.city-badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;flex-shrink:0;}
.city-badge.best{background:#6bcb7722;color:#2a9440;}
.city-badge.surprise{background:#a06bff22;color:#a06bff;}
.city-badge.challenge{background:#ff6b6b22;color:#ff6b6b;}
[data-theme="dark"] .city-badge.best{color:#3fb950;}
[data-theme="dark"] .city-badge.surprise{color:#c49bff;}
[data-theme="dark"] .city-badge.challenge{color:#f85149;}
.city-name{font-family:var(--font-disp);font-weight:700;font-size:18px;}
.city-score{font-size:11px;color:var(--dim);margin-left:auto;}
.city-story{font-size:13px;line-height:1.8;color:var(--text);}
.city-shuffle-btn{background:none;border:1.5px solid var(--border);border-radius:20px;padding:3px 10px;font-size:12px;cursor:pointer;color:var(--muted);transition:all 0.15s;}
.city-shuffle-btn:hover:not(:disabled){border-color:var(--c6);color:var(--c6);transform:scale(1.05);}
.city-shuffle-btn:disabled{opacity:0.35;cursor:default;}
.break-overlay{position:fixed;inset:0;background:rgba(10,10,20,0.75);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.35s;backdrop-filter:blur(4px);}
.break-overlay.show{opacity:1;pointer-events:all;}
.break-box{background:var(--surface);border-radius:var(--radius);padding:36px 28px 28px;width:88%;max-width:340px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,0.3);}
.break-phase{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:3px;text-transform:uppercase;margin-bottom:10px;}
.break-title{font-family:var(--font-disp);font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text);}
.break-msg{font-size:12px;color:var(--muted);line-height:1.8;margin-bottom:24px;}
.break-ring{position:relative;width:72px;height:72px;margin:0 auto 24px;}
.break-svg{width:72px;height:72px;transform:rotate(-90deg);}
.break-track{fill:none;stroke:var(--border);stroke-width:3;}
.break-prog{fill:none;stroke:var(--c6);stroke-width:3;stroke-linecap:round;stroke-dasharray:113;stroke-dashoffset:0;transition:stroke-dashoffset 1s linear;}
.break-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;font-family:var(--font-disp);color:var(--c6);}
.break-skip-btn{font-size:14px;padding:12px 32px;}
.axis-info-btn{background:none;border:1.5px solid var(--border);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;cursor:pointer;color:var(--muted);font-family:var(--font-body);transition:all 0.15s;}
.axis-info-btn:hover{border-color:var(--c6);color:var(--c6);}
.axis-modal{background:var(--surface);border-radius:var(--radius);width:92%;max-width:420px;max-height:82vh;display:flex;flex-direction:column;overflow:hidden;}
.axis-modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;font-weight:700;font-size:15px;font-family:var(--font-disp);border-bottom:1px solid var(--border);}
.axis-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);padding:0 4px;}
.axis-modal-body{overflow-y:auto;padding:12px 16px 20px;display:flex;flex-direction:column;gap:14px;}
.axis-item{display:flex;gap:12px;align-items:flex-start;}
.axis-icon{font-size:22px;width:32px;flex-shrink:0;margin-top:1px;}
.axis-name{font-weight:700;font-size:14px;margin-bottom:3px;color:var(--text);}
.axis-desc{font-size:12px;color:var(--muted);line-height:1.7;}
.code-label{font-size:12px;color:var(--muted);margin-bottom:10px;}
.code-display{font-family:monospace;font-size:28px;font-weight:700;letter-spacing:6px;color:var(--c6);background:var(--bg);border:2px dashed var(--border);border-radius:12px;padding:12px 20px;display:inline-block;cursor:pointer;transition:all 0.15s;user-select:all;}
.code-display:hover{border-color:var(--c6);background:var(--c6)08;}
.code-hint{font-size:11px;color:var(--dim);margin-top:8px;}

/* Restore link on top */
.top-restore{margin-top:16px;display:flex;align-items:center;justify-content:center;gap:6px;}
.top-restore-link{font-size:12px;color:var(--muted);cursor:pointer;background:none;border:none;text-decoration:underline;font-family:var(--font-body);}
.top-restore-link:hover{color:var(--text);}

/* Restore modal */
.restore-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:800;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.restore-overlay.show{display:flex;}
.restore-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px 24px;width:90%;max-width:340px;text-align:center;}
.restore-title{font-family:var(--font-disp);font-weight:700;font-size:18px;margin-bottom:8px;}
.restore-sub{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.6;}
.restore-input{width:100%;padding:14px;font-family:monospace;font-size:24px;font-weight:700;letter-spacing:6px;text-align:center;text-transform:uppercase;border:2px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);outline:none;transition:border-color 0.15s;}
.restore-input:focus{border-color:var(--c6);}
.restore-input::placeholder{letter-spacing:2px;font-size:14px;color:var(--dim);}
.restore-actions{display:flex;gap:8px;margin-top:16px;}
.restore-btn{flex:1;padding:12px;border-radius:12px;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all 0.15s;}
.restore-btn.primary{background:var(--c6);color:#fff;border:none;}
.restore-btn.primary:hover{opacity:0.9;}
.restore-btn.secondary{background:none;border:1.5px solid var(--border);color:var(--muted);}
.restore-btn.secondary:hover{border-color:var(--text);color:var(--text);}
.restore-error{font-size:12px;color:var(--c1);margin-top:10px;display:none;}

/* ── Gate card ── */
.gate-card{text-align:center;padding:28px 20px;}
.gate-lock-icon{font-size:32px;margin-bottom:10px;}
.gate-title{font-family:var(--font-disp);font-size:18px;font-weight:700;margin-bottom:16px;}
.gate-items{text-align:left;display:inline-flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.gate-item{font-size:13px;color:var(--muted);line-height:1.6;}
.btn-pay{width:100%;font-size:16px;padding:16px;margin-bottom:14px;background:linear-gradient(135deg,var(--c6),var(--c4));}
.promo-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;}
.promo-toggle{background:none;border:none;font-size:12px;color:var(--dim);cursor:pointer;text-decoration:underline;font-family:var(--font-body);}
.promo-input-wrap{display:flex;gap:8px;width:100%;}
.promo-input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:monospace;letter-spacing:2px;text-transform:uppercase;background:var(--bg);color:var(--text);outline:none;}
.promo-input:focus{border-color:var(--c6);}
.promo-apply-btn{padding:10px 16px;background:var(--c6);color:#fff;border:none;border-radius:10px;font-family:var(--font-body);font-weight:700;font-size:13px;cursor:pointer;}
.promo-error{font-size:12px;color:#ff6b6b;font-weight:700;}

/* ── Loading ── */
.report-loading-card{text-align:center;padding:32px 20px;}
.report-loading-inner{display:flex;flex-direction:column;align-items:center;gap:12px;}
.report-loading-dots{display:flex;gap:8px;}
.report-loading-dots span{width:10px;height:10px;border-radius:50%;background:var(--c6);animation:dotPulse 1.2s ease-in-out infinite;}
.report-loading-dots span:nth-child(2){animation-delay:0.2s;}
.report-loading-dots span:nth-child(3){animation-delay:0.4s;}
@keyframes dotPulse{0%,80%,100%{transform:scale(0.6);opacity:0.4}40%{transform:scale(1);opacity:1}}
.report-loading-text{font-weight:700;font-size:15px;}
.report-loading-sub{font-size:12px;color:var(--muted);}

/* ── Locked zone ── */
.locked-zone{position:relative;overflow:hidden;min-height:180px;padding:20px 20px 0;}
.locked-head{font-weight:700;font-size:14px;margin-bottom:16px;color:var(--muted);}
.locked-placeholder{display:flex;flex-direction:column;gap:10px;padding-bottom:20px;}
.locked-line{height:12px;background:var(--border);border-radius:6px;opacity:0.7;}
.locked-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 0%,var(--surface) 55%);pointer-events:none;}
.locked-zone.unlocked{min-height:unset;padding:0;overflow:visible;}
.locked-zone.unlocked .locked-overlay{display:none;}

/* ── Report content ── */
.report-wrap{padding:4px 0;}
.report-dna-head{font-family:var(--font-disp);font-size:20px;font-weight:700;padding:20px 20px 4px;color:var(--text);}
.report-dna-desc{font-size:13px;color:var(--muted);padding:0 20px 16px;line-height:1.7;border-bottom:1px solid var(--border);}
.report-value-card{padding:20px;border-bottom:1px solid var(--border);}
.report-value-rank{font-family:var(--font-disp);font-size:16px;font-weight:700;margin-bottom:6px;}
.report-value-headline{font-size:14px;font-weight:700;color:var(--c6);margin-bottom:14px;font-style:italic;}
.report-section-label{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin:12px 0 6px;}
.report-text{font-size:13px;line-height:1.85;color:var(--text);}
.future-scene{background:var(--bg);border-radius:10px;padding:12px 14px;font-style:italic;}
.report-shadow{font-size:12px;color:var(--muted);margin-top:12px;padding:8px 12px;border-left:3px solid var(--border);line-height:1.7;}
.report-question{font-size:13px;font-weight:700;color:var(--c6);margin-top:12px;padding:10px 14px;background:var(--bg);border-radius:8px;}
.report-letter{padding:20px;background:var(--bg);margin:0 0 4px;}
.report-letter-head{font-family:var(--font-disp);font-size:16px;font-weight:700;margin-bottom:12px;}
.report-letter-body{font-size:13px;line-height:2;color:var(--text);}
