/* ============================================================
   DigiDeepam v3 — Premium Classic Editorial Theme
   Ivory & ink, serif display, gold accent. Mobile-first.
   ============================================================ */
:root{
  --bg:#faf8f4;
  --bg2:#f3efe7;
  --surface:#ffffff;
  --ink:#181a1f;
  --ink2:#2b2e36;
  --text:#494d57;
  --muted:#7d818c;
  --line:#e6e0d4;
  --line2:#d8d0bf;
  --gold:#b08940;
  --gold2:#8f6c2c;
  --gold-soft:#f4ecdd;
  --green:#1f7a4d;
  --r:14px;
  --font-h:'Fraunces',Georgia,serif;
  --font-b:'Inter',-apple-system,sans-serif;
  --shadow-sm:0 1px 3px rgba(24,26,31,.06),0 4px 14px rgba(24,26,31,.05);
  --shadow-md:0 6px 28px rgba(24,26,31,.09);
  --shadow-lg:0 18px 50px rgba(24,26,31,.13);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
html,body{overflow-x:hidden}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.75;font-size:16px;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--font-h);color:var(--ink);line-height:1.18;font-weight:600;letter-spacing:-.01em}
a{color:var(--gold2);text-decoration:none;transition:.25s}
a:hover{color:var(--ink)}
img{max-width:100%}
::selection{background:var(--gold);color:#fff}
.container{max-width:1180px;margin:0 auto;padding:0 22px}
section{padding:84px 0;position:relative}
.grad-text{color:var(--gold2);font-style:italic}
.blob{display:none}

/* Reveal: only animate when JS is active — content NEVER invisible without JS */
html.js .reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.22,.61,.36,1)}
html.js .reveal.in{opacity:1;transform:none}

