/* ============================================
   mike gaiter's daughter — shared styles
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Libre+Franklin:wght@300;400;500;600&family=Courier+Prime:wght@400;700&display=swap');

:root{
  --cream: #F3E9D8;
  --cream-card: #FBF5E8;
  --ink: #2B2218;
  --brown: #4A3526;
  --brown-deep: #2E2118;
  --brown-soft: #87674C;
  --gold: #B58A3D;
  --gold-soft: #E3C988;
  --rose: #B97F75;
  --rose-soft: #E7D0C8;
  --line: rgba(74,53,38,0.18);
  --shadow: 0 14px 30px -16px rgba(43,34,24,0.45);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }

body{
  margin:0;
  background: var(--cream);
  background-image:
    radial-gradient(circle at 20% 10%, rgba(181,138,61,0.06), transparent 40%),
    radial-gradient(circle at 85% 60%, rgba(185,127,117,0.06), transparent 45%);
  color: var(--ink);
  font-family: 'Libre Franklin', sans-serif;
  font-weight: 400;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4{
  font-family: 'Fraunces', serif;
  font-weight: 500;
  margin: 0 0 0.4em 0;
  color: var(--brown-deep);
  letter-spacing: -0.01em;
}

a{ color: var(--brown); }

.eyebrow{
  font-family: 'Courier Prime', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rose);
  display: inline-block;
  margin-bottom: 0.9em;
}

.wrap{
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 28px;
}

/* ---------- header ---------- */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(243,233,216,0.92);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--line);
}
.site-header .wrap{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding-top: 16px;
  padding-bottom: 16px;
}
.brand{
  font-family:'Fraunces', serif;
  font-style: italic;
  font-weight: 500;
  font-size: 1.18rem;
  color: var(--brown-deep);
  text-decoration: none;
  white-space: nowrap;
}
.brand .dot{ color: var(--gold); }

nav.main-nav{
  display:flex;
  gap: 26px;
  flex-wrap: wrap;
}
nav.main-nav a{
  font-family:'Courier Prime', monospace;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--brown-soft);
  position: relative;
  padding-bottom: 3px;
  transition: color 0.2s ease;
}
nav.main-nav a:hover, nav.main-nav a.active{ color: var(--brown-deep); }
nav.main-nav a.active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-2px;
  height: 2px;
  background: var(--gold);
}
.nav-toggle{
  display:none;
  background:none;
  border:1px solid var(--line);
  border-radius:6px;
  width:40px; height:36px;
  font-size: 1.1rem;
  color: var(--brown-deep);
  cursor:pointer;
}

@media (max-width: 760px){
  nav.main-nav{
    display:none;
    position:absolute;
    top: 100%;
    left:0; right:0;
    background: var(--cream-card);
    border-bottom: 1px solid var(--line);
    flex-direction: column;
    gap: 0;
    padding: 6px 28px 18px;
  }
  nav.main-nav.open{ display:flex; }
  nav.main-nav a{ padding: 12px 0; border-bottom: 1px dashed var(--line); }
  .nav-toggle{ display:block; }
}

/* ---------- footer ---------- */
.site-footer{
  margin-top: 100px;
  padding: 46px 0 60px;
  border-top: 1px solid var(--line);
  text-align:center;
}
.site-footer .gold-rule{
  width: 60px; height: 2px;
  background: var(--gold);
  margin: 0 auto 20px;
}
.site-footer p{
  font-family:'Courier Prime', monospace;
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--brown-soft);
  text-transform: uppercase;
  margin: 4px 0;
}
.site-footer .signature{
  font-family:'Fraunces', serif;
  font-style: italic;
  font-size: 1rem;
  color: var(--brown-deep);
  text-transform: none;
  letter-spacing: normal;
  margin-bottom: 10px;
}

