/* ═══════════════════════════════════════════════════
   SWANI ENTERPRISES THEME CSS v2.2.0
   Navy #1E3A8A · Gold #C9A84C · Ivory #FDFAF4
   Playfair Display + Jost
═══════════════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
:root{
  --navy:#1E3A8A;--navy2:#2548B0;--navy3:#163070;
  --gold:#C9A84C;--gold2:#E8C96A;
  --dark:#0F1A2E;--bg:#FDFAF4;--bg2:#F5EDD8;--bg3:#EDE0C4;
  --white:#fff;--line:rgba(30,58,138,.12);--mu:rgba(15,26,46,.52);
  --nav-h:72px;--inner:1240px;--r:8px;
}
body{font-family:'Jost',sans-serif;font-weight:300;background:var(--bg);color:var(--dark);overflow-x:hidden;line-height:1.65}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit;transition:color .25s}
ul{list-style:none}
address{font-style:normal}

/* LAYOUT */
.site-inner{max-width:var(--inner);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.section{padding:clamp(64px,9vw,110px) 0}
.section-bg2{background:var(--bg2)}
.section-head{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.section-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.55rem;letter-spacing:.42em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:10px}
.section-eyebrow::before{content:'';width:20px;height:2px;background:var(--navy)}
.section-title{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(1.8rem,3.8vw,3rem);line-height:1.12;color:var(--dark)}
.section-title em{font-style:italic;color:var(--navy)}
.section-title.lt{color:#fff}.section-title.lt em{color:var(--gold)}
.section-more{text-align:center;margin-top:clamp(28px,4vw,44px)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Jost',sans-serif;font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:13px 28px;transition:all .28s;cursor:pointer;border:none;text-decoration:none;line-height:1}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:var(--navy2);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid rgba(30,58,138,.3)}.btn-outline:hover{background:var(--navy);color:#fff}
.btn-wa{background:#25D366;color:#fff}.btn-wa:hover{background:#1DB854;color:#fff}

/* REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}

/* ═══════════════════════════════════════
   NAV — all states consolidated
═══════════════════════════════════════ */
#swNav{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  height:var(--nav-h);
  background:transparent;
  transition:background .4s,box-shadow .4s;
}
/* Navy top accent line always */
#swNav::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--navy),var(--navy2),var(--navy));
  z-index:10;pointer-events:none;
}
/* SCROLLED STATE — white bg (inner pages always get this via JS) */
#swNav.scrolled{
  background:rgba(253,250,244,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 2px 24px rgba(30,58,138,.1);
}
#swNav.scrolled::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:1px;background:var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;padding:0 clamp(18px,4vw,56px);gap:20px;padding-top:3px;
}

/* ── LOGO ── */
.nav-logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.nav-logo-img{height:44px;width:auto;object-fit:contain}
/* Transparent nav → yellow+white logo */
#logoDark{display:block}
#logoLight{display:none}
/* Scrolled/white nav → blue+black logo */
#swNav.scrolled #logoDark{display:none}
#swNav.scrolled #logoLight{display:block}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:1.2rem;color:#fff;font-weight:600}
#swNav.scrolled .nav-logo-text{color:var(--dark)}

/* ── NAV LINKS ── */
.nav-menu{display:flex;align-items:center}
.nav-links{display:flex;gap:clamp(16px,2.5vw,34px);align-items:center}
/* Transparent (over hero) → white text */
.nav-links li a{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.75);transition:color .25s}
.nav-links li a:hover{color:#fff}
/* Scrolled (white bg / inner pages) → dark text */
#swNav.scrolled .nav-links li a{color:rgba(15,26,46,.65)}
#swNav.scrolled .nav-links li a:hover{color:var(--navy)}

/* ── NAV RIGHT BUTTONS ── */
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* WhatsApp button */
.nav-wa{
  display:flex;align-items:center;gap:7px;
  border-radius:100px;padding:8px 16px;
  font-size:.6rem;font-weight:500;letter-spacing:.06em;
  transition:all .25s;white-space:nowrap;text-decoration:none;
}
/* Transparent nav → frosted white */
#swNav:not(.scrolled) .nav-wa{
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  color:#fff;border:1px solid rgba(255,255,255,.3);
}
#swNav:not(.scrolled) .nav-wa:hover{background:rgba(255,255,255,.3);color:#fff}
#swNav:not(.scrolled) .nav-wa svg path{fill:white}
/* Scrolled/white nav → navy solid */
#swNav.scrolled .nav-wa{background:var(--navy);color:#fff;border:none}
#swNav.scrolled .nav-wa:hover{background:var(--navy2)}

