/* Occasional Good — landing page styles.
   Design: warm "oat" paper, Fraunces serif headings + Hanken Grotesk body, a green spotlight motif.
   Static, no build. Fonts loaded from Google Fonts in index.html. */

:root{
  --oat:#F0EDE6;
  --paper:#FAF8F3;
  --ink:#211E19;
  --muted:#6B655B;
  --green:#1E9C57;
  --green-dark:#167A43;
  --green-tint:#E5F1E8;
  --line:#DED9CE;
  --glow:255, 241, 207; /* warm spotlight light */

  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif;

  --maxw:1120px;
  --gut:clamp(1.25rem, 4vw, 3rem);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--oat);
  color:var(--ink);
  font-family:var(--sans);
  font-size:clamp(1rem, 0.96rem + 0.2vw, 1.075rem);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.05;margin:0;letter-spacing:-0.01em;}
p{margin:0;}
a{color:inherit;}
strong{font-weight:600;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}

.eyebrow{
  font-family:var(--sans);
  font-size:0.74rem;
  font-weight:600;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--green-dark);
}

/* ---------- spotlight mark ---------- */
.mark{
  display:inline-grid;place-items:center;
  width:13px;height:13px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 4px rgba(30,156,87,0.16), 0 0 16px 2px rgba(30,156,87,0.35);
  flex:none;
}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:40;
  background:rgba(240,237,230,0.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
header.scrolled{border-bottom-color:var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;}
.brand{display:flex;align-items:center;gap:0.6rem;font-family:var(--serif);font-size:1.18rem;font-weight:600;letter-spacing:-0.015em;text-decoration:none;}
.btn{
  font-family:var(--sans);font-weight:600;font-size:0.95rem;
  border-radius:999px;border:0;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:0.45rem;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
}
.btn-primary{background:var(--green);color:#fff;padding:0.85rem 1.4rem;box-shadow:0 6px 18px -8px rgba(30,156,87,0.7);}
.btn-primary:hover{background:var(--green-dark);transform:translateY(-1px);}
.btn-primary:disabled{opacity:0.7;cursor:default;transform:none;}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);padding:0.6rem 1.15rem;}
.btn-ghost:hover{border-color:var(--ink);}
.btn-lg{padding:1rem 1.7rem;font-size:1.02rem;}

/* language toggle */
.nav-right{display:flex;align-items:center;gap:0.7rem;}
.lang-toggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--oat);}
.lang-toggle .lang{
  font-family:var(--sans);font-weight:600;font-size:0.8rem;letter-spacing:0.04em;
  padding:0.42rem 0.72rem;border:0;background:transparent;color:var(--muted);cursor:pointer;
  transition:background .2s ease, color .2s ease;
}
.lang-toggle .lang:hover{color:var(--ink);}
.lang-toggle .lang.active{background:var(--green);color:#fff;}

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

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding-top:clamp(3rem,9vw,7rem);padding-bottom:clamp(3.5rem,9vw,7rem);}
.spotlight{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(620px 620px at var(--mx,50%) var(--my,38%),
    rgba(var(--glow),0.95) 0%,
    rgba(var(--glow),0.55) 26%,
    rgba(var(--glow),0.12) 52%,
    rgba(var(--glow),0) 70%);
  opacity:0;transition:opacity 1.1s ease;
  mix-blend-mode:normal;
}
.spotlight.lit{opacity:1;}
.hero-inner{position:relative;z-index:1;max-width:840px;}
.hero h1{
  font-size:clamp(2.6rem, 1.6rem + 4.2vw, 5.1rem);
  font-weight:500;
  letter-spacing:-0.025em;
  margin-top:1.1rem;
  filter:blur(8px);opacity:0;transform:translateY(8px);
  transition:filter 1s ease .15s, opacity 1s ease .15s, transform 1s ease .15s;
}
.hero h1 em{font-style:italic;color:var(--green-dark);}
.hero.revealed h1{filter:blur(0);opacity:1;transform:none;}
.hero-sub{
  margin-top:1.5rem;max-width:34em;font-size:clamp(1.05rem,1rem+0.4vw,1.3rem);color:var(--muted);
  opacity:0;transform:translateY(8px);transition:opacity .9s ease .55s, transform .9s ease .55s;
}
.hero.revealed .hero-sub{opacity:1;transform:none;}
.hero-cta{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:0.9rem 1.4rem;align-items:center;
  opacity:0;transform:translateY(8px);transition:opacity .9s ease .75s, transform .9s ease .75s;}
.hero.revealed .hero-cta{opacity:1;transform:none;}
.hero-note{font-size:0.92rem;color:var(--muted);}

/* ---------- section frame ---------- */
section{padding-block:clamp(3.5rem,8vw,6.5rem);}
.section-head{max-width:640px;margin-bottom:clamp(2rem,4vw,3.2rem);}
.section-head h2{font-size:clamp(1.9rem,1.4rem+1.8vw,3rem);margin-top:0.7rem;}

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