/* ---------- scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--gold);z-index:3000}

/* ---------- Navbar ---------- */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:.3s;background:rgba(250,248,244,.85);backdrop-filter:blur(10px)}
.navbar.scrolled{padding:11px 0;background:rgba(255,255,255,.95);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--font-h);font-weight:700;font-size:23px;color:var(--ink);letter-spacing:-.01em}
.brand span{color:var(--gold2);font-style:italic}
.brand em{color:var(--gold);font-style:normal}
.nav-links{display:flex;gap:2px;list-style:none;align-items:center}
.nav-links a{color:var(--ink2);font-weight:500;font-size:14px;padding:8px 13px;border-radius:8px;letter-spacing:.01em}
.nav-links a:hover{color:var(--gold2)}
.nav-links a.active{color:var(--gold2);font-weight:600}
.btn-nav{background:var(--ink);color:#fff!important;padding:10px 22px!important;border-radius:50px;font-weight:600;margin-left:12px}
.btn-nav:hover{background:var(--gold2);transform:translateY(-1px)}
.nav-toggle{display:none;background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--ink);font-size:24px;cursor:pointer;width:44px;height:42px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 30px;border-radius:50px;font-weight:600;font-size:14.5px;border:none;cursor:pointer;transition:.25s;font-family:var(--font-b);letter-spacing:.01em}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--gold2);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--line2)}
.btn-outline:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-2px)}
.btn-sm{padding:9px 18px;font-size:13px}
.btn-red{background:#c0392b;color:#fff}
.btn-red:hover{background:#962d22}

/* ---------- Hero ---------- */
.hero{min-height:92vh;display:flex;align-items:center;padding:140px 0 70px;background:var(--bg)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);color:var(--ink2);padding:8px 18px;border-radius:50px;font-size:13px;font-weight:500;margin-bottom:26px;box-shadow:var(--shadow-sm)}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{font-size:clamp(38px,5.4vw,64px);font-weight:600;margin-bottom:14px}
.typed-line{font-size:clamp(17px,2.2vw,23px);font-family:var(--font-b);font-weight:500;min-height:34px;margin-bottom:20px;color:var(--gold2)}
.typed-line .cursor{color:var(--gold);animation:blink .8s infinite;font-weight:300}
@keyframes blink{50%{opacity:0}}
.hero p.lead{max-width:540px;color:var(--text);font-size:16.5px;margin-bottom:32px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:40px}
.hero-proof{display:flex;gap:0;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:26px;max-width:560px}
.proof-item{display:flex;gap:12px;align-items:center;font-size:12.5px;color:var(--muted);flex:1 1 33%;padding-right:14px}
.proof-item b{color:var(--ink);font-size:15.5px;font-family:var(--font-h);display:block;line-height:1.3;font-weight:600}
.proof-item .ic{width:42px;height:42px;border-radius:50%;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--gold2);flex:0 0 42px}
.proof-item .ic.gold,.proof-item .ic.cyan,.proof-item .ic.hot{color:var(--gold2)}
.hero-photo{position:relative;text-align:center}
.hero-photo .ring{width:min(360px,78vw);height:min(430px,94vw);margin:0 auto;border-radius:200px 200px 18px 18px;padding:0;background:none;position:relative}
.hero-photo .ring::before{content:'';position:absolute;inset:-14px -14px auto auto;width:75%;height:75%;border:1.5px solid var(--gold);border-radius:200px 200px 0 0;opacity:.55;z-index:0}
.hero-photo .ring .inner{width:100%;height:100%;border-radius:200px 200px 18px 18px;background:var(--bg2);display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:110px;color:var(--line2);position:relative;z-index:1;box-shadow:var(--shadow-lg)}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-chip{position:absolute;background:var(--surface);border:1px solid var(--line);border-radius:50px;padding:9px 22px 9px 9px;font-size:13px;font-weight:600;color:var(--ink);display:flex;gap:12px;align-items:center;box-shadow:var(--shadow-md);z-index:2;font-family:var(--font-h)}
.hero-chip small{display:block;font-weight:400;color:var(--muted);font-size:10.5px;font-family:var(--font-b);letter-spacing:.04em}
.hero-chip .chip-ic{width:38px;height:38px;border-radius:50%;background:var(--gold-soft);border:1px solid #e7d9bb;display:flex;align-items:center;justify-content:center;flex:0 0 38px}
.hero-chip .chip-ic i{font-size:16px;color:var(--gold2)}
.chip-1{top:6%;left:-6%}
.chip-2{bottom:22%;right:-7%}
.chip-3{bottom:-2%;left:2%}

/* ---------- Marquee ---------- */
.marquee-band{background:var(--ink);padding:16px 0;overflow:hidden}
.marquee{display:flex;width:max-content;animation:scrollx 36s linear infinite}
.marquee:hover{animation-play-state:paused}
.mq-item{display:inline-flex;align-items:center;gap:11px;padding:0 28px;font-family:var(--font-b);font-weight:500;font-size:13px;color:#b9bcc4;white-space:nowrap;letter-spacing:.12em;text-transform:uppercase}
.mq-item i{color:var(--gold);font-size:9px}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- Section headers ---------- */
.sec-head{text-align:center;max-width:660px;margin:0 auto 54px}
.sec-head .kicker{display:inline-flex;align-items:center;gap:8px;color:var(--gold2);font-weight:600;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px}
.sec-head .kicker i{font-size:12px}
.sec-head h2{font-size:clamp(28px,3.8vw,42px)}
.sec-head p{color:var(--muted);margin-top:13px;font-size:15.5px}

/* ---------- Card base ---------- */
.gcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);transition:.3s ease;box-shadow:var(--shadow-sm)}
.gcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--line2)}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.svc-card{padding:32px 26px;position:relative}
.svc-card .num{position:absolute;top:22px;right:24px;font-family:var(--font-h);font-weight:600;font-size:15px;color:var(--line2);font-style:italic}
.svc-card .ic{width:54px;height:54px;border-radius:50%;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px;transition:.3s}
.svc-card .ic i{color:var(--gold2)}
.svc-card:hover .ic{background:var(--ink)}
.svc-card:hover .ic i{color:#fff}
.svc-card h3{font-size:17.5px;margin-bottom:10px}
.svc-card p{font-size:13.8px;color:var(--muted);line-height:1.7}

/* ---------- Stats band ---------- */
.stats-band{padding:0}
.stats-band .wrap{background:var(--ink);border-radius:0;border:none;padding:58px 22px;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats-band{background:var(--ink)}
.stats-band .container{max-width:1180px}
.stat h3{font-size:44px;font-weight:600;color:#fff;font-family:var(--font-h)}
.stat h3::after{content:'';display:block;width:28px;height:2px;background:var(--gold);margin:12px auto 10px}
.stat span{color:#9a9da6;font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:50px;align-items:start}
.about-card{padding:34px}
.about-card ul{list-style:none}
.about-card li{padding:12px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;font-size:14px}
.about-card li:last-child{border:none}
.about-card li b{color:var(--ink);white-space:nowrap;font-weight:600}
.about-text h3{font-size:28px;margin-bottom:18px}
.about-text p{color:var(--text);margin-bottom:16px;white-space:pre-line;font-size:15.5px}
.why-list{list-style:none;margin:20px 0}
.why-list li{padding:8px 0;display:flex;gap:12px;align-items:flex-start;font-size:14.8px;color:var(--ink2)}
.why-list li i{color:var(--gold2);font-size:16px;margin-top:4px}
.open-to{display:inline-flex;gap:10px;align-items:center;background:var(--gold-soft);border:1px solid #e7d9bb;border-radius:10px;padding:13px 20px;font-size:13.5px;color:var(--gold2);margin-top:6px;font-weight:500}

/* ---------- Skills ---------- */
.skill-cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px}
.skill-card{padding:30px 28px}
.skill-card h3{font-size:16.5px;margin-bottom:20px;display:flex;align-items:center;gap:12px}
.skill-card h3 .ic{width:40px;height:40px;border-radius:50%;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:16px;flex:0 0 40px}
.skill-card h3 .ic i{color:var(--gold2)}
.skill-row{margin-bottom:14px}
.skill-row .top{display:flex;justify-content:space-between;font-size:13.3px;margin-bottom:6px}
.skill-row .top b{color:var(--ink2);font-weight:500}
.skill-row .top span{color:var(--gold2);font-weight:600;font-size:12px}
.bar{height:4px;background:var(--bg2);border-radius:4px;overflow:hidden}
.bar i{display:block;height:100%;width:0;background:var(--gold);border-radius:4px;transition:width 1.2s cubic-bezier(.22,.61,.36,1)}
html:not(.js) .bar i{width:85%}

/* ---------- Campaigns ---------- */
.camp-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.camp-card{padding:36px 34px}
.camp-card .platform{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--line2);color:var(--muted);padding:6px 15px;border-radius:50px;margin-bottom:18px}
.camp-card .platform i{color:var(--gold2)}
.camp-card h3{font-size:22px;margin-bottom:12px}
.camp-card > p{color:var(--muted);font-size:14.4px;margin-bottom:26px}
.camp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.camp-stat{padding:18px 8px 4px;text-align:center;border-right:1px solid var(--line)}
.camp-stat:last-child{border-right:none}
.camp-stat b{display:block;font-family:var(--font-h);font-weight:600;font-size:24px;color:var(--gold2)}
.camp-stat span{font-size:10.5px;color:var(--muted);font-weight:500;letter-spacing:.06em;text-transform:uppercase}

/* ---------- Gallery ---------- */
.filter-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:42px}
.filter-btn{background:transparent;color:var(--ink2);border:1px solid var(--line2);padding:9px 22px;border-radius:50px;font-size:13px;font-weight:500;cursor:pointer;transition:.25s;font-family:var(--font-b)}
.filter-btn.active,.filter-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.gal-grid{columns:3;column-gap:20px}
.gal-item{break-inside:avoid;margin-bottom:20px;border-radius:12px;overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--line);transition:.3s;background:var(--surface);box-shadow:var(--shadow-sm)}
.gal-item img{width:100%;display:block;transition:.45s}
.gal-item:hover{box-shadow:var(--shadow-md)}
.gal-item:hover img{transform:scale(1.04)}
.gal-item .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,18,12,.85) 0%,transparent 50%);opacity:0;transition:.3s;display:flex;flex-direction:column;justify-content:flex-end;padding:20px}
.gal-item:hover .ov{opacity:1}
.gal-item .ov b{color:#fff;font-family:var(--font-h);font-size:15.5px;font-weight:600}
.gal-item .ov span{color:var(--gold);font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.gal-item .zoom{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:14px;opacity:0;transition:.3s;box-shadow:var(--shadow-sm)}
.gal-item:hover .zoom{opacity:1}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(16,15,12,.95);z-index:4000;display:none;align-items:center;justify-content:center;flex-direction:column;padding:28px}
.lightbox.open{display:flex;animation:lbIn .25s}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:min(980px,92vw);max-height:76vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox .lb-cap{color:#fff;font-family:var(--font-h);font-weight:600;margin-top:18px;font-size:16px;text-align:center}
.lightbox .lb-cap small{display:block;color:var(--gold);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-top:5px;font-family:var(--font-b)}
.lb-btn{position:absolute;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:19px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s}
.lb-btn:hover{background:var(--gold)}
.lb-close{top:24px;right:24px}
.lb-prev{left:22px;top:50%;transform:translateY(-50%)}
.lb-next{right:22px;top:50%;transform:translateY(-50%)}

/* ---------- Projects ---------- */
.pf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.pf-card{padding:30px 28px}
.pf-card .cat{display:inline-block;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold2);font-weight:600;margin-bottom:12px}
.pf-card h3{font-size:18.5px;margin-bottom:9px}
.pf-card p{color:var(--muted);font-size:13.8px;margin-bottom:16px}
.pf-card img{border-radius:10px;margin-bottom:16px;aspect-ratio:16/9;object-fit:cover;width:100%}
.pf-card a.link{font-weight:600;font-size:13.5px;display:inline-flex;gap:7px;align-items:center;color:var(--ink)}
.pf-card a.link:hover{color:var(--gold2);gap:11px}

/* ---------- Timeline ---------- */
.timeline{position:relative;max-width:880px;margin:0 auto}
.timeline::before{content:'';position:absolute;left:11px;top:8px;bottom:8px;width:1.5px;background:var(--line2)}
.tl-item{position:relative;padding:0 0 30px 54px}
.tl-item::before{content:'';position:absolute;left:4px;top:10px;width:15px;height:15px;border-radius:50%;background:var(--bg);border:2.5px solid var(--gold)}
.tl-card{padding:28px 32px}
.tl-item .period{display:inline-flex;gap:7px;align-items:center;color:var(--gold2);font-size:11.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}
.tl-item h3{font-size:20px}
.tl-item .company{color:var(--muted);font-weight:500;font-size:14px;margin:4px 0 14px;display:flex;gap:8px;align-items:center}
.tl-item .company i{color:var(--gold2)}
.tl-item ul{list-style:none}
.tl-item ul li{position:relative;padding:4px 0 4px 22px;color:var(--text);font-size:14.2px}
.tl-item ul li::before{content:'—';position:absolute;left:0;color:var(--gold);font-size:13px}

/* ---------- Education / awards ---------- */
.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.edu-col h3.col-title{font-size:19px;margin-bottom:20px;display:flex;align-items:center;gap:11px}
.edu-col h3.col-title i{color:var(--gold2)}
.edu-card{padding:22px 26px;display:flex;gap:17px;margin-bottom:15px}
.edu-card .ic{flex:0 0 46px;height:46px;border-radius:50%;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:19px}
.edu-card .ic i{color:var(--gold2)}
.edu-card .ic.gold-ic{background:var(--gold-soft)}
.edu-card .ic.gold-ic i{color:var(--gold2)}
.edu-card h4{font-size:16px;margin-bottom:4px}
.edu-card .inst{color:var(--gold2);font-size:13px;font-weight:600}
.edu-card .yr{color:var(--muted);font-size:12.5px;display:block;margin:2px 0 6px}
.edu-card p{color:var(--muted);font-size:13.5px}

/* ---------- YouTube ---------- */
.yt-section{background:var(--bg2)}
.channel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:20px;margin-bottom:50px}
.channel-card{padding:30px 24px;text-align:center}
.channel-card .yt-ic{width:58px;height:58px;margin:0 auto 16px;border-radius:50%;background:#faeae8;display:flex;align-items:center;justify-content:center;color:#c0392b;font-size:25px}
.channel-card h4{font-size:16.5px}
.channel-card p{font-size:13.2px;color:var(--muted);margin-top:7px}
.gold-badge{display:inline-flex;gap:6px;align-items:center;background:var(--gold);color:#fff;font-size:10.5px;font-weight:700;padding:6px 15px;border-radius:50px;margin-top:13px;letter-spacing:.08em}
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.video-card{overflow:hidden;padding:0}
.video-card .frame{aspect-ratio:16/9;width:100%;border:none;display:block}
.video-card .vc-body{padding:18px 22px}
.video-card h4{font-size:15.5px}
.video-card p{font-size:13px;color:var(--muted);margin-top:5px}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.testi-card{padding:32px;position:relative}
.testi-card .quote{font-size:54px;line-height:1;color:var(--gold);font-family:var(--font-h);position:absolute;top:18px;right:26px;opacity:.5}
.testi-card .stars{color:var(--gold);margin-bottom:14px;font-size:12px;letter-spacing:3px}
.testi-card p{color:var(--ink2);font-size:14.8px;margin-bottom:22px;font-style:italic;font-family:var(--font-h);line-height:1.8}
.testi-card .who{display:flex;align-items:center;gap:13px}
.testi-card .who .av{width:46px;height:46px;border-radius:50%;background:var(--ink);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;overflow:hidden;font-family:var(--font-h)}
.testi-card .who img{width:100%;height:100%;object-fit:cover}
.testi-card .who b{color:var(--ink);display:block;font-size:14.5px}
.testi-card .who span{font-size:12.5px;color:var(--muted)}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:22px}
.blog-card{overflow:hidden;display:flex;flex-direction:column;padding:0}
.blog-card .thumb{aspect-ratio:16/9;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--line2);overflow:hidden}
.blog-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.45s}
.blog-card:hover .thumb img{transform:scale(1.04)}
.blog-card .bc-body{padding:24px 26px;flex:1;display:flex;flex-direction:column}
.bc-meta{display:flex;gap:13px;font-size:12px;color:var(--muted);margin-bottom:11px;flex-wrap:wrap;align-items:center}
.bc-meta .tag{background:var(--gold-soft);color:var(--gold2);padding:4px 13px;border-radius:50px;font-weight:600;font-size:11px;letter-spacing:.04em}
.bc-meta .tag.research{background:#ece8f5;color:#5b4a8a}
.blog-card h3{font-size:17.5px;margin-bottom:9px;line-height:1.4}
.blog-card h3 a{color:var(--ink)}
.blog-card h3 a:hover{color:var(--gold2)}
.blog-card p{font-size:13.8px;color:var(--muted);flex:1}
.blog-card .read{margin-top:16px;font-weight:600;font-size:13.5px;display:inline-flex;gap:7px;align-items:center;color:var(--ink)}
.blog-card .read:hover{color:var(--gold2);gap:11px}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:800px;margin:0 auto}
.faq-item{margin-bottom:12px;overflow:hidden}
.faq-item:hover{transform:none}
.faq-q{width:100%;background:none;border:none;color:var(--ink);font-family:var(--font-h);font-weight:600;font-size:16.5px;padding:21px 26px;display:flex;justify-content:space-between;align-items:center;gap:16px;cursor:pointer;text-align:left}
.faq-q i{color:var(--gold2);font-size:15px;transition:.3s;flex:0 0 auto}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
html:not(.js) .faq-a{max-height:none}
.faq-a p{padding:0 26px 22px;color:var(--text);font-size:14.5px}