/* Get Quote CTA */
.nav-cta{
  font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  padding:10px 22px;transition:all .25s;white-space:nowrap;text-decoration:none;
}
/* Transparent nav → gold */
#swNav:not(.scrolled) .nav-cta{background:var(--gold);color:var(--dark)}
#swNav:not(.scrolled) .nav-cta:hover{background:var(--gold2);color:var(--dark)}
/* Scrolled/white nav → navy */
#swNav.scrolled .nav-cta{background:var(--navy);color:#fff}
#swNav.scrolled .nav-cta:hover{background:var(--navy2);color:#fff}

/* ── BURGER ── */
.burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:none;padding:6px;cursor:pointer;width:36px;height:36px;
}
/* Transparent nav → white lines */
.burger span{display:block;width:22px;height:2px;border-radius:2px;background:rgba(255,255,255,.9);transition:all .25s}
/* Scrolled/white nav → dark lines */
#swNav.scrolled .burger span{background:var(--dark)}
/* Open state */
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0;width:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav */
.mobile-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--dark);z-index:9998;overflow-y:auto}
.mobile-nav.open{display:flex;flex-direction:column}
.mobile-nav-inner{display:flex;flex-direction:column;padding:28px 28px 48px}
.mobile-nav-inner a{font-family:'Playfair Display',serif;font-size:1.6rem;color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.07);padding:16px 0;transition:color .25s}
.mobile-nav-inner a:hover{color:var(--gold)}
.mobile-nav-inner .mob-wa{display:flex;align-items:center;gap:10px;background:var(--navy);color:#fff;padding:16px 24px;margin-top:24px;border-radius:var(--r);font-family:'Jost',sans-serif;font-size:.85rem;font-weight:600;justify-content:center}

/* ═══════════════════════
   HERO — redesigned
═══════════════════════ */
.hero{
  position:relative;height:100vh;min-height:600px;
  overflow:hidden;background:var(--dark);
  display:flex;align-items:flex-end;
}
/* Scenes */
.hero-scenes{position:absolute;inset:0;z-index:0}
.scene{position:absolute;inset:0;opacity:0;transition:opacity 1.8s ease}
.scene.active{opacity:1}
.scene img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  /* Lighter — images visible */
  filter:brightness(.55) saturate(1.05);
  transform:scale(1);
}
/* Ken Burns — use scale only, no translate to avoid edge cuts */
.s1.active img{animation:kb1 12s ease-out forwards}
.s2.active img{animation:kb2 12s ease-out forwards}
.s3.active img{animation:kb3 12s ease-out forwards}
.s4.active img{animation:kb4 12s ease-out forwards}
.s5.active img{animation:kb5 12s ease-out forwards}
.s6.active img{animation:kb6 12s ease-out forwards}
@keyframes kb1{from{transform:scale(1) translateX(0)}to{transform:scale(1.12) translateX(-2%)}}
@keyframes kb2{from{transform:scale(1.1) translateX(2%)}to{transform:scale(1) translateX(0)}}
@keyframes kb3{from{transform:scale(1) translateY(0)}to{transform:scale(1.1) translateY(-2%)}}
@keyframes kb4{from{transform:scale(1.08) translateX(-1%)}to{transform:scale(1.18) translateX(1%)}}
@keyframes kb5{from{transform:scale(1) translateX(1%)}to{transform:scale(1.12) translateX(-1%)}}
@keyframes kb6{from{transform:scale(1.1) translateY(2%)}to{transform:scale(1) translateY(0)}}

