/* ============================================================
   DIGILYTIXS — Performance Marketing Agency
   Master Stylesheet | Mobile-first | 2026
   ============================================================ */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Plus Jakarta Sans','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.6;color:var(--text);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:none;background:none;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:1rem}
ul{list-style:none}

/* ---------- Variables ---------- */
:root{
  --primary:#0e1a2e;
  --primary-light:#1a2942;
  --accent:#ff5722;
  --accent-hover:#e64a1f;
  --accent-soft:#ffe5dc;
  --text:#0e1a2e;
  --text-muted:#64748b;
  --bg:#f5f6f8;
  --bg-alt:#ffffff;
  --border:#e5e7eb;
  --success:#10b981;
  --shadow-sm:0 1px 2px rgba(14,26,46,.05);
  --shadow:0 4px 12px rgba(14,26,46,.08);
  --shadow-lg:0 12px 32px rgba(14,26,46,.12);
  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;
  --container:1200px;
  --header-h:64px;
}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
section{padding:64px 0}
@media(min-width:768px){section{padding:96px 0}}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5{font-weight:800;color:var(--primary);line-height:1.15;letter-spacing:-0.02em}
h1{font-size:clamp(2rem,6vw,4rem)}
h2{font-size:clamp(1.75rem,4.5vw,3rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}
h4{font-size:1.15rem}
.section-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--accent-soft);color:var(--accent);font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:8px 16px;border-radius:var(--radius-pill);margin-bottom:18px}
.section-title{text-align:center;margin-bottom:14px}
.section-subtitle{text-align:center;color:var(--text-muted);max-width:640px;margin:0 auto 56px;font-size:1.05rem}
.text-accent{color:var(--accent)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-pill);font-weight:700;font-size:.95rem;transition:transform .2s ease,background .2s ease,box-shadow .2s ease;white-space:nowrap;line-height:1}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 14px rgba(255,87,34,.32)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 22px rgba(255,87,34,.4)}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-light{background:#fff;color:var(--primary)}
.btn-light:hover{background:var(--accent);color:#fff}
.btn-sm{padding:10px 20px;font-size:.85rem}
.btn-lg{padding:16px 34px;font-size:1rem}

/* ============================================================
   HEADER & NAVBAR
   ============================================================ */
.header{
  position:sticky;
  top:0;left:0;right:0;
  height:var(--header-h);
  background:rgba(245,246,248,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  z-index:900;
  transition:background .3s ease,box-shadow .3s ease;
  border-bottom:1px solid transparent;
}
.header.scrolled{
  background:rgba(255,255,255,.98);
  box-shadow:var(--shadow-sm);
  border-bottom-color:var(--border);
}

/* Nav wrapper */
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:var(--header-h);
  gap:20px;
}

/* Logo */
.logo{font-size:1.5rem;font-weight:800;letter-spacing:-0.03em;color:var(--primary);flex-shrink:0}
.logo span{color:var(--accent)}

/* ============================================================
   DESKTOP NAV LINKS  (≥1024px only)
   ============================================================ */
.nav-desktop{
  display:none; /* hidden by default (mobile-first) */
  align-items:center;
  gap:6px;
  list-style:none;
}
@media(min-width:1024px){
  .nav-desktop{display:flex}
}
.nav-desktop a{
  font-weight:600;
  font-size:.92rem;
  color:var(--text);
  padding:8px 12px;
  border-radius:8px;
  transition:color .15s,background .15s;
  white-space:nowrap;
}
.nav-desktop a:hover,
.nav-desktop a.active{color:var(--accent)}
.nav-desktop li:last-child a.btn{padding:10px 20px}

/* ============================================================
   HAMBURGER BUTTON  (visible <1024px)
   ============================================================ */
.menu-toggle{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  width:44px;
  height:44px;
  gap:5px;
  border-radius:8px;
  transition:background .15s;
  flex-shrink:0;
  z-index:1001; /* always above overlay */
  position:relative;
}
.menu-toggle:hover{background:var(--bg)}
.menu-toggle span{
  display:block;
  width:22px;
  height:2px;
  background:var(--primary);
  border-radius:2px;
  transition:transform .3s ease, opacity .3s ease;
  transform-origin:center;
}

/* Animated X state */
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hide hamburger on desktop */
@media(min-width:1024px){
  .menu-toggle{display:none}
}

/* ============================================================
   MOBILE NAV OVERLAY
   — Completely outside .header and .container
   — Covers the FULL viewport: top:0, left:0, right:0, bottom:0
   — No container clipping ever possible
   ============================================================ */
.mobile-nav-overlay{
  /* Hidden state */
  position:fixed;
  inset:0;                          /* top/right/bottom/left all 0 */
  z-index:999;                      /* below hamburger (1001), above everything else */
  background:#fff;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:stretch;
  padding:calc(var(--header-h) + 24px) 24px 40px;
  overflow-y:auto;

  /* Slide-in from right */
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1),
              visibility 0s linear .32s;
  visibility:hidden;
  pointer-events:none;
}

/* Open state — JS adds .open to this element */
.mobile-nav-overlay.open{
  transform:translateX(0);
  visibility:visible;
  pointer-events:auto;
  transition:transform .32s cubic-bezier(.4,0,.2,1),
              visibility 0s linear 0s;
}

/* Only show overlay on mobile/tablet */
@media(min-width:1024px){
  .mobile-nav-overlay{display:none !important}
}

/* Nav links inside the overlay */
.mobile-nav-menu{
  list-style:none;
  width:100%;
  max-width:480px;
  margin:0 auto;
}
.mobile-nav-menu li{
  border-bottom:1px solid var(--border);
}
.mobile-nav-menu li:last-child{
  border-bottom:none;
  margin-top:20px;
}
.mobile-nav-menu a{
  display:block;
  width:100%;
  font-size:1.15rem;
  font-weight:600;
  color:var(--text);
  padding:18px 8px;
  transition:color .15s;
}
.mobile-nav-menu a:hover{color:var(--accent)}
.mobile-nav-menu li.nav-cta a{
  display:flex;
  justify-content:center;
  width:100%;
  border-radius:var(--radius-pill);
  padding:16px 28px;
  font-size:1rem;
}

/* Body scroll lock when menu open */
body.nav-open{overflow:hidden}

/* ============================================================
   Hero
   ============================================================ */
.hero{padding:50px 0 60px;position:relative;overflow:hidden}
@media(min-width:768px){.hero{padding:80px 0 90px}}
.hero::before{content:"";position:absolute;top:-120px;right:-120px;width:480px;height:480px;background:radial-gradient(circle,rgba(255,87,34,.08),transparent 70%);pointer-events:none}
.hero h1{margin-bottom:22px}
.hero h1 .accent{color:var(--accent)}
.hero-tagline{font-size:1.05rem;color:var(--text-muted);margin-bottom:34px;max-width:560px;font-weight:500}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
@media(max-width:480px){.hero-ctas .btn{width:100%;justify-content:center}}

/* ---------- Stats Bar ---------- */
.stats-bar{background:var(--primary);color:#fff;padding:22px 0}
.stats-grid{display:flex;flex-wrap:wrap;justify-content:space-around;align-items:center;text-align:center;gap:16px}
.stats-grid > div{flex:1;min-width:200px;font-weight:600;font-size:.95rem;position:relative}
.stats-grid > div + div::before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:1px;height:24px;background:rgba(255,255,255,.2)}
@media(max-width:600px){.stats-grid > div + div::before{display:none}.stats-grid{flex-direction:column;gap:8px}}

/* ---------- Marquee ---------- */
.marquee{background:var(--accent);color:#fff;overflow:hidden;padding:14px 0;font-weight:700}
.marquee-track{display:flex;gap:60px;animation:scroll-x 40s linear infinite;white-space:nowrap}
.marquee-track > span{display:inline-flex;align-items:center;gap:10px;font-size:.95rem}
.marquee-track > span::before{content:"★";color:#ffe5dc}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Cards / Grid ---------- */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{background:#fff;border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:transform .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}

/* ---------- Service Cards ---------- */
.service-card{position:relative;padding:32px 28px}
.service-card .icon{width:56px;height:56px;border-radius:14px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:18px}
.service-card h3{margin-bottom:10px;font-size:1.2rem}
.service-card p{color:var(--text-muted);font-size:.95rem;margin-bottom:18px}
.service-card a{color:var(--accent);font-weight:700;font-size:.92rem}
.service-card a::after{content:" →";transition:margin-left .2s}
.service-card a:hover::after{margin-left:4px}

/* ---------- Case Study Cards ---------- */
.filter-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:40px}
.filter-pill{background:#fff;border:1px solid var(--border);padding:8px 18px;border-radius:var(--radius-pill);font-size:.88rem;font-weight:600;color:var(--text-muted);transition:all .2s}
.filter-pill:hover,.filter-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.case-card{display:flex;flex-direction:column;padding:28px}
.case-card .tags{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.case-card .tag{background:var(--accent-soft);color:var(--accent);font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.04em}
.case-card .tag.industry{background:#e8eef7;color:var(--primary)}
.case-card p.problem{color:var(--text-muted);font-size:.95rem;margin-bottom:18px;flex:1}
.before-after{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px;background:var(--bg);border-radius:var(--radius);padding:18px}
.before-after h5{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;font-weight:700}
.before-after .before h5{color:#94a3b8}
.before-after .after h5{color:var(--success)}
.before-after .metric{font-size:.85rem;color:var(--text-muted);margin-bottom:4px}
.before-after .metric strong{color:var(--text);font-weight:700;display:block;font-size:.95rem}
.case-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:16px;margin-top:auto}
.roi-badge{font-weight:800;color:var(--accent);font-size:1.1rem}
.case-footer a{color:var(--primary);font-weight:700;font-size:.88rem}

/* ---------- Testimonials ---------- */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.testimonial-card{background:#fff;padding:32px 28px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative}
.testimonial-card::before{content:"\201C";position:absolute;top:8px;left:20px;font-size:5rem;color:var(--accent-soft);font-family:Georgia,serif;line-height:1}
.testimonial-card blockquote{font-size:1rem;line-height:1.6;color:var(--text);margin:14px 0 22px;position:relative;z-index:1}
.testimonial-author{display:flex;align-items:center;gap:14px}
.testimonial-author img{width:52px;height:52px;border-radius:50%;object-fit:cover;background:var(--bg)}
.testimonial-author .name{font-weight:700;font-size:.95rem}
.testimonial-author .role{font-size:.82rem;color:var(--text-muted)}

/* ---------- Industries ---------- */
.industries-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.industry-card{background:#fff;border-radius:var(--radius-lg);padding:28px 24px;border:1px solid var(--border);transition:all .25s ease;cursor:pointer}
.industry-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.industry-card .ico{font-size:1.8rem;margin-bottom:12px;color:var(--accent)}
.industry-card h3{font-size:1.1rem;margin-bottom:8px}
.industry-card p{font-size:.9rem;color:var(--text-muted);margin-bottom:14px;min-height:42px}
.industry-card .result{font-weight:700;color:var(--accent);font-size:.95rem}

/* ---------- Why Choose ---------- */
.why-section{background:var(--primary);color:#fff}
.why-section h2,.why-section .section-eyebrow{color:#fff}
.why-section .section-eyebrow{background:rgba(255,87,34,.18)}
.why-section .section-subtitle{color:rgba(255,255,255,.7)}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-bottom:60px}
.why-card{padding:32px 28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg)}
.why-card .ico{width:52px;height:52px;border-radius:14px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:18px}
.why-card h3{color:#fff;margin-bottom:10px}
.why-card p{color:rgba(255,255,255,.75);font-size:.95rem}
.counter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;text-align:center}
.counter-grid > div .num{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;color:var(--accent);line-height:1;display:block}
.counter-grid > div .lbl{font-size:.92rem;color:rgba(255,255,255,.7);margin-top:8px;display:block}

/* ---------- CTA Form Section ---------- */
.cta-section{background:linear-gradient(135deg,var(--accent),#ff8c5a);color:#fff;text-align:center}
.cta-section h2{color:#fff}
.cta-section p{margin:14px auto 32px;max-width:540px;color:rgba(255,255,255,.95)}
.lead-form{background:#fff;color:var(--text);max-width:540px;margin:0 auto;padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:left}
.form-row{display:grid;gap:14px;margin-bottom:14px}
.form-row.cols-2{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:12px;background:#fff;color:var(--text);transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.form-group textarea{min-height:100px;resize:vertical}
.form-msg{margin-top:14px;padding:12px;border-radius:10px;font-size:.9rem;display:none}
.form-msg.success{display:block;background:#d1fae5;color:#065f46}
.form-msg.error{display:block;background:#fee2e2;color:#991b1b}
.cta-section .form-note{font-size:.85rem;color:var(--text-muted);text-align:center;margin-top:14px;display:block}

/* ---------- Footer ---------- */
.footer{background:var(--primary);color:rgba(255,255,255,.78);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:36px;margin-bottom:40px}
.footer-grid h4{color:#fff;font-size:.95rem;margin-bottom:18px;text-transform:uppercase;letter-spacing:.06em}
.footer-grid ul li{margin-bottom:10px}
.footer-grid a{font-size:.92rem;transition:color .2s}
.footer-grid a:hover{color:var(--accent)}
.footer-brand p{margin:14px 0 18px;font-size:.92rem}
.social-icons{display:flex;gap:12px}
.social-icons a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background .2s}
.social-icons a:hover{background:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:.85rem}

/* ---------- FABs ---------- */
.fab-container{position:fixed;bottom:18px;right:18px;display:flex;flex-direction:column;gap:12px;z-index:80}
.fab{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;box-shadow:0 8px 22px rgba(0,0,0,.18);transition:transform .25s ease;position:relative}
.fab:hover{transform:scale(1.08)}
.fab.call{background:linear-gradient(135deg,var(--accent),#ff8c5a)}
.fab.whatsapp{background:#25d366}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid currentColor;animation:pulse-ring 2s ease-out infinite;opacity:.5;pointer-events:none}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.6);opacity:0}}
@media(min-width:768px){.fab-container{bottom:24px;right:24px}.fab{width:60px;height:60px;font-size:1.55rem}}

/* ---------- Sticky Mobile CTA ---------- */
.sticky-cta{display:none}
@media(max-width:767px){
  .sticky-cta{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:10px 12px;gap:8px;z-index:75;box-shadow:0 -4px 12px rgba(0,0,0,.06)}
  .sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border-radius:var(--radius-pill);font-weight:700;font-size:.85rem}
  .sticky-cta a.call{background:var(--primary);color:#fff}
  .sticky-cta a.whats{background:#25d366;color:#fff}
  body{padding-bottom:72px}
  .fab-container{bottom:80px}
}

/* ---------- Page Hero (sub-pages) ---------- */
.page-hero{padding:60px 0 40px;text-align:center;background:#fff;border-bottom:1px solid var(--border)}
.page-hero h1{margin-bottom:14px}
.page-hero p{color:var(--text-muted);max-width:680px;margin:0 auto;font-size:1.05rem}
.breadcrumb{font-size:.85rem;color:var(--text-muted);margin-bottom:14px}
.breadcrumb a{color:var(--accent)}

/* ---------- Services Page ---------- */
.service-block{padding:50px 30px;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--border);margin-bottom:30px;display:grid;grid-template-columns:1fr;gap:30px}
@media(min-width:900px){.service-block{grid-template-columns:1.1fr 1fr;gap:50px}.service-block:nth-child(even) > div:first-child{order:2}}
.service-block .case-result{background:var(--accent-soft);border-radius:12px;padding:14px 18px;margin:14px 0 18px;font-size:.92rem}
.service-block .case-result strong{color:var(--accent);display:block;margin-bottom:4px;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}
.deliverables h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:16px 0 10px}
.deliverables ul{display:grid;grid-template-columns:1fr;gap:8px}
@media(min-width:520px){.deliverables ul{grid-template-columns:1fr 1fr}}
.deliverables ul li{display:flex;align-items:flex-start;gap:8px;font-size:.92rem}
.deliverables ul li::before{content:"✓";color:var(--accent);font-weight:700;flex-shrink:0}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.tag-list span{background:var(--bg);padding:5px 12px;border-radius:var(--radius-pill);font-size:.82rem;color:var(--text-muted)}

/* ---------- Process / Steps ---------- */
.process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:40px}
.process-step{position:relative;padding:30px 24px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border)}
.process-step .step-num{font-size:2.2rem;font-weight:800;color:var(--accent-soft);position:absolute;top:18px;right:24px}
.process-step h3{margin-bottom:8px;font-size:1.15rem}
.process-step p{color:var(--text-muted);font-size:.92rem}

/* ---------- Pricing ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;align-items:stretch}
.price-card{background:#fff;border-radius:var(--radius-lg);padding:36px 28px;border:1px solid var(--border);position:relative;display:flex;flex-direction:column}
.price-card.featured{border:2px solid var(--accent);transform:scale(1.02);box-shadow:var(--shadow-lg)}
.price-card.featured .badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:4px 14px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.price-card h3{margin-bottom:6px}
.price-card .desc{color:var(--text-muted);font-size:.9rem;margin-bottom:20px}
.price-card .price{font-size:2rem;font-weight:800;color:var(--primary);margin-bottom:24px}
.price-card .price small{font-size:.88rem;font-weight:500;color:var(--text-muted)}
.price-card ul{margin-bottom:30px;flex:1}
.price-card ul li{padding:8px 0;font-size:.92rem;display:flex;align-items:flex-start;gap:8px}
.price-card ul li::before{content:"✓";color:var(--accent);font-weight:700}
.price-card .btn{width:100%;justify-content:center}

/* ---------- FAQ ---------- */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden}
.faq-question{width:100%;padding:18px 22px;text-align:left;font-weight:700;font-size:1rem;color:var(--primary);display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-question::after{content:"+";font-size:1.4rem;color:var(--accent);transition:transform .2s;flex-shrink:0}
.faq-item.open .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 22px}
.faq-item.open .faq-answer{max-height:500px;padding:0 22px 18px}
.faq-answer p{color:var(--text-muted);font-size:.95rem;line-height:1.65}

/* ---------- About Page ---------- */
.about-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:900px){.about-grid{grid-template-columns:1.1fr 1fr;gap:60px}.about-grid.reverse > div:first-child{order:2}}
.about-grid img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.team-card{text-align:center;background:#fff;padding:24px;border-radius:var(--radius-lg);border:1px solid var(--border);transition:transform .25s}
.team-card:hover{transform:translateY(-4px)}
.team-card img{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto 14px}
.team-card h4{font-size:1.05rem;margin-bottom:4px}
.team-card .role{font-size:.85rem;color:var(--accent);font-weight:600;margin-bottom:10px}
.timeline{position:relative;padding:20px 0;max-width:780px;margin:0 auto}
.timeline::before{content:"";position:absolute;left:24px;top:0;bottom:0;width:2px;background:var(--accent-soft)}
@media(min-width:768px){.timeline::before{left:50%}}
.timeline-item{position:relative;padding-left:64px;margin-bottom:36px}
@media(min-width:768px){.timeline-item{width:50%;padding-left:0;padding-right:50px}.timeline-item:nth-child(even){margin-left:50%;padding-left:50px;padding-right:0}}
.timeline-item .year{position:absolute;left:0;top:0;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem}
@media(min-width:768px){.timeline-item .year{left:auto;right:-24px}.timeline-item:nth-child(even) .year{left:-24px;right:auto}}
.timeline-item h4{margin-bottom:6px}
.timeline-item p{color:var(--text-muted);font-size:.92rem}

/* ---------- Contact Page ---------- */
.contact-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:900px){.contact-grid{grid-template-columns:1.4fr 1fr;gap:50px}}
.contact-info{background:#fff;border-radius:var(--radius-lg);padding:32px;border:1px solid var(--border)}
.contact-info h3{font-size:1.1rem;margin-bottom:14px}
.contact-info p,.contact-info a{color:var(--text-muted);font-size:.95rem;margin-bottom:8px;display:block}
.contact-info a:hover{color:var(--accent)}
.contact-info .info-block{padding:16px 0;border-bottom:1px solid var(--border)}
.contact-info .info-block:last-child{border-bottom:none}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}
.blog-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.blog-card .img{aspect-ratio:16/10;background:var(--bg) center/cover;background-image:linear-gradient(135deg,var(--accent-soft),var(--bg))}
.blog-card .content{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card .meta{font-size:.78rem;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}
.blog-card h3{font-size:1.1rem;margin-bottom:10px;line-height:1.35}
.blog-card p{color:var(--text-muted);font-size:.92rem;flex:1;margin-bottom:16px}
.blog-card a.read{color:var(--accent);font-weight:700;font-size:.88rem;align-self:flex-start}

/* ---------- Animations ---------- */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-up.in{opacity:1;transform:translateY(0)}

/* ---------- Utility ---------- */
.bg-white{background:#fff}
.bg-light{background:var(--bg)}
.text-center{text-align:center}
.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-8{margin-top:32px}
.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-8{margin-bottom:32px}
.hidden{display:none}
