*{box-sizing:border-box}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--bg:#eef4ff;--card:#fff;--text:#172033;--muted:#667085;--line:#dbe3f1;--success:#138a4b;--danger:#c43434;--shadow:0 10px 30px rgba(26,45,92,.12);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans JP",sans-serif;color:var(--text);background:var(--bg);line-height:1.5}body{margin:0;min-height:100vh;background:radial-gradient(circle at 8% 3%,rgba(37,99,235,.12),transparent 26%),linear-gradient(145deg,#f6f9ff,var(--bg))}button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px max(16px,env(safe-area-inset-right)) 14px max(16px,env(safe-area-inset-left));background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:11px}.brand-mark{display:grid;place-items:center;width:46px;height:46px;border-radius:15px;color:#fff;background:var(--primary);font-weight:900;letter-spacing:-.05em}.topbar h1{margin:0;font-size:1.28rem}.eyebrow{margin:0 0 2px;font-size:.7rem;font-weight:900;letter-spacing:.12em;opacity:.7}.eyebrow.dark{color:var(--muted)}.header-button,.small-button,.primary-button,.secondary-button{min-height:42px;border-radius:12px;font-weight:800}.header-button{padding:8px 12px;border:0;color:white;background:var(--primary)}.small-button{padding:8px 11px;border:0;color:var(--primary);background:#e9efff}.primary-button,.secondary-button{padding:10px 15px;border:0}.primary-button{color:white;background:var(--primary)}.primary-button:hover{background:var(--primary-dark)}.primary-button:disabled{cursor:not-allowed;opacity:.45}.secondary-button{color:var(--primary);background:#e9efff}.danger-text{color:var(--danger);background:#fff0f0}.page{width:min(1180px,100%);margin:0 auto;padding:20px 16px 42px}.card{border-radius:22px;background:var(--card);box-shadow:var(--shadow)}.hero{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:16px;padding:24px;background:linear-gradient(135deg,#fff,#eef4ff)}.hero h2{margin:3px 0 6px;font-size:clamp(1.45rem,3vw,2.2rem)}.hero p{margin:0;color:var(--muted)}.hero-icon{display:grid;grid-template-columns:repeat(2,34px);grid-template-rows:repeat(2,34px);gap:8px;padding:12px;border-radius:20px;background:#10203d}.hero-icon span{border-radius:7px;background:white}.hero-icon span:nth-child(2),.hero-icon span:nth-child(3){background:var(--primary)}.layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.82fr);gap:16px;align-items:start}.input-card,.result-card,.history-card,.help-card{padding:20px}.section-heading{display:flex;justify-content:space-between;align-items:end;gap:12px;margin-bottom:16px}.section-heading h2{margin:0;font-size:1.18rem}.field{display:grid;gap:7px;margin-bottom:13px;font-weight:800;color:#344054}.field input,.field select,.field textarea{width:100%;min-height:46px;padding:10px 12px;border:1px solid #cbd5e1;border-radius:12px;color:var(--text);background:#fff}.field textarea{min-height:120px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:3px solid rgba(37,99,235,.16);border-color:var(--primary)}.check-field{display:flex;gap:9px;align-items:center;margin:4px 0 14px;font-weight:800}.check-field input{width:20px;height:20px}.option-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px}.option-grid .field{margin-bottom:0}.button-row{display:flex;gap:10px;margin-top:16px}.button-row button{flex:1}.note{margin:12px 0 0;color:var(--muted);font-size:.86rem}.badge{display:inline-flex;align-items:center;min-height:34px;padding:6px 10px;border-radius:999px;color:var(--muted);background:#f2f4f7;font-weight:800;font-size:.8rem}.badge.ok{color:var(--success);background:#e8f8ee}.qr-stage{position:relative;display:grid;place-items:center;min-height:360px;border:1px dashed #b7c4d8;border-radius:18px;background:linear-gradient(45deg,#f8fafc 25%,transparent 25%),linear-gradient(-45deg,#f8fafc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f8fafc 75%),linear-gradient(-45deg,transparent 75%,#f8fafc 75%);background-size:24px 24px;background-position:0 0,0 12px,12px -12px,-12px 0}#qrCanvas{display:none;width:min(100%,320px);height:auto;border-radius:12px;background:white;box-shadow:0 8px 24px rgba(0,0,0,.08)}#qrCanvas.show{display:block}.placeholder{display:grid;place-items:center;gap:6px;color:#98a2b3;text-align:center}.placeholder strong{display:grid;place-items:center;width:86px;height:86px;border-radius:22px;color:white;background:#cbd5e1;font-size:2rem}.result-info{display:grid;grid-template-columns:.4fr 1fr;gap:10px;margin-top:13px}.result-info div{padding:11px;border-radius:13px;background:#f7f9fc}.result-info span{display:block;color:var(--muted);font-size:.78rem;font-weight:700}.result-info strong{display:block;margin-top:2px}.preview-box{margin-top:15px;padding:13px;border-radius:14px;background:#f7f9fc}.preview-title{margin:0 0 8px;font-weight:800}pre{margin:0;white-space:pre-wrap;word-break:break-all;color:#344054;font-size:.86rem}.history-card,.help-card{margin-top:16px}.history-list{display:grid;gap:9px}.history-item{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:11px 12px;border:1px solid var(--line);border-radius:13px;background:#fff}.history-item strong{display:block;margin-bottom:2px}.history-item span{display:block;color:var(--muted);font-size:.82rem;word-break:break-all}.history-item button{min-height:36px;border:0;border-radius:9px;color:var(--primary);background:#e9efff;font-weight:800}.empty{padding:18px;color:var(--muted);text-align:center;border:1px dashed var(--line);border-radius:14px}.help-card h2{margin-top:0}.help-card p{color:var(--muted)}.help-card li{margin:6px 0}.toast{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));z-index:50;transform:translate(-50%,20px);max-width:min(90vw,520px);padding:11px 16px;border-radius:999px;color:#fff;background:#172033;opacity:0;pointer-events:none;transition:.25s;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.22)}.toast.show{opacity:1;transform:translate(-50%,0)}@media(max-width:920px){.layout{grid-template-columns:1fr}}@media(max-width:640px){.page{padding:12px 10px 28px}.topbar h1{font-size:1.05rem}.brand-mark{width:40px;height:40px;border-radius:12px}.header-button{display:none!important}.hero{padding:18px}.hero-icon{display:none}.input-card,.result-card,.history-card,.help-card{padding:16px;border-radius:18px}.option-grid{grid-template-columns:1fr 1fr}.button-row{display:grid}.qr-stage{min-height:310px}#qrCanvas{width:min(100%,280px)}.result-info{grid-template-columns:1fr}}