/* =========================================================
   Livia L. Gallo — Christian Spiritual Direction
   "The Blue Hour" — parchment, ultramarine ink, antique gold
   ========================================================= */

:root{
  /* palette */
  --ground:    #F2EEE6;   /* warm parchment page */
  --ground-2:  #E9E2D3;   /* deeper parchment, alternating sections */
  --ink:       #1E2E3D;   /* deep ultramarine-slate: text + dark sections */
  --ink-2:     #2C4257;   /* dusk blue */
  --ink-3:     #3C5A74;   /* lighter dusk for gradients */
  --text:      #283440;   /* body text on light */
  --muted:     #6B6457;   /* warm grey, secondary text */
  --gold:      #A9823C;   /* antique illumination gold */
  --gold-deep: #886429;
  --gold-soft: #C7A35C;
  --paper-on-dark: #ECE4D4; /* warm text on dark sections */
  --line:      rgba(30,46,61,0.14);
  --line-gold: rgba(169,130,60,0.35);

  /* type */
  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --body: "Newsreader", Georgia, serif;

  /* scale */
  --step--1: clamp(0.82rem, 0.79rem + 0.15vw, 0.92rem);
  --step-0:  clamp(1.06rem, 1.0rem + 0.28vw, 1.22rem);
  --step-1:  clamp(1.3rem, 1.18rem + 0.6vw, 1.6rem);
  --step-2:  clamp(1.7rem, 1.45rem + 1.2vw, 2.4rem);
  --step-3:  clamp(2.2rem, 1.7rem + 2.4vw, 3.4rem);
  --step-4:  clamp(2.9rem, 2.0rem + 4.2vw, 5.0rem);

  --maxw: 1180px;
  --measure: 64ch;
  --pad: clamp(1.25rem, 5vw, 4rem);
  --section-y: clamp(4.5rem, 9vw, 8.5rem);
  --radius-arch: clamp(120px, 22vw, 240px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--ground);
  color:var(--text);
  font-family:var(--body);
  font-size:var(--step-0);
  line-height:1.72;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* subtle paper grain for depth */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:0;
  opacity:.5;
  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.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

img{ max-width:100%; display:block; }
a{ color:inherit; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); position:relative; z-index:1; }
.narrow{ max-width:760px; }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:380; line-height:1.06; letter-spacing:-0.01em; color:var(--ink); margin:0; }
h1{ font-size:var(--step-4); font-optical-sizing:auto; }
h2{ font-size:var(--step-3); }
h3{ font-size:var(--step-2); }
h4{ font-size:var(--step-1); font-weight:440; }
p{ margin:0 0 1.1em; max-width:var(--measure); }
em{ font-style:italic; }

.eyebrow{
  font-family:var(--body);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:var(--step--1);
  font-weight:500;
  color:var(--gold-deep);
  display:inline-flex; align-items:center; gap:.7em;
  margin:0 0 1.4rem;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--line-gold);
  display:inline-block;
}
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{
  content:""; width:26px; height:1px; background:var(--line-gold); display:inline-block;
}

