/* =====================================================================
   LOUISIANA LIFE — V2 · Structured Grid (Swiss / architectural)
   Brand-locked: Gold #AE9142 · Navy #143865 · Gray #75787B · Cool Gray #C8C9C7
   Type: MADE Mirage only (system serif fallback until files added)
   ===================================================================== */
@font-face{ font-family:'MADE Mirage'; src:url('../fonts/MADEMirage-Thin.woff2') format('woff2'); font-weight:100; font-display:swap; }
@font-face{ font-family:'MADE Mirage'; src:url('../fonts/MADEMirage-Regular.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face{ font-family:'MADE Mirage'; src:url('../fonts/MADEMirage-Medium.woff2') format('woff2'); font-weight:500; font-display:swap; }
@font-face{ font-family:'MADE Mirage'; src:url('../fonts/MADEMirage-Bold.woff2') format('woff2'); font-weight:700; font-display:swap; }

:root{
  --gold:#AE9142; --navy:#143865; --gray:#75787B; --cool:#C8C9C7; --white:#FFFFFF;
  --line:rgba(20,56,101,.16);
  --line-light:rgba(255,255,255,.18);
  --serif:'MADE Mirage','Didot','Bodoni 72','Bodoni MT','Hoefler Text',Georgia,serif;
  --mono:'MADE Mirage',Georgia,serif;
  --pad:clamp(20px,3.4vw,54px);
  --ease:cubic-bezier(.6,.01,.05,1);
  --fb:clamp(18px,2vw,28px); /* frame inset */
}
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
body{
  font-family:var(--serif); background:var(--white); color:var(--navy);
  line-height:1.5; overflow-x:hidden; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
body.is-loading{ overflow:hidden; height:100vh; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
em{ font-style:italic; color:var(--gold); }
@media (hover:hover) and (pointer:fine){ body.cursor-on, body.cursor-on a, body.cursor-on button{ cursor:none; } }

/* ---------- architectural frame ---------- */
.frame{ position:fixed; inset:var(--fb); z-index:700; pointer-events:none; }
.frame span{ position:absolute; background:var(--line); }
.frame__t{ top:0; left:0; right:0; height:1px; transform:scaleX(0); transform-origin:left; }
.frame__b{ bottom:0; left:0; right:0; height:1px; transform:scaleX(0); transform-origin:right; }
.frame__l{ top:0; bottom:0; left:0; width:1px; transform:scaleY(0); transform-origin:top; }
.frame__r{ top:0; bottom:0; right:0; width:1px; transform:scaleY(0); transform-origin:bottom; }
@media (max-width:680px){ .frame{ display:none; } }

/* ---------- cursor (square, fits Swiss) ---------- */
.cursor{
  position:fixed; top:0; left:0; width:26px; height:26px; z-index:9000; pointer-events:none;
  border:1px solid var(--gold); transform:translate(-50%,-50%);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s; mix-blend-mode:normal;
}
body.cursor-hover .cursor{ width:46px; height:46px; background:rgba(174,145,66,.12); }
@media (hover:none),(pointer:coarse){ .cursor{ display:none; } }

/* ---------- shared ---------- */
.sec-label{
  display:flex; align-items:center; gap:.8em; font-size:.72rem; letter-spacing:.26em;
  text-transform:uppercase; color:var(--gold); font-weight:500; padding-bottom:1.4em;
}
.sec-label span{ color:var(--navy); opacity:.55; }
.sec-label--light{ color:var(--gold); }
.sec-label--light span{ color:var(--white); opacity:.5; }
.sec-label--navy span{ color:var(--navy); opacity:.5; }

.btn{
  display:inline-flex; align-items:center; gap:.7em; padding:1em 1.7em; font-size:.86rem;
  letter-spacing:.04em; font-weight:500; border:1px solid var(--navy); background:var(--navy); color:var(--white);
  transition:background .45s var(--ease), color .45s var(--ease); white-space:nowrap;
}
.btn i{ font-style:normal; transition:transform .4s var(--ease); }
.btn:hover i{ transform:translateX(5px); }
.btn:hover{ background:var(--gold); border-color:var(--gold); color:var(--navy); }
.btn--ghost{ background:transparent; color:var(--navy); border-color:var(--line); }
.btn--ghost:hover{ background:var(--navy); border-color:var(--navy); color:var(--white); }
.btn--ghost-light{ background:transparent; color:var(--white); border-color:var(--line-light); }
.btn--ghost-light:hover{ background:var(--gold); border-color:var(--gold); color:var(--navy); }
.btn--navy{ background:var(--navy); color:var(--white); border-color:var(--navy); }
.btn--navy:hover{ background:var(--white); color:var(--navy); border-color:var(--white); }
.btn--navy-ghost{ background:transparent; color:var(--navy); border-color:var(--navy); }
.btn--navy-ghost:hover{ background:var(--navy); color:var(--white); }

.link-more{ display:inline-flex; align-items:center; gap:.55em; font-size:.92rem; font-weight:500; position:relative; }
.link-more i{ font-style:normal; color:var(--gold); transition:transform .4s var(--ease); }
.link-more:hover i{ transform:translateX(5px); }

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed; top:0; left:0; width:100%; z-index:600;
  display:flex; align-items:center; gap:30px;
  padding:calc(var(--fb) + 14px) calc(var(--fb) + 22px) 14px;
  transition:padding .5s var(--ease), background .5s var(--ease);
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand__mark{ width:34px; transition:width .5s var(--ease); }
.brand__wordmark{ color:var(--navy); height:16px; width:auto; margin-top:2px; transition:height .5s var(--ease); }
.nav__links{ display:flex; gap:30px; margin-left:auto; }
.nav__links a{ font-size:.82rem; letter-spacing:.04em; display:flex; align-items:baseline; gap:.5em; opacity:.85; transition:opacity .3s; }
.nav__links a span{ font-size:.62rem; color:var(--gold); letter-spacing:.1em; }
.nav__links a:hover{ opacity:1; color:var(--gold); }
.nav__cta{ padding:.7em 1.2em; font-size:.78rem; }
.nav.is-scrolled{ background:var(--white); padding-top:14px; box-shadow:0 1px 0 var(--line); }
.nav.is-scrolled .brand__mark{ width:30px; }

.burger{ display:none; width:34px; height:30px; position:relative; margin-left:auto; }
.burger span{ position:absolute; left:4px; right:4px; height:1.5px; background:var(--navy); transition:transform .4s var(--ease); }
.burger span:nth-child(1){ top:11px; } .burger span:nth-child(2){ bottom:11px; }
body.menu-open .burger span:nth-child(1){ transform:translateY(3.5px) rotate(45deg); }
body.menu-open .burger span:nth-child(2){ transform:translateY(-3.5px) rotate(-45deg); }
.menu{ position:fixed; inset:0; z-index:590; background:var(--navy); display:flex; flex-direction:column; justify-content:center; gap:14px; padding:var(--pad); clip-path:inset(0 0 100% 0); transition:clip-path .6s var(--ease); }
body.menu-open .menu{ clip-path:inset(0 0 0 0); }
.menu a{ color:var(--white); font-size:clamp(1.8rem,8vw,3rem); display:flex; align-items:baseline; gap:16px; }
.menu a span{ font-size:.8rem; color:var(--gold); letter-spacing:.2em; }

/* =====================================================================
   HERO
   ===================================================================== */
.hero{ padding:calc(var(--fb) + 96px) calc(var(--fb) + 22px) calc(var(--fb) + 26px); min-height:100svh; display:flex; flex-direction:column; }
.hero__meta{ display:flex; gap:40px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:14px 0; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gray); }
.hero__meta span:last-child{ margin-left:auto; color:var(--gold); }
.hero__grid{ display:grid; grid-template-columns:1.55fr 1fr; gap:0; flex:1; align-items:stretch; }
.hero__headcol{ display:flex; align-items:center; padding:clamp(30px,6vh,80px) 0; }
.hero__title{ font-weight:400; line-height:.92; letter-spacing:-.02em; font-size:clamp(3.2rem,10vw,9.5rem); }
.hero__title .ln{ display:block; overflow:hidden; }
.hero__title .ln--gold{ color:var(--gold); }
.hero__panel{ background:var(--navy); color:var(--white); padding:clamp(32px,4vw,56px); display:flex; flex-direction:column; justify-content:flex-end; gap:1.6em; }
.hero__panel-eyebrow{ font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); }
.hero__panel-text{ font-size:clamp(1.05rem,1.5vw,1.35rem); line-height:1.5; color:rgba(255,255,255,.86); margin-bottom:.4em; }
.hero__index{ display:flex; gap:0; border-top:1px solid var(--line); margin-top:auto; }
.hero__idx{ flex:1; padding:18px 4px; display:flex; align-items:baseline; gap:.6em; font-size:.92rem; border-right:1px solid var(--line); transition:color .3s; }
.hero__idx b{ font-size:.7rem; color:var(--gold); font-weight:500; letter-spacing:.05em; }
.hero__idx:hover{ color:var(--gold); }
.hero__scroll{ padding:18px 4px; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gray); align-self:center; }

/* =====================================================================
   INDEX / LEDGER
   ===================================================================== */
.index{ padding:clamp(70px,11vh,150px) calc(var(--fb) + 22px); }
.index__title{ font-weight:400; line-height:1.0; letter-spacing:-.01em; font-size:clamp(2.2rem,5.5vw,4.6rem); margin-bottom:clamp(40px,6vw,80px); }
.ledger{ list-style:none; border-top:1px solid var(--navy); }
.row{
  position:relative; display:grid; grid-template-columns:64px minmax(220px,1.1fr) 2fr 120px 40px;
  align-items:center; gap:30px; padding:34px 12px; border-bottom:1px solid var(--line);
  transition:padding .5s var(--ease), color .5s var(--ease); overflow:hidden;
}
.row::before{ content:""; position:absolute; inset:0; background:var(--navy); transform:scaleY(0); transform-origin:bottom; transition:transform .5s var(--ease); z-index:0; }
.row > *{ position:relative; z-index:1; }
.row__num{ font-size:.8rem; color:var(--gold); letter-spacing:.1em; }
.row__title{ font-weight:400; font-size:clamp(1.4rem,2.6vw,2.2rem); line-height:1.05; letter-spacing:-.01em; }
.row__desc{ color:var(--gray); font-size:1rem; line-height:1.55; max-width:46ch; transition:color .5s var(--ease); }
.row__tag{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); transition:color .5s var(--ease); }
.row__arrow{ font-size:1.3rem; color:var(--gold); justify-self:end; transition:transform .5s var(--ease); }
.row:hover{ padding-left:26px; padding-right:26px; color:var(--white); }
.row:hover::before{ transform:scaleY(1); transform-origin:top; }
.row:hover .row__desc{ color:rgba(255,255,255,.8); }
.row:hover .row__tag{ color:var(--gold); }
.row:hover .row__arrow{ transform:translateX(8px); }

