/* ============================================================
   Webbloom Digital — shared site styles (sub-pages)
   Mirrors the design system used on index.html
   ============================================================ */
:root{
  --cream:#f5efe4;
  --cream-2:#ebe2d0;
  --paper:#fbf7ef;
  --ink:#1a1612;
  --ink-soft:#3a322a;
  --muted:#7a6f60;
  --line:#d9cfbb;
  --accent:#c2410c;
  --accent-soft:#e8762d;
  --gold:#a87b3e;
  --emerald:#0f6b58;
  --emerald-soft:#1a9077;
  --emerald-bright:#2bb89a;
  --emerald-deep:#0a4d3f;
  --emerald-tint:#e4efe9;
  --max:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
*::selection{background:var(--accent);color:var(--cream)}
html{scroll-behavior:smooth;scroll-padding-top:80px;overflow-x:clip;width:100%}
body{
  font-family:'Inter',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
  width:100%;
  max-width:100%;
  position:relative;
}
.serif{font-family:'Fraunces',serif}
.mono{font-family:'JetBrains Mono',monospace}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}

/* ============ NAV ============ */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(245,239,228,0.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color 0.3s ease, background 0.3s ease;
}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(245,239,228,0.96)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:18px 32px;display:flex;justify-content:space-between;align-items:center;gap:32px}
.nav-logo{font-family:'Fraunces',serif;font-size:18px;font-weight:500;letter-spacing:-0.01em}
.nav-logo b{color:var(--accent);font-style:italic;font-weight:500}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:var(--ink-soft);letter-spacing:0.02em;position:relative;padding:4px 0;transition:color 0.2s ease}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--accent)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--accent);transition:width 0.25s ease}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.15em;text-transform:uppercase;padding:9px 16px;border:1px solid var(--ink);background:var(--ink);color:var(--cream);border-radius:50px;transition:all 0.25s ease;font-weight:500}
.nav-cta:hover{background:var(--accent);border-color:var(--accent)}
.nav-burger{display:none;background:none;border:none;cursor:pointer;font-size:22px;color:var(--ink)}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}

/* ============ PAGE SHELL ============ */
main{display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.page-hero{
  max-width:var(--max);margin:0 auto;padding:72px 32px 40px;
  position:relative;
}
.page-hero::after{
  content:"";display:block;height:1px;margin-top:48px;
  background:linear-gradient(90deg,var(--line),transparent);
}
.breadcrumb{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-bottom:26px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted);transition:color .2s ease}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:var(--line)}
.eyebrow{font-family:'Inter',sans-serif;font-size:12px;letter-spacing:0.3em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:22px;display:flex;align-items:center;gap:12px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--emerald-bright);box-shadow:0 0 0 4px rgba(43,184,154,0.18)}
.page-hero h1{
  font-family:'Fraunces',serif;
  font-size:clamp(40px,6.5vw,86px);
  line-height:0.98;font-weight:300;letter-spacing:-0.03em;color:var(--ink);
  margin-bottom:26px;
}
.page-hero h1 em{font-style:italic;color:var(--accent);font-weight:400}
.page-hero .lead{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(19px,2.4vw,26px);line-height:1.45;color:var(--ink-soft);max-width:760px}

/* ============ CONTENT / PROSE ============ */
.section{max-width:var(--max);margin:0 auto;padding:36px 32px 64px}
.prose{max-width:820px}
.prose h2{font-family:'Fraunces',serif;font-size:clamp(26px,3.4vw,38px);font-weight:400;letter-spacing:-0.02em;color:var(--ink);margin:52px 0 18px}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:'Fraunces',serif;font-size:21px;font-weight:500;color:var(--ink);margin:34px 0 12px}
.prose p{font-size:17px;line-height:1.75;color:var(--ink-soft);margin-bottom:20px}
.prose ul,.prose ol{margin:0 0 22px 0;padding-left:0;list-style:none}
.prose ul li,.prose ol li{position:relative;padding-left:28px;margin-bottom:12px;font-size:17px;line-height:1.7;color:var(--ink-soft)}
.prose ul li::before{content:"";position:absolute;left:2px;top:11px;width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.85}
.prose ol{counter-reset:item}
.prose ol li{counter-increment:item}
.prose ol li::before{content:counter(item);position:absolute;left:0;top:0;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--accent);font-weight:600}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;transition:color .2s ease}
.prose a:hover{color:var(--accent-soft)}
.prose blockquote{border-left:3px solid var(--accent);background:var(--paper);padding:20px 26px;margin:28px 0;font-family:'Fraunces',serif;font-style:italic;font-size:20px;color:var(--ink-soft);border-radius:0 10px 10px 0}
.prose .muted{color:var(--muted);font-size:14px}
.prose code{font-family:'JetBrains Mono',monospace;font-size:0.88em;background:var(--cream-2);color:var(--accent);padding:2px 6px;border-radius:5px}
.lede{font-family:'Fraunces',serif;font-size:22px;line-height:1.55;color:var(--ink);margin-bottom:28px}