/* Overlays — layered for depth */
.hero-overlay-dark{
  position:absolute;inset:0;z-index:1;
  /* Dark vignette around edges, lighter in center so images show */
  background:radial-gradient(ellipse 80% 80% at 60% 50%, rgba(15,26,46,.25) 0%, rgba(15,26,46,.72) 100%);
  pointer-events:none;
}
.hero-overlay-bottom{
  position:absolute;bottom:0;left:0;right:0;height:80%;z-index:2;
  background:linear-gradient(to top,
    rgba(15,26,46,.95) 0%,
    rgba(15,26,46,.65) 35%,
    rgba(15,26,46,.15) 65%,
    transparent 100%
  );
  pointer-events:none;
}
.hero-overlay-left{
  position:absolute;top:0;left:0;bottom:0;width:70%;z-index:2;
  background:linear-gradient(to right,rgba(15,26,46,.55) 0%,transparent 100%);
  pointer-events:none;
}

/* Progress bar — bottom of nav, subtle */
.hero-pb{
  position:absolute;top:3px;left:0;right:0;z-index:20;
  display:flex;gap:3px;height:2px;
}
.pb-s{flex:1;background:rgba(255,255,255,.2);border-radius:2px}
.pb-s.done{background:rgba(255,255,255,.7)}
.pb-s.active{background:#fff;position:relative;overflow:hidden}
.pb-s.active::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.5);
  animation:pbf 7s linear forwards;
  transform-origin:left;transform:scaleX(0);
}
@keyframes pbf{to{transform:scaleX(1)}}

/* HERO CONTENT — bottom-left, full width */
.hero-content{
  position:relative;z-index:10;
  width:100%;
  padding:0 clamp(22px,5vw,72px) clamp(44px,6vw,80px);
}
.hero-content-inner{
  max-width:680px;
}
.hero-eyebrow{
  font-size:.55rem;letter-spacing:.38em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:clamp(12px,2vw,18px);
  display:flex;align-items:center;gap:10px;
}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:rgba(255,255,255,.4)}
/* Product name — big italic gold heading, updates with each slide */
.hero-product-name{
  font-family:'Playfair Display',serif;
  font-weight:400;font-style:italic;
  font-size:clamp(2.2rem,6vw,5rem);
  line-height:1.05;
  color:var(--gold);
  margin-bottom:clamp(6px,1.2vw,12px);
  transition:opacity .35s ease;
  text-shadow:0 2px 24px rgba(0,0,0,.5);
}
.hero-h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(1rem,2.5vw,1.6rem);line-height:1.25;
  color:rgba(255,255,255,.72);
  margin-bottom:clamp(8px,1.5vw,14px);
  letter-spacing:.02em;
}
.hero-h2 em{font-style:italic;color:#fff}
.hero-sub{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:clamp(.82rem,1.4vw,.98rem);
  color:rgba(255,255,255,.45);line-height:1.75;
  margin-bottom:clamp(14px,2.5vw,24px);max-width:460px;
}

.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:clamp(20px,3.5vw,36px)}

/* Slide controls — bottom right, clean */
.hero-ctrl{
  position:absolute;bottom:clamp(36px,5vw,56px);right:clamp(22px,4vw,48px);
  z-index:20;display:flex;gap:8px;
}
.hero-ctrl-btn{
  width:40px;height:40px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(15,26,46,.6);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:rgba(255,255,255,.7);font-size:12px;
  transition:all .25s;border-radius:4px;
}
.hero-ctrl-btn:hover{border-color:#fff;color:#fff;background:rgba(30,58,138,.6)}

/* Stats */
.hero-stats{display:flex;gap:1px}
.hstat{
  background:rgba(15,26,46,.6);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);
  padding:12px 18px;text-align:center;min-width:80px;
}
.hstat-n{display:block;font-family:'Playfair Display',serif;font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--gold);line-height:1}
.hstat-l{display:block;font-size:.48rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:3px}
.hero-no-img{position:absolute;inset:0;background:linear-gradient(135deg,var(--dark) 0%,var(--navy3) 100%)}

