/* ============================================================
   Haut Crochet LA REINE — shared luxury design system
   Warm beige · ivory · linen · walnut · indigo logotype
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700;800&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

:root{
  /* palette */
  --ivory:#FAF6EE;
  --paper:#F4EEE1;
  --linen:#EBE2D1;
  --beige:#E0D2B9;
  --sand:#CBB89A;
  --walnut:#5A4636;
  --walnut-soft:#7A6450;
  --ink:#2A2740;        /* deep indigo, from logotype */
  --ink-soft:#4B4769;
  --gold:#A98545;
  --gold-soft:#C2A878;
  --line:#D8CBB4;
  --cream-text:#EEE6D6;

  /* type */
  --jp: 'Shippori Mincho', 'Hiragino Mincho ProN', 'Yu Mincho', serif;
  --serif: 'Cormorant Garamond', 'Shippori Mincho', serif;
  --label: 'Jost', 'Shippori Mincho', sans-serif;

  --maxw: 1240px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--jp);
  color:var(--walnut);
  background:var(--ivory);
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---- typographic helpers ---- */
.eyebrow{
  font-family:var(--label);
  font-weight:400;
  letter-spacing:.42em;
  text-transform:uppercase;
  font-size:.72rem;
  color:var(--gold);
  display:inline-block;
}
.serif-display{
  font-family:var(--serif);
  font-weight:500;
  letter-spacing:.02em;
}
.jp-title{
  font-family:var(--jp);
  font-weight:600;
  line-height:1.5;
  letter-spacing:.06em;
  color:var(--ink);
}
.lead{
  font-size:1.02rem;
  line-height:2.05;
  color:var(--walnut-soft);
  letter-spacing:.04em;
}

/* ornamental divider — small diamond between two rules (echoes the brand seal) */
.divider{
  display:flex; align-items:center; gap:1rem;
  color:var(--sand);
}
.divider::before,.divider::after{
  content:""; height:1px; flex:1; background:var(--line);
}
.divider .gem{ width:9px; height:9px; transform:rotate(45deg); border:1px solid var(--gold); }
.divider.center{ justify-content:center; }
.divider.short::before,.divider.short::after{ flex:0 0 46px; }

/* section scaffolding */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 40px; }
.section{ padding:120px 0; }
.section-head{ text-align:center; max-width:680px; margin:0 auto 64px; }
.section-head .eyebrow{ margin-bottom:18px; }
.section-head h2{
  font-family:var(--jp); font-weight:600; color:var(--ink);
  font-size:clamp(1.7rem,3vw,2.5rem); letter-spacing:.08em; margin:0 0 10px;
  line-height:1.45;
}
.section-head .sub{
  font-family:var(--serif); font-style:italic; font-size:1.15rem;
  color:var(--gold); letter-spacing:.04em;
}

/* buttons / links */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--label); letter-spacing:.22em; text-transform:uppercase;
  font-size:.74rem; padding:16px 34px; border:1px solid var(--ink);
  color:var(--ink); background:transparent; cursor:pointer;
  transition:.45s ease;
}
.btn:hover{ background:var(--ink); color:var(--ivory); }
.btn.gold{ border-color:var(--gold); color:var(--gold); }
.btn.gold:hover{ background:var(--gold); color:var(--ivory); }
.btn.solid{ background:var(--ink); color:var(--ivory); }
.btn.solid:hover{ background:var(--ink-soft); }
.link-arrow{
  font-family:var(--label); letter-spacing:.18em; text-transform:uppercase;
  font-size:.72rem; color:var(--ink); display:inline-flex; align-items:center; gap:.6em;
  border-bottom:1px solid transparent; padding-bottom:3px; transition:.3s;
}
.link-arrow:hover{ border-color:var(--gold); color:var(--gold); }
.form-status{
  margin:18px 0 0;
  font-size:.82rem;
  color:var(--gold);
  letter-spacing:.04em;
}
.form-status[hidden]{ display:none; }

