:root{
  --sage:#6E8F7A; --sage-dark:#4E6F5A; --sand:#E9DFC9; --offwhite:#FBFAF7; --earth:#A9785A;
  --ink:#1F2A24; --muted:#51635A; --line:rgba(31,42,36,.10); --shadow: 0 10px 30px rgba(31,42,36,.08);
  --radius: 18px; --max: 1120px;
}
*{ box-sizing:border-box; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background: radial-gradient(900px 700px at 10% 0%, rgba(110,143,122,.12), transparent 60%),
              radial-gradient(900px 700px at 90% 10%, rgba(233,223,201,.35), transparent 60%),
              var(--offwhite);
  line-height:1.65;
}
a{ color:inherit; text-decoration:none; }
.container{ max-width:var(--max); margin:0 auto; padding:0 20px; }
header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,250,247,.80);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:12px; }
.brand{ display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:.2px; }
.mark{
  width:34px; height:34px; border-radius:12px;
  background: linear-gradient(135deg, rgba(110,143,122,.95), rgba(233,223,201,.95));
  box-shadow: 0 8px 18px rgba(110,143,122,.20);
  position:relative; overflow:hidden;
}
.mark:before{
  content:""; position:absolute; inset:8px 10px 9px 10px;
  border:2px solid rgba(255,255,255,.85);
  border-top-left-radius:18px; border-bottom-right-radius:18px;
  transform: rotate(10deg); opacity:.9;
}
nav ul{ list-style:none; display:flex; gap:16px; margin:0; padding:0; font-size:14px; color:var(--muted); flex-wrap:wrap; }
nav a:hover{ color:var(--ink); }
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius:999px; border:1px solid var(--line);
  background:rgba(255,255,255,.65); transition: transform .15s ease, box-shadow .15s ease;
  box-shadow: 0 10px 20px rgba(31,42,36,.05); font-size:14px; white-space:nowrap;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow); }
