*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:Noto Sans SC,PingFang SC,Helvetica Neue,sans-serif;background:#f7f6f3;color:#1a1a2e}:root{--bg-page: #f7f6f3;--card: #ffffff;--soft-card: #f9f9f6;--text-main: #1a1a2e;--text-body: #555555;--text-muted: #aaaaaa;--border: #e0e0e0;--line: #ebebeb;--danger: #e24b4a;--primary: #7f77dd;--primary-dark: #534ab7;--soft: #eeedfe;--tarot-bg: #f5f4ff;--tarot-border: #cecbf6}[data-theme=test1]{--primary: #7f77dd;--primary-dark: #534ab7;--soft: #eeedfe;--tarot-bg: #f5f4ff;--tarot-border: #cecbf6}[data-theme=test2]{--primary: #d4537e;--primary-dark: #993556;--soft: #fbeaf0;--tarot-bg: #fff5f7;--tarot-border: #f4c0d1}[data-theme=test3]{--primary: #378add;--primary-dark: #185fa5;--soft: #e6f1fb;--tarot-bg: #eef5ff;--tarot-border: #b5d4f4}[data-theme=test4]{--primary: #ef9f27;--primary-dark: #854f0b;--soft: #faeeda;--tarot-bg: #fff8ee;--tarot-border: #fac775}[data-theme=test5]{--primary: #1d9e75;--primary-dark: #0f6e56;--soft: #e1f5ee;--tarot-bg: #edfaf4;--tarot-border: #9fe1cb}.app-shell{width:min(100vw,480px);min-height:100dvh;margin:0 auto;background:var(--bg-page);border-left:1px solid #ececec;border-right:1px solid #ececec;box-shadow:0 0 30px #00000014}.admin-shell{background:#f7f6f3}.page{min-height:100dvh;padding:14px 16px calc(16px + env(safe-area-inset-bottom))}.page-home{display:grid;gap:12px;align-content:start}.home-topbar{display:flex;justify-content:space-between;align-items:center;padding:4px 2px}.home-topbar h1{margin:0;font-size:22px;font-weight:600;letter-spacing:-.4px}.home-topbar p{margin:2px 0 0;font-size:13px;color:#888}.home-avatar{width:38px;height:38px;border:.5px solid #e0e0e0;border-radius:50%;background:#efefef;font-size:16px}.hero{padding:0 2px 2px;border:none;border-radius:0;background:transparent}.hero-kicker{margin:0;font-size:13px;font-weight:500;color:#666;letter-spacing:0}.test-list{display:grid;gap:10px}.test-card{background:#fff;border:.5px solid #ebebeb;border-left:4px solid var(--primary);border-radius:18px;padding:14px}.test-card-head{display:grid;grid-template-columns:40px 1fr;align-items:center;gap:10px}.test-icon{width:40px;height:40px;border-radius:12px;background:var(--soft);display:grid;place-items:center;font-size:20px}.test-card h3{margin:0;font-size:16px;font-weight:600}.test-card p{margin:3px 0 0;font-size:12px;color:#888}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 12px}.chip{padding:3px 9px;border-radius:50px;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.card-link-btn{border:none;background:transparent;color:var(--primary-dark);font-size:13px;font-weight:500;cursor:pointer;padding:0}.btn-main,.btn-subtle,.btn-danger,.btn-circle-back{font-family:inherit;border-radius:14px;font-weight:700;cursor:pointer}.btn-main{width:100%;border:none;padding:13px 10px;background:var(--primary);color:#fff;font-size:13px;font-weight:800}.btn-main:disabled{opacity:.38;cursor:not-allowed}.btn-subtle{border:1.5px solid #e0e0e0;background:transparent;color:#555;padding:12px 8px;font-size:13px}.btn-danger{border:1px solid #f09595;background:#fff0f0;color:#a32d2d;padding:12px 8px;font-size:13px}.btn-back{border:none;background:transparent;color:#535e7a;font-size:14px;font-weight:700;padding:2px 0 10px;cursor:pointer}.page-redeem{display:flex;flex-direction:column;gap:8px}.redeem-card{border:.5px solid #ebebeb;border-radius:20px;background:#fff;padding:20px 16px}.redeem-card h1{margin:0;font-size:24px;font-weight:600;letter-spacing:-.3px}.redeem-card p{margin:6px 0 16px;font-size:13px;color:#666}.redeem-label{display:block;margin-bottom:6px;font-size:11px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.07em}.redeem-input{width:100%;height:58px;margin-bottom:12px;border:1.5px solid #ddd;border-radius:14px;background:#f9f9f6;text-align:center;color:#1a1a2e;font-size:21px;font-weight:800;letter-spacing:.22em;text-transform:uppercase}.redeem-input:focus{outline:none;border-color:var(--primary)}.redeem-tip{margin:8px 0 0;font-size:11px;color:#aaa;text-align:center}.text-error{margin-top:9px;color:#a32d2d;font-size:12px}.page-quiz{display:flex;flex-direction:column;gap:8px;min-height:100dvh}.quiz-topbar{display:flex;align-items:center;gap:10px}.btn-circle-back{width:40px;height:40px;border:.5px solid #dddddd;border-radius:50%;background:#f0f0ec;color:#1a1a2e;font-size:20px;line-height:1}.quiz-head-meta{flex:1;display:flex;justify-content:space-between;align-items:center;gap:10px}.quiz-head-meta span{font-size:13px;font-weight:700;color:#444}.quiz-counter{font-weight:800}.quiz-progress-track{height:8px;border-radius:99px;background:#efefef;overflow:hidden}.quiz-progress-fill{height:100%;border-radius:99px;background:var(--primary);transition:width .3s ease}.quiz-stage{display:flex;flex-direction:column;gap:8px;align-items:stretch;padding-top:2px}.quiz-tag{margin:6px 2px 0;font-size:11px;font-weight:700;color:#999;letter-spacing:.1em;text-transform:uppercase}.quiz-question-wrap{border:.5px solid #ebebeb;border-radius:16px;background:#fff;padding:12px 14px;margin-bottom:2px}.quiz-question{margin:0;font-size:clamp(18px,4.8vw,21px);font-weight:600;line-height:1.35;letter-spacing:-.3px;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.quiz-options{display:grid;gap:8px;align-content:start}.quiz-option{border:1px solid #d3d3d3;border-radius:18px;background:#fff;min-height:56px;display:grid;grid-template-columns:28px 1fr;align-items:center;gap:10px;padding:8px 12px;text-align:left;color:#1a1a2e;font-size:14px;font-weight:800;line-height:1.3;-webkit-tap-highlight-color:transparent;transition:border-color .15s ease,background-color .15s ease}.quiz-option-dot{width:26px;height:26px;border-radius:50%;border:2px solid #b8b8b8;background:transparent}.quiz-option.selected{border:2px solid var(--primary);background:color-mix(in oklab,var(--soft) 85%,white)}.quiz-option.selected .quiz-option-dot{border-color:var(--primary);box-shadow:inset 0 0 0 6px color-mix(in oklab,var(--primary) 75%,white)}.quiz-footer{margin-top:auto;border-top:.5px solid #ebebeb;padding:12px 0 2px;text-align:center;color:#8f8f8f;font-size:12px}.page-result,.result-share-capture{display:grid;gap:12px}.result-header{background:#fff;border:.5px solid #ebebeb;border-radius:20px;padding:20px 20px 14px;text-align:center}.result-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--primary-dark);background:var(--soft)}.result-emoji{margin-top:10px;font-size:44px;line-height:1}.result-header h1{margin:8px 0 4px;font-size:22px;font-weight:600;letter-spacing:-.4px}.result-header p{margin:0;font-size:13px;font-weight:500;color:#666;line-height:1.55}.result-card,.result-alert,.tarot-cta{margin:0}.result-card{background:#fff;border-radius:18px;border:.5px solid #ebebeb;padding:16px}.section-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-title-row h2{margin:0;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#aaa}.section-title-row span{font-size:11px;color:#ccc}.result-card h2{margin:0 0 10px;font-size:15px;font-weight:800}.result-card p{margin:0;color:#555;font-size:13px;line-height:1.65}.result-card p+p{margin-top:8px}.result-warning{color:var(--danger)!important}.metric-row+.metric-row{margin-top:10px}.metric-head{display:grid;grid-template-columns:1fr 22px;gap:8px;align-items:center;margin-bottom:6px;font-size:11px}.metric-head span:first-child{color:#888;font-weight:600}.metric-head span:last-child{text-align:right;color:var(--primary);font-weight:700}.metric-track{height:9px;border-radius:50px;border:.5px solid #e8e8e8;background:#f0f0f0;overflow:hidden}.metric-fill{height:100%;border-radius:inherit;transition:width 1s cubic-bezier(.4,0,.2,1)}.resonance-card{margin-top:12px;padding:12px 14px;background:#f9f9f9;border-radius:14px;border:.5px solid #ebebeb;display:flex;align-items:center;gap:8px;font-size:13px}.love-chart-wrap{display:flex;align-items:center;gap:14px}.love-donut{width:100px;height:100px;flex-shrink:0}.love-center-text{font-size:10px;font-weight:800;fill:#1a1a2e}.love-legend{flex:1;display:flex;flex-direction:column;gap:6px}.love-legend-row{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#444}.dot{width:9px;height:9px;border-radius:50%}.love-legend-row strong{margin-left:auto;font-size:11px;font-weight:700}.result-alert{padding:14px;border-radius:14px;background:#fcebeb;border:.5px solid #f09595}.result-alert p{margin:0;color:#791f1f;font-size:12px;line-height:1.65}.gauge-chart{width:100%;max-width:240px;display:block;margin:0 auto 8px}.gauge-arc{transition:stroke-dasharray 1s ease}.gauge-needle{transition:x2 1s ease,y2 1s ease}.gauge-score{font-size:16px;font-weight:800;fill:#1a1a2e}.gauge-unit{font-size:10px;font-weight:600;fill:#777}.level-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.level-item{border:1px solid #ebebeb;border-radius:10px;text-align:center;padding:6px 0;font-size:11px;font-weight:700;color:#777;background:#fff}.level-item.active.red{border-color:#e24b4a;color:#e24b4a}.level-item.active.amber{border-color:#ef9f27;color:#ef9f27}.level-item.active.green{border-color:#5da84d;color:#5da84d}.level-item.active.blue{border-color:#378add;color:#378add}.movie-poster{border-radius:20px;border:.5px solid #ebebeb;overflow:hidden}.movie-hero{background:linear-gradient(160deg,#1a0c02,#3d1f00 48%,#1a0c02);padding:24px 20px 18px}.movie-label{margin:0 0 8px;color:#ef9f27;font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}.movie-hero h2{margin:0;color:#fff;font-size:30px;line-height:1.16}.movie-genre{margin:6px 0 10px;color:#ffbf69;font-size:13px;font-weight:600;font-style:italic}.movie-desc{margin:0;color:#ffffffeb;font-size:13px;line-height:1.6}.movie-ref{margin:10px 0 0;color:#ffffffb3;font-size:11px}.movie-list{background:#faf9f5;padding:14px 16px;display:grid;gap:8px}.movie-list p{margin:0;color:#444;font-size:12px}.side-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.side-grid article{background:var(--soft);border-radius:14px;border:.5px solid #ebebeb;padding:10px;text-align:center}.side-grid span{display:block;font-size:10px;font-weight:700;color:var(--primary-dark)}.side-grid strong{display:block;margin-top:4px;font-size:14px;font-weight:800}.step-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.step-list li{display:flex;align-items:flex-start;gap:10px;color:#555;font-size:13px;line-height:1.55}.step-list li:before{content:counter(step);counter-increment:step;width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;flex-shrink:0}.step-list{counter-reset:step}.tarot-cta{border:2px dashed var(--tarot-border);background:var(--tarot-bg);border-radius:18px;padding:16px}.tarot-cta h3{margin:0;font-size:14px;font-weight:800}.tarot-sub{margin:8px 0 10px;font-size:13px;color:#666;line-height:1.55}.tarot-cta ul{margin:0;padding:0;list-style:none;display:grid;gap:8px}.tarot-cta li{padding:7px 11px;border-radius:9px;border:.5px solid #ebebeb;background:#fff;font-size:12px;font-weight:600;color:#555}.tarot-cta .btn-main{margin-top:12px}.result-actions{display:flex;gap:8px;padding-bottom:calc(16px + env(safe-area-inset-bottom))}.result-actions .btn-subtle{flex:1}.result-actions .btn-main{flex:2}.page-admin{display:flex;flex-direction:column;padding:0;gap:0;min-height:100dvh;background:#f7f6f3}.page-admin-login{display:grid;place-items:center;min-height:100dvh;padding:20px 16px}.admin-login-card{width:100%;border:.5px solid #ebebeb;border-radius:20px;background:#fff;padding:22px 16px}.admin-login-card h1{margin:0;font-size:20px;font-weight:700}.admin-login-card p{margin:8px 0 14px;color:#777;font-size:13px;line-height:1.5}.admin-header{padding:14px 18px 12px;background:#fff;border-bottom:.5px solid #ebebeb;display:flex;justify-content:space-between;align-items:center;gap:8px;flex-shrink:0}.admin-header h1{margin:0;font-size:16px;font-weight:800}.admin-header p{margin:2px 0 0;font-size:11px;color:#888}.btn-admin-new{border:none;border-radius:10px;background:#1a1a2e;color:#fff;padding:7px 13px;font-size:12px;font-weight:700}.admin-head-actions{display:flex;align-items:center;gap:6px}.btn-admin-logout{border:.5px solid #ddd;border-radius:10px;background:#fff;color:#666;padding:7px 11px;font-size:12px;font-weight:700}.admin-stats{display:flex;gap:8px;padding:12px 14px;background:#fff;border-bottom:.5px solid #ebebeb;flex-shrink:0}.admin-stats article{flex:1;background:#f9f9f6;border-radius:12px;border:.5px solid #ebebeb;padding:10px 12px;display:flex;flex-direction:column;gap:2px}.admin-stats strong{font-size:20px;font-weight:800;line-height:1}.admin-stats span{font-size:10px;font-weight:600;color:#888}.analytics-card{margin:10px 14px 0;border:.5px solid #ebebeb;border-radius:14px;background:#fff;padding:12px;display:grid;gap:10px}.analytics-head{display:flex;justify-content:space-between;align-items:center}.analytics-head h3{margin:0;font-size:13px;font-weight:700}.analytics-head span{font-size:11px;color:#999}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.analytics-kpi-grid article{border:.5px solid #ebebeb;border-radius:10px;background:#f9f9f6;padding:8px;display:grid;gap:4px}.analytics-kpi-grid span{font-size:10px;color:#888}.analytics-kpi-grid strong{font-size:16px;font-weight:800;line-height:1}.analytics-list{display:grid;gap:8px}.analytics-row{display:grid;gap:4px}.analytics-row-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.analytics-row-head span{font-size:12px;color:#555}.analytics-row-head strong{font-size:12px;color:#1a1a2e}.analytics-track{height:7px;border-radius:99px;background:#efefef;overflow:hidden}.analytics-fill{height:100%;border-radius:inherit;background:#1a1a2e}.analytics-recent{border-top:.5px solid #efefef;padding-top:8px;display:grid;gap:6px}.analytics-recent h4{margin:0;font-size:11px;color:#777;font-weight:700}.admin-filters{display:flex;gap:6px;padding:10px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch;background:#fff;border-bottom:.5px solid #ebebeb;flex-shrink:0}.admin-filters button{border:.5px solid #ddd;border-radius:50px;background:#fff;color:#666;padding:5px 12px;font-size:11px;font-weight:600;white-space:nowrap}.admin-filters button.active{background:#1a1a2e;color:#fff;border-color:transparent}.admin-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:7px;padding:12px 14px 24px}.admin-empty{margin:0;padding:24px 0;text-align:center;color:#aaa;font-size:13px}.admin-error{margin:0;border:1px solid #f09595;background:#fff0f0;color:#a32d2d;border-radius:10px;padding:10px 12px;font-size:12px}.admin-code-card{background:#fff;border:.5px solid #ebebeb;border-radius:14px;padding:12px 14px;transition:opacity .15s;display:grid;gap:8px}.admin-code-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.admin-code-main strong{display:block;font-size:14px;font-weight:800;font-family:Courier New,monospace;letter-spacing:.06em;color:#1a1a2e}.admin-code-main span{display:block;margin-top:2px;font-size:11px;color:#888}.admin-code-meta{font-size:10px;color:#aaa}.status-pill{padding:3px 9px;border-radius:50px;font-size:10px;font-weight:700}.status-active{background:#e1f5ee;color:#0f6e56}.status-expired{background:#f1efe8;color:#5f5e5a}.status-disabled{background:#fcebeb;color:#a32d2d}.status-exhausted{background:#faeeda;color:#854f0b}.admin-actions{display:flex;gap:6px;padding-top:8px;border-top:.5px solid #f0f0f0}.admin-actions .btn-subtle,.admin-actions .btn-danger{flex:1;padding:7px 6px;border-radius:8px;font-size:11px;font-weight:600}.admin-actions .btn-subtle{border:.5px solid #e0e0e0;background:#f9f9f9}.admin-actions .btn-danger{border:.5px solid #f09595;background:#fff0f0}.drawer-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:flex-end;z-index:100}.drawer-panel{width:100%;background:#fff;border-radius:24px 24px 0 0;padding:20px 20px 32px}.drawer-grip{width:36px;height:4px;border-radius:50px;background:#e0e0e0;display:block;margin:0 auto 16px}.drawer-panel h3{margin:0 0 16px;font-size:16px;font-weight:800}.form-field{display:grid;gap:6px;margin-bottom:12px}.form-field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#888}.form-field input,.form-field select{width:100%;border:1.5px solid #ddd;border-radius:12px;background:#f9f9f9;color:#1a1a2e;padding:11px 13px;font-size:14px;font-weight:600;font-family:inherit}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--primary)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.drawer-actions{margin-top:14px;display:flex;gap:8px}.drawer-actions .btn-subtle{flex:1}.drawer-actions .btn-main{flex:2;background:#1a1a2e}.usage-list{display:grid;gap:8px}.usage-row{display:flex;justify-content:space-between;align-items:center;gap:8px;border-bottom:.5px solid #f2f2f2;padding-bottom:8px;font-size:13px;color:#555}.usage-row code{font-size:11px;color:#aaa;font-family:Courier New,monospace}@media(min-width:620px){.app-shell{margin:14px auto;border-radius:28px;overflow:hidden;min-height:min(930px,calc(100dvh - 28px))}}
