/* ============================================================
   Torri's Birth Services — shared styles
   Palette: neutral boho sunset (sand, terracotta, ochre, dusty rose-mauve)
   ============================================================ */
:root{
  /* base neutrals — bright white & cream */
  --cream:   #fdfbf6;   /* near-white page background */
  --paper:   #ffffff;   /* pure white cards / raised surfaces */
  --sand:    #fbf2ea;   /* soft blush-cream tinted sections */
  --line:    #f1e7dc;   /* light hairlines */
  --taupe:   #ddd0c0;   /* soft light borders / details */

  /* beachy sunset accents */
  --clay:      #e3886a;  /* primary sunset coral */
  --rust:      #cf6450;  /* deep coral / hover */
  --amber:     #efba78;  /* golden sand */
  --rose:      #e7a59b;  /* soft sunset blush */
  --mauve:     #6fb0a6;  /* seafoam — the ocean hint */

  /* deep ocean tone for footer */
  --deep:   #2d4844;

  /* text */
  --ink:    #38322c;
  --muted:  #80715f;

  /* beachy sunset gradient (photo arches & accents) */
  --sunset: linear-gradient(165deg, #f7d7aa 0%, #f3aa7e 30%, #e98a72 58%, #df7d8c 100%);
  --sunset-soft: linear-gradient(135deg, #fae0c6, #f1b591 55%, #e8a0a0);

  --maxw: 1180px;
  --r-lg: 26px;
  --r-md: 18px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --f-display: "Fraunces", Georgia, serif;
  --f-body: "Hanken Grotesk", "Segoe UI", sans-serif;
  --f-script: "Caveat", cursive;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; }
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:var(--f-body); font-size:18px; line-height:1.65;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.35;
  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)' opacity='0.035'/%3E%3C/svg%3E");
}

h1,h2,h3{ font-family:var(--f-display); font-weight:500; line-height:1.08; letter-spacing:-.01em; margin:0; }
p{ margin:0 0 1rem; }
a{ color:inherit; }
img{ max-width:100%; display:block; }

.wrap{ width:min(100% - 40px, var(--maxw)); margin-inline:auto; }
.eyebrow{
  font-family:var(--f-body); font-weight:600; font-size:.78rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--clay); display:inline-flex; align-items:center; gap:.6rem; margin:0 0 1rem;
}
.eyebrow::before{ content:""; width:26px; height:1.5px; background:var(--clay); display:inline-block; }
.script{ font-family:var(--f-script); color:var(--rust); }

.btn{
  display:inline-flex; align-items:center; gap:.5rem; font-family:var(--f-body); font-weight:600;
  font-size:1rem; padding:.85rem 1.6rem; border-radius:999px; cursor:pointer;
  border:1.5px solid transparent; text-decoration:none;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--clay); color:#fff; }
.btn-primary:hover{ background:var(--rust); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--taupe); }
.btn-ghost:hover{ border-color:var(--clay); color:var(--rust); }

/* ---------- Header ---------- */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(140%) blur(8px);
  background:color-mix(in srgb, var(--cream) 82%, transparent);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease);
}
header.scrolled{ border-color:var(--line); }
.nav{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; }
.brand{ display:flex; align-items:center; gap:.6rem; text-decoration:none; }
.brand .mark{ flex:none; }
.brand b{ font-family:var(--f-display); font-weight:600; font-size:1.18rem; letter-spacing:-.01em; }
.brand small{ display:block; font-family:var(--f-body); font-size:.62rem; letter-spacing:.2em;
              text-transform:uppercase; color:var(--muted); font-weight:600; margin-top:-2px; }
.nav-links{ display:flex; align-items:center; gap:2rem; list-style:none; margin:0; padding:0; }
.nav-links a{ text-decoration:none; font-weight:500; font-size:1rem; position:relative; padding:4px 0; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:1.5px; width:0;
                     background:var(--clay); transition:width .3s var(--ease); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--rust); }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.hamburger{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.hamburger span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.3s var(--ease); }

/* ---------- Generic sections ---------- */
section{ padding:88px 0; }
.tint{ background:var(--sand); }
.center{ text-align:center; }
.section-head{ max-width:62ch; }
.section-head.center{ margin-inline:auto; }
.section-head.center .eyebrow{ justify-content:center; }
h2.title{ font-size:clamp(2rem,4.2vw,3rem); margin-bottom:.8rem; }
.section-head p{ color:var(--muted); font-size:1.1rem; }

