:root{--bg:#090d19;--bg2:#172248;--panel:rgba(17,24,50,.86);--line:rgba(255,255,255,.11);--text:#eef2ff;--muted:#b8c2e4;--mint:#87f0da;--blue:#7ea2ff;--pink:#ff9bd0;--gold:#ffd28a;--danger:#ff9db4;--input:rgba(255,255,255,.055);--shadow:0 24px 70px rgba(0,0,0,.32)}
*{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans JP","Yu Gothic",sans-serif;background:radial-gradient(circle at 12% 0%,rgba(255,155,208,.18),transparent 30%),radial-gradient(circle at 90% 8%,rgba(135,240,218,.14),transparent 34%),linear-gradient(180deg,var(--bg2),var(--bg));}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}.page-shell{width:min(1320px,calc(100% - 24px));margin:18px auto 28px}.panel{border:1px solid var(--line);border-radius:26px;background:linear-gradient(180deg,rgba(20,29,60,.86),rgba(12,18,42,.9));box-shadow:var(--shadow);backdrop-filter:blur(8px)}.hero{padding:18px 20px;display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px}.eyebrow,.section-kicker{margin:0;color:var(--mint);font-size:13px;font-weight:800;letter-spacing:.04em}.hero h1{margin:6px 0 0;font-size:clamp(30px,4vw,48px);line-height:1.08}.hero-sub{margin:10px 0 0;color:var(--muted);line-height:1.75}.hero-links{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.hero-links a,.pill{display:inline-flex;align-items:center;gap:6px;min-height:32px;padding:0 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.05);font-size:12px;color:var(--muted)}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.nav-btn,.action-btn,.mode-btn,.genre-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease,opacity .16s ease}.nav-btn:hover,.action-btn:hover,.mode-btn:hover,.genre-btn:hover{transform:translateY(-1px)}.action-btn.primary{background:linear-gradient(135deg,rgba(126,162,255,.9),rgba(158,198,255,.78))}.action-btn.accent{background:linear-gradient(135deg,rgba(255,155,208,.36),rgba(126,162,255,.3))}.action-btn.small{min-height:34px;border-radius:12px;font-size:12px;padding:0 10px}.layout-grid{display:grid;grid-template-columns:minmax(0,1.16fr) minmax(360px,.84fr);gap:16px}.side-stack{display:grid;gap:16px;align-content:start}.setup-panel,.draw-panel,.result-panel,.share-panel,.info-panel,.image-panel{padding:18px}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.panel-head.compact{margin-bottom:12px}.panel-head h2{margin:4px 0 0;font-size:clamp(24px,3vw,34px)}.panel-head h3{margin:4px 0 0;font-size:22px}.panel-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.mode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.mode-btn.active,.genre-btn.active{background:linear-gradient(135deg,rgba(135,240,218,.24),rgba(126,162,255,.22));border-color:rgba(135,240,218,.45)}.genre-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.genre-btn{display:grid;align-content:center;justify-items:start;min-height:74px;text-align:left}.genre-btn strong{font-size:14px}.genre-btn span{margin-top:4px;color:var(--muted);font-size:11px;line-height:1.35}.switch-row{display:flex;gap:10px;align-items:center;margin-top:12px;padding:10px 12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.04);color:var(--muted);font-size:13px;font-weight:800}.divider{height:1px;background:var(--line);margin:16px 0}.field-stack{display:grid;gap:12px}.field-stack.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.field{display:grid;gap:6px;min-width:0}.field>span,label{color:var(--muted);font-size:12px;font-weight:800}input[type="text"],input[type="number"],select,textarea{width:100%;min-height:46px;border-radius:16px;border:1px solid var(--line);background:var(--input);color:var(--text);padding:0 14px;outline:none}textarea{min-height:110px;padding:12px 14px;resize:vertical}select option{background:#10182f;color:var(--text)}.calc-box{margin-top:12px;display:flex;gap:10px;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid rgba(135,240,218,.22);border-radius:18px;background:rgba(135,240,218,.08)}.small-err{min-height:1.2em;color:#ff8e9b;font-size:11px;font-style:normal}.inline-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.roles-list{display:grid;gap:10px}.role-row{display:grid;grid-template-columns:1.3fr 120px 1.6fr 58px;gap:10px;align-items:center;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);padding:10px}.role-row button{min-height:44px;border-radius:14px;border:1px solid var(--line);background:rgba(255,107,107,.12);color:var(--text);cursor:pointer}.draw-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.result-stage{display:grid;gap:10px}.empty,.mini-note{margin:0;color:var(--muted);font-size:12px;line-height:1.7}.result-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:22px;background:linear-gradient(135deg,rgba(126,162,255,.16),rgba(255,155,208,.12));padding:14px 16px;display:grid;grid-template-columns:1fr;gap:8px;align-items:center}.result-card::after{content:"";position:absolute;inset:-80px;background:radial-gradient(circle at top right,rgba(255,255,255,.2),transparent 28%);pointer-events:none}.avatar{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;background:rgba(255,255,255,.1);border:1px solid var(--line);font-size:28px}.role-title{font-size:22px;font-weight:1000;line-height:1.15}.role-sub{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.45}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.share-grid{display:grid;gap:12px}.share-box-wrap{display:grid;gap:6px}.meta-line{color:var(--muted);font-size:12px}#cardCanvas{width:100%;height:auto;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.04);display:block}.info-panel{display:grid;gap:8px}@media(max-width:1080px){.layout-grid{grid-template-columns:1fr}.genre-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.hero{flex-direction:column}.hero-actions{width:100%;display:grid;grid-template-columns:1fr 1fr}.field-stack.two-col{grid-template-columns:1fr}.role-row{grid-template-columns:1fr}.draw-actions{grid-template-columns:1fr}.genre-grid{grid-template-columns:1fr}}@media(max-width:640px){.page-shell{width:min(100%,calc(100% - 12px));margin-top:10px}.setup-panel,.draw-panel,.result-panel,.share-panel,.info-panel,.image-panel,.hero{padding:14px}}

/* v2: draw-section settings + nomination board */
.draw-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}
.draw-calc{margin:0 0 12px}
.appointment-box{margin-top:14px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.035);padding:12px}
.appointment-head{align-items:center;margin-bottom:8px!important}
.choice-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}
.choice-btn{min-height:52px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);font-weight:900;cursor:pointer;display:grid;gap:2px;place-items:center;padding:8px 10px}
.choice-btn small{color:var(--muted);font-size:11px;font-weight:800}.choice-btn.active{background:linear-gradient(135deg,rgba(135,240,218,.24),rgba(126,162,255,.22));border-color:rgba(135,240,218,.45)}
.appointment-list{display:grid;gap:10px;margin-top:10px}.appointment-role{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.04);padding:10px}.appointment-title{font-weight:1000;margin-bottom:8px}.appointment-member{display:grid;grid-template-columns:74px 1fr auto;gap:8px;align-items:center;padding:8px;border-radius:12px;background:rgba(255,255,255,.04);margin-top:6px}.appointment-member span{font-size:11px;color:var(--muted);font-weight:900}.appointment-member strong{font-size:14px}.appointment-member em{font-style:normal;color:var(--muted);font-size:12px;font-weight:900}.appointment-member.winner{background:linear-gradient(135deg,rgba(255,155,208,.18),rgba(135,240,218,.12));border:1px solid rgba(255,255,255,.12)}
@media(max-width:760px){.draw-form{grid-template-columns:1fr}.choice-list{grid-template-columns:1fr}.appointment-member{grid-template-columns:1fr}.appointment-member em{justify-self:start}}

.periodic-box{margin-top:14px;border:1px solid rgba(135,240,218,.18);border-radius:20px;background:rgba(255,255,255,.035);padding:12px}.periodic-head{margin-bottom:8px}.periodic-head h3{font-size:18px}.periodic-text{min-height:110px;resize:vertical;background:rgba(3,8,20,.34);font-size:13px;line-height:1.55}
