:root {
  --green-deep:#1c3528; --green-mid:#2d4a35;
  --amber:#c8923a; --amber-light:#e0b060; --gold:#d4a93c;
  --cream:#f4ead8; --cream-light:#fdf6ec;
  --brown-mid:#5c3d22; --black:#0e0e0e;
  --text-body:#2e2018; --text-light:#6b5a44;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'EB Garamond',serif;background:var(--black);color:var(--cream);overflow-x:hidden}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 3rem;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to bottom,rgba(14,14,14,0.95),transparent);transition:background 0.4s}
nav.scrolled{background:rgba(14,14,14,0.97);border-bottom:1px solid rgba(212,169,60,0.15)}
.nav-logo{font-family:'Cinzel',serif;font-size:1.1rem;letter-spacing:0.25em;color:var(--gold);text-decoration:none}
.nav-logo span{color:var(--cream);opacity:0.7;font-size:0.7em;letter-spacing:0.1em;display:block}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-family:'Cinzel',serif;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--cream);opacity:0.7;text-decoration:none;transition:opacity 0.3s,color 0.3s}
.nav-links a:hover{opacity:1;color:var(--gold)}
.nav-order{font-family:'Cinzel',serif;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:0.5rem 1.2rem;text-decoration:none;transition:all 0.3s}
.nav-order:hover{background:var(--gold);color:var(--black)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:0}
.hamburger span{width:24px;height:1px;background:var(--cream);display:block;transition:all 0.3s}
#mobileMenu{display:none;position:fixed;inset:0;background:rgba(14,14,14,0.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem}
#mobile-links{display:flex;flex-direction:column;align-items:center;gap:2.5rem}
.mobile-close{position:absolute;top:1.4rem;right:1.8rem;background:none;border:none;color:var(--cream);font-size:1.3rem;cursor:pointer;opacity:0.7;line-height:1;padding:4px;transition:opacity 0.3s}
.mobile-close:hover{opacity:1}
.mmlink{font-family:'Cinzel',serif;font-size:1rem;letter-spacing:0.3em;color:var(--cream);text-decoration:none;text-transform:uppercase;transition:color 0.3s}
.mmlink:hover{color:var(--gold)}
.mmlink-cta{font-family:'Cinzel',serif;font-size:1rem;letter-spacing:0.3em;color:var(--gold);border:1px solid var(--gold);padding:1rem 2.5rem;text-decoration:none;text-transform:uppercase;transition:all 0.3s}
.mmlink-cta:hover{background:var(--gold);color:var(--black)}

/* HERO */
#hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;overflow:hidden;padding-top:8rem}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 35% 55%,rgba(28,53,40,0.85) 0%,transparent 65%),radial-gradient(ellipse at 75% 25%,rgba(200,146,58,0.12) 0%,transparent 50%),linear-gradient(155deg,#080e09 0%,#0d1a12 45%,#060d08 100%)}
.hero-texture{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:0.35}
.hero-portraits{position:absolute;right:0;top:0;bottom:0;width:48%;display:flex;gap:3px}
.hero-portrait{flex:1;overflow:hidden;height:100%}
.hero-portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
.hero-portrait:first-child img{opacity:0.7;animation:hpIn 2.2s ease forwards}
.hero-portrait:last-child img{opacity:0.5;animation:hpIn 2.6s ease forwards}
.hero-portraits::before{content:'';position:absolute;left:0;top:0;bottom:0;width:200px;background:linear-gradient(to right,rgba(6,13,8,1),transparent);z-index:1}
.hero-portraits::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,rgba(6,13,8,0.4) 100%);z-index:1}
@keyframes hpIn{from{opacity:0;transform:translateY(20px)}to{opacity:inherit;transform:translateY(0)}}
.hero-content{position:relative;z-index:2;max-width:580px;padding:5rem 3rem 0;margin-left:8vw;animation:heroTextIn 1.8s ease forwards}
@keyframes heroTextIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;opacity:0.9}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3.5rem,7vw,5.8rem);font-weight:300;line-height:1.0;color:var(--cream-light);margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:var(--amber-light)}
.hero-tagline{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-style:italic;font-weight:300;color:var(--cream);opacity:0.72;margin-bottom:3rem;line-height:1.7}
.hero-divider{width:60px;height:1px;background:var(--gold);margin-bottom:3rem;opacity:0.6}
.btn-primary{display:inline-block;font-family:'Cinzel',serif;font-size:0.65rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:1rem 2.5rem;text-decoration:none;transition:all 0.4s}
.btn-primary:hover{background:var(--amber-light);transform:translateY(-1px);box-shadow:0 8px 30px rgba(212,169,60,0.3)}
.btn-secondary{display:inline-block;font-family:'Cinzel',serif;font-size:0.65rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(212,169,60,0.5);padding:1rem 2.5rem;text-decoration:none;transition:all 0.4s;margin-left:1.5rem}
.btn-secondary:hover{border-color:var(--gold);background:rgba(212,169,60,0.08)}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;animation:pulse 2.5s ease-in-out infinite;z-index:3}
@keyframes pulse{0%,100%{opacity:0.3}50%{opacity:0.65}}
.hero-scroll span{font-family:'Cinzel',serif;font-size:0.5rem;letter-spacing:0.35em;color:var(--cream)}
.hero-scroll{text-decoration:none;cursor:pointer;transition:opacity 0.3s}
.hero-scroll:hover{opacity:0.85}
.hero-scroll:hover .hero-scroll-line{background:linear-gradient(to bottom,var(--amber-light),transparent)}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent)}