/* =====================================================================
   STATEMENT SPLIT
   ===================================================================== */
.split{ display:grid; grid-template-columns:1.2fr 1fr; min-height:78vh; }
.split__text{ background:var(--navy); color:var(--white); padding:clamp(40px,6vw,96px); display:flex; flex-direction:column; justify-content:center; }
.split__quote{ font-weight:400; line-height:1.18; letter-spacing:-.01em; font-size:clamp(1.7rem,3.4vw,3.2rem); max-width:20ch; margin-bottom:1.4em; }
.split__quote em{ color:var(--gold); }
.split__foot .link-more{ color:var(--white); }
.split__media{ position:relative; overflow:hidden; }
.split__media img{ width:100%; height:100%; object-fit:cover; }
.split__cap{ position:absolute; left:0; bottom:0; background:var(--gold); color:var(--navy); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; padding:12px 20px; }

/* =====================================================================
   STATS BAND
   ===================================================================== */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); border-bottom:1px solid var(--line); }
.stat{ padding:clamp(50px,7vw,90px) clamp(24px,3vw,48px); border-right:1px solid var(--line); display:flex; flex-direction:column; gap:.5em; }
.stat:last-child{ border-right:none; }
.stat__num{ font-size:clamp(3rem,7vw,5.6rem); font-weight:400; color:var(--gold); line-height:.9; letter-spacing:-.02em; }
.stat__label{ font-size:.82rem; letter-spacing:.06em; color:var(--gray); text-transform:uppercase; }