/* MARQUEE */
.marquee-strip{background:var(--dark);overflow:hidden;border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);padding:clamp(10px,1.5vw,13px) 0}
.marquee-track{display:flex;animation:mqa 32s linear infinite;width:max-content}
.mq-item{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(.78rem,1.3vw,.92rem);color:rgba(201,168,76,.62);white-space:nowrap;padding:0 clamp(14px,2vw,24px);display:flex;align-items:center}
.mq-dot{width:4px;height:4px;background:var(--gold);border-radius:50%;opacity:.45;margin-left:clamp(14px,2vw,24px);flex-shrink:0}
@keyframes mqa{to{transform:translateX(-50%)}}

/* ═══════════════════════
   VIDEO SECTION
   Full-width, no black bars, padded like a card with border-radius
═══════════════════════ */
.video-wrap{
  padding:clamp(32px,5vw,56px) clamp(20px,5vw,56px);
  background:var(--dark);
}
.video-section{
  position:relative;
  width:100%;
  padding-top:56.25%;   /* 16:9 */
  background:#000;
  overflow:hidden;
  border-radius:12px;   /* rounded corners */
  box-shadow:0 24px 64px rgba(0,0,0,.5);
}
.video-section iframe,
.video-section video{
  position:absolute;
  /* Overscan to eliminate black letterbox bars */
  top:50%;left:50%;
  min-width:100%;min-height:100%;
  width:177.78%;        /* 16/9 * 100 */
  height:100%;
  transform:translate(-50%,-50%);
  border:none;
  object-fit:cover;
  pointer-events:none;  /* hide YouTube UI interactions */
}
/* Transparent overlay blocks any residual YouTube click targets */
.video-section::after{
  content:'';position:absolute;inset:0;z-index:2;
  border-radius:inherit;
}

/* PHOTO MOSAIC (fallback when no video) */
.photo-mosaic{display:grid;grid-template-columns:repeat(5,1fr);height:clamp(220px,30vw,400px)}
.mosaic-item{position:relative;overflow:hidden}
.mosaic-item img{width:100%;height:100%;object-fit:cover;filter:brightness(.72);transition:filter .4s,transform .55s}
.mosaic-item:hover img{filter:brightness(.9);transform:scale(1.06)}
.mosaic-cap{position:absolute;bottom:0;left:0;right:0;padding:10px 12px;background:linear-gradient(to top,rgba(15,26,46,.85),transparent);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8);opacity:0;transition:opacity .3s}
.mosaic-item:hover .mosaic-cap{opacity:1}

/* FOUNDER */
.founder-section{background:var(--white)}
.founder-grid{display:grid;grid-template-columns:1fr 1.6fr;min-height:clamp(320px,50vw,560px)}
.founder-left{background:var(--dark);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.founder-left::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--navy2))}
.founder-mono{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(6rem,14vw,14rem);color:rgba(255,255,255,.04);line-height:1;user-select:none}
.founder-right{padding:clamp(48px,7vw,80px);display:flex;flex-direction:column;justify-content:center}
.founder-rule{width:40px;height:2px;background:var(--navy);margin:20px 0}
.founder-quote{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1.05rem,2vw,1.35rem);color:rgba(15,26,46,.78);line-height:1.85;border-left:3px solid var(--navy);padding-left:22px;margin-bottom:24px}
.founder-sig{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1.6rem,3vw,2.3rem);color:var(--navy)}
.founder-title{font-size:.52rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mu);margin-top:5px}

