/*
Theme Name: Dermhilda
Theme URI: https://dermhilda.com
Author: Dermhilda
Description: Brochure theme for dermhilda.com - five fixed pages with hardcoded nav and approved copy. No menus, widgets, or customizer options by design. Page content lives in the templates, not the WP editor.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: All rights reserved
Text Domain: dermhilda
*/
/* ============================================================
   Dermhilda — shared site styles
   Used by every page. Edit design tokens once, here.
   ============================================================ */

:root{
  --cream:#faf6eb;        /* page background */
  --ink:#221e18;          /* primary warm near-black text */
  --muted:#6b6253;        /* taupe — labels, captions, fine print */
  --cyan:#04cdff;         /* bright brand accent */
  --cyan-deep:#0a7ea4;    /* legible cyan for links/accents on cream */
  --line:#e6dfcc;         /* warm hairline / borders */
  --card:#ffffff;         /* card surface */
  --serif:"Source Serif 4",Georgia,serif;
  --sans:"Public Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --wrap:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
#calculator{scroll-margin-top:16px} /* land on "Build your quote"; the section's own 84px top padding already clears the 72px sticky nav, this just adds breathing room */
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--serif);font-size:1.125rem;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
a{color:var(--cyan-deep);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--cyan-deep);outline-offset:3px;border-radius:2px}

/* ---- type roles ---- */
.eyebrow{
  font-family:var(--mono);font-size:.85rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  margin:0 0 18px;
}
.lead-eyebrow{margin-bottom:14px}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.08;letter-spacing:-.015em;margin:0}
h1{font-size:clamp(2.9rem,6.5vw,4.6rem)}
h1.lead-h1{font-size:clamp(2.2rem,4.4vw,3.4rem)} /* page-lead heading on hero-less pages (e.g. Pricing) */
h2{font-size:clamp(1.85rem,3.6vw,2.6rem);line-height:1.12}
p{margin:1.1em 0}
em{font-style:italic}