/* =====================================================================
   HERITAGE
   ===================================================================== */
.heritage{ display:grid; grid-template-columns:1fr 1.1fr; background:var(--navy); color:var(--white); }
.heritage__media{ position:relative; overflow:hidden; min-height:60vh; }
.heritage__media img{ width:100%; height:100%; object-fit:cover; }
.heritage__text{ padding:clamp(44px,6vw,110px); display:flex; flex-direction:column; justify-content:center; }
.heritage__title{ font-weight:400; line-height:1.0; font-size:clamp(2.4rem,5vw,4.4rem); margin-bottom:.5em; letter-spacing:-.01em; }
.heritage__body{ color:rgba(255,255,255,.78); font-size:1.08rem; line-height:1.6; max-width:42ch; margin-bottom:2em; }

/* =====================================================================
   CTA
   ===================================================================== */
.cta{ background:var(--gold); color:var(--navy); padding:clamp(80px,14vh,180px) calc(var(--fb) + 22px); }
.cta__inner{ max-width:1100px; }
.cta__title{ font-weight:400; line-height:.96; font-size:clamp(2.8rem,8vw,7rem); letter-spacing:-.02em; margin-bottom:.4em; }
.cta__sub{ font-size:clamp(1.05rem,1.6vw,1.3rem); max-width:42ch; margin-bottom:2.2em; line-height:1.55; }
.cta__actions{ display:flex; flex-wrap:wrap; gap:14px; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{ background:var(--navy); color:var(--white); padding:clamp(50px,7vh,90px) calc(var(--fb) + 22px) 30px; }
.footer__top{ display:grid; grid-template-columns:1fr 1.4fr; gap:50px; padding-bottom:46px; border-bottom:1px solid var(--line-light); }
.footer__logo{ width:clamp(140px,15vw,200px); }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.footer__col h4{ font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:1.3em; font-weight:500; }
.footer__col a{ display:block; color:rgba(255,255,255,.72); font-size:.98rem; margin-bottom:.7em; width:fit-content; transition:color .3s; }
.footer__col a:hover{ color:var(--gold); }
.footer__bottom{ display:flex; justify-content:space-between; gap:18px; padding-top:24px; flex-wrap:wrap; }
.footer__bottom p, .footer__legal a{ font-size:.8rem; color:rgba(255,255,255,.5); }
.footer__legal{ display:flex; gap:24px; }
.footer__legal a:hover{ color:var(--gold); }

/* =====================================================================
   VERSION SWITCHER
   ===================================================================== */
.vswitch{ position:fixed; right:calc(var(--fb) + 16px); bottom:calc(var(--fb) + 16px); z-index:750; display:flex; border:1px solid var(--line); background:var(--white); }
.vswitch a{ width:38px; height:38px; display:grid; place-items:center; font-size:.78rem; color:var(--gray); border-right:1px solid var(--line); transition:background .3s,color .3s; }
.vswitch a:last-child{ border-right:none; }
.vswitch a.is-active{ background:var(--navy); color:var(--gold); }
.vswitch a:hover:not(.is-active){ background:var(--gold); color:var(--navy); }

/* =====================================================================
   ANIMATION DEFAULTS
   ===================================================================== */
[data-reveal]{ opacity:0; transform:translateY(24px); }
[data-block]{ opacity:0; clip-path:inset(0 0 100% 0); }
.hero__title .ln .inner{ display:block; transform:translateY(110%); }
html.no-js [data-reveal],html.no-js [data-block]{ opacity:1; transform:none; clip-path:none; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1000px){
  .nav__links{ display:none; } .nav__cta{ display:none; } .burger{ display:block; }
  .hero__grid{ grid-template-columns:1fr; } .hero__panel{ margin-top:30px; }
  .row{ grid-template-columns:44px 1fr 32px; gap:16px 18px; }
  .row__desc{ grid-column:2; max-width:none; } .row__tag{ display:none; }
  .split{ grid-template-columns:1fr; } .split__media{ min-height:50vh; }
  .heritage{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr; } .stat{ border-right:none; border-bottom:1px solid var(--line); }
  .footer__top{ grid-template-columns:1fr; gap:36px; }
}
@media (max-width:600px){
  .hero__meta{ gap:18px; flex-wrap:wrap; } .hero__index{ flex-wrap:wrap; }
  .hero__idx{ flex:1 1 40%; } .hero__scroll{ display:none; }
  .footer__cols{ grid-template-columns:1fr 1fr; } .footer__bottom{ flex-direction:column; }
  .btn{ width:100%; justify-content:space-between; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  [data-reveal],[data-block]{ opacity:1 !important; transform:none !important; clip-path:none !important; }
  .hero__title .ln .inner{ transform:none !important; }
  .frame span{ transform:none !important; }
}