/* ============ BLOG ============ */
.post-meta{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-top:20px;display:flex;gap:18px;flex-wrap:wrap}
.post-meta span{display:flex;align-items:center;gap:8px}
.post-meta b{color:var(--accent);font-weight:500}
.post-tag{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.blog-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:32px;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}
.blog-card:hover{transform:translateY(-4px);border-color:var(--accent-soft);box-shadow:0 16px 40px -22px rgba(26,22,18,0.45)}
.blog-card h2{font-family:'Fraunces',serif;font-size:24px;font-weight:500;line-height:1.2;color:var(--ink);margin:0 0 12px}
.blog-card h2 a{color:inherit;text-decoration:none}
.blog-card h2 a:hover{color:var(--accent)}
.blog-card p{font-size:15px;line-height:1.65;color:var(--ink-soft);margin-bottom:18px}
.blog-card .read{margin-top:auto;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent)}
.post-foot{margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
.prose .checklist{margin:0 0 22px 0;padding-left:0;list-style:none}
.prose .checklist li{position:relative;padding-left:34px;margin-bottom:13px;font-size:17px;line-height:1.7;color:var(--ink-soft)}
.prose .checklist li::before{content:"";position:absolute;left:0;top:4px;width:18px;height:18px;border:1.5px solid var(--accent);border-radius:5px;background:var(--paper)}
.prose .checklist li::after{content:"";position:absolute;left:6px;top:7px;width:5px;height:9px;border:solid var(--accent);border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0}
.prose .checklist li:hover::after{opacity:1}

/* ============ CARDS ============ */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin:8px 0 16px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:28px;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-4px);border-color:var(--accent-soft);box-shadow:0 16px 40px -22px rgba(26,22,18,0.45)}
.card .ic{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.card h3{font-family:'Fraunces',serif;font-size:20px;font-weight:500;margin-bottom:10px;color:var(--ink)}
.card p{font-size:15px;line-height:1.65;color:var(--ink-soft)}

/* ============ STATS ============ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;margin:30px 0;padding:34px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat .n{font-family:'Fraunces',serif;font-size:clamp(34px,5vw,52px);font-weight:300;letter-spacing:-0.03em;color:var(--accent);line-height:1}
.stat .l{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-top:10px}

/* ============ BUTTONS ============ */
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:14px 26px;border-radius:50px;border:1px solid var(--ink);transition:all .25s ease;cursor:pointer}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:var(--accent);border-color:var(--accent)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}

/* ============ CONTACT FORM ============ */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:34px;max-width:640px}
.field{margin-bottom:20px}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field textarea{width:100%;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:13px 15px;transition:border-color .2s ease}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:130px}

