/* ============================================================
   HeroTools — Digital Heroes design system
   Brand-matched to digitalheroesco.com (moss + cream + amber, grain)
   Self-contained, offline-friendly. Fonts vendored in ../fonts/.
   ============================================================ */

/* ---------- Fonts (local-first, system fallback if missing) ---------- */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/space-grotesk-500.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/space-grotesk-700.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-700.woff2') format('woff2')}
@font-face{font-family:'Instrument Serif';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/instrument-serif-400.woff2') format('woff2')}
@font-face{font-family:'Instrument Serif';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/instrument-serif-400-italic.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/jetbrains-mono-500.woff2') format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --ink-0:#0a0a1a;
  --moss-300:#a1c4ab; --moss-500:#6fa37a; --moss-600:#3f6b54; --moss-700:#24453a; --moss-900:#0f1713;
  --amber-500:#cd8a4b; --amber-300:#fcd34d;
  --bg:#f5f0e8; --bg-soft:#ebe4d5;
  --fg:#0f1713; --fg-muted:rgba(15,23,19,.86); --fg-dim:rgba(15,23,19,.72); --fg-faint:rgba(15,23,19,.55);
  --surface:#fffdf8;
  --glass-bg:rgba(255,252,245,.65); --glass-border:rgba(63,107,84,.22);
  --glass-soft-bg:rgba(15,23,19,.03); --glass-soft-border:rgba(63,107,84,.15);
  --rule:rgba(63,107,84,.22);
  --input-bg:rgba(255,252,245,.7); --input-border:rgba(63,107,84,.28);
  --primary:var(--moss-600); --primary-ink:#fffdf8; --accent:var(--amber-500);
  --shadow-sm:0 1px 2px rgba(15,23,19,.06),0 2px 8px rgba(15,23,19,.05);
  --shadow-md:0 8px 30px rgba(15,23,19,.10);
  --shadow-lg:0 20px 60px rgba(15,23,19,.16);
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-pill:9999px;
  --maxw:1180px;
  --grain-opacity:.10; --grain-blend:multiply;
  --font-display:'Space Grotesk',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-serif:'Instrument Serif',Georgia,'Times New Roman',serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
[data-theme="dark"]{
  --bg:#0d1310; --bg-soft:#121b16;
  --fg:#eef3ea; --fg-muted:rgba(238,243,234,.82); --fg-dim:rgba(238,243,234,.66); --fg-faint:rgba(238,243,234,.45);
  --surface:#14201a;
  --glass-bg:rgba(28,42,34,.55); --glass-border:rgba(111,163,122,.22);
  --glass-soft-bg:rgba(255,255,255,.04); --glass-soft-border:rgba(111,163,122,.16);
  --rule:rgba(111,163,122,.20);
  --input-bg:rgba(20,32,26,.7); --input-border:rgba(111,163,122,.28);
  --primary:var(--moss-500); --primary-ink:#0d1310;
  --shadow-md:0 8px 30px rgba(0,0,0,.4); --shadow-lg:0 20px 60px rgba(0,0,0,.5);
  --grain-opacity:.06; --grain-blend:screen;
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);font-size:17px;line-height:1.65;
  color:var(--fg);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  min-height:100vh;position:relative;overflow-x:hidden;
}
/* film grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:var(--grain-opacity);
  mix-blend-mode:var(--grain-blend);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* organic background blobs */
.dh-blob{position:fixed;border-radius:50%;filter:blur(8px);opacity:.5;z-index:-1;pointer-events:none}
.dh-blob.moss{background:radial-gradient(circle at 30% 30%,var(--moss-500),var(--moss-700))}
.dh-blob.amber{background:radial-gradient(circle at 30% 30%,var(--amber-500),#7a4423)}

h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.02em;margin:0 0 .4em;color:var(--fg)}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:1.5rem;letter-spacing:-.01em}
h4{font-size:1.15rem}
p{margin:0 0 1rem}
a{color:var(--moss-600);text-decoration:none}
[data-theme="dark"] a{color:var(--moss-300)}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
hr{border:0;border-top:1px solid var(--rule);margin:2rem 0}
:focus-visible{outline:2px solid var(--moss-600);outline-offset:2px;border-radius:4px}
::selection{background:var(--amber-300);color:#0f1713}
.dh-serif{font-family:var(--font-serif);font-style:italic}
.dh-mono{font-family:var(--font-mono)}

/* ---------- Layout ---------- */
.dh-container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.dh-section{padding:64px 0}
.dh-narrow{max-width:880px;margin-inline:auto}

/* ---------- Eyebrow label ---------- */
.dh-eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);
  font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--moss-600);margin:0 0 14px}