/* CTA SECTION */
.cta-section{background:var(--bg2);padding:clamp(60px,8vw,110px) 0;border-top:1px solid var(--line)}
.cta-inner{text-align:center;max-width:700px;margin:0 auto}
.cta-inner h2{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:12px}
.cta-inner h2 em{font-style:italic;color:var(--navy)}
.cta-inner p{font-size:.88rem;color:var(--mu);margin-bottom:28px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* PAGE / INNER CONTENT */
.main-content{min-height:60vh;padding-top:var(--nav-h)}
.home .main-content,.hero-page .main-content{padding-top:0}

/* ── PAGE HEADER (About Us, Contact, etc.) ── */
.page-header{
  position:relative;
  background:var(--dark);
  border-bottom:3px solid var(--navy);
  overflow:hidden;
  min-height:clamp(220px,32vw,380px);
  display:flex;align-items:flex-end;
}
/* Header image (set via page meta or plugin setting) */
.page-header-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transition:transform 8s ease;
}
.page-header:hover .page-header-bg{transform:scale(1.04)}
/* Dark overlay — gradient from bottom so title always readable */
.page-header-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to top,
    rgba(15,26,46,.92) 0%,
    rgba(15,26,46,.55) 50%,
    rgba(15,26,46,.38) 100%
  );
  z-index:1;
}
/* Navy top accent line on page headers */
.page-header::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--navy),var(--navy2),var(--navy));
  z-index:3;pointer-events:none;
}
.page-header-content{
  position:relative;z-index:2;
  width:100%;
  padding:clamp(28px,5vw,56px) clamp(20px,5vw,56px);
  padding-top:calc(var(--nav-h) + clamp(28px,5vw,56px));
  max-width:var(--inner);
  margin:0 auto;
}
.page-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.52rem;letter-spacing:.38em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:10px;
}
.page-eyebrow::before{content:'';width:16px;height:1px;background:rgba(255,255,255,.4)}
.page-title{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(2rem,5vw,3.8rem);
  color:#fff;line-height:1.05;
  text-shadow:0 2px 20px rgba(0,0,0,.3);
}
.page-subtitle{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:clamp(.88rem,1.6vw,1.1rem);
  color:rgba(255,255,255,.5);margin-top:8px;
}

/* Page body padding — fix mobile side cut */
.page-body{padding:clamp(36px,6vw,80px) 0}
.page-body .site-inner{
  padding-left:clamp(16px,5vw,56px);
  padding-right:clamp(16px,5vw,56px);
}
.entry-content{font-size:.95rem;color:var(--mu);line-height:1.85;max-width:820px}
.entry-content h2,.entry-content h3{font-family:'Playfair Display',serif;color:var(--dark);margin:28px 0 12px}
.entry-content p{margin-bottom:14px}
.entry-content a{color:var(--navy);border-bottom:1px solid rgba(30,58,138,.3)}
.entry-content a:hover{color:var(--navy2)}
.entry-content img{border-radius:var(--r);margin:18px 0;max-width:100%}
.entry-content blockquote{border-left:3px solid var(--navy);padding-left:20px;font-style:italic;color:var(--mu);margin:20px 0}

/* SINGLE PRODUCT */
.single-product{padding-top:var(--nav-h)}
.breadcrumb{font-size:.7rem;color:var(--mu);padding:clamp(16px,2.5vw,24px) 0;display:flex;gap:8px;align-items:center;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:clamp(24px,4vw,40px)}
.breadcrumb a{color:var(--navy)}.breadcrumb a:hover{color:var(--navy2)}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);margin-bottom:clamp(40px,6vw,72px)}
.product-main-img{border-radius:var(--r);overflow:hidden;aspect-ratio:1/1}
.product-main-img img{width:100%;height:100%;object-fit:cover}
.product-img-placeholder{width:100%;aspect-ratio:1/1;background:var(--bg2);border-radius:var(--r)}
.product-cat{display:block;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:10px}
.product-title{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--dark);margin-bottom:14px;line-height:1.15}
.product-excerpt{font-size:.9rem;color:var(--mu);line-height:1.75;margin-bottom:18px}
.product-price{font-size:.85rem;color:var(--navy);font-weight:600;margin-bottom:18px;padding:10px 14px;background:rgba(30,58,138,.06);border-radius:6px;display:inline-block}
.product-specs{background:var(--bg2);border-radius:var(--r);padding:18px 22px;margin-bottom:22px}
.spec-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(30,58,138,.08);font-size:.82rem}
.spec-row:last-child{border-bottom:none}
.spec-k{color:var(--mu)}.spec-v{color:var(--dark);font-weight:600;text-align:right}
.related-products{margin-top:clamp(48px,7vw,80px);padding-top:clamp(32px,5vw,56px);border-top:1px solid var(--line)}
.related-products h3{font-family:'Playfair Display',serif;font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--dark);margin-bottom:24px}

