/* =========================================================
   Viva Forte — editorial / print-inspired stylesheet
   ========================================================= */

:root{
  --ink:#16243f;
  --ink-dark:#0b1424;
  --ink-soft:#2c3c5c;
  --cream:#f8f4ea;
  --paper:#fffdf7;
  --gold:#a9802f;
  --gold-deep:#7c5d20;
  --gold-pale:#d8c084;
  --sage:#4f6b52;
  --sage-light:#76906f;
  --text:#21283a;
  --text-muted:#5c5648;
  --rule:#cdbf94;
  --border:#e3dac2;
  --shadow:0 2px 10px rgba(22,36,63,.07);
  --shadow-md:0 6px 22px rgba(22,36,63,.10);
  --radius:6px;
  --radius-lg:10px;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  font-family:'Lora',serif;
  color:var(--text);
  background:var(--cream);
  line-height:1.75;
  overflow-x:hidden;
  font-size:16px;
}

h1,h2,h3,h4{
  font-family:'Playfair Display',serif;
  color:var(--ink);
  line-height:1.25;
  font-weight:700;
}

a{text-decoration:none;color:inherit;}
ul{list-style:none;}
img{max-width:100%;display:block;}

.container{
  width:100%;
  max-width:1220px;
  margin:0 auto;
  padding:0 24px;
}

/* ---------- eyebrow / labels ---------- */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:'PT Sans',sans-serif;
  font-weight:700;
  font-size:.74rem;
  letter-spacing:2.2px;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:18px;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;
  background:var(--gold);
  display:inline-block;
}

.section-title{
  font-size:clamp(1.7rem,3.2vw,2.4rem);
  margin-bottom:18px;
}
.section-sub{
  color:var(--text-muted);
  font-size:1.02rem;
  max-width:660px;
  margin-bottom:10px;
  font-style:italic;
}
.section-head{
  text-align:center;
  max-width:740px;
  margin:0 auto 54px;
}
.ornament{
  display:block;
  margin:0 auto 22px;
  height:14px;
  opacity:.85;
}

.hairline{
  border:none;
  border-top:1px solid var(--border);
  margin:0;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:13px 30px;
  border-radius:3px;
  font-family:'PT Sans',sans-serif;
  font-weight:700;
  font-size:.88rem;
  letter-spacing:.6px;
  text-transform:uppercase;
  cursor:pointer;
  border:1.5px solid transparent;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
  white-space:nowrap;
}
.btn-primary{
  background:var(--gold);
  color:var(--paper);
  border-color:var(--gold);
}
.btn-primary:hover{background:var(--gold-deep);border-color:var(--gold-deep);transform:translateY(-2px);}
.btn-outline{
  background:transparent;
  border-color:rgba(255,255,255,.55);
  color:var(--paper);
}
.btn-outline:hover{background:rgba(255,255,255,.1);transform:translateY(-2px);}
.btn-outline-navy{
  background:transparent;
  border-color:var(--ink);
  color:var(--ink);
}
.btn-outline-navy:hover{background:var(--ink);color:var(--paper);}
.btn-light{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}
.btn-light:hover{background:var(--cream);transform:translateY(-2px);}

/* ===== MASTHEAD / HEADER ===== */
header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  background:var(--paper);
  border-bottom:1px solid var(--border);
}
.masthead-top{
  background:var(--ink);
  color:rgba(255,255,255,.75);
}
.masthead-top-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:7px 24px;
  font-family:'PT Sans',sans-serif;
  font-size:.74rem;
  letter-spacing:.5px;
}
.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 24px;
  max-width:1220px;
  margin:0 auto;
}
.logo{
  display:flex;
  align-items:center;
  gap:12px;
}
.logo-text{
  font-family:'Playfair Display',serif;
  font-size:1.5rem;
  font-weight:700;
  color:var(--ink);
  letter-spacing:.3px;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:34px;
}
.nav-links a{
  font-family:'PT Sans',sans-serif;
  color:var(--text);
  font-weight:700;
  font-size:.88rem;
  letter-spacing:.3px;
  position:relative;
  padding:6px 0;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;bottom:0;
  width:0;height:2px;
  background:var(--gold);
  transition:width .25s ease;
}
.nav-links a:hover::after{width:100%;}