/* ---------- gifts ---------- */
.gifts{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.gift-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.gift{
  background:var(--oat);border:1px solid var(--line);border-radius:18px;
  padding:1.8rem 1.7rem 2rem;display:flex;flex-direction:column;gap:0.85rem;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.gift:hover{transform:translateY(-4px);box-shadow:0 20px 40px -28px rgba(33,30,25,0.4);border-color:#cfc8ba;}
.gift .ico{width:42px;height:42px;border-radius:11px;background:var(--green-tint);display:grid;place-items:center;color:var(--green-dark);}
.gift .ico svg{width:22px;height:22px;}
.gift h3{font-size:1.35rem;font-weight:600;}
.gift p{color:var(--muted);font-size:0.98rem;}
.free-tag{
  align-self:flex-start;margin-top:auto;font-family:var(--sans);font-size:0.72rem;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--green-dark);
  background:var(--green-tint);padding:0.32rem 0.7rem;border-radius:999px;
}

/* ---------- why ---------- */
.why .wrap{max-width:760px;}
.why h2{font-size:clamp(1.9rem,1.4rem+1.8vw,2.9rem);margin-top:0.7rem;margin-bottom:1.4rem;}
.why p{color:var(--ink);font-size:clamp(1.08rem,1rem+0.45vw,1.32rem);line-height:1.6;margin-bottom:1.1rem;}
.why p.fine{color:var(--muted);font-size:1.02rem;line-height:1.6;}
.pull{
  border-left:3px solid var(--green);padding-left:1.2rem;margin:1.6rem 0;
  font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,1.1rem+0.9vw,1.75rem);
  line-height:1.32;color:var(--ink);
}

/* ---------- signup ---------- */
.signup{background:var(--paper);border-top:1px solid var(--line);position:relative;overflow:hidden;}
.signup::before{
  content:"";position:absolute;top:-30%;left:50%;transform:translateX(-50%);
  width:900px;height:600px;pointer-events:none;
  background:radial-gradient(closest-side, rgba(var(--glow),0.6), rgba(var(--glow),0) 75%);
}
.signup .wrap{position:relative;}
.signup-head{max-width:620px;margin-bottom:2.4rem;}
.signup-head h2{font-size:clamp(1.9rem,1.4rem+1.8vw,3rem);margin-top:0.7rem;}
.signup-head p{color:var(--muted);margin-top:0.9rem;}
form{background:var(--oat);border:1px solid var(--line);border-radius:22px;padding:clamp(1.5rem,4vw,2.6rem);max-width:760px;}
.fieldset-label{font-family:var(--sans);font-size:0.74rem;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--muted);margin:0 0 1.1rem;}
.fieldset-label:not(:first-of-type){margin-top:2.2rem;}
.field{margin-bottom:1.15rem;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem;}
label.lab{display:block;font-size:0.92rem;font-weight:600;margin-bottom:0.42rem;}
label.lab .req{color:var(--green-dark);}
input,select,textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:11px;
  padding:0.8rem 0.95rem;transition:border-color .15s ease, box-shadow .15s ease;
}
/* custom dropdown chevron — sits ~6px in from the right edge */
select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  padding-right:2.6rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B655B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 0.95rem center;
  background-size:12px;
}
textarea{resize:vertical;min-height:60px;}
input::placeholder,textarea::placeholder{color:#a39c8f;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(30,156,87,0.15);}
/* invalid field state + per-field message */
input.invalid,select.invalid,textarea.invalid{border-color:#c2452f;}
input.invalid:focus,select.invalid:focus,textarea.invalid:focus{box-shadow:0 0 0 3px rgba(194,69,47,0.15);}
.field-error{color:#a8331f;font-size:0.82rem;line-height:1.4;margin-top:0.4rem;}
.consent.invalid{color:#a8331f;}
.consent.invalid input{outline:2px solid #c2452f;outline-offset:2px;}
.consent{display:flex;gap:0.7rem;align-items:flex-start;margin-top:1.4rem;font-size:0.95rem;color:var(--muted);}
.consent input{width:auto;margin-top:0.2rem;flex:none;accent-color:var(--green);}
.submit-row{margin-top:1.8rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem;}
.submit-row .hint{font-size:0.88rem;color:var(--muted);}

/* honeypot — visually hidden, off-screen; real people never see or fill it */
.hp{position:absolute !important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}

/* form-level status banner (server / network errors) */
.form-status{margin-top:1.1rem;font-size:0.92rem;}
.form-status:empty{display:none;}
.form-status.err,.form-status.ok{padding:0.7rem 0.95rem;border-radius:11px;border:1px solid;}
.form-status.err{color:#8f2f1f;background:#fbece8;border-color:#e6b8ac;}
.form-status.ok{color:var(--green-dark);background:var(--green-tint);border-color:#bfe0c9;}

/* submit button loading spinner */
.spinner{width:1em;height:1em;border-radius:50%;flex:none;
  border:2px solid rgba(255,255,255,0.45);border-top-color:#fff;
  animation:spin .6s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

.thanks{display:none;background:var(--green-tint);border:1px solid #bfe0c9;border-radius:22px;
  padding:clamp(1.8rem,4vw,2.8rem);max-width:760px;}
.thanks.show{display:block;}
.thanks h3{font-size:1.7rem;color:var(--green-dark);margin-bottom:0.6rem;}
.thanks p{color:var(--ink);}

/* ---------- footer ---------- */
footer{padding-block:2.6rem;border-top:1px solid var(--line);}
footer .wrap{display:flex;flex-wrap:wrap;gap:0.8rem 1.5rem;align-items:center;justify-content:space-between;}
footer .brand{font-size:1rem;}
footer .fineprint{font-size:0.88rem;color:var(--muted);}
.lucidareia{display:inline-flex;align-items:baseline;gap:0.3em;color:var(--ink);text-decoration:none;font-weight:600;}
.lucidareia:hover{color:var(--green-dark);text-decoration:underline;text-underline-offset:2px;}
.lucidareia .eye{width:1em;height:1em;align-self:center;flex:none;color:var(--green-dark);}

/* ---------- responsive ---------- */
@media (max-width:820px){
  .gift-grid{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .nav .btn-ghost{padding:0.5rem 1rem;}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{transition:none !important;animation:none !important;}
  .hero h1,.hero-sub,.hero-cta{filter:none;opacity:1;transform:none;}
  .reveal{opacity:1;transform:none;}
  .spotlight{opacity:1;}
}