/* ---- top navigation ---- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 48px; transition:.4s ease;
  background:rgba(250,246,238,0); 
}
.nav.scrolled{
  background:rgba(250,246,238,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding:16px 48px;
}
.nav .brand{ display:flex; align-items:center; gap:14px; overflow:visible; }
.nav .brand img{
  height:64px; width:auto; object-fit:contain; transition:.4s;
  filter:drop-shadow(0 2px 8px rgba(255,252,246,.7)) drop-shadow(0 2px 12px rgba(42,39,64,.22));
}
.nav.scrolled .brand img{ height:54px; }
.nav-links{
  display:flex; gap:30px; align-items:center;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(250,246,238,.12);
  backdrop-filter:blur(6px);
}
.nav-links a{
  font-family:var(--jp); font-size:1.08rem; font-weight:600; letter-spacing:.08em; color:var(--ink);
  position:relative; padding-bottom:4px; white-space:nowrap;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:1px;
  background:var(--gold); transition:.3s;
}
.nav-links a:hover::after,.nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--gold); }
.nav-cta{
  font-family:var(--label); letter-spacing:.2em; text-transform:uppercase;
  font-size:.78rem; border:1px solid var(--ink); padding:12px 24px; color:var(--ink);
  transition:.4s;
}
.nav-cta:hover{ background:var(--ink); color:var(--ivory); }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; }

/* light nav while at top over a dark hero (site pages) */
.nav-over:not(.scrolled) .brand img{ filter:drop-shadow(0 2px 10px rgba(255,252,246,.82)) drop-shadow(0 3px 16px rgba(0,0,0,.28)); }
.nav-over:not(.scrolled) .nav-links{ background:rgba(28,24,40,.26); }
.nav-over:not(.scrolled) .nav-links a{ color:#fff; text-shadow:0 2px 14px rgba(0,0,0,.55); }
.nav-over:not(.scrolled) .nav-links a.active{ color:var(--gold-soft); }
.nav-over:not(.scrolled) .nav-links a::after{ background:var(--gold-soft); }
.nav-over:not(.scrolled) .nav-cta{ color:#fff; border-color:rgba(255,255,255,.65); }
.nav-over:not(.scrolled) .nav-cta:hover{ background:#fff; color:var(--ink); }
.nav-over:not(.scrolled) .nav-toggle line{ stroke:#fff; }

/* ---- footer ---- */
.footer{ background:var(--walnut); color:var(--cream-text); padding:90px 0 40px; }
.footer .wrap{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:50px; }
.footer .logotype{
  font-family:var(--serif); font-size:2rem; letter-spacing:.06em; color:var(--ivory);
  line-height:1.1;
}
.footer .logotype small{
  display:block; font-family:var(--label); letter-spacing:.5em; font-size:.66rem;
  text-transform:uppercase; color:var(--gold-soft); margin-top:8px;
}
.footer p{ font-size:.9rem; line-height:1.9; color:#D9CDBA; opacity:.85; }
.footer h4{
  font-family:var(--label); letter-spacing:.24em; text-transform:uppercase;
  font-size:.74rem; color:var(--gold-soft); margin:0 0 20px; font-weight:400;
}
.footer ul{ list-style:none; padding:0; margin:0; }
.footer ul li{ margin-bottom:12px; }
.footer ul a{ font-size:.9rem; color:#E4D9C7; transition:.3s; letter-spacing:.05em; }
.footer ul a:hover{ color:var(--gold-soft); }
.footer .base{
  max-width:var(--maxw); margin:60px auto 0; padding:24px 40px 0;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--label); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:#B7A88F;
}

/* "made with love" round seal — echoes the source banners */
.seal{
  width:96px; height:96px; border-radius:50%; border:1px solid var(--gold-soft);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; color:var(--gold-soft); gap:5px;
}
.seal .mark{ font-size:1.1rem; }
.seal small{
  font-family:var(--label); letter-spacing:.2em; text-transform:uppercase;
  font-size:.52rem; line-height:1.5;
}

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(28px); transition:1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }

@media(max-width:900px){
  .footer .wrap{ grid-template-columns:1fr; gap:36px; }
  .nav-links{ display:none; }
  .nav-toggle{ display:block; }
  .section{ padding:80px 0; }
  .wrap{ padding:0 24px; }
}

/* ============================================================
   Interior-page shared components (multipage site)
   ============================================================ */
@media(max-width:1140px){
  .nav-links{ gap:20px; padding:8px 12px; }
  .nav-links a{ font-size:.98rem; letter-spacing:.05em; }
  .nav-cta{ font-size:.74rem; padding:11px 20px; }
}
@media(max-width:1040px){
  .nav-links{ display:none; }
  .nav-toggle{ display:block; }
}

/* shared mobile drawer */
.mobile-drawer{ position:fixed; inset:0; background:var(--ivory); z-index:60; transform:translateY(-100%); transition:.5s cubic-bezier(.16,1,.3,1); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:24px; }
.mobile-drawer.open{ transform:none; }
.mobile-drawer a{ font-family:var(--jp); font-size:1.3rem; color:var(--ink); letter-spacing:.1em; }
.mobile-drawer .close{ position:absolute; top:24px; right:28px; font-size:2rem; background:none; border:none; color:var(--ink); cursor:pointer; }

/* interior page hero / banner */
.page-hero{ position:relative; height:62vh; min-height:440px; display:flex; align-items:flex-end; overflow:hidden; }
.page-hero .bg{ position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.04); }
.page-hero .bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(28,24,40,.6), rgba(28,24,40,.12) 60%, rgba(28,24,40,.28)); }
.page-hero .inner{ position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; width:100%; padding:0 40px 64px; }
.page-hero .eyebrow{ color:var(--gold-soft); margin-bottom:18px; }
.page-hero h1{ font-family:var(--jp); font-weight:600; color:#fff; font-size:clamp(2rem,4.4vw,3.4rem); letter-spacing:.1em; margin:0 0 14px; line-height:1.4; text-shadow:0 4px 30px rgba(0,0,0,.3); }
.page-hero .sub{ font-family:var(--serif); font-style:italic; color:rgba(255,255,255,.92); font-size:1.2rem; letter-spacing:.03em; }

/* breadcrumb */
.crumb{ max-width:var(--maxw); margin:0 auto; padding:26px 40px; font-family:var(--label); letter-spacing:.16em; text-transform:uppercase; font-size:.66rem; color:var(--sand); }
.crumb a{ color:var(--walnut-soft); }
.crumb a:hover{ color:var(--gold); }
.crumb span{ margin:0 .6em; }

/* product / work card (no prices) */
.work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:34px 30px; }
.work{ text-decoration:none; display:block; }
.work .pic{ overflow:hidden; aspect-ratio:4/5; background:var(--linen); }
.work .pic img{ width:100%; height:100%; object-fit:cover; transition:1.1s cubic-bezier(.16,1,.3,1); }
.work:hover .pic img{ transform:scale(1.06); }
.work .meta{ padding:22px 4px 0; }
.work .cat{ font-family:var(--label); letter-spacing:.24em; text-transform:uppercase; font-size:.62rem; color:var(--sand); display:block; margin-bottom:8px; }
.work h3{ font-family:var(--jp); font-weight:600; color:var(--ink); font-size:1.16rem; letter-spacing:.05em; margin:0 0 6px; }
.work p{ font-size:.84rem; color:var(--walnut-soft); line-height:1.8; margin:0 0 14px; }
.work .detail{ font-family:var(--label); letter-spacing:.18em; text-transform:uppercase; font-size:.66rem; color:var(--ink); display:inline-flex; gap:.5em; align-items:center; border-bottom:1px solid transparent; padding-bottom:3px; transition:.3s; }
.work:hover .detail{ border-color:var(--gold); color:var(--gold); }
.work.feature-wide .pic{ aspect-ratio:898/477; }
.work.feature-wide .pic img{
  padding:0;
  transform:none;
}
.work.feature-wide:hover .pic img{ transform:scale(1.015) !important; }

/* magazine instagram grid */
.insta-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.insta-grid figure{ margin:0; overflow:hidden; aspect-ratio:1/1; position:relative; }
.insta-grid img{ width:100%; height:100%; object-fit:cover; transition:1s cubic-bezier(.16,1,.3,1); }
.insta-grid figure:hover img{ transform:scale(1.08); }
.insta-grid figure::after{ content:"✦"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.3rem; background:rgba(42,39,64,.32); opacity:0; transition:.4s; }
.insta-grid figure:hover::after{ opacity:1; }

/* journal article cards */
.journal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:40px 32px; }
.article{ text-decoration:none; display:block; }
.article .pic{ overflow:hidden; aspect-ratio:3/2; }
.article .pic img{ width:100%; height:100%; object-fit:cover; transition:1.1s cubic-bezier(.16,1,.3,1); }
.article:hover .pic img{ transform:scale(1.06); }
.article .tag{ font-family:var(--label); letter-spacing:.22em; text-transform:uppercase; font-size:.62rem; color:var(--gold); display:block; margin:22px 0 10px; }
.article h3{ font-family:var(--jp); font-weight:600; color:var(--ink); font-size:1.22rem; letter-spacing:.04em; line-height:1.6; margin:0 0 10px; }
.article .date{ font-family:var(--serif); font-style:italic; color:var(--sand); font-size:.95rem; }