/* SHARED */
.section-inner{max-width:1100px;margin:0 auto;padding:0 3rem}
.section-label{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--gold);opacity:0.85;margin-bottom:1rem}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:300;line-height:1.15;margin-bottom:2.5rem}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.85s ease,transform 0.85s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* STORY */
#story{background:var(--cream-light);color:var(--text-body);padding:9rem 0 6rem}
#story .section-label{color:var(--brown-mid)}
#story .section-title{font-size:clamp(2.4rem,4vw,3.5rem);color:var(--green-deep)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;margin-bottom:6rem}
.story-text p{font-size:1.12rem;line-height:1.9;color:var(--text-body);margin-bottom:1.4rem}
.story-text p em{font-style:italic;color:var(--green-mid)}
.story-pull{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-style:italic;line-height:1.6;color:var(--green-deep);border-left:2px solid var(--gold);padding-left:1.5rem;margin:2.5rem 0}
.story-portrait{aspect-ratio:3/4;position:relative}
.story-portrait img{width:100%;height:100%;object-fit:cover;display:block}
.story-image-caption{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--green-deep);color:var(--gold);font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.25em;padding:1rem 1.5rem}
.patent-badge{display:inline-block;background:var(--green-deep);color:var(--gold);font-family:'Cinzel',serif;font-size:0.65rem;letter-spacing:0.2em;padding:0.7rem 1.5rem;margin-top:1rem}
.story-portraits{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3px;margin-top:1rem}
.story-portrait-item{aspect-ratio:2/3;overflow:hidden;position:relative}
.story-portrait-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 6s ease}
.story-portrait-item:hover img{transform:scale(1.04)}
.story-portraits-caption{grid-column:1/-1;background:var(--green-deep);color:var(--gold);font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.35em;text-transform:uppercase;text-align:center;padding:1.2rem}

/* SENSORY */
#sensory{background:var(--green-deep);padding:9rem 0;overflow:hidden}
#sensory .section-title{font-size:clamp(2rem,3.5vw,3rem);color:var(--cream-light)}
.sensory-header{text-align:center;margin-bottom:5rem}
.sensory-header p{font-size:1.1rem;font-style:italic;color:var(--amber-light);opacity:0.8}
.sensory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:5rem}
.sensory-card{padding:2.5rem 2rem;border-right:1px solid rgba(212,169,60,0.12);transition:background 0.4s}
.sensory-card:last-child{border-right:none}
.sensory-card:hover{background:rgba(255,255,255,0.03)}
.sensory-icon{font-size:1.6rem;margin-bottom:1rem;display:block}
.sensory-label{font-family:'Cinzel',serif;font-size:0.58rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);margin-bottom:0.8rem;display:block}
.sensory-card h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;color:var(--cream-light);margin-bottom:0.8rem}
.sensory-card p{font-size:0.93rem;line-height:1.75;color:var(--cream);opacity:0.7}
.sensory-portrait-wrap{max-width:500px;margin:0 auto;aspect-ratio:1/1.1;overflow:hidden;position:relative}
.sensory-portrait-wrap img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}
.sensory-portrait-caption{text-align:center;margin-top:1.5rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;color:var(--cream-light);opacity:0.7;letter-spacing:0.04em}