/* ============ FOOTER ============ */
.contact-section{
  background:
    radial-gradient(ellipse at 15% 10%, rgba(43,184,154,0.16), transparent 50%),
    linear-gradient(165deg, #0c1815 0%, var(--emerald-deep) 55%, #0c1815 100%);
  color:var(--cream);padding:120px 32px;position:relative;overflow:hidden;
}
.contact-section::before{content:"";position:absolute;top:-20%;right:-10%;width:520px;height:520px;background:radial-gradient(circle, rgba(232,118,45,0.18), transparent 62%);pointer-events:none}
.contact-section::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);background-size:52px 52px;pointer-events:none;mask-image:radial-gradient(ellipse at 70% 30%, #000 20%, transparent 75%);-webkit-mask-image:radial-gradient(ellipse at 70% 30%, #000 20%, transparent 75%)}
.contact-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.contact-eyebrow{font-family:'Inter',sans-serif;font-size:12px;letter-spacing:0.3em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:30px;font-weight:500;display:flex;align-items:center;gap:14px}
.contact-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,0.18)}
.contact-title{font-family:'Fraunces',serif;font-size:clamp(48px,7.5vw,120px);line-height:0.95;font-weight:300;letter-spacing:-0.04em;margin-bottom:36px;color:var(--cream)}
.contact-title em{font-style:italic;color:var(--accent-soft);font-weight:400}
.contact-title .light{font-weight:200}
.contact-body{font-family:'Fraunces',serif;font-style:italic;font-size:24px;color:rgba(245,239,228,0.78);max-width:780px;line-height:1.45;margin-bottom:60px;font-weight:400}
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:36px 0;border-top:1px solid rgba(245,239,228,0.18);border-bottom:1px solid rgba(245,239,228,0.18);margin-bottom:36px}
.contact-item .lbl{font-family:'Inter',sans-serif;font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:rgba(245,239,228,0.5);margin-bottom:10px;font-weight:500}
.contact-item .val{font-family:'Fraunces',serif;font-size:19px;font-weight:500;word-break:break-word;color:var(--cream)}
.contact-item a:hover{color:var(--accent-soft)}
.foot-links{margin-top:28px;display:flex;justify-content:center;gap:32px;flex-wrap:wrap;color:var(--ink-soft)}
.foot-links a{color:rgba(245,239,228,0.7);transition:color .2s ease;font-size:14px}
.foot-links a:hover{color:var(--accent-soft)}
.contact-foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-top:36px}
.sig{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(28px,4vw,44px);font-weight:400;color:var(--cream);letter-spacing:-0.015em;white-space:nowrap}
.sig::before{content:"— "}
.foot-meta{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:rgba(245,239,228,0.45);text-transform:uppercase;text-align:right;line-height:1.9}

/* ============ RESPONSIVE ============ */
@media (max-width:768px){
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--cream)}
  .nav.scrolled{background:var(--cream)}
  .nav-inner{padding:14px 20px}
  .nav-links{position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--cream);flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:40px 24px;gap:0;transform:translateX(100%);transition:transform 0.3s ease, visibility 0.3s;border-top:1px solid var(--line);visibility:hidden;will-change:transform}
  .nav-links.open{transform:translateX(0);visibility:visible}
  .nav-links li{width:100%;border-bottom:1px solid var(--line)}
  .nav-links a{display:block;padding:18px 0;font-size:18px;font-family:'Fraunces',serif;font-weight:500}
  .nav-links a::after{display:none}
  .nav-burger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--line);border-radius:50%;background:transparent;margin-left:12px;transition:background 0.25s ease}
  .nav-burger:hover{background:var(--cream-2)}
  .nav-burger span{display:block;width:16px;height:1.5px;background:var(--ink);position:relative;transition:transform 0.25s ease, opacity 0.25s ease}
  .nav-burger span::before,.nav-burger span::after{content:"";position:absolute;left:0;width:16px;height:1.5px;background:var(--ink);transition:transform 0.25s ease}
  .nav-burger span::before{top:-5px}
  .nav-burger span::after{top:5px}
  .nav-burger.open span{background:transparent}
  .nav-burger.open span::before{top:0;transform:rotate(45deg)}
  .nav-burger.open span::after{top:0;transform:rotate(-45deg)}
  .nav-cta{padding:8px 14px;font-size:10px;letter-spacing:0.12em}
  .nav-logo{font-size:16px}

  .page-hero{padding:48px 20px 32px}
  .section{padding:28px 20px 52px}
  .wrap{padding:0 20px}

  .contact-section{padding:72px 20px}
  .contact-title{font-size:48px;line-height:1}
  .contact-body{font-size:18px;margin-bottom:36px}
  .contact-grid{grid-template-columns:repeat(2,1fr);gap:22px;padding:24px 0;margin-bottom:28px}
  .contact-item .lbl{font-size:9px}
  .contact-item .val{font-size:14.5px}
  .contact-foot{flex-direction:column;align-items:flex-start;gap:18px}
  .foot-meta{text-align:left}
  .sig{font-size:30px}
}
@media (max-width:420px){
  .contact-title{font-size:38px}
  .contact-body{font-size:16px}
  .contact-grid{grid-template-columns:1fr;gap:20px}
  .sig{font-size:26px}
  .foot-meta{font-size:9px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