.nav-actions{display:flex;align-items:center;gap:18px;}

.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:8px;
  z-index:1100;
}
.hamburger span{
  width:24px;height:2px;
  background:var(--ink);
  transition:all .3s ease;
}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.nav-cta-mobile{display:none;}

/* ===== HERO ===== */
.hero{
  position:relative;
  background:var(--ink);
  padding:170px 0 100px;
  color:var(--paper);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:60px;
  align-items:start;
}
.hero h1{
  color:var(--paper);
  font-size:clamp(2.1rem,4.2vw,3.2rem);
  margin-bottom:22px;
}
.hero h1 em{
  font-style:italic;
  color:var(--gold-pale);
}
.hero p.lead{
  color:rgba(255,255,255,.78);
  font-size:1.1rem;
  max-width:540px;
  margin-bottom:34px;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:46px;}

.hero-mini-stats{
  display:flex;
  gap:0;
  flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:24px;
}
.hero-mini-stats div{
  display:flex;
  flex-direction:column;
  padding:0 26px;
  border-right:1px solid rgba(255,255,255,.18);
}
.hero-mini-stats div:first-child{padding-left:0;}
.hero-mini-stats div:last-child{border-right:none;}
.hero-mini-stats strong{
  font-size:1.5rem;
  color:var(--gold-pale);
  font-family:'Playfair Display',serif;
}
.hero-mini-stats span{
  font-family:'PT Sans',sans-serif;
  font-size:.76rem;
  letter-spacing:.4px;
  color:rgba(255,255,255,.6);
}

/* fact box (replaces glassy hero card) */
.fact-box{
  background:var(--paper);
  color:var(--text);
  border-top:3px solid var(--gold);
  box-shadow:var(--shadow-md);
}
.fact-box-head{
  display:flex;
  align-items:center;
  gap:14px;
  padding:24px 26px;
  border-bottom:1px solid var(--border);
}
.fact-box-head img{width:38px;height:38px;}
.fact-box-head h3{font-size:1.08rem;margin-bottom:2px;}
.fact-box-head p{font-family:'PT Sans',sans-serif;font-size:.8rem;color:var(--text-muted);}

.fact-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 26px;
  border-bottom:1px solid var(--border);
}
.fact-row:last-child{border-bottom:none;}
.fact-row-left{display:flex;align-items:center;gap:14px;}
.fact-row-left i{
  width:30px;
  text-align:center;
  color:var(--gold-deep);
  font-size:1rem;
}
.fact-row-left strong{display:block;font-size:.94rem;font-family:'Playfair Display',serif;}
.fact-row-left span{font-family:'PT Sans',sans-serif;font-size:.76rem;color:var(--text-muted);}
.fact-row-mark{color:var(--sage);font-size:.85rem;}

/* ===== ABOUT ===== */
.about{
  padding:100px 0;
  background:var(--paper);
}
.about-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:64px;
  align-items:start;
}
.about-text p{color:var(--text-muted);margin-bottom:18px;font-size:1.04rem;}
.about-text p.lead-drop::first-letter{
  font-family:'Playfair Display',serif;
  font-size:3.4rem;
  font-weight:700;
  float:left;
  line-height:.8;
  margin:6px 10px 0 0;
  color:var(--gold-deep);
}
.about-list{margin-top:26px;display:flex;flex-direction:column;}
.about-list li{
  display:flex;
  align-items:baseline;
  gap:14px;
  font-family:'PT Sans',sans-serif;
  font-weight:700;
  color:var(--ink);
  font-size:.92rem;
  padding:14px 0;
  border-bottom:1px solid var(--border);
}
.about-list li:first-child{border-top:1px solid var(--border);}
.about-list li span.mark{color:var(--gold-deep);}