/* ---- button ---- */
.btn{
  display:inline-block;font-family:var(--sans);font-weight:600;font-size:1rem;
  letter-spacing:.01em;background:var(--cyan);color:var(--ink);
  padding:14px 26px;border-radius:999px;border:1px solid #00b6e2;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
  box-shadow:0 1px 0 rgba(0,0,0,.04);
}
.btn:hover{text-decoration:none;background:#23d4ff;transform:translateY(-1px);box-shadow:0 6px 18px rgba(4,205,255,.28)}
.btn:active{transform:translateY(0)}
.cta-row{margin-top:28px}
.cta-note{margin:14px 0 0;font-family:var(--serif);font-size:.98rem;color:var(--muted)}
/* wraps a CTA button + its fallback note so the note centers under the
   button whether the CTA is left-aligned (hero) or centered (closing) */
.cta-stack{display:inline-block;text-align:center}

/* ---- nav ---- */
header.nav{
  position:sticky;top:0;z-index:20;background:rgba(250,246,235,.86);
  backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:1.4rem;color:var(--ink);letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand img{display:block}
.nav-links{display:flex;gap:26px;font-family:var(--sans);font-size:.95rem;font-weight:500}
.nav-links a{color:var(--ink)}
.nav-links a:hover{color:var(--cyan-deep);text-decoration:none}
.nav-links a[aria-current="page"]{color:var(--cyan-deep)}
.nav-menu{display:flex;align-items:center;gap:26px;margin-left:auto}
.nav-login{font-family:var(--sans);font-size:.95rem;font-weight:500;color:var(--ink)}
.nav-login:hover{color:var(--cyan-deep);text-decoration:none}
.nav .btn{padding:10px 20px}
.nav-toggle{display:none;width:44px;height:44px;margin-left:auto;border:0;background:transparent;color:var(--ink);cursor:pointer;align-items:center;justify-content:center}
.nav-toggle-bars,.nav-toggle-bars::before,.nav-toggle-bars::after{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform .15s ease,background .15s ease}
.nav-toggle-bars{position:relative}
.nav-toggle-bars::before,.nav-toggle-bars::after{content:"";position:absolute;left:0}
.nav-toggle-bars::before{top:-7px}
.nav-toggle-bars::after{top:7px}
.nav-toggle[aria-expanded="true"] .nav-toggle-bars{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-toggle-bars::before{transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bars::after{transform:translateY(-7px) rotate(-45deg)}
@media(max-width:860px){
  .nav-toggle{display:flex}
  .nav-menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;margin:0;padding:6px 0 16px;background:var(--cream);border-bottom:1px solid var(--line);box-shadow:0 16px 30px -22px rgba(34,30,24,.45)}
  .nav-menu.open{display:flex}
  .nav-links{flex-direction:column;gap:0}
  .nav-links a{padding:13px 24px}
  .nav-login{padding:13px 24px}
  .nav-menu .btn{margin:12px 24px 0;text-align:center}
}

/* ---- sections ---- */
section{padding:84px 0}
.section-narrow{max-width:760px}
.body-lg p{font-size:1.18rem}
.body-lg .eyebrow{font-size:.85rem} /* keep eyebrows at the label size; beats .body-lg p */
.center{text-align:center}
.measure{max-width:60ch;margin-left:auto;margin-right:auto}

/* ---- divider ---- */
.rule{border:0;max-width:var(--wrap);margin:0 auto;height:16px;display:flex;align-items:center;background:url('images/glasses.png') center/26px auto no-repeat}
.rule::before,.rule::after{content:"";flex:1;height:1px;background:var(--line)}
.rule::before{margin-right:24px}
.rule::after{margin-left:24px}

/* ---- hero ---- */
.hero{padding:72px 0 64px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.hero-grid>*{min-width:0}
.hero-grid h1{font-size:clamp(2.5rem,4.5vw,3.5rem);margin:0 0 22px}
.hero-text{max-width:900px}
.hero-text h1{font-size:clamp(2.4rem,4.6vw,3.7rem);margin:0 0 22px}
.hero .sub{font-size:1.28rem;line-height:1.5;max-width:38ch}
.hero-visual{position:relative;width:100%;max-width:480px;justify-self:end}
.hero-visual>img{width:100%;height:auto;display:block;border-radius:18px}
.card.hero-card{position:relative;z-index:2;width:calc(100% - 8px);margin:-50% 0 0 -40px;padding:26px 28px}
.hero-card .greeting{font-family:var(--serif);font-size:1.18rem;font-weight:600;margin:0 0 16px}
.hero-card .hero-item{display:flex;gap:12px;align-items:flex-start;margin:14px 0}
.hero-card .num{flex:0 0 auto;min-width:13px;font-family:var(--serif);font-style:italic;font-size:1.02rem;line-height:1.5;color:var(--cyan-deep)}
.hero-card .hero-item p{margin:0;font-size:1rem;line-height:1.5}
.hero-card .bar{height:12px;border-radius:6px;background:var(--line);margin-top:7px}
.hero-card .hero-item:nth-child(1) .bar{width:82%}
.hero-card .hero-item:nth-child(2) .bar{width:64%}
.hero-card .hero-item:nth-child(4) .bar{width:74%}
.hero-card .hero-item:nth-child(5) .bar{width:56%}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{max-width:400px;justify-self:start}
  .card.hero-card{width:100%;margin:-64px 0 0 0}
}

/* How It Works hero — standalone briefing card on the left, copy on the right */
.hero-visual--solo .card.hero-card{margin:0;width:100%}
@media(min-width:861px){
  .hero-grid-flip .hero-copy{order:2}
  .hero-grid-flip .hero-visual{order:1;justify-self:start}
}

/* ---- briefing card (signature) ---- */
.brief-wrap{max-width:760px;margin:0 auto}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:30px 32px;margin:30px 0 28px;
  box-shadow:0 14px 40px -22px rgba(34,30,24,.35);
}
.card-label{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cyan-deep);margin:0 0 16px;display:flex;align-items:center;gap:9px;
}
.card-label img{display:block;flex:0 0 auto}
.card-body{display:flex;gap:16px;align-items:flex-start}
.card-body p{margin:0;font-size:1.14rem;line-height:1.55}

/* ---- chat exchange (You / Dermhilda) ---- */
.chat{max-width:680px;margin:26px 0}
.chat .turn{margin:0 0 18px}
.chat .turn:last-child{margin-bottom:0}
.chat .who{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 6px}
.chat .says{margin:0;font-size:1.12rem;line-height:1.5}
.chat .turn.her{border-left:2px solid var(--cyan);padding-left:18px}
.chat .turn.her .who{color:var(--cyan-deep)}

/* ---- leak ledger (ROI section) ---- */
.leak-list{list-style:none;margin:24px 0;padding:0;border-top:1px solid var(--line)}
.leak-list li{display:flex;gap:18px;align-items:baseline;border-bottom:1px solid var(--line);padding:13px 0;font-size:1.06rem;line-height:1.45}
.leak-tag{flex:0 0 150px;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan-deep)}
@media(max-width:560px){.leak-list li{flex-direction:column;gap:4px}.leak-tag{flex:none}}