/* ---------- CTA band ---------- */
.cta-band{padding:0;background:var(--ink)}
.cta-wrap{padding:84px 22px;text-align:center;background:none;border-radius:0}
.cta-wrap h2{font-size:clamp(28px,4vw,44px);color:#fff;margin-bottom:14px}
.cta-wrap h2 em,.cta-wrap h2 .grad-text{color:var(--gold)}
.cta-wrap p{color:#a3a6af;max-width:540px;margin:0 auto 32px;font-size:15.5px}
.cta-wrap .btn{background:var(--gold);color:#fff}
.cta-wrap .btn:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}
.cta-wrap .btn.ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3);margin-left:12px}
.cta-wrap .btn.ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}

/* ---------- Single post ---------- */
.post-hero{padding:150px 0 52px;background:var(--bg2);border-bottom:1px solid var(--line)}
.post-hero h1{font-size:clamp(26px,3.8vw,42px);max-width:840px}
.post-wrap{max-width:780px;margin:0 auto}
.post-content{font-size:16.5px;color:var(--ink2);line-height:1.85}
.post-content h2{margin:36px 0 14px;font-size:26px}
.post-content h3{margin:26px 0 12px;font-size:20px}
.post-content p{margin-bottom:16px}
.post-content ul,.post-content ol{margin:0 0 18px 22px}
.post-content li{margin-bottom:8px}
.post-content img{border-radius:12px;margin:14px 0}
.post-content blockquote{border-left:3px solid var(--gold);padding:14px 24px;background:var(--surface);border-radius:0 12px 12px 0;margin:20px 0;font-family:var(--font-h);font-style:italic}
.post-content strong{color:var(--ink)}
.share-row{display:flex;gap:11px;align-items:center;margin:36px 0;padding:20px 0;border-block:1px solid var(--line);flex-wrap:wrap}
.share-row b{color:var(--ink)}
.share-row a{width:40px;height:40px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink2)}
.share-row a:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.tag-pill{background:var(--surface);border:1px solid var(--line);padding:5px 16px;border-radius:50px;font-size:12.5px;color:var(--ink2);display:inline-block;margin:0 6px 8px 0}
.tag-pill:hover{border-color:var(--gold2);color:var(--gold2)}
.comment{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:20px 24px;margin-bottom:14px}
.comment b{color:var(--ink)}
.comment .when{font-size:12px;color:var(--muted);margin-left:10px}
.comment p{margin-top:7px;font-size:14.2px;color:var(--text)}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}
input[type=text],input[type=email],input[type=tel],textarea,select{width:100%;background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:13px 17px;color:var(--ink);font-family:var(--font-b);font-size:14.3px;outline:none;transition:.25s}
input:focus,textarea:focus,select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,137,64,.13);background:#fff}
textarea{resize:vertical;min-height:140px}
label{font-size:13px;font-weight:600;color:var(--ink);display:block;margin-bottom:7px}
::placeholder{color:#a8aab2}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:30px}
.contact-info-card{padding:36px}
.ci-row{display:flex;gap:16px;margin-bottom:26px}
.ci-row .ic{flex:0 0 48px;height:48px;border-radius:50%;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gold2)!important}
.ci-row .ic i{color:var(--gold2)}
.ci-row b{color:var(--ink);display:block;font-size:14.5px;margin-bottom:1px}
.ci-row a,.ci-row span{color:var(--muted);font-size:13.8px}
.ci-row a:hover{color:var(--gold2)}
.contact-form-card{padding:36px}