.sidebar-box{
  border:1px solid var(--border);
  background:var(--cream);
}
.sidebar-box-title{
  font-family:'PT Sans',sans-serif;
  font-weight:700;
  font-size:.78rem;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--paper);
  background:var(--ink);
  padding:14px 22px;
}
.sidebar-item{
  display:flex;
  gap:16px;
  padding:20px 22px;
  border-bottom:1px solid var(--border);
}
.sidebar-item:last-child{border-bottom:none;}
.sidebar-item .num{
  font-family:'Playfair Display',serif;
  font-size:1.3rem;
  color:var(--gold-deep);
  min-width:34px;
}
.sidebar-item h4{font-size:1rem;margin-bottom:4px;}
.sidebar-item p{font-size:.86rem;color:var(--text-muted);}

/* ===== PILLARS ===== */
.pillars{
  padding:100px 0;
  background:var(--cream);
}
.pillars-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border:1px solid var(--border);
}
.pillar-card{
  background:var(--paper);
  padding:38px 28px;
  position:relative;
  border-right:1px solid var(--border);
}
.pillar-card:last-child{border-right:none;}
.pillar-num{
  position:absolute;
  top:22px;right:24px;
  font-family:'Playfair Display',serif;
  font-size:.8rem;
  color:var(--rule);
  font-weight:700;
}
.pillar-icon{
  width:54px;height:54px;
  border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;
  margin-bottom:22px;
  color:var(--gold-deep);
}
.pillar-card h3{font-size:1.1rem;margin-bottom:12px;}
.pillar-card p{color:var(--text-muted);font-size:.9rem;}

/* ===== ROUTINE ===== */
.routine{
  padding:100px 0;
  background:var(--paper);
}
.routine-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.routine-step{
  text-align:left;
  padding:40px 36px;
  border-right:1px solid var(--border);
}
.routine-step:last-child{border-right:none;}
.routine-step .roman{
  font-family:'Playfair Display',serif;
  font-size:2.4rem;
  color:var(--gold-pale);
  display:block;
  margin-bottom:14px;
}
.routine-step .step-tag{
  display:block;
  font-family:'PT Sans',sans-serif;
  font-size:.74rem;
  font-weight:700;
  letter-spacing:1.8px;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:10px;
}
.routine-step h3{font-size:1.2rem;margin-bottom:12px;}
.routine-step p{color:var(--text-muted);font-size:.92rem;}

/* ===== STATS ===== */
.stats{
  padding:80px 0;
  background:var(--ink);
  color:var(--paper);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(255,255,255,.18);
  border-bottom:1px solid rgba(255,255,255,.18);
}
.stat-box{
  text-align:center;
  padding:34px 18px;
  border-right:1px solid rgba(255,255,255,.18);
}
.stat-box:last-child{border-right:none;}
.stat-box strong{
  display:block;
  font-family:'Playfair Display',serif;
  font-size:2.1rem;
  color:var(--gold-pale);
  margin-bottom:6px;
}
.stat-box span{
  font-family:'PT Sans',sans-serif;
  font-size:.78rem;
  letter-spacing:.4px;
  color:rgba(255,255,255,.65);
}
.stats-note{
  text-align:center;
  margin-top:28px;
  font-size:.82rem;
  font-style:italic;
  color:rgba(255,255,255,.5);
  max-width:640px;
  margin-left:auto;
  margin-right:auto;
}