/* LIFESTYLE */
#lifestyle{background:var(--black);padding:0}
.lifestyle-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.lifestyle-portrait{aspect-ratio:2/3;overflow:hidden;position:relative}
.lifestyle-portrait img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 6s ease}
.lifestyle-portrait:hover img{transform:scale(1.04)}
.lifestyle-portrait-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,14,14,0.5) 0%,transparent 50%);pointer-events:none}

/* SCIENCE */
#science{background:#0e0e0e;padding:9rem 0}
#science .section-title{font-size:clamp(2rem,3.5vw,3rem);color:var(--cream-light)}
.science-intro{display:grid;grid-template-columns:1.2fr 1fr;gap:5rem;margin-bottom:5rem;align-items:start}
.science-text p{font-size:1.05rem;line-height:1.9;color:var(--cream);opacity:0.8;margin-bottom:1.2rem}
.highlight-box{border:1px solid rgba(212,169,60,0.3);padding:1.5rem 2rem;margin-top:2rem;background:rgba(212,169,60,0.04)}
.highlight-box p{font-style:italic;font-size:1rem;color:var(--amber-light);opacity:0.9;margin:0}
.science-stat-column{display:flex;flex-direction:column;gap:2rem}
.science-stat{border-top:1px solid rgba(212,169,60,0.2);padding-top:1.5rem}
.science-stat .number{font-family:'Cormorant Garamond',serif;font-size:3.2rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:0.4rem}
.science-stat .label{font-family:'Cinzel',serif;font-size:0.58rem;letter-spacing:0.2em;color:var(--cream);opacity:0.5;text-transform:uppercase}
.science-stat .desc{font-size:0.9rem;line-height:1.6;color:var(--cream);opacity:0.55;margin-top:0.5rem}
.patent-block{background:rgba(28,53,40,0.4);border:1px solid rgba(45,74,53,0.6);padding:3rem;margin-bottom:3rem}
.patent-block h3{font-family:'Cinzel',serif;font-size:0.68rem;letter-spacing:0.3em;color:var(--gold);text-transform:uppercase;margin-bottom:2rem}
.patent-item{display:flex;gap:2rem;padding:1.5rem 0;border-bottom:1px solid rgba(212,169,60,0.1)}
.patent-item:last-child{border-bottom:none;padding-bottom:0}
.patent-num{font-family:'Cinzel',serif;font-size:0.73rem;color:var(--gold);white-space:nowrap;min-width:140px;padding-top:0.2rem}
.patent-details h4{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--cream-light);margin-bottom:0.4rem;font-weight:400}
.patent-details p{font-size:0.9rem;line-height:1.6;color:var(--cream);opacity:0.6}
.citations-block{background:rgba(255,255,255,0.02);border-left:2px solid rgba(212,169,60,0.3);padding:2rem 2.5rem}
.citations-block h3{font-family:'Cinzel',serif;font-size:0.65rem;letter-spacing:0.3em;color:var(--gold);text-transform:uppercase;margin-bottom:1.5rem}
.citation{font-size:0.87rem;line-height:1.7;color:var(--cream);opacity:0.55;margin-bottom:1rem;padding-left:1.5rem;text-indent:-1.5rem}
.citation em{font-style:italic;color:var(--amber-light);opacity:0.9}

/* BENEFITS */
#benefits{background:var(--cream-light);color:var(--text-body);padding:9rem 0}
#benefits .section-label{color:var(--brown-mid)}
#benefits .section-title{font-size:clamp(2rem,3.5vw,3rem);color:var(--green-deep)}
.benefits-header{text-align:center;margin-bottom:4rem}
.benefits-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;margin-bottom:3rem}
.benefit-card{background:white;padding:2rem 1.5rem;text-align:center;transition:all 0.3s;position:relative;overflow:hidden}
.benefit-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform 0.3s}
.benefit-card:hover::after{transform:scaleX(1)}
.benefit-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,0.08)}
.benefit-icon{font-size:1.7rem;margin-bottom:1rem;display:block}
.benefit-card h3{font-family:'Cinzel',serif;font-size:0.63rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--green-deep);margin-bottom:0.7rem}
.benefit-card p{font-size:0.87rem;line-height:1.6;color:var(--text-light)}
.disclaimer{text-align:center;font-size:0.78rem;color:var(--text-light);max-width:700px;margin:0 auto;line-height:1.7;border-top:1px solid rgba(0,0,0,0.1);padding-top:2rem;font-style:italic}

