/* ============================================================
   DuitnSen Tools — tools.duitnsen.com
   Matches duitnsen.com design system (Warm Editorial):
   Display: Fraunces · Body: Plus Jakarta Sans · Data: IBM Plex Mono
   ============================================================ */

:root{
  --ink:#1c1c1c; --ink-2:#2a2a2a;
  --paper:#faf8f3; --card:#ffffff;
  --line:#ddd8cc; --line-ink:rgba(0,0,0,.07);
  --grow:#1f7a5a; --grow-dk:#165640;
  --gold:#b8902f; --crash:#b24a36; --amber:#b8902f; --ok:#1f7a5a;
  --tx:#1c1c1c; --tx-soft:#5a5a5a; --tx-faint:#8a8a8a;
  --display:"Fraunces",Georgia,serif;
  --body:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --sh:0 1px 2px rgba(28,28,28,.05),0 8px 24px rgba(28,28,28,.07);
  --r:14px; --r-s:9px;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--tx);font-family:var(--body);font-size:16px;line-height:1.6;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
a{color:var(--grow-dk);text-decoration-thickness:1px;text-underline-offset:2px}
a:hover{color:var(--gold)}
::selection{background:var(--gold);color:#fff}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px 70px}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1080px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.brand{font-family:var(--display);font-weight:700;font-size:22px;color:var(--ink);text-decoration:none;letter-spacing:-.01em}
.brand .sen{color:var(--gold)}
.brand-tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-faint);border-left:1px solid var(--line);padding-left:14px}
.nav-links{margin-left:auto;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.nav-links a{font-size:13.5px;font-weight:600;text-decoration:none;color:var(--tx-soft)}
.nav-links a:hover{color:var(--grow-dk)}
.nav-links a.active{color:var(--grow-dk);border-bottom:2px solid var(--gold);padding-bottom:2px}

/* ---------- eyebrow (site signature: gold dash + mono caps) ---------- */
.eyebrow{font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:10px;margin:0 0 18px}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--gold);display:inline-block}

/* ---------- dark hero (landing — Carbon Modern, matches duitnsen.com home) ---------- */
.hero-dark{background:#143028;color:#eaf0ec;position:relative;overflow:hidden}
.hero-dark::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px);background-size:100% 34px;-webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent)}
.hero-dark .shell{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:84px 20px 92px}
.hero-dark h1{font-family:var(--display);color:#fff;font-size:clamp(2.5rem,6.5vw,4.4rem);font-weight:700;letter-spacing:-.03em;line-height:1.06;margin:0 0 .35em}
.hero-dark h1 em{color:var(--gold);font-weight:700}
.hero-rule{width:48px;height:2px;background:var(--gold);margin:0 0 1.4em}
.hero-sub{font-size:1.15rem;color:rgba(234,240,236,.65);max-width:46ch;margin:0 0 2em;line-height:1.68}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:.83rem;letter-spacing:.02em;background:var(--gold);color:var(--ink);font-weight:600;padding:13px 24px;border-radius:999px;text-decoration:none;transition:transform .15s;border:none;cursor:pointer}
.btn:hover{color:var(--ink);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:#eaf0ec;border:1px solid rgba(255,255,255,.18)}
.btn.ghost:hover{background:rgba(255,255,255,.07);color:#fff}

/* ---------- tool page head (Warm Editorial page header) ---------- */
.tool-hero{padding:56px 0 34px;border-bottom:1px solid var(--line);margin-bottom:34px}
h1.tool-title{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,5.5vw,3.4rem);line-height:1.08;color:var(--ink);margin:0 0 .4em;letter-spacing:-.025em}
h1.tool-title em{font-style:italic;color:var(--grow)}
p.lede{font-size:16.5px;color:var(--tx-soft);margin:0;max-width:62ch;line-height:1.65}
p.lede+p.lede{margin-top:10px}
h2.sec{font-family:var(--display);font-weight:600;font-size:23px;color:var(--ink);margin:30px 0 6px}

/* ---------- landing cards ---------- */
.tool-cards{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:-46px;position:relative;z-index:2}
.tcard{background:var(--card);border:1px solid var(--line);border-top:3px solid var(--gold);border-radius:var(--r);box-shadow:var(--sh);padding:28px 28px 24px;text-decoration:none;color:var(--tx);display:flex;flex-direction:column;gap:11px;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}
.tcard:hover{transform:translateY(-3px);box-shadow:0 2px 4px rgba(28,28,28,.06),0 14px 34px rgba(28,28,28,.12);color:var(--tx)}
.tcard .num{position:absolute;top:2px;right:14px;font-family:var(--display);font-weight:700;font-size:96px;line-height:1;color:rgba(31,122,90,.08);pointer-events:none}
.tcard .tk{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.tcard h3{font-family:var(--display);font-size:24px;font-weight:600;color:var(--ink);margin:0;letter-spacing:-.015em}
.tcard p{font-size:14px;color:var(--tx-soft);margin:0;line-height:1.6;max-width:44ch}
.tcard .go{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--grow-dk);margin-top:10px}
.tcard:hover .go{color:var(--gold)}

/* ---------- landing "how it fits" strip ---------- */
.fit{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-top:34px}
.fit .f{border-left:2px solid var(--gold);padding:2px 0 2px 14px}
.fit .f b{display:block;font-family:var(--display);font-size:15.5px;color:var(--ink);margin-bottom:3px}
.fit .f span{font-size:13px;color:var(--tx-soft);line-height:1.55}

/* ---------- panels & fields ---------- */
.grid{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
.panel .ph{padding:14px 18px;border-bottom:1px solid var(--line);font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:9px}
.pb{padding:18px}
.field{margin-bottom:15px}
.field label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--tx-soft);margin-bottom:6px}
.field .hint{font-weight:400;text-transform:none;letter-spacing:0;font-family:var(--body);color:var(--tx-faint)}
.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:var(--r-s);padding:10px 12px;font-family:var(--body);font-size:14px;background:#fdfcf9;color:var(--tx)}
.field textarea{resize:vertical;min-height:52px;line-height:1.5}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--grow);background:#fff}

