/* ===== DESIGN SYSTEM V2 — Luciano Castro ===== */

:root{
  --navy:#0d1b2a; --navy-2:#13243a; --navy-3:#1b2d45; --navy-deep:#070f18;
  --gold:#c9a84c; --gold-l:#e7cf86; --gold-d:#a88a2e; --gold-glow:rgba(201,168,76,.18);
  --white:#fff; --off:#f8f6f1; --gray:#8a8a8a; --text:#3d3d3d; --dark:#1a1a1a;
  --fh:'Playfair Display',Georgia,serif; --fb:'Inter',-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);color:var(--text);line-height:1.7;overflow-x:hidden;background:var(--navy-deep)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* ===== SCROLL PROGRESS ===== */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold-d),var(--gold-l));z-index:9999;transition:width .1s linear;box-shadow:0 0 12px var(--gold-glow)}

/* ===== NAVBAR ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 2rem;background:rgba(7,15,24,.65);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(201,168,76,.08);transition:all .35s var(--ease)}
.nav.scrolled{padding:.6rem 2rem;background:rgba(7,15,24,.92);box-shadow:0 8px 32px rgba(0,0,0,.45)}
.nav-c{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.nav-logo img{height:48px;transition:transform .4s var(--ease)}
.nav-logo:hover img{transform:scale(1.05)}
.nav ul{display:flex;gap:2rem;list-style:none;align-items:center}
.nav ul a{color:rgba(255,255,255,.78);font-size:.78rem;letter-spacing:1.2px;text-transform:uppercase;font-weight:500;position:relative;padding:.4rem 0;transition:color .3s}
.nav ul a:not(.cta)::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav ul a:not(.cta):hover{color:var(--gold)}
.nav ul a:not(.cta):hover::after{width:100%}
.cta{background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--navy)!important;padding:.7rem 1.6rem;border-radius:50px;font-weight:600;letter-spacing:.5px!important;box-shadow:0 4px 20px var(--gold-glow);transition:all .35s var(--ease)}
.cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(201,168,76,.45)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:1.05rem 2.2rem;border-radius:50px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1.3px;cursor:pointer;border:none;transition:all .4s var(--ease);position:relative;overflow:hidden}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--navy);box-shadow:0 6px 24px rgba(201,168,76,.3)}
.btn-gold::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold-l),var(--gold));opacity:0;transition:opacity .4s}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(201,168,76,.5)}
.btn-gold:hover::before{opacity:1}
.btn-gold span{position:relative;z-index:1}
.btn-gold::after{content:'→';position:relative;z-index:1;font-size:1.1rem;transition:transform .35s var(--ease)}
.btn-gold:hover::after{transform:translateX(4px)}
.btn-out{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.28)}
.btn-out:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06)}
.btn-out-dark{background:transparent;color:var(--navy);border:1px solid var(--navy)}
.btn-out-dark:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ===== HERO (HOME) ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:120px 2rem 80px;background:radial-gradient(ellipse at 20% 0%,var(--navy-3) 0%,var(--navy) 40%,var(--navy-deep) 100%)}
.mesh{position:absolute;inset:0;z-index:0;overflow:hidden}
.mesh::before,.mesh::after{content:'';position:absolute;width:60vmax;height:60vmax;border-radius:50%;filter:blur(80px);opacity:.35;animation:drift 22s ease-in-out infinite}
.mesh::before{background:radial-gradient(circle,rgba(201,168,76,.5),transparent 60%);top:-20vmax;right:-15vmax}
.mesh::after{background:radial-gradient(circle,rgba(36,59,90,.9),transparent 60%);bottom:-25vmax;left:-15vmax;animation-delay:-8s}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.1)}}
.beams{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;opacity:.55}
.beam{position:absolute;top:-30%;width:1px;height:160%;background:linear-gradient(180deg,transparent,rgba(201,168,76,.55),transparent);transform-origin:top center;animation:beamMove 11s linear infinite}
.beam:nth-child(1){left:18%;transform:rotate(8deg);animation-delay:-2s}
.beam:nth-child(2){left:42%;transform:rotate(-6deg);animation-delay:-5s;opacity:.6}
.beam:nth-child(3){left:68%;transform:rotate(10deg);animation-delay:-9s;opacity:.5}
.beam:nth-child(4){left:88%;transform:rotate(-4deg);animation-delay:-1s;opacity:.4}
@keyframes beamMove{0%{opacity:0;transform:translateY(-20%) rotate(var(--r,8deg))}50%{opacity:1}100%{opacity:0;transform:translateY(20%) rotate(var(--r,8deg))}}
.particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.particle{position:absolute;width:3px;height:3px;border-radius:50%;background:var(--gold-l);box-shadow:0 0 8px var(--gold);opacity:0;animation:rise 9s linear infinite}
@keyframes rise{0%{opacity:0;transform:translateY(20vh) scale(.5)}10%{opacity:.7}90%{opacity:.6}100%{opacity:0;transform:translateY(-90vh) scale(1.2)}}

.hero-c{position:relative;z-index:3;max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:4rem;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;padding:.5rem 1rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.25);border-radius:50px;color:var(--gold-l);font-size:.72rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1.6rem;backdrop-filter:blur(12px)}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(.85)}50%{opacity:1;transform:scale(1.2)}}
.hero h1{font-family:var(--fh);font-size:clamp(2.4rem,4.6vw,4.2rem);line-height:1.08;color:var(--white);font-weight:700;letter-spacing:-.5px;margin-bottom:1.4rem}
.hero h1 .accent{display:block;color:var(--gold);font-style:italic;font-weight:600}
.hero h1 .word{display:inline-block;opacity:0;transform:translateY(40px);animation:wordIn .9s var(--ease) forwards}
.hero h1 .word:nth-child(1){animation-delay:.1s}
.hero h1 .word:nth-child(2){animation-delay:.18s}
.hero h1 .word:nth-child(3){animation-delay:.26s}
.hero h1 .word:nth-child(4){animation-delay:.34s}
.hero h1 .word:nth-child(5){animation-delay:.42s}
.hero h1 .word:nth-child(6){animation-delay:.5s}
.hero h1 .word:nth-child(7){animation-delay:.58s}
.hero h1 .accent .word:nth-child(1){animation-delay:.7s}
.hero h1 .accent .word:nth-child(2){animation-delay:.78s}
.hero h1 .accent .word:nth-child(3){animation-delay:.86s}
.hero h1 .accent .word:nth-child(4){animation-delay:.94s}
.hero h1 .accent .word:nth-child(5){animation-delay:1.02s}
.hero h1 .accent .word:nth-child(6){animation-delay:1.1s}
.hero h1 .accent .word:nth-child(7){animation-delay:1.18s}
@keyframes wordIn{to{opacity:1;transform:translateY(0)}}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.72);max-width:560px;margin-bottom:2.4rem;font-weight:300;opacity:0;animation:fadeUp .9s var(--ease) 1.3s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.4rem;opacity:0;animation:fadeUp .9s var(--ease) 1.5s forwards}
.stat{padding:1.2rem;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.18);border-radius:14px;backdrop-filter:blur(14px);text-align:center;transition:all .4s var(--ease)}
.stat:hover{transform:translateY(-4px);border-color:var(--gold);background:rgba(201,168,76,.06);box-shadow:0 12px 30px rgba(0,0,0,.3)}
.stat .num{font-family:var(--fh);font-size:2rem;font-weight:700;color:var(--gold);line-height:1}
.stat .lbl{font-size:.68rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:1.2px;margin-top:.5rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s var(--ease) 1.7s forwards}
.hero-img{position:relative;text-align:center}
.hero-img-wrap{position:relative;display:inline-block;animation:floatY 6s ease-in-out infinite}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero-img img{max-height:620px;filter:drop-shadow(0 30px 60px rgba(0,0,0,.55));mask-image:linear-gradient(to bottom,#000 78%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,#000 78%,transparent 100%)}
.hero-img-wrap::before{content:'';position:absolute;inset:-15% -10% -5% -10%;background:radial-gradient(circle at 60% 40%,rgba(201,168,76,.22),transparent 60%);z-index:-1;filter:blur(30px)}
.hero-img-wrap::after{content:'';position:absolute;width:120%;height:120%;left:-10%;top:-10%;border:1px solid rgba(201,168,76,.15);border-radius:50%;animation:rotate 40s linear infinite;z-index:-1}
@keyframes rotate{to{transform:rotate(360deg)}}
.scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:5;color:rgba(255,255,255,.5);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.6rem;animation:fadeUp .9s var(--ease) 2s both}
.scroll-cue::after{content:'';width:1px;height:36px;background:linear-gradient(180deg,var(--gold),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===== HERO (PRODUCT PAGES) ===== */
.phero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;padding:140px 2rem 80px;background:radial-gradient(ellipse at 20% 0%,var(--navy-3) 0%,var(--navy) 40%,var(--navy-deep) 100%)}
.phero-c{position:relative;z-index:3;max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center}
.phero-logo{background:linear-gradient(180deg,#fff,var(--off));padding:1.2rem 1.8rem;border-radius:18px;display:inline-block;margin-bottom:1.6rem;box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 10px 30px rgba(0,0,0,.4);border:1px solid rgba(201,168,76,.2);max-width:fit-content}
.phero-logo img{max-height:90px;display:block}
.phero h1{font-family:var(--fh);font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.15;color:var(--white);font-weight:700;letter-spacing:-.3px;margin-bottom:1.2rem}
.phero h1 em,.phero h1 span{color:var(--gold);font-style:italic;font-weight:600}
.phero-desc{font-size:1.05rem;color:rgba(255,255,255,.72);max-width:560px;margin-bottom:2rem;line-height:1.7}
.phero-img{position:relative;text-align:center}
.phero-img img{max-height:560px;filter:drop-shadow(0 30px 60px rgba(0,0,0,.55));mask-image:linear-gradient(to bottom,#000 80%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,#000 80%,transparent 100%)}
.phero-img-wrap{position:relative;display:inline-block;animation:floatY 6s ease-in-out infinite}
.phero-img-wrap::before{content:'';position:absolute;inset:-15% -10% -5% -10%;background:radial-gradient(circle at 60% 40%,rgba(201,168,76,.22),transparent 60%);z-index:-1;filter:blur(30px)}

/* ===== MARQUEE ===== */
.marquee{background:#070f18;border-block:1px solid rgba(201,168,76,.1);overflow:hidden;padding:1.2rem 0}
.marquee-track{display:flex;gap:4rem;animation:marquee 36s linear infinite;width:max-content}
.marquee-item{display:flex;align-items:center;gap:.8rem;color:rgba(255,255,255,.55);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:500;white-space:nowrap}
.marquee-item::before{content:'✦';color:var(--gold);font-size:.7rem}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ===== SECTIONS COMMON ===== */
section{padding:7rem 2rem;position:relative}
.container{max-width:1200px;margin:0 auto}
.eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:3px;color:var(--gold);font-weight:600;margin-bottom:.9rem;display:inline-block}
.title{font-family:var(--fh);font-size:clamp(1.9rem,3.4vw,2.9rem);line-height:1.18;margin-bottom:1.2rem;color:var(--dark);letter-spacing:-.3px}
.title.white{color:var(--white)}
.title .acc{color:var(--gold);font-style:italic}
.sub{font-size:1.05rem;color:var(--gray);max-width:680px;line-height:1.7}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* reveal */
.reveal{opacity:0;transform:translateY(40px);transition:all .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-l{opacity:0;transform:translateX(-40px);transition:all .9s var(--ease)}
.reveal-l.in{opacity:1;transform:none}
.reveal-r{opacity:0;transform:translateX(40px);transition:all .9s var(--ease)}
.reveal-r.in{opacity:1;transform:none}

/* ===== PAIN ===== */
.pain{background:var(--off);position:relative;overflow:hidden}
.pain::before{content:'';position:absolute;inset:0;background-image:url('img/pain-bg.jpg');background-size:cover;background-position:center;opacity:.22;mix-blend-mode:multiply;z-index:0}
.pain::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,var(--off) 0%,transparent 18%,transparent 82%,var(--off) 100%);z-index:1}
.pain .container{position:relative;z-index:2}
.pain .head{text-align:center;margin-bottom:3.5rem}
.pain .head .sub{margin:0 auto}
.pain-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;margin-bottom:3rem}
.pain-card{padding:2rem;background:var(--white);border-radius:18px;border:1px solid rgba(13,27,42,.06);position:relative;font-style:italic;color:var(--text);font-size:1.02rem;line-height:1.6;transition:all .5s var(--ease);overflow:hidden}
.pain-card::before{content:'"';position:absolute;top:-30px;left:1rem;font-family:var(--fh);font-size:9rem;color:var(--gold);opacity:.15;line-height:1}
.pain-card:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:0 18px 40px rgba(13,27,42,.1)}
.pain-answer{padding:2.4rem 2.5rem;background:linear-gradient(135deg,var(--navy),var(--navy-3));color:rgba(255,255,255,.92);border-radius:24px;text-align:center;font-size:1.08rem;border:1px solid rgba(201,168,76,.2);position:relative;overflow:hidden}
.pain-answer::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(201,168,76,.15),transparent 60%)}
.pain-answer span{display:block;color:var(--gold-l);font-family:var(--fh);font-style:italic;font-size:1.4rem;margin-top:1rem;position:relative}

