*,*: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}.result-card-soft{background:linear-gradient(180deg,#fff,#faf9ff)}.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-emphasis{color:#2d2947!important;font-weight:700}.result-warning{color:var(--danger)!important}.result-card-divider{height:1px;margin:14px 0;background:#f0e8eb}.result-rich-head{display:grid;gap:10px}.result-rich-summary{margin-top:6px!important}.result-rarity-pill{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:7px 12px;border-radius:999px;background:var(--soft);color:var(--primary-dark);font-size:12px;font-weight:800}.social-mask-card{overflow:hidden}.social-mask-quadrant{position:relative;margin-top:6px;padding:20px 18px 14px;border-radius:18px;background:linear-gradient(180deg,#faf9ff,#f4f1ff);border:1px solid #ece9ff}.social-mask-plot{width:100%;display:block}.social-mask-axis{position:absolute;font-size:11px;font-weight:700;color:#8e8aa9;letter-spacing:.04em}.social-mask-axis-top{top:8px;left:50%;transform:translate(-50%)}.social-mask-axis-right{top:50%;right:10px;transform:translateY(-50%)}.social-mask-axis-bottom{bottom:8px;left:50%;transform:translate(-50%)}.social-mask-axis-left{top:50%;left:10px;transform:translateY(-50%)}.social-mask-cell{position:absolute;font-size:10px;font-weight:700;color:#b2afc6}.social-mask-cell-tl{top:32px;left:18px}.social-mask-cell-tr{top:32px;right:18px}.social-mask-cell-bl{bottom:28px;left:18px}.social-mask-cell-br{bottom:28px;right:18px}.social-mask-caption{margin:12px 0 0!important;color:#5c567d!important;font-weight:700}.social-mask-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.social-mask-metric-card{padding:12px;border-radius:14px;border:.5px solid #ece9ff;background:#fcfbff}.social-mask-metric-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.social-mask-metric-head span{font-size:12px;font-weight:700;color:#6b6787}.social-mask-metric-head strong{font-size:12px;color:#27233f}.social-mask-metric-bar{height:8px;border-radius:999px;overflow:hidden;background:#ece8fb}.social-mask-metric-fill{height:100%;border-radius:inherit}.social-mask-metric-card p{margin-top:8px;font-size:11px;color:#8b87a5}.scene-grid{display:grid;gap:10px}.scene-card{padding:12px;border-radius:14px;background:#faf9ff;border:.5px solid #ece9ff}.scene-card span{display:inline-block;margin-bottom:6px;font-size:11px;font-weight:800;color:var(--primary-dark);letter-spacing:.04em}.scene-card p{margin:0}.insight-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.insight-list li{position:relative;padding-left:18px;color:#555;font-size:13px;line-height:1.65}.insight-list li:before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;background:var(--primary)}.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}.love-guide-grid{display:grid;gap:10px}.love-guide-card{padding:12px;border-radius:14px;background:#fff6f9;border:.5px solid #f3d8e3}.love-guide-card strong{display:block;margin-bottom:6px;font-size:12px;color:#993556}.love-guide-card p{margin:0;font-size:12px;color:#6d5561;line-height:1.65}.love-movie-card{overflow:hidden}.love-movie-poster{padding:16px;border-radius:16px;background:linear-gradient(160deg,#fff5f9,#ffdce8);border:.5px solid #f0c5d6}.love-movie-poster span{display:inline-block;margin-bottom:8px;font-size:11px;font-weight:800;letter-spacing:.12em;color:#a74b6f}.love-movie-poster strong{display:block;font-size:24px;line-height:1.2;color:#7b284a}.love-movie-poster p{margin-top:10px;color:#70495b}.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}.result-alert-soft{background:#f8f7ff;border-color:#d8d1fa}.result-alert-soft p{color:#4d4678}.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}.smile-gauge-caption{margin:0 0 10px!important;color:#7d7796!important;text-align:center;font-size:12px!important}.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.teal{border-color:#1d9e75;color:#1d9e75}.smile-energy-card{overflow:hidden}.smile-energy-layout{display:grid;gap:14px}.smile-energy-chart-shell{padding:14px;border-radius:18px;background:linear-gradient(180deg,#faf9ff,#f3f0ff);border:.5px solid #e6e0ff}.smile-energy-chart{width:100%;display:block}.smile-energy-axis-label{font-size:11px;font-weight:700;fill:#807aa2;letter-spacing:.04em}.smile-energy-summary{display:flex;align-items:baseline;gap:8px;margin-top:8px}.smile-energy-summary strong{font-size:24px;line-height:1;color:#2d2947}.smile-energy-summary p{color:#67617f;font-size:12px}.smile-energy-metrics{display:grid;gap:10px}.smile-energy-metric{padding:12px;border-radius:14px;border:.5px solid #ece9ff;background:#fcfbff}.smile-energy-metric-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.smile-energy-metric-head span{font-size:12px;font-weight:700;color:#5f597f}.smile-energy-metric-head strong{font-size:13px;color:#27233f}.smile-energy-metric-bar{height:8px;border-radius:999px;overflow:hidden;background:#ece8fb}.smile-energy-metric-fill{height:100%;border-radius:inherit}.smile-energy-metric p{margin-top:8px;font-size:12px;color:#6d6887;line-height:1.6}.smile-energy-compare{display:inline-flex;margin-top:8px;padding:5px 9px;border-radius:999px;background:#f1eefc;color:#675fa0;font-size:11px;font-weight:700}.movie-poster{border-radius:20px;border:.5px solid #d8c0a0;overflow:hidden;box-shadow:0 20px 40px #64360814}.movie-hero{background:radial-gradient(circle at top right,rgba(255,196,107,.16),transparent 34%),linear-gradient(160deg,#1a0c02,#3d1f00 48%,#1a0c02);padding:24px 20px 20px}.movie-topline{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.movie-label{margin:0;color:#ef9f27;font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}.movie-ticket{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,191,105,.28);background:#ffbf6914;color:#ffcf93;font-size:10px;font-weight:700}.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-quote{margin:14px 0 0;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);color:#ffedcdeb;font-size:13px;line-height:1.65}.movie-list{background:#faf9f5;padding:16px;display:grid;gap:8px}.movie-list-label{font-size:11px;font-weight:800;letter-spacing:.08em;color:#9a6c2d;text-transform:uppercase}.movie-list strong{font-size:18px;line-height:1.25;color:#2a2319}.movie-list p{margin:0;color:#5c5144;font-size:13px;line-height:1.7}.movie-scene-grid{margin-top:12px}.movie-scene-card{background:#fffaf4;border-color:#f1ddc3}.movie-director-note{margin-top:14px!important;padding:12px 14px;border-radius:14px;background:#fbf4e8;color:#74572d!important;font-size:12px!important;line-height:1.7!important}.movie-rec-grid{display:grid;gap:10px}.movie-rec-card{padding:14px;border-radius:16px;border:.5px solid #eedcc8;background:linear-gradient(180deg,#fffdf9,#faf4ec)}.movie-rec-card span{display:inline-block;margin-bottom:8px;font-size:11px;font-weight:800;letter-spacing:.04em;color:#9a6c2d}.movie-rec-card strong{display:block;font-size:17px;line-height:1.3;color:#2f2619}.movie-rec-card p{margin-top:8px;color:#645548;font-size:12px;line-height:1.7}.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}.side-path-grid{display:grid;gap:10px}.side-path-card{padding:14px;border-radius:16px;border:.5px solid #dceee7;background:linear-gradient(180deg,#fcfffd,#f3fbf7)}.side-path-card strong{display:block;font-size:16px;line-height:1.25;color:#173d34}.side-path-fit{margin-top:6px!important;color:#1d9e75!important;font-size:12px!important;font-weight:700}.side-path-divider{height:1px;margin:10px 0;background:#dff0e8}.side-path-card p{font-size:12px;color:#556a63;line-height:1.7}.side-path-card p+p{margin-top:6px}.side-path-card b{color:#183f36}.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}.result-more-btn{width:100%}@media(min-width:420px){.scene-grid,.love-guide-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.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))}}