/* TESTIMONIALS */
#testimonials{background:var(--green-deep);padding:9rem 0;overflow:hidden}
#testimonials .section-title{font-size:clamp(2rem,3.5vw,3rem);color:var(--cream-light);text-align:center}
.testimonials-header{text-align:center;margin-bottom:4rem}
.testimonials-track-wrap{overflow:hidden}
.testimonials-track{display:flex;gap:2rem;transition:transform 0.55s cubic-bezier(0.4,0,0.2,1)}
.testimonial-card{min-width:calc(33.333% - 1.4rem);background:rgba(255,255,255,0.04);border:1px solid rgba(212,169,60,0.15);padding:2.5rem;flex-shrink:0}
.testimonial-quote{font-family:'Cormorant Garamond',serif;font-size:3rem;color:var(--gold);line-height:1;margin-bottom:1rem;opacity:0.45}
.testimonial-text{font-size:1rem;line-height:1.8;color:var(--cream);opacity:0.85;margin-bottom:1.5rem;font-style:italic}
.testimonial-author{font-family:'Cinzel',serif;font-size:0.58rem;letter-spacing:0.2em;color:var(--gold);text-transform:uppercase}
.testimonials-controls{display:flex;justify-content:center;gap:1rem;margin-top:3rem;align-items:center}
.t-btn{width:44px;height:44px;border:1px solid rgba(212,169,60,0.4);background:transparent;color:var(--gold);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.3s}
.t-btn:hover{background:var(--gold);color:var(--black)}
.t-dot{width:6px;height:6px;border-radius:50%;background:rgba(212,169,60,0.3);transition:background 0.3s;cursor:pointer;margin:0 0.25rem;display:inline-block}
.t-dot.active{background:var(--gold)}

/* ORDER */
#order{background:#0e0e0e;padding:9rem 0}
#order .section-title{font-size:clamp(2rem,3.5vw,3rem);color:var(--cream-light)}
.order-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.order-portraits{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.order-portrait-item{aspect-ratio:2/3;overflow:hidden}
.order-portrait-item img{width:100%;height:100%;object-fit:cover;display:block}
.order-product-sub{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.25em;color:var(--gold);margin-bottom:1.5rem;text-transform:uppercase}
.order-description{font-size:0.95rem;line-height:1.8;color:var(--cream);opacity:0.7;margin-bottom:2rem}
.order-price{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:300;color:var(--gold);margin-bottom:0.3rem}
.order-price-note{font-size:0.8rem;color:var(--cream);opacity:0.38;margin-bottom:2rem;letter-spacing:0.05em}
.order-divider{height:1px;background:rgba(212,169,60,0.15);margin-bottom:2rem}
.qty-label{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.2em;color:var(--cream);opacity:0.5;text-transform:uppercase;display:block;margin-bottom:0.75rem}
.qty-control{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.qty-btn{width:36px;height:36px;border:1px solid rgba(212,169,60,0.3);background:transparent;color:var(--gold);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.3s}
.qty-btn:hover{background:rgba(212,169,60,0.1)}
.qty-num{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--cream-light);min-width:40px;text-align:center}
.order-btn{width:100%;padding:1.2rem;background:var(--gold);color:var(--black);border:none;font-family:'Cinzel',serif;font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;margin-bottom:1rem}
.order-btn:hover{background:var(--amber-light);transform:translateY(-1px);box-shadow:0 8px 30px rgba(212,169,60,0.3)}
.shipping-note{font-size:0.8rem;color:var(--cream);opacity:0.38;text-align:center;margin-bottom:2rem;letter-spacing:0.05em;line-height:1.7}
.payment-icons{display:flex;justify-content:center;gap:1rem;opacity:0.38;margin-bottom:2rem}
.pay-icon{font-size:0.68rem;font-family:'Cinzel',serif;letter-spacing:0.1em;border:1px solid rgba(255,255,255,0.2);padding:0.4rem 0.8rem;color:var(--cream)}
.enquiry-note{padding:1.5rem;border:1px solid rgba(212,169,60,0.2);font-size:0.88rem;color:var(--cream);opacity:0.6;line-height:1.6;text-align:center}
.enquiry-note a{color:var(--gold);text-decoration:none}

/* MEDIA */
#media{background:var(--cream-light);color:var(--text-body);padding:9rem 0}
#media .section-label{color:var(--brown-mid)}
#media .section-title{font-size:clamp(2rem,3.5vw,3rem);color:var(--green-deep)}
.media-header{text-align:center;margin-bottom:4rem}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.media-card{background:white;padding:2.5rem;position:relative;overflow:hidden;transition:all 0.3s;border-bottom:3px solid transparent}
.media-card:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(0,0,0,0.1);border-bottom-color:var(--gold)}
.media-outlet{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.25em;color:var(--brown-mid);text-transform:uppercase;margin-bottom:0.5rem;opacity:0.7}
.media-date{font-size:0.8rem;color:var(--text-light);margin-bottom:1rem}
.media-card h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--text-body);line-height:1.4;margin-bottom:1rem}
.media-card p{font-size:0.9rem;line-height:1.7;color:var(--text-light);margin-bottom:1.5rem}
.media-link{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.2em;color:var(--green-mid);text-decoration:none;text-transform:uppercase;transition:color 0.3s}
.media-link:hover{color:var(--gold)}
.media-tag{display:inline-block;background:var(--green-deep);color:var(--gold);font-family:'Cinzel',serif;font-size:0.55rem;letter-spacing:0.15em;padding:0.3rem 0.7rem;text-transform:uppercase;position:absolute;top:1rem;right:1rem}