/* ===== ABOUT ===== */
.about{background:var(--white);overflow:hidden}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:center}
.about-img{position:relative}
.about-img img{border-radius:18px;filter:drop-shadow(0 20px 50px rgba(13,27,42,.18))}
.about-img::before{content:'';position:absolute;width:80%;height:80%;border:2px solid var(--gold);border-radius:18px;top:8%;left:8%;z-index:-1;transition:all .6s var(--ease)}
.about-img:hover::before{top:5%;left:5%}
.about p{margin-bottom:1rem;color:var(--text)}
.about .quote{font-family:var(--fh);font-size:1.18rem;color:var(--navy);font-style:italic;border-left:3px solid var(--gold);padding-left:1.2rem;margin:1.6rem 0}
.creds{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.cred{padding:.5rem 1rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.3);border-radius:50px;font-size:.78rem;color:var(--navy);font-weight:500;transition:all .35s var(--ease)}
.cred:hover{background:var(--gold);color:var(--navy);transform:translateY(-2px)}

/* ===== PRODUCTS ===== */
.products{background:linear-gradient(180deg,var(--navy-deep),var(--navy));color:#fff;padding-top:8rem}
.products .head{text-align:center;margin-bottom:4rem}
.products .title{color:var(--white)}
.products .sub{margin:0 auto;color:rgba(255,255,255,.65)}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem}
.prod-card{padding:2rem 1.6rem;background:rgba(255,255,255,.03);border:1px solid rgba(201,168,76,.12);border-radius:20px;text-align:center;transition:all .5s var(--ease);position:relative;overflow:hidden;backdrop-filter:blur(10px)}
.prod-card::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transition:width .5s var(--ease)}
.prod-card:hover{transform:translateY(-10px);border-color:var(--gold);background:rgba(201,168,76,.05);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.prod-card:hover::before{width:80%}
.prod-step{display:inline-block;padding:.3rem .8rem;background:rgba(201,168,76,.15);color:var(--gold-l);border-radius:50px;font-size:.65rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:1.4rem;font-weight:600}
.prod-card h3{font-family:var(--fh);font-size:1.5rem;color:var(--white);margin:1rem 0}
.prod-card p{color:rgba(255,255,255,.65);font-size:.92rem;line-height:1.6;margin-bottom:1.8rem;min-height:80px}
.prod-logo{height:110px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;padding:1rem 1.4rem;background:linear-gradient(180deg,#fff,var(--off));border-radius:14px;border:1px solid rgba(201,168,76,.15);box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 4px 16px rgba(0,0,0,.25);max-width:240px;transition:all .4s var(--ease)}
.prod-card:hover .prod-logo{box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 8px 24px rgba(201,168,76,.2);border-color:var(--gold)}
.prod-logo img{max-height:75px;max-width:200px;object-fit:contain}
.btn-prod{padding:.75rem 1.6rem;background:transparent;border:1px solid var(--gold);color:var(--gold);border-radius:50px;font-size:.78rem;text-transform:uppercase;letter-spacing:1.2px;font-weight:600;display:inline-block;transition:all .35s var(--ease)}
.btn-prod:hover{background:var(--gold);color:var(--navy)}

/* ===== STRATEGIES ===== */
.strat{background:var(--off)}
.strat .head{text-align:center;margin-bottom:4rem}
.strat .head .sub{margin:0 auto}
.strat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.strat-card{padding:2.5rem 2rem;background:var(--white);border-radius:20px;position:relative;transition:all .5s var(--ease);border:1px solid rgba(13,27,42,.06)}
.strat-card:hover{transform:translateY(-8px);border-color:var(--gold);box-shadow:0 20px 50px rgba(13,27,42,.1)}
.strat-num{font-family:var(--fh);font-size:4.5rem;font-weight:800;color:transparent;-webkit-text-stroke:1.5px var(--gold);line-height:1;margin-bottom:.5rem;transition:all .5s var(--ease)}
.strat-card:hover .strat-num{color:var(--gold);-webkit-text-stroke:0}
.strat-card h3{font-family:var(--fh);font-size:1.4rem;color:var(--navy);margin-bottom:1rem}

/* ===== FAITH ===== */
.faith{background:linear-gradient(180deg,var(--navy-deep),var(--navy));color:#fff;text-align:center;position:relative;overflow:hidden}
.faith::before{content:'';position:absolute;inset:0;background-image:url('img/faith-bg.jpg');background-size:cover;background-position:center;opacity:.35;z-index:0}
.faith::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 0%,var(--navy-deep) 80%);z-index:1}
.faith .container{position:relative;z-index:2;max-width:780px}
.cross-svg{width:54px;height:54px;margin:0 auto 1.6rem;color:var(--gold);filter:drop-shadow(0 0 20px var(--gold-glow))}
.cross-svg path{stroke:var(--gold);stroke-width:2;fill:none;stroke-dasharray:200;stroke-dashoffset:200;transition:stroke-dashoffset 2.4s var(--ease)}
.faith.in .cross-svg path{stroke-dashoffset:0}
.faith blockquote{font-family:var(--fh);font-size:clamp(1.4rem,2.6vw,2rem);font-style:italic;color:rgba(255,255,255,.95);line-height:1.5;margin-bottom:1rem}
.faith cite{color:var(--gold);font-style:normal;font-size:.85rem;letter-spacing:2px;text-transform:uppercase;font-weight:600;display:block;margin-bottom:2rem}
.faith p{color:rgba(255,255,255,.75);font-size:1.05rem;max-width:620px;margin:0 auto;line-height:1.75}

/* ===== TESTIMONIALS ===== */
.tst{background:var(--white);position:relative;overflow:hidden}
.tst::before{content:'';position:absolute;inset:0;background-image:url('img/testimonials-bg.jpg');background-size:cover;background-position:center;opacity:.28;z-index:0}
.tst::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,var(--white) 0%,transparent 20%,transparent 80%,var(--white) 100%);z-index:1}
.tst .container{position:relative;z-index:2}
.tst .head{text-align:center;margin-bottom:4rem}
.tst .head .sub{margin:0 auto}
.tst-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.6rem}
.tst-card{padding:2.2rem;background:var(--off);border-radius:18px;position:relative;transition:all .5s var(--ease);border:1px solid transparent}
.tst-card:hover{transform:translateY(-6px);background:var(--white);border-color:var(--gold);box-shadow:0 20px 40px rgba(13,27,42,.08)}
.tst-quote{font-family:var(--fh);font-size:5rem;color:var(--gold);opacity:.3;line-height:1;position:absolute;top:.6rem;left:1rem}
.tst-card p{position:relative;color:var(--text);font-size:1rem;line-height:1.7;margin-bottom:1.6rem;font-style:italic}
.tst-author{display:flex;align-items:center;gap:.9rem;padding-top:1.2rem;border-top:1px solid rgba(13,27,42,.08)}
.tst-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-l));display:flex;align-items:center;justify-content:center;color:var(--navy);font-weight:700;font-size:1.1rem;font-family:var(--fh)}
.tst-name{font-weight:600;color:var(--navy);font-size:.95rem}
.tst-result{font-size:.78rem;color:var(--gold-d);text-transform:uppercase;letter-spacing:1px;margin-top:.15rem}