[data-theme="dark"] .dh-eyebrow{color:var(--moss-300)}
.dh-eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--moss-500);box-shadow:0 0 0 4px rgba(111,163,122,.22)}

/* ---------- Header / nav ---------- */
.dh-header{position:sticky;top:0;z-index:100;padding:14px 0}
.dh-header-inner{display:flex;align-items:center;gap:18px;justify-content:space-between}
.dh-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--fg);letter-spacing:-.02em}
.dh-brand:hover{text-decoration:none}
.dh-brand .mark{width:30px;height:30px;border-radius:9px;background:var(--moss-600);color:#fffdf8;display:grid;place-items:center;font-weight:700;font-size:1rem;box-shadow:var(--shadow-sm)}
.dh-brand .dot{color:var(--moss-500)}
.dh-nav{display:flex;align-items:center;gap:4px;padding:6px;background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:var(--r-pill);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:var(--shadow-sm)}
.dh-nav a{padding:8px 16px;border-radius:var(--r-pill);color:var(--fg-muted);font-size:.92rem;font-weight:500}
.dh-nav a:hover{background:var(--glass-soft-bg);text-decoration:none;color:var(--fg)}
.dh-nav a.active{background:var(--moss-600);color:#fffdf8}
.dh-head-actions{display:flex;align-items:center;gap:10px}
.dh-icon-btn{width:42px;height:42px;border-radius:var(--r-pill);border:1px solid var(--glass-border);background:var(--glass-bg);
  color:var(--fg);display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(14px);transition:.15s}
.dh-icon-btn:hover{background:var(--glass-soft-bg);transform:translateY(-1px)}
.dh-nav-toggle{display:none}

/* ---------- Buttons ---------- */
.dh-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:.98rem;line-height:1;
  padding:14px 26px;border-radius:var(--r-pill);border:1px solid transparent;transition:.16s ease;text-decoration:none;white-space:nowrap}
.dh-btn:hover{text-decoration:none;transform:translateY(-1px)}
.dh-btn:active{transform:translateY(0)}
.dh-btn.primary{background:var(--moss-600);color:#fffdf8;box-shadow:var(--shadow-sm)}
.dh-btn.primary:hover{background:var(--moss-700);box-shadow:var(--shadow-md)}
[data-theme="dark"] .dh-btn.primary{background:var(--moss-500);color:#0d1310}
.dh-btn.ghost{background:var(--glass-bg);color:var(--fg);border-color:var(--glass-border);backdrop-filter:blur(10px)}
.dh-btn.ghost:hover{background:var(--glass-soft-bg)}
.dh-btn.amber{background:var(--amber-500);color:#1a1206}
.dh-btn.sm{padding:9px 16px;font-size:.86rem}
.dh-btn.lg{padding:17px 34px;font-size:1.05rem}
.dh-btn[disabled],.dh-btn.is-disabled{opacity:.5;pointer-events:none}
.dh-btn .arrow{transition:transform .16s}
.dh-btn:hover .arrow{transform:translateX(3px)}

/* ---------- Cards ---------- */
.dh-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);
  padding:26px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:var(--shadow-sm)}
.dh-card.solid{background:var(--surface)}
.dh-card.soft{background:var(--glass-soft-bg);border-color:var(--glass-soft-border);backdrop-filter:none}

/* ---------- Tool grid (hub) ---------- */
.dh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.dh-tool-card{position:relative;display:flex;flex-direction:column;gap:10px;background:var(--glass-bg);
  border:1px solid var(--glass-border);border-radius:var(--r-md);padding:22px;cursor:pointer;
  transition:.18s ease;text-decoration:none;color:var(--fg);backdrop-filter:blur(12px);overflow:hidden}
.dh-tool-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--moss-500);text-decoration:none}
.dh-tool-card .ti{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.4rem;
  background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border)}