/* FOOTER */
footer{background:var(--black);border-top:1px solid rgba(212,169,60,0.12);padding:5rem 0 3rem}
.footer-inner{max-width:1100px;margin:0 auto;padding:0 3rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:4rem;margin-bottom:4rem}
.footer-brand-name{font-family:'Cinzel',serif;font-size:1.2rem;letter-spacing:0.3em;color:var(--gold);margin-bottom:0.3rem}
.footer-brand-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:0.9rem;color:var(--cream);opacity:0.4;margin-bottom:1.5rem}
.footer-desc{font-size:0.87rem;line-height:1.8;color:var(--cream);opacity:0.38;margin-bottom:1.5rem}
.footer-social{display:flex;gap:1rem}
.footer-social a{width:36px;height:36px;border:1px solid rgba(212,169,60,0.25);display:flex;align-items:center;justify-content:center;color:var(--gold);text-decoration:none;transition:all 0.3s}
.footer-social a:hover{background:var(--gold);color:var(--black)}
.footer-col h4{font-family:'Cinzel',serif;font-size:0.6rem;letter-spacing:0.3em;color:var(--gold);text-transform:uppercase;margin-bottom:1.5rem;opacity:0.8}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:0.75rem}
.footer-col ul a{font-size:0.87rem;color:var(--cream);opacity:0.42;text-decoration:none;transition:opacity 0.3s,color 0.3s}
.footer-col ul a:hover{opacity:0.9;color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding-top:2rem;display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:0.77rem;color:var(--cream);opacity:0.22;letter-spacing:0.05em}
.footer-legal{display:flex;gap:2rem}
.footer-legal a{font-size:0.75rem;color:var(--cream);opacity:0.22;text-decoration:none;transition:opacity 0.3s}
.footer-legal a:hover{opacity:0.6}