/* ===== MAGAZINE ===== */
.magazine{
  padding:100px 0;
  background:var(--cream);
}
.magazine-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border:1px solid var(--border);
}
.article-card{
  background:var(--paper);
  display:flex;
  flex-direction:column;
  border-right:1px solid var(--border);
}
.article-card:last-child{border-right:none;}
.article-thumb{
  height:120px;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;
  color:var(--gold-deep);
  background:var(--cream);
  border-bottom:1px solid var(--border);
}
.article-body{
  padding:24px 24px 28px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.article-cat{
  font-family:'PT Sans',sans-serif;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:1.4px;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:10px;
}
.article-body h3{font-size:1.05rem;margin-bottom:10px;}
.article-body p{font-size:.87rem;color:var(--text-muted);flex:1;margin-bottom:18px;}
.article-link{
  font-family:'PT Sans',sans-serif;
  font-size:.84rem;
  font-weight:700;
  color:var(--ink);
  border-bottom:1px solid var(--ink);
  display:inline-flex;
  align-items:center;
  gap:8px;
  align-self:flex-start;
  padding-bottom:2px;
  transition:color .2s ease, border-color .2s ease;
}
.article-link:hover{color:var(--gold-deep);border-color:var(--gold-deep);}

/* ===== WHY ===== */
.why{
  padding:100px 0;
  background:var(--paper);
}
.why-grid{
  display:grid;
  grid-template-columns:.8fr 1.2fr;
  gap:60px;
  align-items:start;
}
.why-points{display:flex;flex-direction:column;}
.why-point{
  display:flex;
  gap:18px;
  align-items:flex-start;
  padding:20px 0;
  border-bottom:1px solid var(--border);
}
.why-point:first-child{border-top:1px solid var(--border);}
.why-point .check{
  font-family:'Playfair Display',serif;
  font-size:1.2rem;
  color:var(--gold-deep);
  min-width:24px;
}
.why-point h4{font-size:1.02rem;margin-bottom:4px;}
.why-point p{font-size:.87rem;color:var(--text-muted);}

.why-visual{
  border:1px solid var(--border);
  background:var(--ink);
  padding:46px 36px;
  color:var(--paper);
  text-align:center;
}
.why-visual img{margin:0 auto 22px;width:64px;height:64px;}
.why-visual h3{color:var(--paper);font-size:1.3rem;margin-bottom:14px;}
.why-visual p{color:rgba(255,255,255,.72);font-size:.93rem;}

/* ===== CTA ===== */
.cta{
  padding:90px 0;
  background:var(--ink);
  text-align:center;
  color:var(--paper);
  border-top:3px solid var(--gold);
  border-bottom:3px solid var(--gold);
}
.cta h2{color:var(--paper);font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:18px;}
.cta p{
  color:rgba(255,255,255,.8);
  max-width:600px;
  margin:0 auto 32px;
  font-size:1.04rem;
  font-style:italic;
}

/* ===== CONTACT ===== */
.contact{
  padding:100px 0;
  background:var(--cream);
}
.contact-grid{
  display:grid;
  grid-template-columns:1.3fr .7fr;
  gap:0;
  border:1px solid var(--border);
}
.contact-form{
  background:var(--paper);
  padding:44px;
  border-right:1px solid var(--border);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.form-group{margin-bottom:20px;display:flex;flex-direction:column;}
.form-group label{
  font-family:'PT Sans',sans-serif;
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.3px;
  margin-bottom:8px;
  color:var(--ink);
}
.form-group input,
.form-group textarea{
  border:none;
  border-bottom:1.5px solid var(--border);
  border-radius:0;
  padding:12px 4px;
  font-family:'Lora',serif;
  font-size:.96rem;
  background:transparent;
  transition:border-color .2s ease;
}
.form-group input:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--gold);
}
.field-error{color:#9b3b2b;font-family:'PT Sans',sans-serif;font-size:.78rem;margin-top:6px;}
.form-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-bottom:26px;
  font-family:'PT Sans',sans-serif;
  font-size:.84rem;
  color:var(--text-muted);
}
.form-check input{margin-top:3px;accent-color:var(--gold);}

.alert-success{
  display:flex;
  align-items:flex-start;
  gap:16px;
  background:var(--cream);
  border-left:3px solid var(--sage);
  color:var(--sage);
  padding:20px 22px;
  margin-bottom:28px;
  font-family:'PT Sans',sans-serif;
  font-weight:700;
  font-size:.9rem;
}
.alert-success i{font-size:1.2rem;margin-top:2px;}