.dh-tool-card h4{margin:0;font-family:var(--font-display);font-size:1.12rem}
.dh-tool-card p{margin:0;color:var(--fg-dim);font-size:.9rem;line-height:1.5}
.dh-tool-card .cat{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint)}

/* ---------- Badges ---------- */
.dh-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:.66rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border-radius:var(--r-pill);
  background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border);color:var(--fg-dim)}
.dh-badge.pro{display:none!important}
.dh-badge.free{color:var(--moss-600);border-color:var(--moss-500)}
.dh-badge.local{color:var(--moss-600)}

/* ---------- Forms ---------- */
.dh-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.dh-field label,.dh-label{font-size:.82rem;font-weight:600;color:var(--fg-muted);letter-spacing:.01em}
.dh-field .hint{font-size:.78rem;color:var(--fg-faint)}
.dh-input,.dh-select,.dh-textarea,input[type=text].dh,input[type=number].dh{
  width:100%;font-family:var(--font-body);font-size:.96rem;color:var(--fg);
  background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--r-sm);padding:12px 14px;transition:.15s}
.dh-textarea{min-height:140px;resize:vertical;line-height:1.6}
.dh-input:focus,.dh-select:focus,.dh-textarea:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 3px rgba(111,163,122,.2)}
.dh-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%233f6b54' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.dh-row{display:flex;gap:14px;flex-wrap:wrap}
.dh-row>*{flex:1;min-width:160px}
.dh-check{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:.92rem;color:var(--fg-muted)}
.dh-check input{width:18px;height:18px;accent-color:var(--moss-600)}
input[type=range].dh-range{width:100%;accent-color:var(--moss-600);height:6px}
.dh-seg{display:inline-flex;background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border);border-radius:var(--r-pill);padding:4px;gap:2px}
.dh-seg button{border:0;background:transparent;color:var(--fg-dim);font-family:var(--font-body);font-weight:600;font-size:.85rem;padding:7px 15px;border-radius:var(--r-pill);cursor:pointer}
.dh-seg button.active{background:var(--moss-600);color:#fffdf8}

/* ---------- Dropzone ---------- */
.dh-dropzone{border:2px dashed var(--input-border);border-radius:var(--r-md);padding:46px 24px;text-align:center;
  background:var(--glass-soft-bg);cursor:pointer;transition:.18s;color:var(--fg-dim)}
.dh-dropzone:hover,.dh-dropzone.drag{border-color:var(--moss-500);background:rgba(111,163,122,.1);color:var(--fg)}
.dh-dropzone .big{font-size:2.4rem;margin-bottom:8px}
.dh-dropzone strong{color:var(--fg);font-weight:600}

/* ---------- Tool page header ---------- */
.dh-tool-header{padding:30px 0 14px}
.dh-breadcrumb{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:14px}
.dh-breadcrumb a{color:var(--moss-600)}
.dh-tool-header h1{font-size:clamp(2.1rem,4.5vw,3.2rem);margin-bottom:.25em}
.dh-tool-header .sub{font-size:1.08rem;color:var(--fg-dim);max-width:680px}
.dh-toolcredit{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-family:var(--font-mono);font-size:.73rem;letter-spacing:.03em;color:var(--fg-dim);text-decoration:none;border:1px solid var(--glass-soft-border);background:var(--glass-soft-bg);padding:7px 13px;border-radius:var(--r-pill);width:fit-content;transition:.15s}
.dh-toolcredit:hover{color:var(--fg);border-color:var(--moss-500);text-decoration:none;transform:translateY(-1px)}
.dh-toolcredit strong{color:var(--moss-600);font-weight:600}
[data-theme="dark"] .dh-toolcredit strong{color:var(--moss-300)}
.dh-toolcredit .arrow{transition:transform .16s}
.dh-toolcredit:hover .arrow{transform:translateX(3px)}

/* ---------- Hero (hub) ---------- */
.dh-hero{padding:56px 0 30px;position:relative}
.dh-hero h1{margin-bottom:.2em}
.dh-hero .lead{font-size:1.22rem;color:var(--fg-dim);max-width:620px}
.dh-hero .lead .dh-serif{color:var(--moss-600);font-size:1.3em}
.dh-ghost-word{position:absolute;right:-2%;top:-10%;font-family:var(--font-display);font-weight:700;
  font-size:18vw;color:transparent;-webkit-text-stroke:1.5px rgba(63,107,84,.10);z-index:-1;pointer-events:none;user-select:none;line-height:1}

/* ---------- Search ---------- */
.dh-search{position:relative;max-width:520px}
.dh-search input{width:100%;font-size:1rem;padding:15px 18px 15px 48px;border-radius:var(--r-pill);
  background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--fg);backdrop-filter:blur(12px)}