/* ===== CTA BANNER ===== */
.cta-banner{background:linear-gradient(135deg,var(--navy),var(--navy-3));color:#fff;position:relative;overflow:hidden;padding:5rem 2rem}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(201,168,76,.2),transparent 60%)}
.cta-c{position:relative;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.2fr .8fr;gap:3rem;align-items:center}
.cta-c h2{font-family:var(--fh);font-size:clamp(1.8rem,3vw,2.5rem);line-height:1.2;margin-bottom:1rem}
.cta-c h2 span{color:var(--gold);font-style:italic}
.cta-c p{color:rgba(255,255,255,.78);margin-bottom:2rem;line-height:1.7}
.cta-img img{max-height:400px;filter:drop-shadow(0 20px 50px rgba(0,0,0,.45))}

/* ===== CONTACT FORM ===== */
.contact{background:var(--off);position:relative;overflow:hidden}
.contact::before{content:'';position:absolute;top:-100px;left:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.18),transparent 70%);filter:blur(40px);z-index:0}
.contact::after{content:'';position:absolute;bottom:-100px;right:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(36,59,90,.15),transparent 70%);filter:blur(40px);z-index:0}
.contact .container{position:relative;z-index:1}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:start}
.contact-info .title{margin-bottom:1.4rem}
.contact-info p.lead{color:var(--text);font-size:1.02rem;margin-bottom:2rem;line-height:1.7}
.contact-detail{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem;padding:.9rem 1.2rem;background:rgba(255,255,255,.6);border:1px solid rgba(201,168,76,.18);border-radius:14px;transition:all .35s var(--ease);backdrop-filter:blur(8px)}
.contact-detail:hover{border-color:var(--gold);background:#fff;transform:translateX(4px)}
.contact-detail .ico{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--gold),var(--gold-l));display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:1.2rem;flex-shrink:0;box-shadow:0 4px 12px var(--gold-glow)}
.contact-detail .txt{font-size:.95rem;color:var(--navy);font-weight:500}
.contact-form{background:#fff;padding:2.6rem;border-radius:22px;border:1px solid rgba(13,27,42,.06);box-shadow:0 24px 60px rgba(13,27,42,.08)}
.form-row{margin-bottom:1.2rem}
.form-row label{display:block;font-size:.78rem;color:var(--navy);text-transform:uppercase;letter-spacing:1.2px;font-weight:600;margin-bottom:.5rem}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.95rem 1.1rem;border:1.5px solid rgba(13,27,42,.1);border-radius:12px;font-family:var(--fb);font-size:.95rem;color:var(--text);background:var(--off);transition:all .3s var(--ease);outline:none}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px var(--gold-glow)}
.form-row textarea{resize:vertical;min-height:110px;font-family:var(--fb)}
.phone-row{display:grid;grid-template-columns:.3fr .7fr;gap:.6rem}
.contact-form .btn{width:100%;justify-content:center;margin-top:.5rem}
.form-disclaimer{font-size:.78rem;color:var(--gray);text-align:center;margin-top:1rem;line-height:1.5}