/* ---------- conviction dots ---------- */
.conv{display:flex;align-items:center;gap:10px}
.dots{display:flex;gap:6px}
.dot{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);cursor:pointer;background:#fff;transition:.12s;padding:0}
.dot.on{background:var(--grow);border-color:var(--grow)}
.conv .lbl{font-size:12.5px;color:var(--tx-soft)}

/* ---------- guard panel ---------- */
.guard{position:sticky;top:76px}
.guard .gh{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.gcard{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--tx-faint);border-radius:10px;padding:14px 15px;box-shadow:var(--sh);margin-bottom:12px}
.gcard.ok{border-left-color:var(--ok)} .gcard.amber{border-left-color:var(--amber)} .gcard.red{border-left-color:var(--crash)} .gcard.neutral{border-left-color:var(--tx-faint)}
.gcard .verdict{font-family:var(--display);font-weight:600;font-size:15.5px;margin-bottom:6px}
.gcard.ok .verdict{color:var(--ok)} .gcard.amber .verdict{color:var(--amber)} .gcard.red .verdict{color:var(--crash)}
.gcard .gtext{font-size:13px;color:var(--tx);line-height:1.5}
.gates{font-size:12.5px;color:var(--tx-soft);line-height:1.7}
.gate{display:flex;gap:8px;align-items:flex-start}
.gate .mk{font-family:var(--mono);font-weight:700}
.gate.pass .mk{color:var(--ok)} .gate.fail .mk{color:var(--crash)}