.dh-search input:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 3px rgba(111,163,122,.18)}
.dh-search .si{position:absolute;left:17px;top:50%;transform:translateY(-50%);color:var(--fg-faint)}
.dh-cat-filter{display:flex;gap:8px;flex-wrap:wrap;margin:22px 0}
.dh-chip{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:8px 14px;border-radius:var(--r-pill);background:var(--glass-bg);border:1px solid var(--glass-border);
  color:var(--fg-dim);cursor:pointer;transition:.14s}
.dh-chip:hover{color:var(--fg)}
.dh-chip.active{background:var(--moss-600);color:#fffdf8;border-color:transparent}
.dh-tagrow{margin-top:-10px}
.dh-chip.tagon{background:var(--amber-500);color:#1a1206;border-color:transparent;font-weight:700}

/* ---------- Toast ---------- */
.dh-toasts{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:10001;display:flex;flex-direction:column;gap:10px;align-items:center}
.dh-toast{background:var(--moss-900);color:#f5f0e8;padding:13px 20px;border-radius:var(--r-pill);box-shadow:var(--shadow-lg);
  font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:10px;animation:dh-toast-in .25s ease;max-width:90vw}
.dh-toast.err{background:#7a2a2a}
.dh-toast.ok{background:var(--moss-600)}
@keyframes dh-toast-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ---------- Modal ---------- */
.dh-modal-backdrop{position:fixed;inset:0;z-index:10000;background:rgba(10,10,26,.55);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:20px}
.dh-modal-backdrop.open{display:flex}
.dh-modal{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);
  max-width:460px;width:100%;padding:30px;box-shadow:var(--shadow-lg);animation:dh-toast-in .22s ease}
.dh-modal h3{margin-top:0}
.dh-modal .close{float:right;cursor:pointer;color:var(--fg-faint);font-size:1.4rem;line-height:1;background:none;border:0}

/* ---------- Command palette (⌘K) ---------- */
.dh-cmdk{position:fixed;inset:0;z-index:10002;background:rgba(10,10,26,.5);backdrop-filter:blur(4px);display:none;align-items:flex-start;justify-content:center;padding:13vh 16px 16px}
.dh-cmdk.open{display:flex}
.dh-cmdk-box{width:100%;max-width:580px;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:dh-toast-in .18s ease;display:flex;flex-direction:column;max-height:74vh}
.dh-cmdk-box input{width:100%;border:0;border-bottom:1px solid var(--rule);background:transparent;color:var(--fg);font-family:var(--font-body);font-size:1.06rem;padding:16px 18px;outline:none}
.dh-cmdk-list{overflow-y:auto;padding:6px;flex:1}
.dh-cmdk-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);text-decoration:none;color:var(--fg)}
.dh-cmdk-item .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border);font-size:1rem;flex:none}
.dh-cmdk-item .nm{flex:1;font-weight:500}
.dh-cmdk-item .ct{font-size:.66rem;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.1em;font-family:var(--font-mono)}
.dh-cmdk-item.active,.dh-cmdk-item:hover{background:var(--moss-600);color:#fffdf8;text-decoration:none}
.dh-cmdk-item.active .ct,.dh-cmdk-item:hover .ct{color:rgba(255,255,255,.82)}
.dh-cmdk-item.active .ic,.dh-cmdk-item:hover .ic{background:rgba(255,255,255,.18);border-color:transparent}
.dh-cmdk-empty{padding:26px;text-align:center;color:var(--fg-faint)}
.dh-cmdk-foot{border-top:1px solid var(--rule);padding:9px 14px;color:var(--fg-faint);font-size:.7rem}

/* ---------- Per-tool SEO section (FAQ + related) ---------- */
.dh-seo{padding:14px 24px 0}
.dh-seo .dh-seo-h{font-size:1.4rem;margin:30px 0 14px}
.dh-faq{border:1px solid var(--glass-soft-border);background:var(--glass-soft-bg);border-radius:var(--r-sm);padding:0 16px;margin-bottom:10px}
.dh-faq summary{cursor:pointer;font-weight:600;padding:14px 0;list-style:none;display:flex;align-items:flex-start;gap:10px}
.dh-faq summary::-webkit-details-marker{display:none}
.dh-faq summary::before{content:"+";color:var(--moss-600);font-weight:700}
[data-theme="dark"] .dh-faq summary::before{color:var(--moss-300)}
.dh-faq[open] summary::before{content:"–"}
.dh-faq p{margin:0 0 14px;color:var(--fg-dim)}
.dh-related{margin-top:30px}
.dh-rel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.dh-rel{display:flex;flex-direction:column;gap:3px;padding:14px;border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:var(--r-md);text-decoration:none;color:var(--fg);transition:.15s}
.dh-rel:hover{border-color:var(--moss-500);transform:translateY(-2px);text-decoration:none;box-shadow:var(--shadow-sm)}
.dh-rel span{font-size:1.2rem}
.dh-rel b{font-weight:600}
.dh-rel i{font-style:normal;font-size:.82rem;color:var(--fg-faint)}
.dh-about{margin-bottom:6px}
.dh-about p{color:var(--fg-dim);line-height:1.75;font-size:1rem;margin:0}

/* ---------- Hub: category + subcategory grouping ---------- */
.hub-cat{margin:40px 0 8px}
.hub-cat:first-child{margin-top:8px}
.hub-cath{display:flex;align-items:center;gap:12px;font-size:1.65rem;margin:0 0 2px;letter-spacing:-.01em}
.hub-cath .ci{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:1.15rem;background:var(--glass-bg);border:1px solid var(--glass-border);flex:none}
.hub-count{font-family:var(--font-mono);font-size:.72rem;color:var(--fg-faint);background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border);border-radius:999px;padding:3px 10px}
.hub-subh{display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--moss-600);margin:22px 0 12px}
[data-theme="dark"] .hub-subh{color:var(--moss-300)}
.hub-subh::after{content:"";height:1px;background:var(--rule);flex:1}
/* ---------- Fullscreen / focus mode ---------- */
.dh-fsbtn{position:fixed;right:18px;bottom:18px;z-index:9000;width:48px;height:48px;border-radius:50%;
  background:var(--moss-600);color:#fffdf8;border:0;font-size:1.25rem;cursor:pointer;box-shadow:var(--shadow-md);
  display:grid;place-items:center;transition:.15s;opacity:.85}