/* ---------- hero ---------- */
.hero{
  padding: 64px 0 30px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items:center;
}
@media (max-width: 860px){
  .hero-grid{ grid-template-columns: 1fr; gap: 38px; }
}
.hero h1{
  font-size: clamp(2.1rem, 4.2vw, 3.1rem);
  line-height: 1.12;
}
.hero h1 em{
  font-style: italic;
  color: var(--gold);
}
.hero-lede{
  font-size: 1.05rem;
  color: var(--brown);
  max-width: 46ch;
}
.hero-photo-stack{
  position: relative;
  height: 420px;
}
.hero-photo-stack .polaroid{
  position:absolute;
}
@media (max-width: 860px){
  .hero-photo-stack{ height: 320px; }
}

/* ---------- polaroid / signature element ---------- */
.polaroid{
  background: #fff;
  padding: 10px 10px 32px;
  box-shadow: var(--shadow);
  border-radius: 2px;
  display:inline-block;
}
.polaroid img{
  display:block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.polaroid .tape{
  position:absolute;
  width: 64px; height: 24px;
  top: -12px;
  left: 50%;
  transform: translateX(-50%) rotate(-3deg);
  background: var(--rose-soft);
  opacity: 0.85;
  box-shadow: 0 2px 4px rgba(0,0,0,0.12);
}
.polaroid.tape-gold .tape{ background: var(--gold-soft); }
.polaroid .cap{
  font-family:'Courier Prime', monospace;
  font-size: 0.66rem;
  letter-spacing: 0.04em;
  color: var(--brown-soft);
  text-align:center;
  margin-top: 8px;
  display:block;
}

/* ---------- scrolling gallery ---------- */
.gallery-section{ padding: 70px 0; }
.gallery-head{
  display:flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 36px;
}
.gallery-scroll{
  display:flex;
  gap: 34px;
  overflow-x: auto;
  padding: 30px 28px 50px;
  margin: 0 -28px;
  scroll-snap-type: x proximity;
}
.gallery-scroll::-webkit-scrollbar{ height: 8px; }
.gallery-scroll::-webkit-scrollbar-thumb{ background: var(--gold-soft); border-radius: 4px; }
.gallery-scroll .polaroid{
  flex: 0 0 auto;
  width: 230px;
  height: 230px;
  scroll-snap-align: center;
}
.gallery-scroll .polaroid img{ height: 188px; }

/* ---------- video section ---------- */
.video-section{
  padding: 70px 0;
  background: var(--cream-card);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.video-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 32px;
  margin-top: 36px;
}
.video-frame{
  background: #fff;
  border-radius: 6px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.video-frame blockquote.instagram-media{ margin:0 !important; }
.video-note{
  background: var(--cream-card);
  border: 1px dashed var(--line);
  border-radius: 6px;
  padding: 30px;
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: var(--brown-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  min-height: 220px;
}

/* ---------- nav cards ---------- */
.explore-section{ padding: 70px 0 90px; }
.explore-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 22px;
  margin-top: 36px;
}
.explore-card{
  background: var(--cream-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 30px 26px;
  text-decoration:none;
  display:block;
  position: relative;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.explore-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}
.explore-card .num{
  font-family:'Courier Prime', monospace;
  font-size: 0.7rem;
  color: var(--gold);
  letter-spacing: 0.1em;
}
.explore-card h3{
  font-size: 1.32rem;
  margin: 10px 0 8px;
}
.explore-card p{
  color: var(--brown-soft);
  font-size: 0.92rem;
  margin:0;
}

/* ---------- generic page header band ---------- */
.page-hero{
  padding: 60px 0 40px;
  border-bottom: 1px solid var(--line);
}
.page-hero h1{ font-size: clamp(2rem, 4vw, 2.7rem); }
.page-hero .lede{
  color: var(--brown);
  max-width: 60ch;
  font-size: 1.02rem;
}

/* ---------- story content ---------- */
.story-block{
  padding: 56px 0;
  border-bottom: 1px dashed var(--line);
}
.story-block:last-of-type{ border-bottom: none; }
.story-meta{
  display:flex;
  gap: 16px;
  align-items:center;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.story-meta .who{
  font-family:'Fraunces', serif;
  font-style: italic;
  font-size: 1.05rem;
  color: var(--brown-deep);
}
.story-meta .when{
  font-family:'Courier Prime', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--rose);
}
.story-title{
  font-size: 1.7rem;
  margin-bottom: 0.5em;
}
.story-body p{
  margin: 0 0 1.1em;
  font-size: 1.02rem;
  color: var(--ink);
}
.story-body p:first-of-type::first-letter{
  font-family:'Fraunces', serif;
  font-size: 3.1rem;
  float:left;
  line-height: 0.8;
  padding: 6px 8px 0 0;
  color: var(--gold);
}

/* ---------- callout / cta boxes ---------- */
.callout{
  background: var(--cream-card);
  border: 1px solid var(--line);
  border-left: 4px solid var(--gold);
  border-radius: 6px;
  padding: 28px 30px;
  margin: 40px 0;
}
.callout h3{ font-size: 1.2rem; margin-bottom: 10px; }
.callout p{ color: var(--brown-soft); margin: 0 0 16px; font-size: 0.96rem; }

.btn{
  display:inline-block;
  font-family:'Courier Prime', monospace;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration:none;
  background: var(--brown-deep);
  color: var(--cream);
  padding: 13px 26px;
  border-radius: 4px;
  transition: background 0.2s ease;
}
.btn:hover{ background: var(--gold); color: var(--brown-deep); }
.btn.ghost{
  background: transparent;
  color: var(--brown-deep);
  border: 1px solid var(--brown-deep);
}
.btn.ghost:hover{ background: var(--brown-deep); color: var(--cream); }

/* ---------- timeline (legacy page) ---------- */
.timeline{
  position: relative;
  margin: 50px 0;
  padding-left: 34px;
  border-left: 2px solid var(--gold-soft);
}
.timeline-item{
  position: relative;
  margin-bottom: 38px;
}
.timeline-item::before{
  content:"";
  position:absolute;
  left: -41px;
  top: 4px;
  width: 12px; height:12px;
  border-radius: 50%;
  background: var(--gold);
  border: 3px solid var(--cream);
}
.timeline-item .yr{
  font-family:'Courier Prime', monospace;
  font-size: 0.78rem;
  color: var(--rose);
  letter-spacing: 0.06em;
}
.timeline-item h4{ font-size: 1.18rem; margin: 4px 0 6px; }
.timeline-item p{ color: var(--brown); margin:0; font-size: 0.96rem; }

/* ---------- pull quote ---------- */
.pullquote{
  font-family:'Fraunces', serif;
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1.45;
  color: var(--brown-deep);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 36px 0;
  margin: 50px 0;
  text-align:center;
}
.pullquote span{ color: var(--gold); }

/* ---------- photo grid (legacy/adventures) ---------- */
.photo-grid{
  display:flex;
  flex-wrap: wrap;
  gap: 28px;
  justify-content:center;
  padding: 20px 0 10px;
}
.photo-grid .polaroid{ width: 210px; height: 210px; }
.photo-grid .polaroid img{ height: 168px; }

/* ---------- submission form ---------- */
.story-form{
  background: var(--cream-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 36px;
  margin-top: 30px;
}
.story-form label{
  display:block;
  font-family:'Courier Prime', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--brown-soft);
  margin: 18px 0 6px;
}
.story-form label:first-child{ margin-top:0; }
.story-form input, .story-form textarea{
  width:100%;
  font-family:'Libre Franklin', sans-serif;
  font-size: 0.98rem;
  padding: 12px 14px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
}
.story-form textarea{ min-height: 140px; resize: vertical; }
.story-form .btn{ margin-top: 22px; border:none; cursor:pointer; }

/* ---------- embedded airtable form ---------- */
.airtable-embed{
  background: var(--cream-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 30px;
  margin-top: 30px;
}
.airtable-embed iframe{
  width: 100%;
  height: 560px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

/* ---------- placeholder / empty state ---------- */
.empty-note{
  font-family:'Fraunces', serif;
  font-style: italic;
  color: var(--brown-soft);
  text-align:center;
  padding: 50px 20px;
  border: 1px dashed var(--line);
  border-radius: 8px;
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .explore-card{ transition:none; }
}