.contact-card{
  background:var(--ink);
  padding:38px 32px;
  color:var(--paper);
}
.contact-card h3{color:var(--paper);font-size:1.2rem;margin-bottom:24px;}
.contact-info-item{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-bottom:22px;
}
.contact-info-item i{
  width:30px;
  text-align:center;
  color:var(--gold-pale);
  padding-top:3px;
}
.contact-info-item strong{display:block;font-family:'PT Sans',sans-serif;font-size:.78rem;letter-spacing:.4px;color:rgba(255,255,255,.55);margin-bottom:3px;}
.contact-info-item span{font-size:.96rem;color:var(--paper);font-weight:500;word-break:break-word;}
.contact-card hr{border:none;border-top:1px solid rgba(255,255,255,.16);margin:24px 0;}
.contact-card .small-note{font-family:'PT Sans',sans-serif;font-size:.78rem;color:rgba(255,255,255,.5);}

/* ===== FAQ ===== */
.faq{
  padding:100px 0;
  background:var(--paper);
}
.faq-list{max-width:780px;margin:0 auto;border-top:1px solid var(--border);}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-question{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 4px;
  cursor:pointer;
  font-family:'Playfair Display',serif;
  font-weight:700;
  color:var(--ink);
  font-size:1.04rem;
}
.faq-question .toggle{
  font-family:'PT Sans',sans-serif;
  font-size:1.1rem;
  color:var(--gold-deep);
  transition:transform .25s ease;
}
.faq-item.active .faq-question .toggle{transform:rotate(45deg);}
.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease;
}
.faq-answer-inner{
  padding:0 4px 22px;
  color:var(--text-muted);
  font-size:.94rem;
}

/* ===== FOOTER ===== */
footer{
  background:var(--ink-dark);
  color:rgba(255,255,255,.68);
  padding:64px 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr .8fr .8fr;
  gap:44px;
  padding-bottom:46px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-logo{
  font-family:'Playfair Display',serif;
  font-size:1.3rem;
  color:var(--paper);
  margin-bottom:16px;
  display:flex;
  align-items:center;
  gap:10px;
}
.footer-grid p{font-size:.88rem;color:rgba(255,255,255,.5);max-width:340px;}
.footer-col h4{
  font-family:'PT Sans',sans-serif;
  color:var(--paper);
  font-size:.84rem;
  letter-spacing:1.2px;
  text-transform:uppercase;
  margin-bottom:18px;
}
.footer-col ul{display:flex;flex-direction:column;gap:12px;}
.footer-col a{font-family:'PT Sans',sans-serif;font-size:.88rem;color:rgba(255,255,255,.58);transition:color .2s ease;}
.footer-col a:hover{color:var(--gold-pale);}
.footer-social{display:flex;gap:10px;margin-top:20px;}
.footer-social a{
  width:34px;height:34px;
  border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease, border-color .2s ease;
}
.footer-social a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink-dark);}
.footer-bottom{
  padding:24px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  font-family:'PT Sans',sans-serif;
  font-size:.78rem;
}
.footer-company{
  font-family:'PT Sans',sans-serif;
  font-size:.78rem;
  color:rgba(255,255,255,.55);
  max-width:900px;
  padding-top:30px;
  line-height:1.8;
}
.footer-company strong{color:rgba(255,255,255,.85);}
.footer-disclaimer{
  font-family:'PT Sans',sans-serif;
  font-size:.76rem;
  font-style:italic;
  color:rgba(255,255,255,.4);
  max-width:900px;
  padding-top:14px;
  line-height:1.7;
}

