:root{color:#111827;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7faf7;font-family:Inter,Pretendard,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,textarea,select{font:inherit}.cbti-page{background:radial-gradient(circle at 0 0,#e9f5eee6,#0000 32%),linear-gradient(135deg,#f7faf7 0%,#eef5f1 48%,#f8fbff 100%);place-items:center;min-height:100svh;padding:24px;display:grid}.phone-shell{background:#fff;border:1px solid #d8ded8;border-radius:8px;flex-direction:column;width:min(390px,100%);height:min(780px,100svh - 48px);min-height:640px;display:flex;overflow:hidden;box-shadow:0 24px 70px #102b182e}.app-header,.landing-top{color:#102d18;justify-content:space-between;align-items:center;min-height:52px;padding:0 18px;font-size:14px;display:flex}.app-header{border-bottom:1px solid #edf0ec}.screen-body{flex:1;min-height:0;overflow:auto}.landing-screen,.survey-screen,.analysis-screen,.result-screen,.coffee-screen,.bora-screen{flex-direction:column;min-height:100%;padding:20px;display:flex}.landing-screen{color:#0e2515;padding-top:0;position:relative}.landing-copy{z-index:1;padding-top:42px;position:relative}.landing-copy h1,.survey-screen h2,.analysis-screen h2,.result-screen h2,.coffee-screen h2,.bora-screen h2{color:#0f2416;letter-spacing:0;margin:0}.landing-copy h1{max-width:250px;font-size:34px;line-height:1.24}.landing-copy p{color:#26382b;word-break:keep-all;max-width:250px;margin:24px 0 0;font-size:15px;font-weight:600;line-height:1.7}.landing-visual{object-fit:cover;border-radius:0 0 8px 8px;width:calc(100% + 40px);height:260px;margin:54px -20px -20px}.menu-button,.icon-button{color:#0d2d17;cursor:pointer;background:0 0;border:0;border-radius:8px;place-items:center;width:36px;height:36px;font-size:25px;display:inline-grid}.icon-button{font-size:32px;line-height:1}.step-chip{color:#496052;text-align:right;min-width:62px;font-size:12px}.primary-button,.secondary-button{color:#fff;cursor:pointer;background:#00571d;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:52px;padding:0 22px;font-size:16px;font-weight:800;display:inline-flex;box-shadow:0 10px 20px #00571d33}.landing-screen>.primary-button{z-index:1;position:absolute;bottom:28px;left:28px;right:28px}.primary-button:disabled{cursor:not-allowed;opacity:.45;box-shadow:none}.secondary-button{color:#0f391d;box-shadow:none;background:#edf4ef}.compact{min-width:94px;min-height:44px;padding:0 18px;font-size:14px}.full-width{width:100%;margin-top:auto}.survey-progress{margin-bottom:20px}.survey-progress span{color:#111f15;margin-bottom:10px;font-size:14px;font-weight:800;display:block}.progress-track{background:#dfc9bf;border-radius:999px;height:5px;overflow:hidden}.progress-fill{border-radius:inherit;background:#00571d;height:100%}.survey-screen h2{word-break:keep-all;margin-bottom:18px;font-size:21px;line-height:1.55}.question-help{color:#506052;word-break:keep-all;margin:-8px 0 18px;font-size:13px;font-weight:700;line-height:1.6}fieldset{border:0;min-width:0;margin:0 0 26px;padding:0}legend{color:#1e2d22;margin-bottom:10px;font-size:14px;font-weight:800}.two-column{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.stacked-options,.travel-list,.coffee-list{gap:12px;display:grid}.select-card,.option-card,.travel-card{color:#111f15;text-align:left;cursor:pointer;background:#fff;border:1px solid #e4e9e4;border-radius:8px;align-items:center;gap:12px;width:100%;padding:16px;font-size:15px;font-weight:800;display:flex}.select-card.is-selected,.option-card.is-selected,.travel-card.is-selected{background:#f0f8f2;border-color:#00571d;box-shadow:inset 0 0 0 1px #00571d}.radio-mark{background:#fff;border:2px solid #111f15;border-radius:50%;flex:none;width:17px;height:17px}.is-selected .radio-mark{background:#00571d;border-color:#00571d;box-shadow:inset 0 0 0 4px #fff}.notice{color:#35433a;gap:8px;margin:auto 0 18px;font-size:13px;font-weight:650;line-height:1.65;display:flex}.notice:before{content:"ⓘ";color:#0d321a}.option-icon{background:#fff7e8;border-radius:8px;flex:none;place-items:center;width:34px;height:34px;font-size:24px;display:grid}.option-card span:last-child,.travel-card span{gap:4px;display:grid}.option-card small,.travel-card small{color:#29362d;font-size:12px;font-weight:700;line-height:1.45}.state-word-list{gap:13px;margin-bottom:16px;display:grid}.state-row{grid-template-columns:18px 1fr;align-items:flex-start;gap:9px;display:grid}.state-color{border-radius:50%;width:13px;height:13px;margin-top:7px}.word-cloud{flex-wrap:wrap;gap:6px;display:flex}.word-cloud button{color:#142019;cursor:pointer;background:#f6f8f6;border:1px solid #0000;border-radius:8px;padding:4px 7px;font-size:13px;font-weight:800}.word-cloud button.is-selected{color:#00571d;background:#e8f5ec;border-color:#00571d}.rank-list{gap:18px;margin-top:16px;display:grid}.rank-list label{gap:8px;display:grid}.rank-list span{color:#18251c;font-size:14px;font-weight:800}.rank-list select,.birthday-input input{color:#17201a;background:#fff;border:1px solid #e1e7e1;border-radius:8px;width:100%;min-height:58px;padding:0 16px;font-size:14px;font-weight:700}.birthday-screen{justify-content:flex-start}.birthday-input{align-items:center;gap:12px;margin-top:150px;display:flex}.birthday-input span:last-child{color:#15251a;place-items:center;width:42px;height:42px;font-size:24px;display:grid}.travel-card{min-height:74px;padding:10px}.travel-card img{object-fit:cover;border-radius:8px;flex:none;width:56px;height:56px}.screen-footer{justify-content:flex-end;margin-top:auto;padding-top:20px;display:flex}.analysis-screen,.result-screen,.coffee-screen,.bora-screen{text-align:center;justify-content:center;align-items:center}.analysis-ring{border:14px solid #b44218;border-color:#b44218 #d76217 #efe4dc #efe4dc;border-radius:50%;width:92px;height:92px;margin-bottom:36px;animation:1.1s linear infinite spin}.analysis-screen h2{font-size:28px}.analysis-screen p,.result-screen p,.bora-screen h2{color:#243329;word-break:keep-all;font-size:17px;font-weight:700;line-height:1.8}.analysis-screen .secondary-button,.result-screen .primary-button,.coffee-screen .primary-button,.bora-screen .secondary-button{margin-top:28px}.result-kicker{margin:0}.result-screen h2{margin-top:4px;font-size:30px}.result-image{object-fit:cover;border-radius:50%;width:172px;height:172px;margin:24px 0}.result-screen p{max-width:250px}.coffee-screen{text-align:left;justify-content:flex-start;align-items:stretch}.coffee-screen h2{margin-bottom:22px;padding-top:12px;font-size:23px}.coffee-list{margin-bottom:auto}.coffee-card{border-bottom:1px solid #e8ede8;grid-template-columns:86px 1fr;align-items:center;gap:14px;padding:12px 0;display:grid}.coffee-card img{object-fit:cover;border-radius:8px;width:86px;height:86px}.coffee-card h3{color:#142017;margin:0 0 8px;font-size:17px}.coffee-card p{color:#37423a;margin:0;font-size:14px;font-weight:700;line-height:1.55}.bora-screen{justify-content:flex-start;padding-top:54px}.bora-screen h2{max-width:340px;margin-bottom:28px;font-size:18px}.qr-box{background:#fff;border-radius:8px;place-items:center;width:210px;display:grid}.qr-box img{object-fit:contain;width:100%;height:auto;display:block}.play-bora-logo{color:#231f20;margin:30px 0 0;font-size:28px;font-weight:900}.play-bora-logo span{color:#6647ff}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.admin-page{color:#17201a;background:#f4f6f4;min-height:100svh;padding:32px}.admin-shell{width:min(1180px,100%);margin:0 auto}.admin-header{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:24px;display:flex}.admin-header p{color:#657066;margin:0 0 6px;font-size:13px;font-weight:800}.admin-header h1{color:#111a14;margin:0;font-size:30px;line-height:1.2}.admin-actions{gap:10px;display:flex}.admin-link,.admin-button{color:#18331f;cursor:pointer;background:#fff;border:1px solid #d8ded8;border-radius:8px;justify-content:center;align-items:center;min-height:40px;padding:0 14px;font-size:14px;font-weight:800;text-decoration:none;display:inline-flex}.admin-button{color:#fff;background:#00571d;border-color:#00571d}.admin-button:disabled{cursor:not-allowed;opacity:.6}.metric-grid,.admin-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:14px}.admin-grid.secondary{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-tile,.admin-panel{background:#fff;border:1px solid #dde4dd;border-radius:8px;box-shadow:0 8px 22px #1123170f}.metric-tile{align-content:space-between;gap:10px;min-height:124px;padding:18px;display:grid}.metric-tile span,.metric-tile small,.breakdown-row small,.top-coffee-list small{color:#667066;font-size:13px;font-weight:750}.metric-tile strong{color:#102417;font-size:30px;line-height:1.15}.admin-panel{min-height:260px;padding:20px}.admin-panel h2{color:#152018;margin:0 0 18px;font-size:18px}.admin-status,.empty-text{color:#465148;background:#fff;border:1px solid #dde4dd;border-radius:8px;margin:0 0 14px;padding:16px;font-size:14px;font-weight:750}.empty-text{background:0 0;border:0;margin:0;padding:0}.breakdown-list{gap:16px;display:grid}.breakdown-row{grid-template-columns:1fr auto;align-items:center;gap:8px 12px;display:grid}.breakdown-label{grid-column:1/-1;justify-content:space-between;gap:12px;display:flex}.breakdown-label span,.breakdown-label strong{color:#17201a;font-size:14px;font-weight:800}.bar-track{background:#edf1ed;border-radius:999px;height:9px;overflow:hidden}.bar-track span{border-radius:inherit;background:#00571d;height:100%;display:block}.top-coffee-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.top-coffee-list li{border-bottom:1px solid #edf1ed;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;padding-bottom:12px;display:grid}.top-coffee-list li:last-child{border-bottom:0;padding-bottom:0}.top-coffee-list span{color:#00571d;background:#edf4ef;border-radius:8px;place-items:center;min-height:34px;font-size:13px;font-weight:900;display:inline-grid}.top-coffee-list strong{color:#17201a;font-size:15px}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=480px){.cbti-page{padding:0}.phone-shell{border:0;border-radius:0;width:100%;height:100svh;min-height:100svh}.landing-visual{height:280px}.admin-page{padding:18px}.admin-header{flex-direction:column;align-items:stretch}.admin-actions{width:100%}.admin-link,.admin-button{flex:1}.metric-grid,.admin-grid,.admin-grid.secondary{grid-template-columns:1fr}}