/* MOBILE */
@media(max-width:900px){
  nav{padding:1rem 1.5rem}
  .nav-links,.nav-order{display:none}
  .hamburger{display:flex}
  .hero-portraits{width:100%;opacity:0.3}
  .hero-content{margin-left:0;padding:5rem 1.5rem 0;max-width:100%}
  .hero-title{font-size:3rem}
  .section-inner{padding:0 1.5rem}
  .story-grid{grid-template-columns:1fr;gap:3rem}
  .story-portrait{aspect-ratio:4/5}
  .story-portrait img{order:-1}
  .story-portraits{grid-template-columns:1fr 1fr}
  .sensory-grid{grid-template-columns:1fr 1fr}
  .sensory-card{border-right:none;border-bottom:1px solid rgba(212,169,60,0.1)}
  .lifestyle-strip{grid-template-columns:1fr 1fr}
  .science-intro{grid-template-columns:1fr;gap:3rem}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .testimonial-card{min-width:100%}
  .order-grid{grid-template-columns:1fr;gap:3rem}
  .order-portraits{display:none}
  .media-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  section{padding:5rem 0!important}
  #hero{padding:0!important;height:100vh!important}
  #lifestyle{padding:0!important}
  .patent-item{flex-direction:column;gap:0.75rem}
  .patent-num{min-width:unset}
  .patent-block{padding:1.5rem}
}
@media(max-width:600px){
  .sensory-grid,.benefits-grid{grid-template-columns:1fr}
  .story-portraits{grid-template-columns:1fr}
  .lifestyle-strip{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .btn-secondary{display:none}
  .hero-title{font-size:2.6rem}
}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.back-to-top {
  position:fixed;
  bottom:2.5rem;
  right:2.5rem;
  z-index:500;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0.5rem;
  background:none;
  border:none;
  cursor:pointer;
  padding:0;
  opacity:0;
  pointer-events:none;
  transform:translateY(12px);
  transition:opacity 0.4s, transform 0.4s;
}
.back-to-top.visible {
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
  animation:bttPulse 2.5s ease-in-out infinite;
}
.btt-label {
  font-family:'Cinzel',serif;
  font-size:0.5rem;
  letter-spacing:0.35em;
  color:var(--cream);
  text-transform:uppercase;
  order:2;
}
.btt-line {
  width:1px;
  height:40px;
  background:linear-gradient(to top,var(--gold),transparent);
  order:1;
}
.back-to-top:hover .btt-line {
  background:linear-gradient(to top,var(--amber-light),transparent);
}
.back-to-top:hover .btt-label { color:var(--gold); }
@keyframes bttPulse {
  0%,100%{opacity:0.45}
  50%{opacity:0.9}
}

/* ============================================================
   LEGAL MODALS
   ============================================================ */
.legal-overlay {
  position:fixed;inset:0;
  background:rgba(14,14,14,0.88);
  backdrop-filter:blur(6px);
  z-index:2000;
  opacity:0;pointer-events:none;
  transition:opacity 0.35s;
}
.legal-overlay.open { opacity:1; pointer-events:auto; }

.legal-modal {
  position:fixed;
  top:50%;left:50%;
  transform:translate(-50%,-44%);
  width:90%;max-width:720px;
  max-height:80vh;
  background:var(--cream-light);
  color:var(--text-body);
  z-index:2001;
  opacity:0;pointer-events:none;
  transition:opacity 0.35s,transform 0.35s;
  overflow:hidden;
  display:flex;flex-direction:column;
}
.legal-modal.open {
  opacity:1;pointer-events:auto;
  transform:translate(-50%,-50%);
}
.legal-close {
  position:absolute;top:1.2rem;right:1.4rem;
  background:none;border:none;
  font-size:1.1rem;color:var(--text-light);
  cursor:pointer;transition:color 0.2s;z-index:1;
}
.legal-close:hover { color:var(--green-deep); }
.legal-inner {
  padding:3rem;
  overflow-y:auto;
  flex:1;
}
.legal-title {
  font-family:'Cinzel',serif;
  font-size:1rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--green-deep);
  margin-bottom:2rem;
  padding-bottom:1rem;
  border-bottom:1px solid rgba(28,53,40,0.15);
}
.legal-body {
  font-family:'EB Garamond',serif;
  font-size:1rem;
  line-height:1.85;
  color:var(--text-body);
}
.legal-body p { margin-bottom:1.2rem; }
.legal-body strong {
  font-weight:600;
  color:var(--green-deep);
  display:block;
  margin-top:1.5rem;
  margin-bottom:0.4rem;
  font-family:'Cinzel',serif;
  font-size:0.72rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
}
@media(max-width:600px){
  .back-to-top{bottom:1.5rem;right:1.5rem}
  .legal-modal{width:95%;max-height:88vh}
  .legal-inner{padding:2rem 1.5rem}
}