/* ---- closing band ---- */
.closing{background:#f3edda;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.closing .measure{font-size:1.18rem}

/* ---- legal long-form (Terms, Privacy) ---- */
.updated{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:14px 0 0}
.legal{font-size:1rem;line-height:1.65}
.legal h2{font-size:1.25rem;line-height:1.25;margin:34px 0 10px}
.legal p{margin:0 0 14px}
.legal ul{margin:0 0 14px;padding-left:1.25em}
.legal li{margin:7px 0;line-height:1.55}
.legal a{color:var(--cyan-deep)}

/* ---- footer ---- */
footer{padding:54px 0 60px}
.foot-grid{display:flex;flex-wrap:wrap;gap:18px 40px;align-items:baseline;justify-content:space-between}
.foot-brand{font-family:var(--serif);font-weight:700;font-size:1.25rem}
.foot-meta{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;color:var(--muted);line-height:1.9;text-align:right}
.foot-meta a{color:var(--muted)}
.foot-nav{display:flex;flex-wrap:wrap;gap:10px 22px;font-family:var(--sans);font-size:.92rem;font-weight:500}
.foot-nav a{color:var(--ink)}
.foot-nav a:hover{color:var(--cyan-deep);text-decoration:none}
.foot-tag{display:block;margin-top:6px;font-family:var(--sans);font-size:.82rem;font-weight:500;color:var(--muted);max-width:32ch}
.foot-base{margin-top:32px;padding-top:20px;border-top:1px solid var(--line);font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--muted)}
.foot-base a{color:var(--muted)}
.foot-base a:hover{color:var(--cyan-deep);text-decoration:none}

/* ---- pricing: four tier cards ---- */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:36px 0 8px}
.tier{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:26px 22px 24px;display:flex;flex-direction:column;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.tier:hover{transform:translateY(-2px);box-shadow:0 14px 36px -22px rgba(34,30,24,.30);border-color:#d6c9a3}
.tier .tier-name{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-deep);margin:0 0 18px}
.tier .from{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 4px;display:block}
.tier .price{font-family:var(--serif);font-size:1.85rem;font-weight:700;color:var(--ink);line-height:1.1;margin:0;letter-spacing:-.015em}
.tier .price .per{font-family:var(--sans);font-size:.95rem;font-weight:500;color:var(--muted);margin-left:2px}
.tier .audience{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:.98rem;margin:18px 0 14px;line-height:1.45}
.tier .what{font-family:var(--serif);font-size:.98rem;line-height:1.5;margin:0;color:var(--ink)}
.tiers-note{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:.98rem;margin:22px 0 0;text-align:center}
@media(max-width:980px){.tiers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tiers{grid-template-columns:1fr}}

/* ---- pricing: calculator embed shell ---- */
.calc-shell{
  background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:52px 32px;margin:34px 0 20px;text-align:center;
  display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;
}
.calc-shell h3{font-family:var(--serif);font-size:clamp(1.5rem,2.6vw,1.85rem);margin:0 0 14px;letter-spacing:-.015em}
.calc-shell p{font-family:var(--serif);font-size:1.06rem;color:var(--muted);max-width:54ch;margin:0 0 24px;line-height:1.55}
.calc-shell .calc-meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:18px 0 0}
.calc-shell .calc-meta a{color:var(--muted);text-decoration:underline}

/* ---- pricing: add-on cards ---- */
.addons{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin:30px 0 0}
.addon{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:28px 30px;
}
.addon .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-deep);margin:0 0 10px}
.addon h3{font-family:var(--serif);font-size:1.42rem;margin:0 0 12px;letter-spacing:-.01em}
.addon p{font-family:var(--serif);font-size:1rem;line-height:1.55;margin:.8em 0}
.addon p:last-child{margin-bottom:0}
.soon{display:inline-block;margin-left:8px;padding:2px 9px;border-radius:999px;background:var(--line);color:var(--muted);font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;vertical-align:middle}
@media(max-width:760px){.addons{grid-template-columns:1fr}}

/* ---- pricing: groups callout ---- */
.groups-callout{
  background:#f3edda;border:1px solid var(--line);border-radius:14px;
  padding:32px 36px;margin:0;display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;
}
.groups-callout .gc-text{flex:1 1 360px}
.groups-callout h2{font-size:clamp(1.5rem,2.4vw,1.85rem);margin:0 0 10px}
.groups-callout p{margin:0;font-size:1.04rem;line-height:1.5}
.groups-callout .btn{flex:0 0 auto}