/* ---------- Boho arch photo ---------- */
.arch{
  position:relative; aspect-ratio:4/5;
  border-radius:50% 50% 14px 14px / 38% 38% 8px 8px;
  background:var(--sunset);
  border:1px solid var(--line); overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(59,48,42,.4);
}
.arch .ph{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:.6rem; color:rgba(255,255,255,.92); text-align:center; padding:1.5rem;
}
.arch .ph svg{ color:rgba(255,255,255,.85); }
.arch .ph span{ font-size:.85rem; letter-spacing:.04em; }

/* decorative shapes */
.blob{ position:absolute; z-index:-1; }
.sun-deco{ position:absolute; color:var(--amber); opacity:.85; }

/* ---------- Page hero (interior pages) ---------- */
.page-hero{ padding:64px 0 28px; }
.page-hero .eyebrow{ margin-bottom:1rem; }
.page-hero h1{ font-size:clamp(2.4rem,5.4vw,3.8rem); }
.page-hero h1 em{ font-style:italic; color:var(--rust); }
.page-hero p{ color:var(--muted); font-size:1.18rem; max-width:54ch; margin-top:1rem; }

/* ---------- Values ---------- */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:54px; }
.value{ text-align:center; padding:0 12px; }
.value .icon{ width:58px; height:58px; border-radius:50%; display:grid; place-items:center;
              margin:0 auto 1rem; background:var(--paper); border:1px solid var(--line); color:var(--clay); }
.value h3{ font-size:1.3rem; margin-bottom:.4rem; }
.value p{ color:var(--muted); font-size:1rem; margin:0; }

/* ---------- About ---------- */
.split{ display:grid; grid-template-columns:.85fr 1.15fr; gap:60px; align-items:center; }
.split.rev{ grid-template-columns:1.15fr .85fr; }
.sig{ font-family:var(--f-script); font-size:2.4rem; color:var(--rust); line-height:1; margin-top:1rem; }
.creds{ list-style:none; padding:0; margin:1.4rem 0 0; display:grid; gap:.7rem; }
.creds li{ display:flex; gap:.7rem; align-items:flex-start; color:var(--muted); font-size:1rem; }
.creds svg{ flex:none; margin-top:3px; color:var(--clay); }

/* ---------- Service cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:54px; }
.card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:34px 30px; display:flex; flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.card:hover{ transform:translateY(-5px); box-shadow:0 24px 48px -28px rgba(59,48,42,.45); }
.card .badge{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center;
              background:var(--sand); color:var(--clay); margin-bottom:1.1rem; }
.card h3{ font-size:1.5rem; margin-bottom:.5rem; }
.card > p{ color:var(--muted); font-size:1rem; }
.card ul{ list-style:none; padding:0; margin:.4rem 0 1.4rem; display:grid; gap:.5rem; }
.card ul li{ position:relative; padding-left:1.4rem; color:var(--muted); font-size:.98rem; }
.card ul li::before{ content:""; position:absolute; left:0; top:.55em; width:7px; height:7px; border-radius:50%; background:var(--amber); }
.price{ margin-top:auto; display:inline-flex; align-self:flex-start; align-items:center; gap:.5rem;
        font-weight:600; color:var(--rust); background:var(--sand); padding:.5rem 1rem; border-radius:999px; font-size:.95rem; }

/* ---------- Steps (how it works) ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:50px; }
.step{ text-align:center; }
.step .n{ width:54px; height:54px; border-radius:50%; margin:0 auto 1rem; display:grid; place-items:center;
          font-family:var(--f-display); font-size:1.3rem; color:#fff; background:var(--sunset); }
.step h3{ font-size:1.25rem; margin-bottom:.4rem; }
.step p{ color:var(--muted); font-size:1rem; margin:0; }

/* ---------- Guides ---------- */
.lead-note{ background:var(--paper); border:1px dashed var(--taupe); border-radius:var(--r-md);
            padding:1rem 1.3rem; color:var(--muted); font-size:.98rem; margin-top:1.6rem; display:inline-block; }