/* ===== LEGAL PAGES ===== */
.legal-page{
  padding:170px 0 110px;
  background:var(--paper);
}
.legal-page .container{max-width:820px;}
.legal-page .eyebrow{display:flex;}
.legal-page h1{font-size:clamp(1.8rem,3.4vw,2.5rem);margin-bottom:8px;}
.legal-page .updated{
  font-family:'PT Sans',sans-serif;
  font-size:.8rem;
  color:var(--text-muted);
  margin-bottom:36px;
  display:block;
}
.legal-page .intro{font-size:1.02rem;color:var(--text-muted);font-style:italic;margin-bottom:30px;}
.legal-page h2{
  font-size:1.28rem;
  margin-top:42px;
  margin-bottom:16px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.legal-page h3{font-size:1.04rem;margin-top:26px;margin-bottom:10px;}
.legal-page p{color:var(--text-muted);margin-bottom:14px;font-size:.98rem;}
.legal-page ul{margin:0 0 18px 0;}
.legal-page ul li{
  position:relative;
  padding-left:22px;
  margin-bottom:10px;
  color:var(--text-muted);
  font-size:.96rem;
}
.legal-page ul li::before{content:"—";position:absolute;left:0;color:var(--gold-deep);}
.legal-page a.inline-link{color:var(--gold-deep);border-bottom:1px solid var(--gold-deep);}

.company-box{
  border:1px solid var(--border);
  background:var(--cream);
  padding:28px 30px;
  margin:32px 0;
}
.company-box .company-name{
  display:block;
  font-family:'Playfair Display',serif;
  color:var(--ink);
  font-size:1.1rem;
  margin-bottom:16px;
}
.company-box dl{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:9px 16px;
  font-family:'PT Sans',sans-serif;
  font-size:.88rem;
}
.company-box dt{color:var(--text-muted);}
.company-box dd{color:var(--text);font-weight:700;}

@media (max-width:680px){
  .legal-page{padding:130px 0 80px;}
  .company-box dl{grid-template-columns:1fr;gap:2px 0;}
  .company-box dt{margin-top:10px;}
}

/* ===== ANIMATIONS ===== */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .6s ease, transform .6s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;}
  .fact-box{max-width:560px;}
  .about-grid{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .why-visual{order:-1;max-width:480px;}
  .pillars-grid{grid-template-columns:repeat(2,1fr);}
  .pillar-card:nth-child(2){border-right:none;}
  .magazine-grid{grid-template-columns:repeat(2,1fr);}
  .article-card:nth-child(2){border-right:none;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .stat-box:nth-child(2){border-right:none;}
  .stat-box:nth-child(3){border-top:1px solid rgba(255,255,255,.18);}
  .stat-box:nth-child(4){border-top:1px solid rgba(255,255,255,.18);}
  .contact-grid{grid-template-columns:1fr;}
  .contact-form{border-right:none;border-bottom:1px solid var(--border);}
  .routine-grid{grid-template-columns:1fr;}
  .routine-step{border-right:none;border-bottom:1px solid var(--border);}
  .routine-step:last-child{border-bottom:none;}
}

@media (max-width:860px){
  .masthead-top-row span:last-child{display:none;}
  .nav-links{
    position:fixed;
    top:0;right:0;
    height:100vh;
    width:78%;
    max-width:320px;
    background:var(--ink);
    flex-direction:column;
    align-items:flex-start;
    padding:110px 32px 40px;
    gap:26px;
    transform:translateX(100%);
    transition:transform .35s ease;
    box-shadow:-10px 0 40px rgba(0,0,0,.3);
  }
  .nav-links.active{transform:translateX(0);}
  .nav-links a{color:rgba(255,255,255,.85);font-size:1.05rem;}
  .nav-links a::after{background:var(--gold-pale);}
  .nav-actions .btn-primary{display:none;}
  .hamburger{display:flex;}
  .nav-cta-mobile{display:block;margin-top:10px;}
}

@media (max-width:680px){
  .hero{padding:130px 0 70px;}
  .hero-actions{flex-direction:column;align-items:flex-start;}
  .hero-actions .btn{width:100%;justify-content:center;}
  .hero-mini-stats{flex-direction:column;gap:14px;}
  .hero-mini-stats div{border-right:none;padding:0;}
  .pillars-grid{grid-template-columns:1fr;}
  .pillar-card{border-right:none;border-bottom:1px solid var(--border);}
  .pillar-card:last-child{border-bottom:none;}
  .magazine-grid{grid-template-columns:1fr;}
  .article-card{border-right:none;border-bottom:1px solid var(--border);}
  .article-card:last-child{border-bottom:none;}
  .stats-grid{grid-template-columns:1fr;}
  .stat-box{border-right:none !important;border-top:1px solid rgba(255,255,255,.18) !important;}
  .stat-box:first-child{border-top:none !important;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .section-head{margin-bottom:40px;}
}