/* ---- groups: six-category metric grid ---- */
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:34px 0 14px}
.metric{
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:22px 24px;
}
.metric h3{font-family:var(--serif);font-size:1.08rem;font-weight:700;margin:0 0 8px;color:var(--ink);letter-spacing:-.005em}
.metric p{font-family:var(--serif);font-size:.98rem;line-height:1.5;color:var(--ink);margin:0}
@media(max-width:880px){.metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.metrics{grid-template-columns:1fr}}

/* ---- groups: portfolio (multi-item) briefing card ---- */
.card.portfolio .card-body{display:block}
.card.portfolio .greeting{
  font-family:var(--serif);font-size:1.18rem;font-weight:600;
  margin:0 0 22px;color:var(--ink);letter-spacing:-.005em;
}
.brief-items{display:grid;gap:18px;margin:0}
.brief-item{
  font-family:var(--serif);font-size:1.06rem;line-height:1.55;
  color:var(--ink);margin:0;
}
.brief-item strong{font-weight:700}

/* sub-heading inside a section (smaller than h2, larger than body) */
.subhead-row{margin-top:46px}
.subhead-row h2{font-size:clamp(1.4rem,2.4vw,1.85rem)}

/* ---- security: AccountableHQ HIPAA seal — small supporting mark ---- */
.compliance-seal{float:right;width:130px;height:auto;margin:4px 0 14px 30px}
@media(max-width:560px){.compliance-seal{float:none;display:block;margin:6px 0 18px}}

/* ---- security: three-layer safeguards grid ---- */
.safeguards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:34px 0 8px}
.safeguard{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:26px 24px;display:flex;flex-direction:column;
}
.safeguard .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-deep);margin:0 0 6px}
.safeguard h3{font-family:var(--serif);font-size:1.18rem;font-weight:700;margin:0 0 16px;letter-spacing:-.005em;color:var(--ink)}
.safeguard ul{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.safeguard li{font-family:var(--serif);font-size:.98rem;line-height:1.5;color:var(--ink);padding-left:18px;position:relative}
.safeguard li::before{content:"";position:absolute;left:2px;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--cyan)}
@media(max-width:880px){.safeguards{grid-template-columns:1fr}}

/* ---- security: document card (linking to the security overview deck) ---- */
.doc-card{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:28px 32px;margin:32px 0 8px;
  display:flex;gap:26px;align-items:center;
}
.doc-card .doc-icon{
  flex:0 0 auto;width:64px;height:64px;background:#eaf8fd;border-radius:14px;
  display:grid;place-items:center;color:var(--cyan-deep);
}
.doc-card .doc-content{flex:1 1 auto;min-width:0}
.doc-card .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-deep);margin:0 0 8px}
.doc-card h3{font-family:var(--serif);font-size:1.35rem;font-weight:700;margin:0 0 8px;letter-spacing:-.01em}
.doc-card .doc-content > p{font-family:var(--serif);font-size:1rem;line-height:1.5;color:var(--ink);margin:0 0 18px}
.doc-card .doc-content .btn{padding:11px 22px;font-size:.95rem}
@media(max-width:640px){
  .doc-card{flex-direction:column;align-items:flex-start;gap:18px;padding:26px}
}

/* ---- security: honest-note (the "we don't warrant" paragraph) ---- */
.honest-note{
  border-left:2px solid var(--cyan);
  padding:4px 0 4px 22px;
  margin:30px 0;
  font-family:var(--serif);
  font-size:1.08rem;
  line-height:1.55;
  color:var(--ink);
}
.honest-note .lede{font-style:italic;color:var(--muted)}

/* ---- about: founder's note (a personal aside from the builder — set apart from Dermhilda's first-person voice) ---- */
.founder-note{
  background:#f3edda;border:1px solid var(--line);border-radius:18px;
  padding:40px 44px;max-width:760px;margin:0 auto;
}
.founder-note .eyebrow{color:var(--cyan-deep)}
.founder-note h2{font-size:clamp(1.5rem,2.6vw,1.95rem);margin:0 0 10px}
.founder-note p{font-family:var(--serif);font-size:1.08rem;line-height:1.6}
.founder-sign{display:flex;align-items:center;gap:16px;margin:26px 0 0;padding-top:22px;border-top:1px solid var(--line)}
.founder-photo{flex:0 0 auto;width:64px;height:64px;border-radius:50%;object-fit:cover;border:1px solid var(--line)}
.founder-by{display:flex;flex-direction:column;line-height:1.3}
.founder-name{font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--ink)}
.founder-title{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:4px}
@media(max-width:560px){.founder-note{padding:30px 24px}}

@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