/* ARCHIVE */
.archive-header{
  position:relative;background:var(--dark);
  padding:clamp(80px,10vw,120px) clamp(16px,5vw,56px) clamp(32px,5vw,56px);
  border-bottom:3px solid var(--navy);overflow:hidden;
}
.archive-header::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--navy2),var(--navy));z-index:1}
.archive-header h1{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(2rem,5vw,3.5rem);color:#fff;position:relative;z-index:1}
.archive-header p{font-family:'Playfair Display',serif;font-style:italic;color:rgba(255,255,255,.52);margin-top:8px;font-size:clamp(.9rem,1.6vw,1.1rem);position:relative;z-index:1}
.archive-body{padding:clamp(36px,5vw,64px) clamp(16px,5vw,56px)}
.archive-pagination{margin-top:40px;display:flex;justify-content:center;gap:6px}
.archive-pagination .page-numbers{padding:8px 14px;border:1px solid var(--line);font-size:.75rem;color:var(--dark);transition:all .25s;border-radius:4px}
.archive-pagination .page-numbers:hover,.archive-pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2.5vw,22px)}
.blog-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:all .3s}
.blog-card:hover{box-shadow:0 8px 32px rgba(30,58,138,.1);transform:translateY(-3px)}
.blog-card-img{display:block;height:clamp(160px,22vw,240px);overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-body{padding:18px 20px}
.blog-date{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);font-weight:600;display:block;margin-bottom:8px}
.blog-card-body h2{font-family:'Playfair Display',serif;font-size:clamp(1rem,1.8vw,1.2rem);color:var(--dark);margin-bottom:8px;line-height:1.25}
.blog-card-body h2 a{color:inherit}.blog-card-body h2 a:hover{color:var(--navy)}
.blog-card-body p{font-size:.8rem;color:var(--mu);line-height:1.7;margin-bottom:12px}
.post-header{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.post-header h1{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.5rem);margin-top:8px;color:var(--dark)}
.post-thumb{border-radius:var(--r);overflow:hidden;margin-bottom:28px;max-height:500px}
.post-thumb img{width:100%;height:100%;object-fit:cover}
.single-post{padding:clamp(36px,5vw,64px) 0}

/* FOOTER */
.footer-nl-strip{background:var(--navy)}
.footer-nl-strip .site-inner{padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(40px,6vw,72px)}
.site-footer{background:var(--dark);border-top:3px solid var(--navy)}
.footer-grid{max-width:var(--inner);margin:0 auto;padding:clamp(48px,7vw,80px) clamp(20px,5vw,56px);display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px,4vw,56px)}
.footer-brand{display:flex;flex-direction:column;gap:0}
.footer-brand-logo{margin-bottom:14px}
.footer-brand-text{display:flex;flex-direction:column;gap:0}
.footer-logo{height:44px;width:auto;display:block;margin-bottom:0;object-fit:contain}
.footer-site-name{font-family:'Playfair Display',serif;font-size:1.4rem;color:#fff;margin-bottom:14px}
.footer-tagline{font-family:'Playfair Display',serif;font-style:italic;font-size:.88rem;color:rgba(201,168,76,.7);margin-bottom:10px}
.footer-desc{font-size:.74rem;color:rgba(255,255,255,.65);line-height:1.78;max-width:270px;margin-bottom:16px}
.footer-social{display:flex;gap:8px}
.social-link{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.52);transition:all .25s}
.social-link:hover{border-color:var(--navy2);background:var(--navy);color:#fff}
.footer-col h5{font-size:.52rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:18px}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{font-size:.76rem;color:rgba(255,255,255,.72);transition:color .25s}
.footer-col ul li a:hover{color:var(--gold)}
.footer-hours{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.07)}
.footer-hours strong{display:block;font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:5px;font-weight:600}
.footer-hours span{display:block;font-size:.76rem;color:rgba(255,255,255,.65)}
.footer-hours small{display:block;font-size:.68rem;color:rgba(255,255,255,.35);margin-top:3px}
.footer-address{font-size:.72rem;color:rgba(255,255,255,.42);line-height:1.7;margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.07)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07)}
.footer-bottom-inner{padding:18px clamp(20px,5vw,56px);max-width:var(--inner);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px}
.footer-copy{font-size:.6rem;color:rgba(255,255,255,.4);letter-spacing:.06em}
.footer-legal{display:flex;gap:16px}
.footer-legal a{font-size:.6rem;color:rgba(255,255,255,.4);transition:color .25s}
.footer-legal a:hover{color:var(--gold)}
.footer-credit{font-size:.6rem;color:rgba(255,255,255,.4)}
.footer-credit a{color:var(--gold);transition:color .25s}
.footer-credit a:hover{color:var(--gold2)}