.commit{width:100%;border:none;background:var(--gold);color:var(--ink);border-radius:999px;padding:13px;font-family:var(--mono);font-size:.85rem;letter-spacing:.02em;font-weight:600;cursor:pointer;margin-top:4px;transition:transform .15s}
.commit:disabled{background:#d9d4c5;color:var(--tx-faint);cursor:not-allowed}
.commit:not(:disabled):hover{transform:translateY(-1px)}

/* ---------- house rules ---------- */
.rules{background:#f1efe6;border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-top:22px}
.rules h4{font-family:var(--display);color:var(--ink);margin:0 0 10px;font-size:16px}
.rules ol{margin:0;padding-left:20px}
.rules li{font-size:13px;color:var(--tx);line-height:1.7;margin-bottom:3px}

/* ---------- decision log ---------- */
.logwrap{margin-top:26px}
.logitem{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--tx-faint);border-radius:10px;padding:13px 15px;margin-bottom:11px;box-shadow:var(--sh)}
.logitem.ok{border-left-color:var(--ok)} .logitem.amber{border-left-color:var(--amber)} .logitem.red{border-left-color:var(--crash)} .logitem.neutral{border-left-color:var(--tx-faint)}
.logitem .lt{display:flex;align-items:center;gap:9px;margin-bottom:6px;flex-wrap:wrap}
.logitem .lt h3{margin:0;font-size:14.5px;font-weight:600;flex:1;min-width:160px}
.logitem .date{font-family:var(--mono);font-size:10.5px;color:var(--tx-faint)}
.mini-dots{display:flex;gap:3px}
.mini-dots i{width:8px;height:8px;border-radius:50%;background:var(--line)}
.mini-dots i.on{background:var(--grow)}
.chip{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:5px;font-weight:700;color:#fff}
.chip.ok{background:var(--ok)} .chip.amber{background:var(--amber)} .chip.red{background:var(--crash)} .chip.neutral{background:var(--tx-faint)}
.logitem .lrow{font-size:12.5px;color:var(--tx-soft);line-height:1.5;margin-top:5px}
.logitem .lrow b{color:var(--tx);font-weight:600}
.logitem .del{float:right;font-size:11px;color:var(--crash);cursor:pointer;border:none;background:none;font-family:var(--body)}
.emptylog{color:var(--tx-faint);font-style:italic;font-size:13.5px;text-align:center;padding:24px}

/* ---------- etf checker ---------- */
.checker{max-width:640px}
.ctrl{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.ctrl .field{flex:1;min-width:150px;margin:0}
.vs{font-family:var(--display);font-style:italic;color:var(--gold);padding-bottom:10px}
.checkbtn{border:none;background:var(--gold);color:var(--ink);border-radius:999px;padding:12px 26px;font-weight:600;cursor:pointer;font-family:var(--mono);font-size:.85rem;letter-spacing:.02em;transition:transform .15s}
.checkbtn:hover{transform:translateY(-1px)}
.result{margin-top:20px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--sh);display:none}
.result.show{display:block}
.result .rpair{font-family:var(--mono);font-size:11px;color:var(--tx-soft);letter-spacing:.08em;text-transform:uppercase}
.result .rbar{height:14px;background:#ece8db;border-radius:999px;overflow:hidden;margin:14px 0 6px}
.result .rfill{height:100%;background:linear-gradient(90deg,var(--grow),var(--grow-dk));border-radius:999px;transition:width .5s}
.result .rov{font-family:var(--mono);font-size:12px;color:var(--tx-soft);display:flex;justify-content:space-between}
.result .rverdict{font-family:var(--display);font-size:20px;font-weight:600;margin:14px 0 6px}
.result .rtext{font-size:14px;color:var(--tx);line-height:1.55}
.result .rverdict.skip{color:var(--crash)} .result .rverdict.dup{color:var(--amber)} .result .rverdict.good{color:var(--ok)}
.rshared h4{font-family:var(--display);font-size:15px;font-weight:600;color:var(--ink);margin:18px 0 8px;padding-top:14px;border-top:1px solid var(--line)}
.rshared table{width:100%;border-collapse:collapse;font-size:13px}
.rshared th{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-faint);text-align:left;padding:4px 8px 6px;border-bottom:1px solid var(--line)}
.rshared td{padding:6px 8px;border-bottom:1px solid #f0ede2;color:var(--tx)}
.rshared td:nth-child(2),.rshared td:nth-child(3),.rshared th:nth-child(2),.rshared th:nth-child(3){text-align:right;font-family:var(--mono);font-size:12px;white-space:nowrap}
.rshared .stk{font-family:var(--mono);font-weight:600;color:var(--grow-dk);margin-right:4px}
.rshared .smore{font-size:11.5px;color:var(--tx-faint);margin-top:7px;font-style:italic}
.rasof{font-family:var(--mono);font-size:10.5px;color:var(--tx-faint);margin-top:14px;letter-spacing:.04em}
.rlinks{font-size:12.5px;color:var(--tx-soft);margin-top:16px;padding-top:12px;border-top:1px solid var(--line)}
.rules-src{font-size:12px;color:var(--tx-soft);margin:12px 0 0;padding-top:10px;border-top:1px solid var(--line)}

/* ---------- disclaimer + footer ---------- */
.disclaimer{background:#f1efe6;border:1px solid var(--line);border-radius:10px;padding:13px 16px;font-size:12.5px;color:var(--tx-soft);line-height:1.6;margin-top:30px}
.disclaimer b{color:var(--gold)}
footer.foot{background:var(--ink);color:#c4d2c9;margin-top:44px}
footer.foot .shell{max-width:1080px;margin:0 auto;padding:34px 20px 40px}
footer.foot h3{font-family:var(--display);font-size:20px;color:#fff;margin:0 0 8px}
footer.foot h3 .sen{color:var(--gold)}
footer.foot p{font-size:13.5px;margin:0 0 14px;max-width:62ch;line-height:1.6}
footer.foot .foot-row{font-size:12.5px;display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:14px}
footer.foot a{color:#c4d2c9}
footer.foot a:hover{color:var(--gold)}
footer.foot .sep{color:rgba(255,255,255,.25)}

@media(max-width:820px){
  .grid{grid-template-columns:1fr}
  .guard{position:static}
  .tool-cards{grid-template-columns:1fr}
  .fit{grid-template-columns:1fr}
  .hero-dark .shell{padding:60px 20px 76px}
}