.guides{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:50px; }
.guide{
  display:flex; gap:18px; align-items:center; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--r-md); padding:22px 24px;
  text-decoration:none; transition:border-color .3s var(--ease), transform .3s var(--ease);
}
.guide:hover{ border-color:var(--clay); transform:translateY(-3px); }
.guide .gnum{ flex:none; width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
              font-family:var(--f-display); font-size:1.2rem; color:#fff; background:var(--amber); }
.guide:nth-child(2) .gnum{ background:var(--clay); }
.guide:nth-child(3) .gnum{ background:var(--rose); }
.guide:nth-child(4) .gnum{ background:var(--mauve); }
.guide h3{ font-size:1.18rem; margin:0 0 .15rem; }
.guide p{ margin:0; font-size:.9rem; color:var(--muted); }
.guide .dl{ margin-left:auto; color:var(--clay); flex:none; }

/* ---------- Testimonials ---------- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:50px; }
.quote{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; }
.quote .qmark{ font-family:var(--f-display); font-size:3rem; line-height:.6; color:var(--taupe); }
.quote p{ font-style:italic; font-family:var(--f-display); font-size:1.12rem; color:var(--ink); }
.quote .who{ font-family:var(--f-body); font-style:normal; font-weight:600; font-size:.92rem; color:var(--muted); }

/* ---------- CTA band ---------- */
.cta-band{ background:var(--sunset); color:#fff; text-align:center; }
.cta-band h2{ font-size:clamp(2rem,4.5vw,3rem); margin-bottom:.6rem; }
.cta-band p{ color:rgba(255,255,255,.92); max-width:48ch; margin:0 auto 1.8rem; font-size:1.12rem; }
.cta-band .btn-primary{ background:#fff; color:var(--rust); }
.cta-band .btn-primary:hover{ background:var(--paper); }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.contact-info .row{ display:flex; gap:.8rem; align-items:center; margin:1rem 0; color:var(--muted); }
.contact-info .row svg{ flex:none; color:var(--clay); }
form .field{ margin-bottom:1.1rem; }
label{ display:block; font-weight:600; font-size:.92rem; margin-bottom:.4rem; }
input,textarea{
  width:100%; font-family:var(--f-body); font-size:1rem; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:.85rem 1rem;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
input:focus,textarea:focus{ outline:none; border-color:var(--clay);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--clay) 22%, transparent); }
textarea{ resize:vertical; min-height:130px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.form-msg{ margin-top:1rem; font-size:.95rem; display:none; }
.form-msg.show{ display:block; }
.form-msg.ok{ color:var(--mauve); }
.form-msg.err{ color:var(--rust); }

/* ---------- Footer ---------- */
footer{ background:var(--deep); color:#e9ddcd; padding:64px 0 30px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
footer h4{ font-family:var(--f-display); font-size:1.3rem; color:#fff; margin:0 0 .6rem; }
footer a{ color:#cdbfac; text-decoration:none; display:block; margin:.4rem 0; font-size:.96rem; }
footer a:hover{ color:#fff; }
.disclaimer{ border-top:1px solid rgba(255,255,255,.14); margin-top:44px; padding-top:24px;
             font-size:.82rem; color:#b3a591; line-height:1.6; }
.copy{ margin-top:18px; font-size:.82rem; color:#9c8e7e; display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width: 920px){
  .split,.split.rev,.contact-grid{ grid-template-columns:1fr; gap:42px; }
  .split.rev > div:first-child{ order:2; }
  .arch{ max-width:400px; margin-inline:auto; }
  .values,.cards,.steps,.quotes,.guides{ grid-template-columns:1fr; }
  .nav-links{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:var(--paper); border-bottom:1px solid var(--line);
    padding:10px 0; transform:translateY(-130%); transition:transform .35s var(--ease); align-items:stretch;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links li{ text-align:center; }
  .nav-links a{ display:block; padding:14px; }
  .nav-links a::after{ display:none; }
  .nav-cta .btn{ display:none; }
  .hamburger{ display:block; }
  .form-row{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; gap:28px; }
}
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--rust); outline-offset:3px;
}
.skip{ position:absolute; left:-9999px; }
.skip:focus{ left:12px; top:12px; background:#fff; padding:10px 16px; border-radius:10px; z-index:100; }