.dh-fsbtn:hover{opacity:1;transform:scale(1.07)}
[data-theme="dark"] .dh-fsbtn{background:var(--moss-500);color:#0d1310}
body.dh-focus #dh-header,body.dh-focus #dh-footer,body.dh-focus .dh-seo,body.dh-focus .dh-toolcredit,
body.dh-focus .dh-breadcrumb,body.dh-focus .dh-eyebrow,body.dh-focus .dh-tool-header .sub,body.dh-focus .dh-blob{display:none!important}
body.dh-focus .dh-tool-header{padding:10px 0 4px}
body.dh-focus .dh-tool-header h1{font-size:1.25rem;margin-bottom:0}
body.dh-focus .dh-container{max-width:100%;padding:0 14px}
body.dh-focus{overflow:auto}

/* ---------- Wide mode: tool stretches to full screen width ---------- */
body.dh-wide .dh-container{max-width:100%;padding:0 20px}
body.dh-wide .dh-tool-header .sub{max-width:900px}
.dh-widebtn{background:var(--glass-bg);color:var(--fg);border:1px solid var(--glass-border);backdrop-filter:blur(10px);font-size:1.1rem}
.dh-widebtn.stacked{bottom:74px}
.dh-widebtn.on{background:var(--amber-500);color:#1a1206;border-color:transparent;opacity:1}
@media(max-width:700px){.dh-widebtn{display:none}} /* phones are already full width */

.dh-howto{margin:0;padding-left:22px;color:var(--fg-dim);line-height:1.85}
.dh-howto li{margin-bottom:7px}
.dh-howto li strong{color:var(--fg)}

/* ---------- Result / preview helpers ---------- */
.dh-result{margin-top:18px}
.dh-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.dh-thumb{background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border);border-radius:var(--r-sm);padding:8px;font-size:.78rem;color:var(--fg-dim);overflow:hidden}
.dh-thumb img{border-radius:6px;margin-bottom:6px}
.dh-kbd{font-family:var(--font-mono);font-size:.78rem;background:var(--glass-soft-bg);border:1px solid var(--glass-soft-border);border-radius:6px;padding:2px 7px}
.dh-stat{font-family:var(--font-mono);font-size:.8rem;color:var(--fg-dim)}
.dh-empty{text-align:center;color:var(--fg-faint);padding:40px 0}

/* ---------- Footer ---------- */
.dh-footer{margin-top:80px;border-top:1px solid var(--rule);background:var(--glass-soft-bg)}
.dh-footer-inner{padding:48px 0;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px}
.dh-footer h5{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);margin:0 0 14px}
.dh-footer a{display:block;color:var(--fg-dim);font-size:.92rem;padding:4px 0}
.dh-footer a:hover{color:var(--fg)}
.dh-cta-card{background:var(--moss-600);color:#fffdf8;border-radius:var(--r-lg);padding:30px;margin:30px 0}
.dh-cta-card h3{color:#fffdf8}
.dh-cta-card p{color:rgba(255,255,255,.82)}
[data-theme="dark"] .dh-cta-card{background:var(--moss-700)}
.dh-footer-bottom{border-top:1px solid var(--rule);padding:22px 0;font-size:.84rem;color:var(--fg-faint);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- Main-site chrome parity (logo + footer closer + contact + map) ---------- */
.dh-logo{display:inline-flex;align-items:center;flex-shrink:0}
.dh-logo:hover{text-decoration:none}
.dh-logo-dark{display:none}
[data-theme="dark"] .dh-logo-light{display:none}
[data-theme="dark"] .dh-logo-dark{display:inline-block}
.dh-foot-closer{display:grid;grid-template-columns:1.4fr 1fr;gap:44px;align-items:start;padding:60px 0 44px;border-bottom:1px solid var(--rule)}
.dh-foot-h{font-family:var(--font-display);font-weight:700;font-size:clamp(2.6rem,6.2vw,5rem);line-height:.94;letter-spacing:-.03em;margin:.25em 0 .32em}
.dh-foot-sub{max-width:32rem;font-size:1.02rem;line-height:1.7}
.dh-foot-ctas{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.dh-foot-form{margin-top:24px;max-width:32rem;display:flex;flex-direction:column;gap:10px}
.dh-foot-form .dh-eyebrow{margin-bottom:2px}
.dh-foot-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dh-cf-input{width:100%;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;padding:11px 15px;font-family:inherit;font-size:.92rem;color:var(--fg)}
.dh-cf-input::placeholder{color:var(--fg-faint)}
.dh-cf-input:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 3px rgba(111,163,122,.18)}
textarea.dh-cf-input{resize:vertical;min-height:62px}
.dh-foot-form .dh-btn{align-self:flex-start;margin-top:2px}
.dh-foot-map{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:14px}
.dh-foot-map-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:4px 6px 14px}
.dh-foot-map-h{font-family:var(--font-display);font-weight:700;font-size:1.15rem;margin:.18em 0 0}
.dh-foot-addr{font-size:.8rem;margin:.35em 0 0}
.dh-foot-call{flex-shrink:0;border:1px solid var(--glass-border);border-radius:var(--r-pill);padding:6px 13px;font-family:var(--font-mono);font-size:.72rem;color:var(--fg-dim)}
.dh-foot-call:hover{color:var(--fg);text-decoration:none}
.dh-foot-map-frame{position:relative;aspect-ratio:16/11;border-radius:14px;overflow:hidden;border:1px solid var(--rule);background:var(--bg-soft)}
.dh-foot-map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.dh-foot-dir{display:inline-flex;align-items:center;gap:6px;margin:12px 0 0 6px;font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--moss-500)}
.dh-foot-dir:hover{text-decoration:none;color:var(--moss-600)}
@media (max-width:860px){ .dh-foot-closer{grid-template-columns:1fr;gap:34px} }
@media (max-width:680px){ .dh-footer-inner{grid-template-columns:1fr 1fr} .dh-foot-form-row{grid-template-columns:1fr} }

/* ---------- Utilities ---------- */
.dh-flex{display:flex}.dh-between{justify-content:space-between}.dh-center{align-items:center}
.dh-wrap-f{flex-wrap:wrap}.dh-col{flex-direction:column}
.dh-gap-6{gap:6px}.dh-gap-10{gap:10px}.dh-gap-14{gap:14px}.dh-gap-20{gap:20px}
.dh-mt-8{margin-top:8px}.dh-mt-16{margin-top:16px}.dh-mt-24{margin-top:24px}.dh-mt-40{margin-top:40px}
.dh-mb-0{margin-bottom:0}.dh-muted{color:var(--fg-dim)}.dh-faint{color:var(--fg-faint)}
.dh-tac{text-align:center}.dh-hidden{display:none!important}.dh-full{width:100%}
.dh-pill-row{display:flex;gap:8px;flex-wrap:wrap}
.dh-grow{flex:1}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  body{font-size:16px}
  .dh-nav{display:none;position:absolute;top:70px;left:24px;right:24px;flex-direction:column;align-items:stretch;padding:10px}
  .dh-nav.open{display:flex}
  .dh-nav a{padding:11px 14px}
  .dh-nav-toggle{display:grid}
  .dh-footer-inner{grid-template-columns:1fr;gap:24px}
  .dh-ghost-word{display:none}
  .dh-section{padding:44px 0}
}
@media (max-width:520px){
  .dh-container{padding:0 16px}
  .dh-btn{padding:13px 20px}
}
@media print{ .dh-header,.dh-footer,.dh-toasts{display:none} body::before{display:none} }