/* WA FLOAT */
.swani-wa-float{position:fixed;bottom:28px;right:28px;z-index:9999;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 28px rgba(37,211,102,.38);transition:transform .25s;text-decoration:none}
.swani-wa-float:hover{transform:scale(1.1)}
.swani-wa-float::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:2px solid rgba(37,211,102,.28);animation:sw-waping 2s ease-out infinite;pointer-events:none}
@keyframes sw-waping{to{transform:scale(1.6);opacity:0}}

/* RESPONSIVE */
@media(max-width:1024px){
  .founder-grid{grid-template-columns:1fr 1.3fr}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .photo-mosaic{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .nav-menu,.nav-right{display:none}
  .burger{display:flex}
  .hero-stats{display:none}
  .hero-h2{font-size:clamp(1.3rem,5vw,2rem)}

  .founder-grid{grid-template-columns:1fr}.founder-left{min-height:160px}
  .product-layout{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .photo-mosaic{grid-template-columns:repeat(2,1fr)}
  .video-wrap{padding:clamp(16px,3vw,28px) clamp(12px,3vw,28px)}
  /* FOOTER MOBILE — brand row + 2 cols */
  .footer-grid{
    grid-template-columns:1fr 1fr;
    gap:24px 18px;
    padding:32px clamp(16px,5vw,28px);
  }
  .footer-brand{
    grid-column:1/-1;
    display:grid;
    grid-template-columns:60px 1fr;
    gap:14px;
    align-items:start;
    padding-bottom:20px;
    margin-bottom:4px;
    border-bottom:1px solid rgba(255,255,255,.1);
  }
  .footer-brand-logo{display:flex;align-items:flex-start}
  .footer-logo{height:52px;width:auto;margin-bottom:0}
  .footer-tagline{font-size:.92rem;margin-bottom:6px}
  .footer-desc{font-size:.78rem;line-height:1.68;margin-bottom:10px}
  .footer-social{margin-top:8px}
  .social-link{width:30px;height:30px}
  .footer-col h5{font-size:.58rem;letter-spacing:.2em;margin-bottom:12px}
  .footer-col ul li{margin-bottom:7px}
  .footer-col ul li a{font-size:.78rem}
  .footer-hours{margin-top:12px}
  .footer-hours strong{font-size:.54rem}
  .footer-hours span{font-size:.78rem}
  .footer-hours small{font-size:.65rem}
  .footer-address{font-size:.72rem;margin-top:12px}
  .footer-bottom-inner{
    flex-direction:column;text-align:center;gap:6px;
    padding:14px clamp(16px,5vw,28px);
  }
  .footer-copy{font-size:.65rem}
  .footer-credit{font-size:.65rem}
  .footer-legal{justify-content:center}
}
@media(max-width:480px){
  .hero-btns{flex-direction:column;align-items:flex-start;gap:10px}
  .hero-ctrl{display:none}
  .cta-btns{flex-direction:column;align-items:center}
  .photo-mosaic{grid-template-columns:1fr 1fr}
  .video-wrap{padding:10px}
  .footer-grid{
    grid-template-columns:1fr 1fr;
    padding:28px 16px;
    gap:20px 14px;
  }
  .footer-brand{
    grid-template-columns:48px 1fr;
    gap:12px;
  }
  .footer-logo{height:44px}
}

/* Founder photo */
.founder-img-wrap{
  width:clamp(200px,70%,340px);
  aspect-ratio:1/1;
  border-radius:50%;
  overflow:hidden;
  border:4px solid rgba(201,168,76,.35);
  box-shadow:0 8px 48px rgba(0,0,0,.4),0 0 0 8px rgba(201,168,76,.1);
  position:relative;z-index:1;
}
.founder-photo{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
}