/* ===== FOOTER ===== */
.foot{background:var(--navy-deep);color:rgba(255,255,255,.65);padding:4rem 2rem 2rem;border-top:1px solid rgba(201,168,76,.08)}
.foot-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.foot-brand img{height:50px;margin-bottom:1.2rem}
.foot-brand p{font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.55);max-width:300px}
.foot h4{color:var(--gold);font-size:.85rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1.2rem;font-weight:600}
.foot ul{list-style:none}
.foot ul li{margin-bottom:.6rem}
.foot ul a{color:rgba(255,255,255,.6);font-size:.92rem;transition:color .3s}
.foot ul a:hover{color:var(--gold)}
.foot-bot{max-width:1200px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);text-align:center;font-size:.82rem;color:rgba(255,255,255,.45)}

/* ===== GENERIC GRID/CARD UTILITIES (for product subpages) ===== */
.section-light{background:var(--off);position:relative}
.section-white{background:var(--white);position:relative}
.section-dark{background:linear-gradient(180deg,var(--navy-deep),var(--navy));color:#fff;position:relative;overflow:hidden}
.section-dark .title{color:#fff}
.section-dark .sub{color:rgba(255,255,255,.65)}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head .sub{margin:0 auto}

/* feature/info card (light bg) */
.fcard{padding:2rem 1.8rem;background:#fff;border-radius:16px;border:1px solid rgba(13,27,42,.06);transition:all .5s var(--ease);position:relative}
.fcard:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:0 18px 40px rgba(13,27,42,.08)}
.fcard .ic{font-size:1.8rem;margin-bottom:.9rem;display:inline-block;color:var(--gold)}
.fcard h4{font-family:var(--fh);font-size:1.1rem;color:var(--navy);margin-bottom:.6rem;line-height:1.3}
.fcard p{font-size:.92rem;color:var(--text);line-height:1.65}

/* feature/info card (dark bg) */
.fcard-d{padding:2rem 1.8rem;background:rgba(255,255,255,.04);border-radius:16px;border:1px solid rgba(201,168,76,.12);transition:all .5s var(--ease);backdrop-filter:blur(10px);color:#fff}
.fcard-d:hover{transform:translateY(-6px);border-color:var(--gold);background:rgba(201,168,76,.06);box-shadow:0 18px 40px rgba(0,0,0,.4)}
.fcard-d .ic{font-size:1.8rem;margin-bottom:.9rem;display:inline-block;color:var(--gold)}
.fcard-d h4{font-family:var(--fh);font-size:1.15rem;color:#fff;margin-bottom:.6rem;line-height:1.3}
.fcard-d p{font-size:.92rem;color:rgba(255,255,255,.7);line-height:1.65}

/* numbered cards (used on stages) */
.num-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.4rem}
.num-card{padding:2.2rem 1.6rem;background:#fff;border-radius:18px;border:1px solid rgba(13,27,42,.06);position:relative;transition:all .5s var(--ease);overflow:hidden;text-align:center}
.num-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-d),var(--gold-l));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.num-card:hover{transform:translateY(-8px);box-shadow:0 18px 40px rgba(13,27,42,.1)}
.num-card:hover::before{transform:scaleX(1)}
.num-card .n{font-family:var(--fh);font-size:3rem;font-weight:800;color:var(--gold);line-height:1;margin-bottom:.5rem}
.num-card h3{font-family:var(--fh);font-size:1.15rem;color:var(--navy);margin-bottom:.6rem}
.num-card p{font-size:.88rem;color:var(--text);line-height:1.65}

/* checklist items */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid rgba(13,27,42,.08)}
.checklist li:last-child{border-bottom:none}
.checklist .ck{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-family:var(--fh);box-shadow:0 4px 12px var(--gold-glow)}
.checklist h4{font-family:var(--fh);font-size:1rem;color:var(--navy);margin-bottom:.2rem}
.checklist p{font-size:.88rem;color:var(--gray);margin:0}
.section-dark .checklist li{border-color:rgba(255,255,255,.08)}
.section-dark .checklist h4{color:#fff}
.section-dark .checklist p{color:rgba(255,255,255,.65)}

/* highlighted callout box (dark) */
.callout{padding:2.6rem;background:linear-gradient(135deg,var(--navy),var(--navy-3));border-radius:22px;color:#fff;position:relative;overflow:hidden;border:1px solid rgba(201,168,76,.2)}
.callout::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 0%,rgba(201,168,76,.15),transparent 60%)}
.callout-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center;position:relative;z-index:1}
.callout h3{font-family:var(--fh);font-size:1.7rem;color:#fff;margin-bottom:1rem;line-height:1.3}
.callout h3 span{color:var(--gold);font-style:italic}
.callout p{color:rgba(255,255,255,.78);font-size:.98rem;line-height:1.7;margin-bottom:1rem}
.callout-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.callout-stat{padding:1.4rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;text-align:center}
.callout-stat .n{font-family:var(--fh);font-size:1.9rem;color:var(--gold);font-weight:700;line-height:1}
.callout-stat .l{font-size:.7rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:1.2px;margin-top:.4rem}

/* price tag (premium feel) */
.price-tag{display:inline-block;padding:1.6rem 3rem;background:linear-gradient(135deg,var(--navy-2),var(--navy-3));border:1px solid rgba(201,168,76,.3);border-radius:14px;text-align:center;position:relative;box-shadow:0 12px 30px rgba(0,0,0,.3)}
.price-tag .pv{font-family:var(--fh);font-size:2.8rem;color:var(--gold);font-weight:700;line-height:1}
.price-tag .pl{font-size:.74rem;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.5);margin-top:.3rem;font-weight:500}