.btn.primary{
  background: linear-gradient(135deg, var(--sage), var(--sage-dark));
  border-color: transparent; color: white; box-shadow: 0 12px 26px rgba(78,111,90,.18);
}
.pill{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 12px; border:1px solid var(--line);
  background:rgba(255,255,255,.6); border-radius:999px; font-size:14px; color:var(--muted);
  backdrop-filter: blur(8px);
}
main{ padding-bottom:24px; }
.hero{ padding:56px 0 30px; }
.hero-grid{ display:grid; grid-template-columns: 1.15fr .85fr; gap:28px; align-items:stretch; }
h1{ font-size:44px; line-height:1.12; margin:14px 0 12px; letter-spacing:-.4px; }
.sub{ font-size:18px; color:var(--muted); max-width: 62ch; margin:0 0 18px; }
.cta-row{ display:flex; gap:12px; flex-wrap:wrap; margin-top:14px; }
.card{
  background: rgba(255,255,255,.78);
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.card h3{ margin:0 0 6px; font-size:18px; }
.card p{ margin:0; color:var(--muted); }
.section{ padding:46px 0; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:18px; margin-bottom:18px; }
h2{ margin:0; font-size:28px; letter-spacing:-.2px; }
.hint{ color:var(--muted); font-size:15px; max-width:70ch; }
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; }
.grid-2{ display:grid; grid-template-columns: repeat(2, 1fr); gap:16px; }
.chiprow{ display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.chip{ font-size:12px; color:var(--muted); border:1px solid var(--line); background: rgba(251,250,247,.85); padding:6px 10px; border-radius:999px; }
.list{ margin:10px 0 0; padding-left:18px; color:var(--muted); }
.list li{ margin:6px 0; }
.banner{ background: linear-gradient(135deg, rgba(110,143,122,.18), rgba(233,223,201,.50)); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.banner .inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding:22px 0; }
.kicker{ font-size:14px; color:var(--muted); margin-top:6px; }
footer{ padding:30px 0; color:var(--muted); }
.footer-grid{ display:grid; grid-template-columns: minmax(0, 1.2fr) repeat(3, minmax(0, .8fr)); gap:16px; border-top:1px solid var(--line); padding-top:18px; }
footer ul{ list-style:none; padding:0; margin:10px 0 0; }
footer li{ margin:8px 0; }
.small{ font-size:13px; color:var(--muted); }
.media{ border-radius: 18px; border:1px solid var(--line); background: rgba(255,255,255,.78); box-shadow: var(--shadow); overflow:hidden; }
.media img{ display:block; width:100%; height:auto; }
.breadcrumb{ font-size:13px; color:var(--muted); margin-top:10px; }
.breadcrumb a{ color:var(--muted); text-decoration:underline; text-decoration-color: rgba(81,99,90,.35); }
.notice{ font-size:13px; color:var(--muted); background: rgba(251,250,247,.85); border:1px solid var(--line); padding:12px; border-radius:16px; }
.form{ display:grid; gap:12px; }
input, textarea, select{ width:100%; padding:12px 12px; border-radius:14px; border:1px solid var(--line); background: rgba(255,255,255,.78); font: inherit; }
textarea{ min-height:140px; resize:vertical; }
label{ font-size:14px; color:var(--muted); }
.faq details{ border:1px solid var(--line); border-radius:16px; background: rgba(255,255,255,.78); padding:14px 16px; box-shadow: var(--shadow); }
.faq summary{ cursor:pointer; font-weight:650; }
.faq p{ color:var(--muted); margin:10px 0 0; }
@media (max-width: 980px){
  .footer-grid{ grid-template-columns: 1fr; }

  .hero-grid{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .grid-2{ grid-template-columns: 1fr; }
  .banner .inner{ flex-direction:column; align-items:flex-start; }
  nav ul{ display:none; }
}


.profile{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap:16px;
  align-items:stretch;
}
.profile .media{ height:100%; }
.profile .media img{ height:100%; object-fit:cover; }
.quote{
  border-left:4px solid rgba(110,143,122,.55);
  padding:12px 14px;
  background: rgba(255,255,255,.55);
  border-radius: 16px;
  color: var(--muted);
}
@media (max-width: 980px){
  .profile{ grid-template-columns: 1fr; }
}

/* Resources: curated reading filters */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.input{width:100%;padding:12px 12px;border:1px solid #E5E7EB;border-radius:12px;outline:none}
.input:focus{border-color:#111827}
.filters{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.search{min-width:260px;flex:1;max-width:520px}


/* Exit Intent Modal */
.hy-modal{position:fixed;inset:0;display:none;z-index:9999}
.hy-modal.is-open{display:block}
.hy-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.45)}
.hy-modal__card{position:relative;width:min(720px, calc(100% - 28px));margin:10vh auto 0;background:var(--surface,#fff);border:1px solid var(--border,#e5e7eb);border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,0.18);padding:18px}
.hy-modal__close{position:absolute;top:10px;right:10px;width:38px;height:38px;border-radius:12px;border:1px solid var(--border,#e5e7eb);background:#fff;cursor:pointer;font-size:22px;line-height:1}
@media (max-width: 720px){.hy-modal__card{margin:12vh auto 0;padding:16px}}


/* Legal pages: tighter vertical rhythm */
.legal-page .section{ padding: 22px 0; }
.legal-page .section + .section{ border-top: 1px solid var(--line); }
.legal-page h1{ margin-bottom: 10px; }
.legal-page h2{ margin-bottom: 6px; }
.legal-page p{ margin: 8px 0; }
.legal-page .list li{ margin: 4px 0; }
.legal-page .notice{ margin-top: 12px; }

/* Footer: prevent column overflow */
footer .footer-grid > div{ min-width:0; }



/* ========== Mobile hamburger navigation (SVG) ========== */
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border:1px solid var(--line);
  background:rgba(251,250,247,.9);
  border-radius:12px;
  cursor:pointer;
}
.nav-toggle svg{ width:22px; height:22px; display:block; }
.nav-toggle .icon-close{ display:none; }
.nav-toggle[aria-expanded="true"] .icon-menu{ display:none; }
.nav-toggle[aria-expanded="true"] .icon-close{ display:block; }
.nav-toggle:focus{ outline:2px solid rgba(110,143,122,.45); outline-offset:2px; }

@media (max-width: 980px){
  .nav{ position:relative; gap:10px; }
  .nav-toggle{ display:inline-flex; }
  /* dropdown */
  .nav nav ul{
    display:none !important;
    position:absolute;
    top:58px;
    left:0;
    right:0;
    flex-direction:column;
    gap:0;
    padding:10px;
    margin:0;
    list-style:none;
    background:rgba(251,250,247,.98);
    border:1px solid var(--line);
    border-radius:16px;
    box-shadow: var(--shadow);
    z-index:999;
  }
  .nav nav.is-open ul{ display:flex !important; }
  .nav nav ul li a{
    display:block;
    padding:12px 12px;
    border-radius:12px;
  }
  .nav nav ul li a:hover{
    background:rgba(110,143,122,.10);
  }
}



/* SHOP DROPDOWN (global) */
nav li{ position:relative; }
.has-submenu > a{ display:inline-flex; align-items:center; gap:6px; }
.has-submenu > a:after{
  content:"▾";
  font-size:12px;
  opacity:.75;
  transform: translateY(-1px);
}
.submenu{
  position:absolute;
  top: 100%;
  left: 0;
  min-width: 190px;
  list-style:none;
  padding:10px;
  margin:0;
  border:1px solid var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow);
  display:none;
  z-index: 50;
}
.submenu li{ margin:0; }
.submenu a{
  display:block;
  padding:10px 10px;
  border-radius: 12px;
  color: var(--ink);
}
.submenu a:hover{
  background: rgba(110,143,122,.10);
}

.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu{
  display:block;
}

/* Mobile: show submenu items stacked when nav is open */
@media (max-width: 920px){
  nav ul{ flex-direction:column; align-items:flex-start; gap:10px; }
  .submenu{
    position:static;
    display:block;
    padding:6px 0 0;
    border:none;
    box-shadow:none;
    background: transparent;
    min-width: auto;
  }
  .submenu a{ padding:8px 0 8px 12px; }
  .has-submenu > a:after{ content:""; }
}


.nav li.has-submenu > a { display:flex; align-items:center; justify-content:space-between; }
  .nav li.has-submenu > a::after{
    content:"▾";
    font-size:12px;
    opacity:.7;
    margin-left:10px;
  }
  .nav .submenu{
    position: static !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    transform:none !important;
    width:100% !important;
    margin: 6px 0 0 0 !important;
    padding: 6px 0 !important;
    box-shadow: none !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.55) !important;
    backdrop-filter: blur(10px);
  }
  .nav .submenu a{
    padding: 10px 14px !important;
  }
}


/* === Mobile nav: Shop submenu as accordion (tap to expand) === */
@media (max-width: 900px){
  .nav li.has-submenu > a{
    position: relative;
  }
  .nav li.has-submenu > a::after{
    content:"▾";
    font-size:12px;
    opacity:.7;
    margin-left:10px;
  }
  /* collapsed by default */
  .nav li.has-submenu .submenu{
    display:none !important;
    position: static !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    transform:none !important;
    width:100% !important;
    margin: 6px 0 0 0 !important;
    padding: 6px 0 !important;
    box-shadow: none !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.55) !important;
    backdrop-filter: blur(10px);
  }
  .nav li.has-submenu.submenu-open .submenu{
    display:block !important;
  }
  .nav .submenu a{
    padding: 10px 14px !important;
  }
}



/* === SHOP DROPDOWN: prevent layout jump on desktop ===
   Some pages may trigger the mobile submenu rules at intermediate widths.
   Force desktop dropdown to be absolute overlay above 981px, so it never pushes the nav layout.
*/
@media (min-width: 981px){
  .nav li{ position: relative; }
  .nav .submenu{
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: auto !important;
    width: 210px !important;
    margin: 0 !important;
    padding: 10px !important;
    border: 1px solid var(--line) !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.92) !important;
    box-shadow: var(--shadow) !important;
    backdrop-filter: blur(10px);
    display: none;
    z-index: 9999;
  }
  .nav li.has-submenu:hover .submenu,
  .nav li.has-submenu:focus-within .submenu{
    display: block !important;
  }
}

/* Mobile/tablet: submenu should only expand within the open menu (accordion behaviour) */
@media (max-width: 980px){
  .nav .submenu{ position: static !important; width: 100% !important; }
}
