:root{--bg:#f4f7fb;--card:#fff;--ink:#10213b;--accent:#16c;--danger:#b42318;--line:#d0d8e4}*{box-sizing:border-box}body{margin:0;font-family:Hiragino Sans,Noto Sans JP,sans-serif;background:linear-gradient(160deg,#edf4ff,#f8fbff 45%,#f5f8f1);color:var(--ink)}main{max-width:760px;margin:0 auto;padding:24px 16px 40px}.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin-top:12px}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}button,input{border-radius:10px;border:1px solid var(--line);padding:10px 12px;font-size:14px}button{cursor:pointer;background:#fff}button.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}button:disabled{opacity:.6;cursor:not-allowed}.choice{width:100%;text-align:left}.badge{display:inline-block;padding:4px 10px;border-radius:999px;border:1px solid var(--line);font-size:12px}.timer{font-size:24px;font-weight:700}.error{color:var(--danger);font-weight:600}.hero{text-align:center;padding:32px 0 8px}.hero-title{font-size:2.4em;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#16c,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.hero-sub{font-size:1em;opacity:.6;margin:4px 0 0}.divider{display:flex;align-items:center;gap:12px;font-size:.8em;opacity:.5}.divider:after,.divider:before{content:"";flex:1 1;height:1px;background:var(--line)}.link-btn{background:none;border:none;color:var(--accent);font-size:.9em;cursor:pointer;padding:4px;text-decoration:underline}.link-btn:hover{opacity:.7}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:var(--card);border-radius:16px;padding:24px;max-width:480px;width:100%;max-height:80vh;overflow-y:auto}select,textarea{border-radius:10px;border:1px solid var(--line);padding:10px 12px;font-size:14px;font-family:inherit}