:root{
  --coral:#E8602C; --coral-dark:#C44D1E; --orange:#F59E42;
  --navy:#1F3A5F; --navy-2:#16294a; --cream:#FFF5EF;
  --ink:#1f2937; --muted:#64748b; --faint:#94a3b8;
  --line:#e5e7eb; --line-2:#f1f5f9; --surface:#ffffff; --bg:#f8fafc;
  --green:#16a34a; --amber:#d97706; --rose:#e11d48;
  --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select{font-family:inherit}
a{color:inherit;text-decoration:none}
code{font-family:ui-monospace,Menlo,Consolas,monospace}

.page{display:none;min-height:100vh;flex-direction:column}
.page.active{display:flex}
.wrap{width:100%;max-width:1100px;margin:0 auto;padding:0 20px}
.flex1{flex:1}

.hdr{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.hdr-in{height:58px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--navy);font-size:16px}
.logo svg{color:var(--coral)}
.nav{display:flex;gap:22px;font-size:14px;color:var(--muted)}
.nav button:hover{color:var(--ink)}
.hdr-actions{display:flex;align-items:center;gap:10px}
@media(max-width:760px){.nav{display:none}}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:14px;font-weight:600;padding:9px 16px;border-radius:8px;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-dark)}
.btn-ghost{border:1px solid var(--line);color:#374151}
.btn-ghost:hover{background:#f9fafb}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2)}
.btn-block{width:100%}
.btn-sm{font-size:12px;padding:6px 11px;font-weight:600}
.btn[disabled]{opacity:.5;cursor:default}

.ftr{border-top:1px solid var(--line);background:#fff}
.ftr-in{padding:20px 0;display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;font-size:12px;color:var(--faint)}
.ftr-links{display:flex;gap:20px}
.ftr-links button:hover{color:#374151}

.tag{display:inline-block;padding:4px 12px;border-radius:99px;background:#fdece3;color:var(--coral-dark);font-size:11px;font-weight:700;letter-spacing:.02em}
.crumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);margin-bottom:14px}
.crumb .cur{font-weight:700;color:#374151}
.crumb-home{display:inline-flex;align-items:center;gap:4px;color:var(--coral);cursor:pointer;transition:.15s}
.crumb-home:hover{color:var(--coral-dark);text-decoration:underline}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.label{font-size:12px;font-weight:600;color:#475569}
.field{width:100%;padding:9px 12px;margin-top:5px;border:1px solid #cbd5e1;border-radius:8px;font-size:14px;outline:none}
.field:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(232,96,44,.12)}
.hint{font-size:11px;color:var(--faint);margin-top:4px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.grid2{grid-template-columns:1fr}}

/* ===== A. LP ===== */
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#16294a,#1F3A5F 55%,#16294a);color:#fff;text-align:center}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(circle at 25% 15%,rgba(232,96,44,.55),transparent 42%),radial-gradient(circle at 82% 70%,rgba(245,158,66,.4),transparent 38%)}
.hero-in{position:relative;max-width:760px;margin:0 auto;padding:90px 20px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border-radius:99px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);font-size:12px;margin-bottom:22px}
.hero h1{font-size:46px;line-height:1.2;font-weight:800;letter-spacing:-.01em}
.hero p{margin-top:18px;color:#cbd5e1;font-size:17px}
.hero-form{margin-top:30px;display:flex;gap:8px;max-width:560px;margin-inline:auto}
.hero-form input{flex:1;padding:13px 16px;border-radius:9px;border:none;font-size:14px;color:var(--ink)}
.hero-note{margin-top:12px;font-size:12px;color:#94a3b8}
@media(max-width:560px){.hero h1{font-size:34px}.hero-form{flex-direction:column}}

.section{padding:80px 0}
.section-label{font-size:13px;font-weight:700;color:var(--faint);margin-bottom:22px}
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.bento .b{border:1px solid var(--line);border-radius:16px;padding:24px;background:#fff;transition:.15s}
.bento .b:hover{border-color:#fcd2bd;box-shadow:0 8px 24px -12px rgba(232,96,44,.25)}
.bento .b.big{grid-column:span 2;background:linear-gradient(135deg,#fff5ef,#fff)}
.b-ico{width:42px;height:42px;border-radius:11px;background:#fdece3;color:var(--coral);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.bento h3{font-size:16px;margin-bottom:6px;color:var(--ink)}
.bento .b p{font-size:14px;color:var(--muted)}
@media(max-width:760px){.bento{grid-template-columns:1fr}.bento .b.big{grid-column:span 1}}

/* 対応言語フィーチャー */
.langfeat{border:1px solid var(--line);border-radius:16px;padding:24px;background:linear-gradient(135deg,#fff5ef,#fff);margin-bottom:16px}
.langfeat-head{display:flex;gap:16px;align-items:flex-start;margin-bottom:18px}
.langfeat-head h3{font-size:18px;color:var(--ink);margin-bottom:6px}
.langfeat-head p{font-size:14px;color:var(--muted)}
.langfeat-sub{font-size:12px;font-weight:700;color:var(--faint);margin-bottom:10px}
.langgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.langgrid-all{margin-top:14px;max-height:300px;overflow:auto;padding-right:6px}
.langcell{display:flex;flex-direction:column;padding:8px 12px;border:1px solid var(--line);border-radius:8px;background:#fff}
.langcell .lj{font-size:13px;font-weight:600;color:#374151}
.langcell .ln{font-size:11px;color:var(--faint)}
.langmore{margin-top:14px}
@media(max-width:760px){.langgrid{grid-template-columns:1fr}}

.pricing{background:var(--cream)}
.price-card{max-width:460px;margin:0 auto;background:#fff;border:2px solid var(--coral);border-radius:18px;padding:34px;text-align:center;box-shadow:0 16px 40px -20px rgba(232,96,44,.4)}
.price-free{display:inline-block;background:#dcfce7;color:#15803d;font-size:12px;font-weight:700;padding:4px 12px;border-radius:99px;margin-bottom:14px}
.price-big{font-size:44px;font-weight:800;color:var(--navy);line-height:1}
.price-big small{font-size:15px;font-weight:500;color:var(--faint)}
.price-sub{font-size:13px;color:var(--muted);margin-top:8px}
.counter{display:flex;align-items:center;justify-content:center;gap:16px;margin:24px 0 6px}
.counter .lbl{font-size:13px;color:#475569}
.stepbtn{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);font-size:18px;font-weight:700;color:var(--coral);display:flex;align-items:center;justify-content:center}
.stepbtn:hover{background:#fff5ef}
.counter .num{font-size:20px;font-weight:800;min-width:28px}
.price-total{font-size:14px;color:#475569;margin-bottom:22px}
.price-total b{color:var(--coral-dark);font-size:18px}
.price-feats{list-style:none;text-align:left;margin:0 auto 24px;max-width:280px}
.price-feats li{display:flex;gap:8px;align-items:center;font-size:14px;color:#475569;padding:5px 0}
.price-feats li::before{content:"✓";color:var(--green);font-weight:800}
.price-note{font-size:11px;color:var(--faint);line-height:1.7;margin-top:14px;text-align:left}

/* ===== Auth ===== */
.auth-head{text-align:center;margin:50px 0 14px}
.auth-head h1{font-size:24px}
.auth-head p{font-size:14px;color:var(--muted);margin-top:4px}
.free-banner{max-width:760px;margin:0 auto 28px;display:flex;align-items:center;justify-content:center;gap:8px;background:#dcfce7;color:#15803d;font-size:13px;font-weight:600;padding:9px 14px;border-radius:8px}
.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:760px;margin:0 auto 56px}
.auth-grid h2{font-size:16px;text-align:center;margin-bottom:18px}
.gbtn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:11px;border:1px solid #cbd5e1;border-radius:9px;font-size:14px;font-weight:600;color:#374151;transition:.15s}
.gbtn:hover{background:#f9fafb}
.gbtn[disabled]{opacity:.5;cursor:default}
.gbtn[disabled]:hover{background:#fff}
.steps-list{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:10px}
.steps-list li{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted)}
.snum{width:20px;height:20px;border-radius:50%;background:#fdece3;color:var(--coral);font-weight:700;font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.note-ok{margin-top:18px;display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;background:#dcfce7;color:#15803d;font-size:12px}
.otp{margin-top:22px;opacity:.4;pointer-events:none;transition:.2s}
.otp.live{opacity:1;pointer-events:auto}
.otp-row{display:flex;justify-content:center;gap:8px;margin:12px 0}
.otp-row input{width:44px;height:48px;text-align:center;font-size:20px;font-weight:800;border:1px solid #cbd5e1;border-radius:9px;outline:none}
.otp-row input:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(232,96,44,.12)}
@media(max-width:760px){.auth-grid{grid-template-columns:1fr}}

/* 規約同意チェック */
.agree{display:flex;gap:8px;align-items:flex-start;margin-top:14px;font-size:12px;color:var(--muted);line-height:1.6}
.agree input{margin-top:2px;width:16px;height:16px;flex-shrink:0;accent-color:var(--coral);cursor:pointer}
.agree a{color:var(--coral-dark);text-decoration:underline;cursor:pointer}

/* reCAPTCHA（モック） */
.recaptcha{display:flex;align-items:center;gap:12px;width:100%;max-width:304px;margin:18px auto 0;padding:10px 12px;background:#f9fafb;border:1px solid #d3d3d3;border-radius:4px;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.rc-check{position:relative;width:28px;height:28px;flex-shrink:0}
.rc-box{appearance:none;-webkit-appearance:none;width:28px;height:28px;margin:0;border:2px solid #c1c1c1;border-radius:3px;background:#fff;cursor:pointer}
.rc-box:focus-visible{outline:2px solid var(--coral)}
.rc-spin{position:absolute;inset:2px;border:3px solid #d3d3d3;border-top-color:#4285F4;border-radius:50%;display:none;animation:spin .8s linear infinite;pointer-events:none}
.rc-tick{position:absolute;left:4px;top:4px;display:none;pointer-events:none}
.recaptcha.verifying .rc-box{visibility:hidden}
.recaptcha.verifying .rc-spin{display:block}
.recaptcha.verified .rc-box{visibility:hidden}
.recaptcha.verified .rc-tick{display:block}
.rc-label{font-size:14px;color:#222;flex:1}
.rc-brand{display:flex;flex-direction:column;align-items:center;gap:1px;color:#9aa0a6;line-height:1.1}
.rc-logo{font-size:20px}
.rc-name{font-size:10px;font-weight:600;color:#555}
.rc-brand small{font-size:8px}

/* 3日間無料トライアル説明 */
.trial-box{border:1px solid #fcd2bd;background:linear-gradient(135deg,#fff5ef,#fff);border-radius:12px;padding:18px 20px;margin-bottom:22px}
.trial-hd{font-size:15px;font-weight:700;color:var(--coral-dark);margin-bottom:10px}
.trial-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.trial-list li{font-size:13px;color:#475569;line-height:1.7;padding-left:18px;position:relative}
.trial-list li::before{content:"•";position:absolute;left:4px;color:var(--coral)}
.trial-list b{color:#374151}
.note-google{margin-top:12px;display:flex;gap:6px;padding:10px 12px;border-radius:8px;background:#eff6ff;border:1px solid #bfdbfe;font-size:12px;color:#1e40af;line-height:1.6}

/* ===== Setup / 共通 ===== */
.stepper{display:flex;align-items:center;margin:8px 0 36px}
.stepper .st{display:flex;align-items:center;gap:8px}
.stepper .line{flex:1;height:2px;background:var(--line);margin:0 12px}
.stepper .line.done{background:#86efac}
.dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:#e2e8f0;color:var(--faint)}
.dot.done{background:var(--green);color:#fff}
.dot.cur{background:var(--coral);color:#fff}
.st span{font-size:12px;color:var(--faint)}
.st.act span{color:#374151;font-weight:600}
.lang-pricepill{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:6px 12px;border-radius:8px;background:#fff5ef;border:1px solid #fcd2bd;font-size:13px;color:var(--coral-dark);font-weight:600}
.method{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.method label{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border:1px solid var(--line);border-radius:9px;cursor:pointer;transition:.15s}
.method label.sel{border-color:var(--coral);background:#fff5ef}
.method input{margin-top:3px;accent-color:var(--coral)}
.method .mt{font-size:14px;font-weight:600;color:#374151}
.method .md{font-size:12px;color:var(--muted);margin-top:2px}
.dpanel{display:none}
.dpanel.show{display:block}
.warn-box{display:flex;gap:8px;padding:10px 12px;border-radius:8px;background:#fffbeb;border:1px solid #fde68a;font-size:11px;color:#92400e;margin:4px 0 14px}
.ok-box{display:flex;gap:8px;padding:10px 12px;border-radius:8px;background:#ecfdf5;border:1px solid #a7f3d0;font-size:12px;color:#047857;margin:4px 0 14px}
.cname{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;background:#f1f5f9;border:1px solid var(--line);margin-bottom:12px}
.cname code{font-size:14px;color:#334155}
.copy-btn{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--coral);font-weight:600;white-space:nowrap}
.lamp{display:flex;align-items:center;gap:8px;font-size:12px;padding:2px 0}
.lamp .led{width:11px;height:11px;border-radius:50%;background:currentColor}
.lamp.red{color:var(--rose)} .lamp.green{color:var(--green);font-weight:600}
.lamp.off{color:#cbd5e1;text-decoration:line-through}
.subdomain{display:flex;align-items:center;gap:8px;margin-top:5px}
.subdomain input{width:80px}
.accordion-hd{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:8px;background:#f8fafc;border:1px solid var(--line);font-size:14px;font-weight:600;color:#374151}
.chev{transition:.2s}.chev.open{transform:rotate(180deg)}
.acc-body{margin-top:16px;display:none}
.acc-body.open{display:block}
.taginput{margin-top:5px;padding:8px 10px;border:1px solid #cbd5e1;border-radius:8px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.taginput input{flex:1;min-width:120px;border:none;outline:none;font-size:14px}
.chip{display:flex;align-items:center;gap:5px;padding:4px 9px;border-radius:6px;background:#fdece3;color:var(--coral-dark);font-size:12px}
.chip button{color:inherit;font-size:13px;line-height:1}
.bill-notice{margin-top:0;padding:14px 16px;border-radius:10px;background:#fff5ef;border:1px solid #fcd2bd}
.bill-notice .row{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:#475569;padding:3px 0}
.bill-notice .row.tot{border-top:1px dashed #fcd2bd;margin-top:6px;padding-top:8px;font-weight:700}
.bill-notice .row b{color:var(--coral-dark)}
.addurl{margin-top:5px;padding:12px 14px;border-radius:8px;background:#f1f5f9;border:1px solid var(--line);font-size:14px}
.addurl code{color:var(--coral-dark);font-weight:600}

/* ===== Dashboard ===== */
.dash-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:12px 0 22px}
.dash-head h1{font-size:24px}
.alert{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;background:#eff6ff;border:1px solid #bfdbfe;font-size:14px;color:#1e40af;margin-bottom:22px}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.metric{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px}
.metric .ml{font-size:12px;color:var(--faint);margin-bottom:4px}
.metric .mv{font-size:24px;font-weight:800;color:var(--ink)}
.metric .mv.sm{font-size:15px}
.metric .ms{font-size:12px;margin-top:4px;color:var(--faint)}
.metric .ms.green{color:var(--green)}
@media(max-width:760px){.metrics{grid-template-columns:1fr 1fr}}
.charts{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.chart{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px}
.chart h3{font-size:14px;margin-bottom:16px;color:#374151}
.bars{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;height:128px}
.bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px}
.bar .b{width:100%;border-radius:4px 4px 0 0}
.bar .lbl{font-size:10px;color:var(--faint)}
@media(max-width:760px){.charts{grid-template-columns:1fr}}
.ff-wrap{display:grid;grid-template-columns:2fr 1fr;gap:16px}
.ff{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px}
.ff-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:8px;flex-wrap:wrap}
.ff-top h3{font-size:14px;color:#374151}
.search{position:relative}
.search input{padding:6px 8px 6px 28px;border:1px solid var(--line);border-radius:6px;font-size:12px;width:150px}
.search svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--faint)}
.ff-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line-2)}
.ff-row:last-child{border-bottom:none}
.ff-file{display:flex;align-items:center;gap:8px;font-size:14px;color:#475569}
.ff-actions{display:flex;gap:8px}
.mini{display:flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--line);border-radius:6px;font-size:12px}
.mini.purge{color:var(--rose)}.mini.purge:hover{background:#fff1f2}
.mini.upd{color:var(--coral)}.mini.upd:hover{background:#fff5ef}
.spin{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.langcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px}
.langcard h3{font-size:14px;color:#374151;margin-bottom:12px}
.langrow{display:flex;align-items:center;gap:12px;font-size:14px;padding:8px 0;border-bottom:1px solid var(--line-2)}
.langrow:last-of-type{border-bottom:none}
.langrow>span:first-child{flex:1;min-width:0}
.langrow .nm{font-weight:600;color:#374151}
.langrow .url{font-size:11px;color:var(--faint);word-break:break-all}
.langrow .pr{font-size:13px;color:var(--coral-dark);font-weight:700;min-width:92px;text-align:right;white-space:nowrap}
.langrow-right{display:flex;align-items:center;gap:10px;flex:none}
.langrow .lang-del{flex:none;white-space:nowrap}
/* 翻訳対象外URL */
.exurl-form{display:flex;gap:8px;align-items:stretch;margin-top:10px;flex-wrap:wrap}
.exurl-type{width:auto;min-width:120px;margin-top:0}
.exurl-val{flex:1;min-width:200px;margin-top:0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.exurl-form .btn{margin-top:0;white-space:nowrap}
.exurl-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.exurl-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line-2);border-radius:8px;background:#fafafa}
.exurl-badge{flex:none;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}
.exurl-badge.prefix{color:#1e40af;background:#e0edff}
.exurl-badge.regex{color:#7c3aed;background:#efe5ff}
.exurl-code{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:#374151;word-break:break-all}
/* 領収書 */
.rcpt-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.rcpt-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--line-2);border-radius:8px}
.rcpt-info{font-size:13px;color:#374151}
.rcpt-no{font-weight:700}
.rcpt-meta{font-size:12px;color:var(--faint)}
.rcpt-demo{display:inline-block;font-size:10px;font-weight:700;color:#92400e;background:#fef3c7;border-radius:4px;padding:1px 6px;vertical-align:middle}
.langtot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line);font-size:14px;font-weight:700}
.langtot b{color:var(--coral-dark);font-size:17px}
.add-cta{margin-top:16px}
@media(max-width:760px){.ff-wrap{grid-template-columns:1fr}}

/* 言語セレクタ設置 */
.embed-intro{font-size:13px;color:var(--muted);margin-bottom:4px}
.embed-intro b{color:#374151}
.embed-steps{list-style:none;margin:12px 0 0;display:flex;flex-direction:column;gap:9px}
.embed-steps li{display:flex;gap:10px;font-size:13px;color:#475569;align-items:center}
.embed{position:relative;margin-top:16px;background:#0f172a;border-radius:10px;padding:16px;overflow:auto}
.embed code{color:#e2e8f0;font-size:12px;white-space:pre;display:block;line-height:1.7;font-family:ui-monospace,Menlo,Consolas,monospace}
.embed-copy{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.14);color:#fff;font-size:11px;font-weight:600;padding:5px 11px;border-radius:6px}
.embed-copy:hover{background:rgba(255,255,255,.26)}
.sel-preview{margin-top:16px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);flex-wrap:wrap}
.sel-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:7px 12px;background:#fff}
.sel-mock{border:none;outline:none;font-size:14px;color:#374151;background:transparent;font-weight:600}

/* ===== Stripe ===== */
.flow{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:40px}
.fstep{border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center;background:#f8fafc}
.fstep.act{border-color:#fcd2bd;background:#fff}
.fstep .fn{width:28px;height:28px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:#e2e8f0;color:var(--faint)}
.fstep.done .fn{background:var(--green);color:#fff}.fstep.cur .fn{background:var(--coral);color:#fff}
.fstep .ft{font-size:12px;font-weight:700;color:#374151}
.fstep .fd{font-size:10px;color:var(--faint);margin-top:4px;white-space:pre-line}
@media(max-width:640px){.flow{grid-template-columns:repeat(2,1fr)}}
.checkout{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.checkout-hd{background:var(--coral);color:#fff;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600}
.checkout-bd{padding:20px;background:#fff}
.ck-brand{font-size:11px;letter-spacing:.04em;color:var(--faint)}
.ck-price{font-size:24px;font-weight:800;margin-bottom:16px}
.ck-price small{font-size:12px;font-weight:400;color:var(--faint)}
.bill-table{border:1px solid var(--line);border-radius:12px;overflow:hidden;width:100%;border-collapse:collapse;font-size:14px}
.bill-table td{padding:11px 14px;border-bottom:1px solid var(--line-2)}
.bill-table tr:last-child td{border-bottom:none;font-weight:700}
.bill-table .r{text-align:right;color:var(--coral-dark)}
.bill-table .total td{background:#fff5ef}
.pay-section{font-size:12px;font-weight:700;color:var(--faint);letter-spacing:.02em;margin:18px 0 8px;padding-top:14px;border-top:1px solid var(--line-2)}
.req{display:inline-block;font-size:10px;font-weight:700;color:#fff;background:var(--rose);border-radius:4px;padding:1px 6px;margin-left:4px;vertical-align:middle}
.note-google a{color:var(--coral-dark);text-decoration:underline}
.pay-agree{font-size:12px;color:var(--muted);line-height:1.7;margin-bottom:14px}
.pay-agree a{color:var(--coral-dark);text-decoration:underline}
.field-note{font-size:11px;color:var(--faint);line-height:1.6;margin-top:5px}
.saved-card{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#f8fafc;font-size:14px;font-weight:600;color:#374151;margin-top:6px}

/* ===== Legal ===== */
.legal-card{max-width:760px;margin:0 auto}
.legal-art{padding:0 0 18px;border-bottom:1px solid var(--line-2);margin-bottom:18px}
.legal-art:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.legal-art h3{color:var(--coral-dark);font-size:14px;margin-bottom:6px}
.legal-art p{font-size:14px;color:#475569}
.legal-table{width:100%;border:1px solid var(--line);border-radius:8px;overflow:hidden;border-collapse:collapse;font-size:14px}
.legal-table th{background:#f8fafc;text-align:left;font-weight:700;color:#374151;width:170px;vertical-align:top}
.legal-table th,.legal-table td{padding:11px 14px;border-bottom:1px solid var(--line-2);white-space:pre-line}
.legal-table tr:last-child th,.legal-table tr:last-child td{border-bottom:none}
.legal-table td{color:#475569}
.legal-note{display:flex;gap:8px;max-width:760px;margin:16px auto 0;padding:12px 14px;border-radius:8px;background:#fffbeb;border:1px solid #fde68a;font-size:12px;color:#92400e}
.legal-art ul{margin:8px 0 0 18px}
.legal-art ul li{font-size:14px;color:#475569;padding:2px 0}
.legal-art a{color:var(--coral-dark);text-decoration:underline}
.lk{color:var(--coral-dark);text-decoration:underline;font-size:inherit;padding:0}

/* ===== Cookie同意（GDPR / CCPA） ===== */
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top:1px solid var(--line);box-shadow:0 -10px 30px -18px rgba(15,23,42,.4);transform:translateY(120%);transition:transform .28s ease}
.cc-banner.show{transform:translateY(0)}
.cc-banner-in{max-width:1100px;margin:0 auto;padding:16px 20px;display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cc-text{flex:1;min-width:260px}
.cc-text strong{display:block;font-size:14px;color:var(--ink);margin-bottom:4px}
.cc-text p{font-size:12px;color:var(--muted);line-height:1.7}
.cc-text a{color:var(--coral-dark);text-decoration:underline;cursor:pointer}
.cc-actions{display:flex;gap:8px;flex-wrap:wrap}
@media(max-width:560px){.cc-actions{width:100%}.cc-actions .btn{flex:1}}

.cc-modal{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(15,23,42,.5)}
.cc-modal.show{display:flex}
.cc-modal-card{background:#fff;border-radius:14px;max-width:560px;width:100%;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px -20px rgba(15,23,42,.5)}
.cc-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.cc-modal-hd h2{font-size:16px;color:var(--ink)}
.cc-x{font-size:16px;color:var(--faint);width:30px;height:30px;border-radius:8px}
.cc-x:hover{background:#f1f5f9;color:var(--ink)}
.cc-modal-bd{padding:18px 20px;overflow:auto}
.cc-intro{font-size:12px;color:var(--muted);margin-bottom:14px;line-height:1.7}
.cc-cat{border:1px solid var(--line);border-radius:10px;padding:14px;margin-bottom:12px}
.cc-cat-hd{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.cc-cat-hd strong{font-size:14px;color:var(--ink)}
.cc-always{font-size:11px;color:var(--green);font-weight:700;margin-left:4px}
.cc-cat p{font-size:12px;color:var(--muted);line-height:1.7}
.cc-ccpa{display:block;margin-top:6px;color:#92400e}
.cc-switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}
.cc-switch input{opacity:0;width:0;height:0}
.cc-slider{position:absolute;inset:0;background:#cbd5e1;border-radius:99px;transition:.2s}
.cc-slider::before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.cc-switch input:checked + .cc-slider{background:var(--coral)}
.cc-switch input:checked + .cc-slider::before{transform:translateX(18px)}
.cc-switch input:disabled + .cc-slider{opacity:.6;cursor:not-allowed}
.cc-modal-ft{display:flex;gap:8px;padding:16px 20px;border-top:1px solid var(--line);flex-wrap:wrap}
.cc-modal-ft .btn{flex:1;min-width:120px}