/* ---------- Page hero ---------- */
.page-hero{padding:150px 0 64px;text-align:center;background:var(--bg2);border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(32px,4.4vw,50px)}
.page-hero p{color:var(--muted);max-width:560px;margin:13px auto 0;font-size:15.5px}

/* ---------- Misc ---------- */
.flash{position:fixed;top:86px;left:50%;transform:translateX(-50%);z-index:5000;padding:13px 30px;border-radius:12px;font-weight:600;font-size:14px;animation:fadeout 5s forwards;box-shadow:var(--shadow-lg)}
.flash-success{background:#103b27;color:#a7e8c5}
.flash-error{background:#4a1010;color:#f3b3b3}
@keyframes fadeout{0%,80%{opacity:1}100%{opacity:0;visibility:hidden}}
.back-top{position:fixed;right:26px;bottom:100px;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--line2);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:17px;opacity:0;visibility:hidden;transition:.3s;z-index:900;box-shadow:var(--shadow-md)}
.back-top.show{opacity:1;visibility:visible}
.back-top:hover{background:var(--ink);color:#fff}
.wa-float{position:fixed;right:22px;bottom:26px;width:56px;height:56px;border-radius:50%;background:#22a55a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;z-index:950;box-shadow:0 8px 26px rgba(34,165,90,.42)}
.wa-float:hover{transform:scale(1.07);color:#fff}
.pagination{display:flex;gap:9px;justify-content:center;margin-top:48px}
.pagination a,.pagination span{min-width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface);border:1px solid var(--line);color:var(--ink2);font-weight:600;font-size:13.5px;padding:0 12px}
.pagination a:hover{border-color:var(--ink);color:var(--ink)}
.pagination .cur{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);padding:70px 0 0;color:#b9bcc4}
.footer .brand{color:#fff}
.footer .brand span{color:var(--gold)}
.footer-grid{display:grid;grid-template-columns:1.35fr 1fr 1.15fr 1.15fr;gap:40px;padding-bottom:46px}
.footer h4{font-size:15px;margin-bottom:18px;color:#fff;font-family:var(--font-b);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:12.5px}
.footer-about{color:#9a9da6;font-size:13.8px;margin:14px 0 18px}
.footer-links{list-style:none}
.footer-links li{margin-bottom:11px;font-size:13.8px;color:#9a9da6}
.footer-links a{color:#9a9da6}
.footer-links a:hover{color:var(--gold);padding-left:3px}
.footer-links i{color:var(--gold);margin-right:7px}
.social-row{display:flex;gap:10px;flex-wrap:wrap}
.social-row a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#cdd0d8;font-size:15px}
.social-row a:hover{background:var(--gold);color:#fff;transform:translateY(-3px)}
.newsletter-form{display:flex;gap:9px}
.newsletter-form input{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:#fff}
.newsletter-form input:focus{background:rgba(255,255,255,.1);border-color:var(--gold)}
.newsletter-form input::placeholder{color:#8e919b}
.newsletter-form button{background:var(--gold);border:none;border-radius:10px;width:48px;color:#fff;font-size:16px;cursor:pointer;transition:.25s}
.newsletter-form button:hover{background:#fff;color:var(--ink)}
.footer-bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:22px 0;border-top:1px solid rgba(255,255,255,.09);font-size:12.8px;color:#8e919b}
.footer-bottom a{color:#8e919b}
.footer-bottom a:hover{color:var(--gold)}

/* ---------- Lite YouTube embed (speed) ---------- */
.yt-lite{position:relative;aspect-ratio:16/9;background:#0c0d10;cursor:pointer;overflow:hidden;display:block;width:100%}
.yt-lite img{width:100%;height:100%;object-fit:cover;opacity:.85;transition:.3s}
.yt-lite:hover img{opacity:1;transform:scale(1.03)}
.yt-lite .yt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:44px;background:#c0392b;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;box-shadow:0 8px 24px rgba(0,0,0,.4);transition:.25s}
.yt-lite:hover .yt-play{background:#e74c3c;transform:translate(-50%,-50%) scale(1.08)}
.yt-lite iframe{position:absolute;inset:0;top:0;left:0;width:100%;height:100%;border:none}

/* ---------- Post CTA + tables ---------- */
.post-cta{background:var(--gold-soft);border:1px solid #e7d9bb;border-left:4px solid var(--gold);border-radius:12px;padding:20px 24px;margin:26px 0;font-size:15px;color:var(--ink2)}
.post-cta .btn{margin-top:10px}
.post-content table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14.5px;background:var(--surface);border-radius:10px;overflow:hidden}
.post-content th{background:var(--ink);color:#fff;text-align:left;padding:12px 16px;font-weight:600;font-size:13.5px}
.post-content td{padding:11px 16px;border-bottom:1px solid var(--line);color:var(--ink2)}
.post-content tr:last-child td{border-bottom:none}

/* ---------- Ads & Deals ---------- */
.ad-slot{margin:26px 0;text-align:center;min-height:0}
.ad-slot:empty{display:none}
.aff-banner{margin:30px 0;text-align:center;position:relative}
.aff-banner img{max-width:100%;height:auto;border-radius:12px;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.25s}
.aff-banner a:hover img{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.deal-box{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:28px;margin:36px 0;box-shadow:var(--shadow-sm)}
.deal-box h3{font-size:19px;margin-bottom:18px}
.deal-box h3 i{color:var(--gold2)}
.deal-row{display:flex;align-items:center;gap:16px;padding:14px 0;border-top:1px solid var(--line)}
.deal-ic{width:46px;height:46px;border-radius:12px;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--gold2);flex:0 0 46px}
.deal-ic.big{width:58px;height:58px;font-size:25px;border-radius:50%;margin-bottom:18px}
.deal-info{flex:1}
.deal-info b{color:var(--ink);display:block;font-size:15px}
.deal-info small{color:var(--muted);font-size:12px}
.coupon-chip{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:var(--gold);font-weight:700;font-size:12.5px;letter-spacing:.12em;padding:6px 14px;border-radius:8px;cursor:pointer;border:1px dashed var(--gold);margin:4px 6px 0 0;user-select:none}
.coupon-chip:hover{background:var(--gold2);color:#fff}
.coupon-chip.copied{background:var(--green);color:#fff;border-color:var(--green)}
.deal-disclosure{font-size:12px;color:var(--muted);margin-top:16px}
.deals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.deal-card{padding:34px 30px;position:relative;display:flex;flex-direction:column;align-items:flex-start}
.deal-card h3{font-size:20px;margin-bottom:10px}
.deal-card p{font-size:14px;color:var(--muted);flex:1;margin-bottom:18px}
.deal-card .btn{margin-top:6px}
.deal-featured{border-color:var(--gold);box-shadow:0 8px 30px rgba(176,137,64,.16)}
.deal-badge{position:absolute;top:-12px;right:22px;background:var(--gold);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:50px}
.coupon-line{margin-bottom:16px}
.coupon-line small{display:block;color:var(--muted);font-size:12px;margin-top:5px}

/* ============================================================
   RESPONSIVE — tablet & mobile
   ============================================================ */
@media(max-width:1240px){
  .nav-links{gap:0}
  .nav-links a{padding:8px 9px;font-size:13.3px}
  .btn-nav{padding:9px 16px!important;margin-left:6px}
}
@media(max-width:1100px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{columns:2}
}
@media(max-width:991px){
  .hero{min-height:auto;padding:120px 0 60px}
  .hero-grid,.about-grid,.contact-grid,.camp-grid{grid-template-columns:1fr;gap:36px}
  .hero-photo{order:-1}
  .hero-photo .ring{width:min(250px,66vw);height:min(300px,80vw)}
  .stats-band .wrap{grid-template-columns:repeat(2,1fr);padding:44px 18px}
  .edu-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-toggle{display:flex;align-items:center;justify-content:center}
  .nav-links{position:fixed;top:0;bottom:0;left:auto;right:-110%;height:100%;width:min(310px,85vw);background:#fff;flex-direction:column;align-items:stretch;padding:88px 26px 30px;gap:2px;transition:right .35s ease;border-left:1px solid var(--line);z-index:999;box-shadow:var(--shadow-lg);overflow-y:auto;visibility:hidden}
  .nav-links.open{right:0;visibility:visible}
  .nav-links a{padding:13px 14px;font-size:15px;border-radius:10px;display:block}
  .nav-links a:hover{background:var(--bg2)}
  .btn-nav{margin:14px 0 0;text-align:center;justify-content:center;display:flex}
}
@media(max-width:640px){
  .container{padding:0 18px}
  section{padding:56px 0}
  .sec-head{margin-bottom:36px}
  .sec-head h2{font-size:26px}
  .sec-head p{font-size:14px}
  .hero{padding:104px 0 48px}
  .hero h1{font-size:33px}
  .typed-line{font-size:16.5px;min-height:28px;margin-bottom:16px}
  .hero p.lead{font-size:14.8px;margin-bottom:24px}
  .hero-badge{font-size:11px;padding:7px 14px;margin-bottom:18px}
  .hero-cta{gap:10px;margin-bottom:30px}
  .hero-cta .btn{flex:1 1 calc(50% - 10px);justify-content:center;padding:12px 14px;font-size:13px}
  .hero-proof{padding-top:20px;gap:14px 0}
  .proof-item{flex:1 1 100%;padding-right:0}
  .hero-photo .ring{width:min(210px,60vw);height:min(252px,72vw)}
  .hero-chip{display:none}
  .mq-item{padding:0 16px;font-size:11px}
  .marquee-band{padding:12px 0}
  .stats-band .wrap{padding:38px 14px;gap:24px}
  .stat h3{font-size:30px}
  .stat span{font-size:10.5px}
  .svc-grid{grid-template-columns:1fr;gap:14px}
  .svc-card{padding:26px 22px}
  .about-card{padding:24px 20px}
  .about-card li{font-size:13.3px;flex-wrap:wrap;padding:10px 0}
  .about-text h3{font-size:22px}
  .about-text p{font-size:14.5px}
  .why-list li{font-size:13.8px}
  .open-to{font-size:12.3px;padding:12px 15px;flex-wrap:wrap}
  .camp-card{padding:26px 20px}
  .camp-card h3{font-size:19px}
  .camp-card > p{font-size:13.6px;margin-bottom:20px}
  .camp-stat b{font-size:19px}
  .camp-stat span{font-size:9px}
  .gal-grid{columns:2;column-gap:12px}
  .gal-item{margin-bottom:12px;border-radius:10px}
  .filter-row{gap:8px;margin-bottom:28px}
  .filter-btn{padding:8px 15px;font-size:12px}
  .timeline::before{left:8px}
  .tl-item{padding:0 0 22px 36px}
  .tl-item::before{left:2px;width:13px;height:13px}
  .tl-card{padding:20px 18px}
  .tl-item h3{font-size:17px}
  .tl-item ul li{font-size:13.4px;padding-left:18px}
  .skill-cats{grid-template-columns:1fr;gap:14px}
  .skill-card{padding:24px 20px}
  .edu-card{padding:17px 16px;gap:12px;margin-bottom:12px}
  .edu-card .ic{flex:0 0 40px;height:40px;font-size:16px}
  .edu-card h4{font-size:14.3px}
  .channel-card{padding:24px 18px}
  .testi-card{padding:24px 20px}
  .testi-card p{font-size:14px}
  .blog-card .bc-body{padding:20px 18px}
  .blog-card h3{font-size:15.8px}
  .faq-q{font-size:14.3px;padding:16px 18px}
  .faq-a p{padding:0 18px 16px;font-size:13.5px}
  .cta-wrap{padding:56px 20px}
  .cta-wrap .btn{width:100%;justify-content:center}
  .cta-wrap .btn.ghost{margin:12px 0 0}
  .contact-info-card,.contact-form-card{padding:24px 20px}
  .ci-row{gap:13px;margin-bottom:20px}
  .ci-row .ic{flex:0 0 42px;height:42px;font-size:16px}
  .form-grid{grid-template-columns:1fr}
  .page-hero{padding:112px 0 44px}
  .page-hero h1{font-size:28px}
  .page-hero p{font-size:14px}
  .page-hero .btn{padding:12px 18px;font-size:13px;margin:5px 3px!important}
  .post-hero{padding:108px 0 36px}
  .post-content{font-size:15.2px}
  .footer{padding:50px 0 0}
  .footer-grid{grid-template-columns:1fr;gap:28px;padding-bottom:30px}
  .footer-bottom{justify-content:center;text-align:center}
  .btn{padding:13px 24px;font-size:13.5px}
  .back-top{right:16px;bottom:88px;width:40px;height:40px;font-size:15px}
  .wa-float{right:14px;bottom:18px;width:50px;height:50px;font-size:23px}
  .video-grid,.pf-grid,.testi-grid,.blog-grid{grid-template-columns:1fr}
  .channel-grid{grid-template-columns:1fr 1fr;gap:12px}
  .flash{width:calc(100% - 28px);text-align:center;font-size:13px;padding:12px 14px}
  .lightbox{padding:12px}
  .lb-btn{width:40px;height:40px;font-size:16px}
  .lb-close{top:12px;right:12px}
  .lb-prev{left:6px}.lb-next{right:6px}
}
@media(max-width:380px){
  .hero h1{font-size:28px}
  .hero-cta .btn{flex:1 1 100%}
  .gal-grid{columns:1}
  .channel-grid{grid-template-columns:1fr}
}

/* ============================================================
   CROSS-BROWSER FALLBACKS (Safari / old Chrome / Firefox / Edge)
   ============================================================ */
/* fallback font-sizes for browsers without clamp() */
@supports not (font-size: clamp(1rem, 2vw, 2rem)){
  .hero h1{font-size:46px}
  .typed-line{font-size:20px}
  .sec-head h2{font-size:34px}
  .page-hero h1{font-size:38px}
  .post-hero h1{font-size:32px}
  .cta-wrap h2{font-size:34px}
}
/* -webkit- prefix for backdrop blur (Safari) */
.navbar{-webkit-backdrop-filter:blur(10px)}
.navbar.scrolled{-webkit-backdrop-filter:blur(10px)}
/* explicit box offsets for browsers without `inset` */
.lightbox{top:0;right:0;bottom:0;left:0}
.scroll-progress{top:0;left:0}
.wa-float{right:22px;bottom:26px}
/* aspect-ratio fallback (old Safari/Firefox) */
@supports not (aspect-ratio: 16 / 9){
  .video-card .frame{height:230px}
  .blog-card .thumb{height:200px;position:relative}
  .pf-card img{height:180px}
}
/* column masonry prefixes */
.gal-grid{-webkit-columns:3;-moz-columns:3}
.gal-item{-webkit-column-break-inside:avoid;page-break-inside:avoid}
@media(max-width:1100px){.gal-grid{-webkit-columns:2;-moz-columns:2}}
@media(max-width:640px){.gal-grid{-webkit-columns:2;-moz-columns:2}}
@media(max-width:380px){.gal-grid{-webkit-columns:1;-moz-columns:1}}
/* flex gap fallback for old Safari (margins instead of gap loss) */
@supports not (gap: 1rem) {
  .hero-cta .btn{margin:0 12px 12px 0}
  .nav-links li{margin-left:4px}
  .social-row a{margin-right:10px}
  .filter-row .filter-btn{margin:0 8px 8px 0}
}
/* sticky nav fallback when position:fixed quirks (very old) */
.navbar{will-change:auto}
/* smooth font rendering on Windows/Firefox */
body{-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