/* badge (used in hero) */
.badge{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem 1rem;background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.3);border-radius:50px;color:var(--gold-l);font-size:.7rem;text-transform:uppercase;letter-spacing:2px;font-weight:600;margin-bottom:1.2rem}
.badge.dark{background:rgba(13,27,42,.05);color:var(--navy);border-color:rgba(13,27,42,.15)}

/* MEC seal row */
.mec-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.4rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;margin:1.5rem 0;max-width:fit-content;backdrop-filter:blur(8px)}
.mec-row img{height:50px;display:block}
.mec-row .mt{font-size:.78rem;line-height:1.45;color:rgba(255,255,255,.78)}
.mec-row .mt strong{color:var(--gold);display:block;font-size:.85rem;margin-bottom:.15rem}

/* trademark line */
.tm-line{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;color:rgba(255,255,255,.6);margin-top:.6rem}
.tm-line .tm{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--gold);color:var(--navy);font-size:.7rem;font-weight:700}

/* guarantee box */
.guar-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.guar-card{padding:2.4rem;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.2);border-radius:18px;text-align:center;transition:all .4s var(--ease)}
.guar-card:hover{border-color:var(--gold);background:rgba(201,168,76,.06)}
.guar-card .ic{font-size:2.4rem;margin-bottom:.8rem;display:inline-block;color:var(--gold)}
.guar-card h3{font-family:var(--fh);font-size:1.3rem;color:#fff;margin-bottom:.8rem}
.guar-card p{color:rgba(255,255,255,.7);font-size:.92rem;line-height:1.65}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .nav ul{display:none}
  .hero-c,.phero-c{grid-template-columns:1fr;text-align:center;gap:2rem}
  .hero-img img,.phero-img img{max-height:380px}
  .hero-stats{grid-template-columns:1fr;gap:.8rem}
  .stat{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.9rem}
  .stat .num{font-size:1.5rem}
  .stat .lbl{margin-top:0}
  .hero-ctas{justify-content:center}
  .about-grid,.cta-c,.contact-grid,.callout-grid{grid-template-columns:1fr;gap:2rem}
  .contact-form{padding:1.8rem}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .guar-grid{grid-template-columns:1fr}
  .phero-logo{margin-left:auto;margin-right:auto}
  section{padding:4.5rem 1.4rem}
}