/* product imagery should show the full handmade piece, not crop into it */
.work .pic,
.insta-grid figure,
.article .pic,
.gallery figure,
.examples figure,
.portfolio figure,
.svc .thumb,
.s-card .pic{
  background:var(--paper);
}
.work .pic img,
.insta-grid img,
.article .pic img,
.gallery img,
.examples img,
.portfolio img,
.svc .thumb img,
.s-card .pic img{
  object-fit:contain !important;
  object-position:center center !important;
  padding:30px;
}
.svc .thumb img,
.s-card .pic img{
  padding:20px;
}
.work:hover .pic img,
.insta-grid figure:hover img,
.article:hover .pic img,
.gallery figure:hover img,
.examples figure:hover img,
.portfolio figure:hover img,
.svc:hover .thumb img,
.s-card:hover .pic img{
  transform:scale(1.01) !important;
}

@media(max-width:900px){
  .work-grid{ grid-template-columns:1fr 1fr; gap:28px 20px; }
  .journal-grid{ grid-template-columns:1fr; gap:36px; }
  .insta-grid{ grid-template-columns:repeat(2,1fr); }
  .page-hero .inner,.crumb{ padding-left:24px; padding-right:24px; }
}
@media(max-width:560px){
  .work-grid{ grid-template-columns:1fr; }
}