.lede{ font-size:var(--step-1); line-height:1.55; color:#33424f; font-weight:380; }
.script{ font-style:italic; color:var(--gold-deep); }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink); --fg:var(--paper-on-dark);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--body); font-size:var(--step-0); font-weight:500;
  letter-spacing:.01em;
  padding:.82em 1.5em;
  background:var(--bg); color:var(--fg);
  border:1px solid var(--bg);
  border-radius:999px;
  text-decoration:none; cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, background .35s, color .35s;
  box-shadow:0 1px 0 rgba(30,46,61,.04);
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -14px rgba(30,46,61,.5); }
.btn .arr{ transition:transform .35s; }
.btn:hover .arr{ transform:translateX(4px); }
.btn--gold{ --bg:var(--gold); --fg:#2a1f08; border-color:var(--gold); }
.btn--gold:hover{ box-shadow:0 14px 30px -12px rgba(169,130,60,.6); }
.btn--ghost{
  --bg:transparent; --fg:var(--ink); border-color:var(--line);
}
.btn--ghost:hover{ border-color:var(--ink); }
.btn--on-dark{ --bg:transparent; --fg:var(--paper-on-dark); border-color:rgba(236,228,212,.32); }
.btn--on-dark:hover{ border-color:var(--gold-soft); color:#fff; }

.link-underline{
  text-decoration:none; color:var(--ink); font-weight:500;
  background-image:linear-gradient(var(--gold),var(--gold));
  background-size:0% 1.5px; background-position:0 100%; background-repeat:no-repeat;
  transition:background-size .4s cubic-bezier(.2,.8,.2,1);
  padding-bottom:2px;
}
.link-underline:hover{ background-size:100% 1.5px; }

/* ---------- header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--ground);
  background:color-mix(in srgb, var(--ground) 86%, transparent);
  backdrop-filter:blur(10px) saturate(1.1);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding-block:.95rem;
}
.brand{
  font-family:var(--display); font-weight:430; font-size:1.32rem;
  letter-spacing:.01em; color:var(--ink); text-decoration:none;
  display:inline-flex; align-items:center; gap:.6rem; line-height:1;
}
.brand .mark{ width:26px; height:30px; flex:0 0 auto; }
.brand small{
  display:block; font-family:var(--body); font-weight:500;
  font-size:.6rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold-deep); margin-top:.28em;
}
.nav-links{ display:flex; align-items:center; gap:clamp(1.1rem,2.4vw,2.4rem); list-style:none; margin:0; padding:0; }
.nav-links a{
  text-decoration:none; color:var(--text); font-size:.98rem; letter-spacing:.01em;
  position:relative; padding:.2em 0; transition:color .3s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--gold); transition:width .35s cubic-bezier(.2,.8,.2,1);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after,
.nav-links a[aria-current="page"]::after{ width:100%; }
.nav-links a[aria-current="page"]{ color:var(--ink); }
.nav-cta{ margin-left:.4rem; }

.nav-toggle{ display:none; }

@media (max-width:860px){
  .nav-cta{ display:none; }
  .nav-toggle{
    display:inline-flex; flex-direction:column; gap:5px; justify-content:center;
    width:44px; height:44px; background:none; border:1px solid var(--line);
    border-radius:10px; cursor:pointer;
  }
  .nav-toggle span{ height:1.5px; width:20px; margin-inline:auto; background:var(--ink); transition:.3s; }
  .nav[data-open="true"] .nav-toggle span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
  .nav[data-open="true"] .nav-toggle span:nth-child(2){ opacity:0; }
  .nav[data-open="true"] .nav-toggle span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }
  .nav-links{
    position:absolute; left:0; right:0; top:100%;
    flex-direction:column; align-items:flex-start; gap:.2rem;
    background:var(--ground); border-bottom:1px solid var(--line);
    padding:1rem var(--pad) 1.6rem;
    clip-path:inset(0 0 100% 0); opacity:0; pointer-events:none;
    transition:clip-path .4s ease, opacity .3s;
  }
  .nav[data-open="true"] .nav-links{ clip-path:inset(0 0 0 0); opacity:1; pointer-events:auto; }
  .nav-links a{ font-size:1.2rem; padding:.55em 0; width:100%; font-family:var(--display); }
  .nav-links .btn{ margin-top:.6rem; }
}

/* ---------- arch signature ---------- */
.arch{
  border-top-left-radius:var(--radius-arch);
  border-top-right-radius:var(--radius-arch);
  border-bottom-left-radius:14px;
  border-bottom-right-radius:14px;
  overflow:hidden;
}

/* ---------- hero ---------- */
.hero{ padding-top:clamp(2rem,5vw,4rem); padding-bottom:var(--section-y); }
.hero-window{
  position:relative;
  background:
    radial-gradient(120% 90% at 50% 118%, rgba(199,163,92,.45) 0%, rgba(199,163,92,0) 52%),
    linear-gradient(176deg, rgba(30,46,61,.88) 0%, rgba(44,66,87,.88) 58%, rgba(60,90,116,.88) 100%),
    url('cherry-blossoms.jpg') center/cover no-repeat;
  color:var(--paper-on-dark);
  text-align:center;
  padding:clamp(3.5rem,8vw,6.5rem) clamp(1.5rem,5vw,4.5rem) clamp(3rem,6vw,5rem);
  isolation:isolate;
}
.hero-window::after{ /* inner gold rule following the arch */
  content:""; position:absolute; inset:14px;
  border:1px solid rgba(199,163,92,.32);
  border-top-left-radius:calc(var(--radius-arch) - 14px);
  border-top-right-radius:calc(var(--radius-arch) - 14px);
  border-bottom-left-radius:8px; border-bottom-right-radius:8px;
  pointer-events:none;
}
.hero-window .eyebrow{ color:var(--gold-soft); }
.hero-window .eyebrow::before,.hero-window .eyebrow::after{ background:rgba(199,163,92,.5); }
.hero h1{ color:#fff; max-width:18ch; margin-inline:auto; font-weight:340; }
.hero h1 em{ color:var(--gold-soft); }
.hero-sub{
  color:rgba(236,228,212,.82); font-size:var(--step-1); line-height:1.55;
  max-width:42ch; margin:1.4rem auto 2.2rem; font-weight:340;
}
.hero-cta{ display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }

/* small star/cross glints in the arch sky */
.hero-window .glint{ position:absolute; width:3px; height:3px; border-radius:50%;
  background:var(--gold-soft); opacity:.0; z-index:-1; }

/* ---------- generic sections ---------- */
.section{ padding-block:var(--section-y); }
.section.alt{ background:var(--ground-2); }
.section.ink{
  background:
    radial-gradient(110% 120% at 80% -10%, rgba(60,90,116,.5) 0%, rgba(60,90,116,0) 55%),
    linear-gradient(165deg, var(--ink) 0%, var(--ink-2) 100%);
  color:var(--paper-on-dark);
}
.section.ink h2,.section.ink h3{ color:#fff; }
.section.ink p{ color:rgba(236,228,212,.82); }
.section.ink .eyebrow{ color:var(--gold-soft); }
.section.ink .eyebrow::before,.section.ink .eyebrow::after{ background:rgba(199,163,92,.5); }

.section-head{ max-width:34ch; margin-bottom:clamp(2.4rem,5vw,3.6rem); }
.section-head.center{ margin-inline:auto; text-align:center; max-width:44ch; }

/* ---------- intro / who it's for ---------- */
.litany{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:clamp(1rem,2.5vw,1.6rem); margin-top:2.4rem;
}
.seeker{
  background:var(--ground); border:1px solid var(--line);
  border-radius:18px; padding:1.9rem 1.6rem;
  position:relative; transition:transform .4s, border-color .4s, box-shadow .4s;
}
.section.alt .seeker{ background:#F4F0E8; }
.seeker:hover{ transform:translateY(-4px); border-color:var(--line-gold); box-shadow:0 18px 40px -26px rgba(30,46,61,.5); }
.seeker .num{
  font-family:var(--display); font-style:italic; font-size:1.05rem; color:var(--gold-deep);
  display:block; margin-bottom:.7rem;
}
.seeker h4{ margin-bottom:.4rem; }
.seeker p{ margin:0; font-size:.98rem; color:var(--muted); }

/* ---------- split (image + text) ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:center; }
.split.reverse .split-media{ order:2; }
@media (max-width:840px){ .split{ grid-template-columns:1fr; } .split.reverse .split-media{ order:0; } }

.portrait{ position:relative; }
.portrait-frame{
  position:relative; aspect-ratio:4/5;
  background:linear-gradient(165deg, var(--ink-2), var(--ink));
  display:flex; align-items:flex-end; justify-content:center;
}
.portrait-frame img{ width:100%; height:100%; object-fit:cover; object-position:50% 26%; }
.portrait-frame .ph{
  color:rgba(236,228,212,.7); text-align:center; padding:2rem; font-family:var(--display);
  font-style:italic; font-size:1.1rem; align-self:center;
}
.portrait::after{ /* gold seam */
  content:""; position:absolute; inset:0;
  border:1px solid var(--line-gold);
  border-top-left-radius:var(--radius-arch); border-top-right-radius:var(--radius-arch);
  border-bottom-left-radius:14px; border-bottom-right-radius:14px;
  transform:translate(14px,14px); z-index:-1;
}

/* ---------- credentials ---------- */
.creds{ list-style:none; margin:2rem 0 0; padding:0; display:grid; gap:0; }
.creds li{
  display:grid; grid-template-columns:auto 1fr; gap:1.1rem;
  padding:1.15rem 0; border-top:1px solid var(--line); align-items:baseline;
}
.creds li:last-child{ border-bottom:1px solid var(--line); }
.creds .yr{ font-family:var(--display); font-style:italic; color:var(--gold-deep); font-size:1.05rem; white-space:nowrap; }
.creds .what{ margin:0; }
.creds .what strong{ font-weight:600; color:var(--ink); display:block; font-size:1.06rem; }
.creds .what span{ color:var(--muted); font-size:.96rem; }

/* ---------- "how it works" steps ---------- */
.shape{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.4rem; margin-top:2.6rem; }
.shape .item{ padding-top:1.4rem; border-top:2px solid var(--line-gold); }
.shape .k{ font-family:var(--display); font-size:var(--step-2); color:var(--ink); display:block; line-height:1; margin-bottom:.5rem; }
.section.ink .shape .k{ color:#fff; }
.shape .l{ text-transform:uppercase; letter-spacing:.18em; font-size:.74rem; color:var(--gold-deep); font-weight:600; }
.section.ink .shape .l{ color:var(--gold-soft); }
.shape .d{ margin:.5rem 0 0; font-size:.96rem; color:var(--muted); }
.section.ink .shape .d{ color:rgba(236,228,212,.75); }

/* ---------- callout (disclaimer) ---------- */
.callout{
  border:1px solid var(--line-gold);
  background:#F3EAD6;
  background:color-mix(in srgb, var(--gold) 7%, var(--ground));
  border-radius:18px; padding:clamp(1.4rem,3vw,2rem) clamp(1.5rem,3.5vw,2.4rem);
  display:flex; gap:1.2rem; align-items:flex-start;
}
.callout .ic{ flex:0 0 auto; color:var(--gold-deep); margin-top:.2rem; }
.callout p{ margin:0; font-size:1rem; color:#3a3326; }
.callout p strong{ color:var(--ink); }

/* ---------- FAQ ---------- */
.faq{ margin-top:2rem; border-top:1px solid var(--line); }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{
  cursor:pointer; list-style:none; padding:1.3rem 2.5rem 1.3rem 0; position:relative;
  font-family:var(--display); font-size:var(--step-1); color:var(--ink); font-weight:420;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+"; position:absolute; right:.2rem; top:50%; transform:translateY(-50%);
  font-family:var(--body); font-size:1.5rem; color:var(--gold-deep); transition:transform .3s;
}
.faq details[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.faq .a{ padding:0 0 1.5rem; max-width:var(--measure); color:var(--muted); }
.faq .a p{ margin:0; }

/* ---------- contact form ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
@media (max-width:840px){ .contact-grid{ grid-template-columns:1fr; } }
.field{ margin-bottom:1.3rem; }
.field label{
  display:block; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold-deep); font-weight:600; margin-bottom:.5rem;
}
.field input,.field textarea,.field select{
  width:100%; font-family:var(--body); font-size:1.02rem; color:var(--ink);
  background:var(--ground); border:1px solid var(--line); border-radius:12px;
  padding:.85em 1em; transition:border-color .3s, box-shadow .3s;
}
.section.alt .field input,.section.alt .field textarea,.section.alt .field select{ background:#F4F0E8; }
.field textarea{ min-height:150px; resize:vertical; line-height:1.6; }
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(169,130,60,.16);
}
.hp{ position:absolute; left:-9999px; }
.form-note{ font-size:.86rem; color:var(--muted); margin-top:.4rem; }

.contact-aside{ }
.contact-aside .line{ display:flex; gap:.9rem; align-items:flex-start; padding:1.1rem 0; border-top:1px solid var(--line); }
.contact-aside .line:last-child{ border-bottom:1px solid var(--line); }
.contact-aside .ic{ color:var(--gold-deep); flex:0 0 auto; margin-top:.15rem; }
.contact-aside .line h4{ margin:0 0 .15rem; font-family:var(--body); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.contact-aside .line p{ margin:0; }

/* ---------- closing CTA band ---------- */
.closing{ text-align:center; }
.closing h2{ color:#fff; max-width:18ch; margin:0 auto 1.2rem; }
.closing p{ margin:0 auto 2rem; color:rgba(236,228,212,.82); max-width:46ch; }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink); color:var(--paper-on-dark); padding-block:clamp(3rem,6vw,4.5rem) 2rem; }
.footer-top{ display:flex; justify-content:space-between; gap:2rem; flex-wrap:wrap; align-items:flex-start; }
.footer-brand{ font-family:var(--display); font-size:1.7rem; color:#fff; font-weight:380; }
.footer-brand small{ display:block; font-family:var(--body); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-soft); margin-top:.5rem; }
.footer-nav{ display:flex; gap:1.6rem; flex-wrap:wrap; list-style:none; margin:0; padding:0; }
.footer-nav a{ text-decoration:none; color:rgba(236,228,212,.78); font-size:.96rem; transition:color .3s; }
.footer-nav a:hover{ color:var(--gold-soft); }
.footer-rule{ height:1px; background:rgba(236,228,212,.16); margin:2.4rem 0 1.4rem; }
.footer-bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.82rem; color:rgba(236,228,212,.55); }
.footer-bottom a{ color:rgba(236,228,212,.7); }

/* ---------- full-width image band ---------- */
.photo-band{ width:100%; height:clamp(300px,46vh,560px); overflow:hidden; position:relative; }
.photo-band img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-band::after{ /* faint gold seam top + bottom */
  content:""; position:absolute; inset:0; pointer-events:none;
  box-shadow:inset 0 1px 0 var(--line-gold), inset 0 -1px 0 var(--line-gold);
}

/* ---------- framed interlude image ---------- */
.photo-feature{ max-width:560px; margin-inline:auto; }
.photo-feature .frame{ position:relative; aspect-ratio:3/4; overflow:hidden; }
.photo-feature .frame img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-feature::after{
  content:""; position:absolute; inset:0;
  border:1px solid var(--line-gold);
  border-top-left-radius:var(--radius-arch); border-top-right-radius:var(--radius-arch);
  border-bottom-left-radius:14px; border-bottom-right-radius:14px;
  transform:translate(14px,14px); z-index:-1;
}

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* hero load sequence */
.hero .load{ opacity:0; transform:translateY(16px); animation:rise .95s cubic-bezier(.2,.8,.2,1) forwards; }
.hero .l1{ animation-delay:.15s; } .hero .l2{ animation-delay:.32s; }
.hero .l3{ animation-delay:.5s; } .hero .l4{ animation-delay:.68s; }
@keyframes rise{ to{ opacity:1; transform:none; } }
.hero-window{ animation:dawn 1.8s ease forwards; }
@keyframes dawn{ from{ filter:brightness(.82) saturate(.9); } to{ filter:none; } }

:focus-visible{ outline:2.5px solid var(--gold); outline-offset:3px; border-radius:3px; }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero .load{ opacity:1; transform:none; animation:none; }
  .hero-window{ animation:none; }
  .btn:hover{ transform:none; }
}
