:root{
  --paper:#f3f0e9; --card:#fcfbf7; --ink:#16221f; --ink-soft:#5c6a64; --ink-faint:#8d978f;
  --line:#e3ddd0; --line-2:#eee9dd; --accent:#0f5e57; --accent-2:#3f8f84; --accent-soft:#dbeae6;
  --green:#2e7d46; --green-soft:#dbeedd;
  --t1:#b5482f; --t2:#c97b1e; --t3:#8f8a2b; --t4:#2f7d6e; --t5:#2e7d46;
  --mono:'IBM Plex Mono',ui-monospace,Menlo,monospace;
  --sans:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'IBM Plex Serif',Georgia,serif;
  --r:16px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.5;-webkit-font-smoothing:antialiased;padding:24px}
.wrap{max-width:1000px;margin:0 auto;min-height:calc(100vh - 48px);display:flex;flex-direction:column}

header{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.brand{font-family:var(--mono);font-weight:700;font-size:1.1rem;letter-spacing:.12em;color:#f3f0e9;background:var(--accent);border-radius:11px;padding:10px 13px;line-height:1;box-shadow:0 1px 2px rgba(22,34,31,.14)}
.brandtext h1{font-family:var(--serif);font-weight:600;font-size:1.35rem;margin:0;line-height:1.12}
.brandtext .sub{color:var(--ink-faint);font-size:.84rem}
.brandtext .sub b{color:var(--ink-soft);font-weight:600}
.brandtext .disclaimer{margin-top:5px;font-size:.74rem;color:var(--ink-faint);line-height:1.45;max-width:62ch}
.brandtext .disclaimer a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* ---- language switch ---- */
.langs{margin-left:auto;align-self:flex-start;display:flex;align-items:center;gap:2px;font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.06em}
.langs a{padding:5px 8px;border-radius:8px;color:var(--ink-faint);text-decoration:none;transition:.15s}
.langs a:hover{color:var(--ink-soft);background:var(--line-2)}
.langs a.on{color:var(--accent);background:var(--accent-soft)}

.grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:20px;align-items:stretch}
@media(max-width:780px){.grid{grid-template-columns:1fr}body{padding:16px}}

/* ---- inputs ---- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint);font-weight:600;margin:0 0 14px}

.seg{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.seg button{font-family:var(--sans);font-size:.8rem;font-weight:500;text-align:left;line-height:1.2;padding:11px 12px;border:1.5px solid var(--line);border-radius:11px;background:transparent;color:var(--ink-soft);cursor:pointer;transition:.15s}
.seg button b{display:block;font-weight:600;color:var(--ink);font-size:.88rem}
.seg button.on{border-color:var(--accent);background:var(--accent-soft);color:var(--ink)}
.seg button.on b{color:var(--accent)}

.field{margin-bottom:16px}
.field .flabel{font-size:.82rem;color:var(--ink-soft);margin-bottom:6px;display:block}
.field .flabel em{font-style:normal;color:var(--ink-faint)}
.in{position:relative;display:flex;align-items:center}
.in input{width:100%;font-family:var(--mono);font-weight:600;color:var(--ink);border-radius:11px;background:#fff;text-align:right;border:1.5px solid var(--line);padding:12px 46px 12px 14px;font-size:1.2rem}
.in .kr{position:absolute;right:14px;font-family:var(--mono);color:var(--ink-faint);font-size:.9rem;pointer-events:none}
.in input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
/* active (primary) field gets weight */
.field.primary .flabel{color:var(--ink);font-weight:600}
.field.primary input{font-size:1.55rem;border-color:var(--accent-2);background:#fff}
.field.primary input:focus{border-color:var(--accent)}

.badge{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:7px 12px;margin-top:9px}
.badge .tdot{width:11px;height:11px;border-radius:50%;flex:none}
.badge b{font-weight:600}

.reset{font-family:var(--sans);font-size:.8rem;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;margin-top:6px;text-decoration:underline;text-underline-offset:2px}

/* ---- result hero ---- */
.hero{background:var(--ink);color:#f3f0e9;border-radius:var(--r);padding:26px 24px 22px}
.hero .eyebrow{color:rgba(243,240,233,.6);margin-bottom:10px}
.hero .pay{font-family:var(--mono);font-weight:700;font-size:3.4rem;line-height:1;letter-spacing:-.02em}
.hero .pay small{font-size:1.3rem;font-weight:600;opacity:.6;margin-left:4px}
.hero .heroSub{font-size:.95rem;color:rgba(243,240,233,.78);margin-top:12px}
.hero .heroSub b{color:#fff;font-weight:600;font-family:var(--mono)}
@media(max-width:780px){.hero .pay{font-size:2.8rem}}

/* ---- progress to cap ---- */
.prog{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px;margin-top:20px}
.progTop{display:flex;justify-content:space-between;align-items:baseline;font-size:.84rem;margin-bottom:11px}
.progTop .k{color:var(--ink-soft)}
.progTop .v{font-family:var(--mono);font-weight:600}
.track{position:relative;height:18px;border-radius:10px;background:var(--line-2);overflow:hidden}
.fillPrior{position:absolute;left:0;top:0;height:100%;background:var(--accent-2);transition:width .35s ease}
.fillNow{position:absolute;top:0;height:100%;background:var(--accent);transition:left .35s ease,width .35s ease}
.track.done .fillPrior,.track.done .fillNow{background:var(--green)}
.tick{position:absolute;top:-3px;height:24px;width:2px;background:rgba(22,34,31,.22);transform:translateX(-1px)}
.progBot{margin-top:13px}
.freeNote{font-weight:600;font-size:.92rem;margin-bottom:11px}
.freeNote .muted{color:var(--ink-faint);font-weight:500}
.freeNote.done{color:var(--green)}
.stepNow{display:flex;flex-wrap:wrap;gap:8px}
.pill{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;font-size:.8rem;background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:7px 12px}
.pill .tdot{width:10px;height:10px;border-radius:50%;flex:none}
.pill b{font-weight:600}
.pill .muted{color:var(--ink-faint)}

/* ---- disclosure ---- */
details{margin-top:20px;background:var(--card);border:1px solid var(--line);border-radius:var(--r)}
summary{list-style:none;cursor:pointer;padding:16px 20px;font-size:.84rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:8px}
summary::-webkit-details-marker{display:none}
summary .chev{transition:transform .2s;font-size:.7rem}
details[open] summary .chev{transform:rotate(90deg)}
.detailBody{padding:0 20px 18px}
table{width:100%;border-collapse:collapse;font-size:.82rem}
th,td{text-align:right;padding:8px 6px;border-bottom:1px solid var(--line-2)}
th:first-child,td:first-child{text-align:left}
thead th{font-size:.66rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-faint);font-weight:600;border-bottom:1.5px solid var(--line)}
td.num{font-family:var(--mono);font-weight:500}
tr.active td{background:var(--accent-soft)}
tr.dim td{color:var(--ink-faint)}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
tfoot td{font-weight:700;border-top:1.5px solid var(--ink);border-bottom:none;padding-top:10px}
.reg{margin-top:14px;font-size:.74rem;color:var(--ink-faint);line-height:1.55}
.reg b{color:var(--ink-soft)}
.reg a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* ---- credit footer ---- */
.credit{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:auto;padding-top:24px;border-top:1px solid var(--line)}
.credit-label{font-family:var(--mono);font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap}
.credit-divider{width:1px;height:38px;background:var(--line);flex:none}
.credit-partner{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;text-decoration:none;transition:opacity .2s}
.credit-partner:hover{opacity:.65}
.credit-partner .moria-icon{display:block;width:42px;height:30px;margin-bottom:.3rem;opacity:.9}
.credit-partner-name{font-family:var(--serif);font-size:.95rem;font-weight:600;color:var(--ink);letter-spacing:.02em;line-height:1}
.credit-partner-url{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;color:var(--accent);text-transform:lowercase}
