/* ============================================================
   ARTHIVA — style.css v3.1 (Padding Fix)
   ============================================================ */

:root {
  --forest:#1b4332; --forest-mid:#2d5a3d; --forest-light:#3d7a52;
  --sage:#8aad94; --mint:#c8e6c9;
  --cream:#f8f5f0; --parchment:#f0ede6; --white:#ffffff;
  --text-dark:#1a2420; --text-mid:#3d4e46; --text-muted:#6b8070;
  --gold:#c9a84c; --gold-light:#f5e6b8;
  --border:rgba(26,56,40,0.12);
  --shadow-sm:0 2px 8px rgba(26,56,40,0.08);
  --shadow-md:0 8px 32px rgba(26,56,40,0.12);
  --shadow-lg:0 24px 64px rgba(26,56,40,0.16);

  --page-max:1280px;
  --page-px:2.5rem;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;font-family:'Source Serif 4',serif}
html{scroll-behavior:smooth;font-size:16px;overflow-x:clip}
body{font-family:'Source Serif 4',serif;color:var(--text-dark);line-height:1.6;overflow-x:clip;background:radial-gradient(ellipse 60% 50% at 95% 2%,rgba(138,173,148,0.45) 0%,transparent 55%),radial-gradient(ellipse 50% 40% at 75% 8%,rgba(201,168,76,0.22) 0%,transparent 50%),radial-gradient(ellipse 55% 45% at 5% 30%,rgba(201,168,76,0.18) 0%,transparent 55%),radial-gradient(ellipse 65% 50% at 20% 80%,rgba(138,173,148,0.35) 0%,transparent 55%),radial-gradient(ellipse 50% 40% at 85% 65%,rgba(45,90,61,0.15) 0%,transparent 55%),radial-gradient(ellipse 40% 35% at 50% 50%,rgba(201,168,76,0.08) 0%,transparent 60%),#f5f5f2;background-attachment:fixed}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--parchment)}
::-webkit-scrollbar-thumb{background:var(--forest-mid);border-radius:3px}

/* ── NAV ─────────────────────────────────────────────────── */
.nav-wrapper{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:center;padding:28px 0;transition:padding 0.35s ease;pointer-events:none}
.nav-wrapper.scrolled{padding:0}
#mainNav{pointer-events:all;width:100%;max-width:var(--page-max);background:rgba(248,245,240,0.65);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(26,56,40,0.10);border-radius:100px;box-shadow:0 4px 24px rgba(26,56,40,0.08);transition:border-radius 0.35s,max-width 0.35s,background 0.35s;margin:0 2.5rem}
#mainNav.scrolled{border-radius:0;max-width:100%;margin:0;border-left:none;border-right:none;border-top:none;background:rgba(248,245,240,0.97);box-shadow:0 2px 16px rgba(26,56,40,0.10)}
.nav-inner{max-width:var(--page-max);margin:0 auto;padding:0 var(--page-px);height:60px;display:flex;align-items:center;justify-content:space-between;transition:height 0.35s}
#mainNav.scrolled .nav-inner{height:68px}
.logo{font-family:'Source Serif 4',serif;font-size:1.4rem;font-weight:700;color:var(--forest);letter-spacing:-0.01em;text-decoration:none;display:flex;align-items:center;gap:0.6rem;flex-shrink:0}
.logo-img{height:28px;width:auto;display:block}
.nav-links{display:flex;gap:2rem;list-style:none;position:absolute;left:50%;transform:translateX(-50%)}
.nav-links a{font-size:0.875rem;font-weight:500;color:var(--text-mid);text-decoration:none;letter-spacing:0.02em;transition:color 0.2s;white-space:nowrap}
.nav-links a:hover{color:var(--forest)}
.nav-cta{display:flex;gap:0.6rem;align-items:center;flex-shrink:0}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn-ghost{font-family:'Source Serif 4',serif;font-size:0.85rem;font-weight:500;color:var(--forest);background:none;border:1.5px solid rgba(26,56,40,0.22);padding:0.45rem 1.1rem;border-radius:100px;cursor:pointer;text-decoration:none;transition:all 0.2s;white-space:nowrap}
.btn-ghost:hover{border-color:var(--forest);background:rgba(26,56,40,0.05)}
.btn-primary{font-family:'Source Serif 4',serif;font-size:0.85rem;font-weight:600;color:var(--white);background:var(--forest);border:none;padding:0.45rem 1.25rem;border-radius:100px;cursor:pointer;text-decoration:none;transition:all 0.25s;letter-spacing:0.01em;white-space:nowrap}
.btn-primary:hover{background:var(--forest-mid);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-xl{font-size:1rem!important;padding:0.9rem 2.25rem!important;border-radius:12px!important}
.btn-white{font-family:'Source Serif 4',serif;font-size:0.9rem;font-weight:600;color:var(--forest);background:var(--white);border:none;padding:0.8rem 2rem;border-radius:10px;cursor:pointer;text-decoration:none;transition:all 0.25s}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.2)}
.btn-outline-white{font-family:'Source Serif 4',serif;font-size:0.9rem;font-weight:600;color:var(--white);background:none;border:1.5px solid rgba(255,255,255,0.28);padding:0.8rem 2rem;border-radius:10px;cursor:pointer;text-decoration:none;transition:all 0.25s}
.btn-outline-white:hover{border-color:rgba(255,255,255,0.65);background:rgba(255,255,255,0.07)}

/* ── HAMBURGER & MOBILE MENU ─────────────────────────────── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--forest);border-radius:2px;transition:all 0.3s}
.mobile-menu{display:none;flex-direction:column;background:rgba(248,245,240,0.97);border-top:1px solid var(--border);padding:12px 0 16px;border-radius:0 0 24px 24px}
.mobile-menu.open{display:flex}
#mainNav:has(.mobile-menu.open),#mainNav.menu-open{border-radius:24px}
#mainNav.scrolled:has(.mobile-menu.open),#mainNav.scrolled.menu-open{border-radius:0}
#mainNav.scrolled .mobile-menu{border-radius:0}
.mobile-menu a{padding:11px 2rem;font-size:0.95rem;font-weight:500;color:var(--text-mid);text-decoration:none;transition:color 0.2s}
.mobile-menu a:hover{color:var(--forest)}
.mobile-menu-cta{display:flex;gap:0.75rem;padding:0.75rem 2rem 0.5rem;border-top:1px solid var(--border);margin-top:0.5rem}
.mobile-menu-cta .btn-ghost,.mobile-menu-cta .btn-primary{flex:1;text-align:center;border-radius:100px!important;padding:0.6rem 1rem!important;font-size:0.85rem!important}
.mobile-menu .mobile-menu-cta .btn-primary{color:var(--white)!important;background:var(--forest)!important}
.mobile-menu .mobile-menu-cta .btn-ghost{color:var(--forest)!important;background:none!important}

/* ── HERO ────────────────────────────────────────────────── */
.hero-wrapper{position:relative;width:100%;overflow:hidden}
.hero-wrapper::before{content:'';position:absolute;top:-100px;right:-60px;width:680px;height:680px;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(circle at center,rgba(138,173,148,0.18) 0%,rgba(61,122,82,0.07) 38%,transparent 68%);animation:orbA 14s ease-in-out infinite alternate}
.hero-wrapper::after{content:'';position:absolute;bottom:-50px;left:-80px;width:560px;height:560px;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(circle at center,rgba(201,168,76,0.10) 0%,rgba(201,168,76,0.03) 42%,transparent 68%);animation:orbB 18s ease-in-out infinite alternate}
@keyframes orbA{0%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,25px) scale(1.06)}100%{transform:translate(16px,-16px) scale(0.97)}}
@keyframes orbB{0%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-32px) scale(1.08)}100%{transform:translate(-16px,26px) scale(0.95)}}
.hero{padding:180px var(--page-px) 100px;max-width:var(--page-max);margin:0 auto;display:grid;grid-template-columns:9fr 11fr;gap:2rem;align-items:center;position:relative;z-index:1}
.hero::before{content:'';position:absolute;top:12%;left:32%;width:460px;height:460px;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(circle at center,rgba(45,90,61,0.05) 0%,transparent 65%);animation:orbC 22s ease-in-out infinite alternate}
@keyframes orbC{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-22px,32px) scale(1.04)}}
.hero-content{position:relative;z-index:1}
.hero-visual{position:relative;z-index:1;width:100%;overflow:visible}
.hero-badge{display:inline-flex;align-items:center;gap:0.5rem;background:var(--gold-light);border:1px solid rgba(201,168,76,0.32);color:#8a6820;font-size:0.8rem;font-weight:600;padding:0.4rem 1rem;border-radius:100px;letter-spacing:0.05em;text-transform:uppercase;margin-bottom:1.5rem;position:relative;overflow:hidden}
.hero-badge::before{content:'●';font-size:0.6rem;color:var(--gold);animation:pulse 2s infinite}
.hero-badge::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.55),transparent);animation:shimmer 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
@keyframes shimmer{0%{left:-60%}100%{left:120%}}
.hero-title{font-size:clamp(2.4rem,4vw,3.5rem);font-weight:700;line-height:1.12;color:var(--text-dark);letter-spacing:-0.02em;margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:var(--forest-mid)}
.hero-sub{font-size:1.1rem;color:var(--text-mid);line-height:1.7;margin-bottom:2.5rem;max-width:480px}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.dashboard-img{width:100%;height:auto;display:block;border-radius:16px;box-shadow:0 24px 60px rgba(26,56,40,0.15)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.floating-chip{position:absolute;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:0.85rem 1.25rem;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:0.75rem}
.floating-chip.left{left:-20px;bottom:-20px;animation:float 7s ease-in-out infinite 1s}
.floating-chip.top-right{right:-20px;top:-20px;animation:float 5s ease-in-out infinite 0.5s}
.chip-icon{width:36px;height:36px;background:var(--mint);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.chip-text{display:flex;flex-direction:column}
.chip-main{font-size:0.85rem;font-weight:700;color:var(--forest)}
.chip-sub{font-size:0.7rem;color:var(--text-muted)}

/* ── TRUST BAR ───────────────────────────────────────────── */
.trust-bar{padding:1.5rem var(--page-px);overflow:hidden}
.trust-bar-track-wrap{max-width:var(--page-max);margin:0 auto;background:var(--forest);border-radius:100px;padding:1.1rem 0;overflow:hidden}
.trust-bar-track{display:flex;align-items:center;width:max-content;animation:ticker 22s linear infinite}
.trust-bar-track:hover{animation-play-state:paused}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.trust-bar-set{display:flex;align-items:center;gap:0;flex-shrink:0}
.trust-bar-item{display:flex;align-items:center;gap:0.6rem;color:rgba(255,255,255,0.85);font-size:0.875rem;font-weight:500;white-space:nowrap;padding:0 2rem}
.trust-bar-item .icon{font-size:1rem;color:var(--sage)}
.trust-bar-sep{color:rgba(255,255,255,0.25);font-size:1.1rem;flex-shrink:0}

/* ── SECTIONS ────────────────────────────────────────────── */
.section{padding:100px var(--page-px);max-width:var(--page-max);margin:0 auto}
.section-label{display:inline-block;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--forest-mid);margin-bottom:1rem;padding:0.35rem 0.85rem;background:rgba(45,90,61,0.08);border-radius:100px}
.section-title{font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--text-dark);letter-spacing:-0.02em;line-height:1.2;margin-bottom:1.25rem}
.section-sub{font-size:1.05rem;color:var(--text-muted);max-width:560px;line-height:1.7}

/* ── SERVICES CARDS ──────────────────────────────────────── */
.services-section{padding:100px var(--page-px) 60px;max-width:var(--page-max);margin:0 auto;position:relative}
.services-section::after{content:'';position:absolute;top:30%;right:-180px;width:580px;height:580px;background:radial-gradient(circle,rgba(138,173,148,0.18) 0%,transparent 65%);border-radius:50%;pointer-events:none;z-index:0}
.services-header{margin-bottom:3.5rem;position:relative;z-index:1;max-width:640px}
.cards-scene{overflow:hidden;position:relative;z-index:1;padding:12px 0 16px;margin:0 -8px;perspective:1400px;perspective-origin:50% 40%;contain:layout}
.cards-row{display:flex;gap:1rem;padding:0 8px}
.sc-card{flex:1;border-radius:20px;padding:2.25rem 1.75rem 2rem;border:1px solid rgba(26,56,40,0.09);display:flex;flex-direction:column;gap:1rem;position:relative;overflow:hidden;min-height:320px;cursor:default;will-change:transform,opacity;transform-style:preserve-3d;transition:box-shadow 0.35s,border-color 0.35s;border-top:2px solid transparent}
.sc-card--1{background:linear-gradient(160deg,#c8e6c9 0%,#f8f5f0 60%);border-top-color:rgba(138,173,148,0.4)}
.sc-card--2{background:linear-gradient(160deg,#f5e6b8 0%,#f8f5f0 60%);border-top-color:rgba(201,168,76,0.4)}
.sc-card--3{background:linear-gradient(160deg,#b2cdb8 0%,#f8f5f0 60%);border-top-color:rgba(45,90,61,0.4)}
.sc-card--4{background:linear-gradient(160deg,#f5e6b8 0%,#f8f5f0 60%);border-top-color:rgba(201,168,76,0.4)}
.sc-card--1.sc-active{border-top-color:#8aad94}
.sc-card--2.sc-active{border-top-color:#c9a84c}
.sc-card--3.sc-active{border-top-color:#2d5a3d}
.sc-card--4.sc-active{border-top-color:#c9a84c}
.sc-card.sc-resting{transition:transform 0.7s cubic-bezier(0.22,1,0.36,1),box-shadow 0.7s cubic-bezier(0.22,1,0.36,1)!important}
.sc-card::after{content:'';position:absolute;inset:0;border-radius:20px;overflow:hidden;background:radial-gradient(circle at var(--mx,50%) var(--my,30%),rgba(255,255,255,0.20) 0%,transparent 60%);opacity:0;pointer-events:none;transition:opacity 0.3s;z-index:1}
.sc-card.sc-active::after{opacity:1}
.sc-icon{font-size:1.7rem;width:52px;height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.75);border:1px solid rgba(26,56,40,0.1);border-radius:14px;backdrop-filter:blur(4px);position:relative;z-index:3;transition:transform 0.3s}
.sc-card.sc-active .sc-icon{transform:scale(1.08)}
.sc-title{font-size:1.2rem;font-weight:700;color:var(--text-dark);letter-spacing:-0.02em;line-height:1.2;position:relative;z-index:1}
.sc-desc{font-size:0.875rem;color:var(--text-muted);line-height:1.7;flex:1;position:relative;z-index:1}
.services-footer{text-align:center;margin-top:2.5rem;position:relative;z-index:1}
.services-footer .btn-ghost{font-size:0.95rem;padding:0.7rem 2rem;border-radius:100px;color:#fff;background:#1b4332;border-color:#1b4332;font-weight:600}
.services-footer .btn-ghost:hover{background:#163a2b;border-color:#163a2b}

/* ── PROCESS (dark bg) ───────────────────────────────────── */
.process-section{background:var(--forest);padding:100px var(--page-px);position:relative;overflow:hidden}
.process-section::before{content:'';position:absolute;top:-80px;right:-80px;width:550px;height:550px;background:radial-gradient(circle,rgba(138,173,148,0.14) 0%,transparent 65%);border-radius:50%;pointer-events:none}
.process-section::after{content:'';position:absolute;bottom:-60px;left:-60px;width:450px;height:450px;background:radial-gradient(circle,rgba(201,168,76,0.10) 0%,transparent 65%);border-radius:50%;pointer-events:none}
.process-inner{max-width:var(--page-max);margin:0 auto;position:relative;z-index:1}
.process-section .section-label{background:rgba(255,255,255,0.12);color:var(--sage)}
.process-section .section-title{color:var(--white)}
.process-section .section-title em{font-style:italic;color:rgba(255,255,255,0.55)}
.process-section .section-sub{color:rgba(255,255,255,0.60)}
.process-header{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-bottom:5rem}
.process-feature{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:16px;padding:2rem}
.pf-stat{font-size:3rem;font-weight:700;color:var(--white);line-height:1;margin-bottom:0.25rem}
.pf-label{font-size:0.875rem;color:rgba(255,255,255,0.5);margin-bottom:2rem}
.pf-items{display:flex;flex-direction:column;gap:1rem}
.pf-item{display:flex;align-items:center;gap:0.75rem;font-size:0.875rem;color:rgba(255,255,255,0.75)}
.pf-check{width:20px;height:20px;background:rgba(138,173,148,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.65rem;color:var(--sage);flex-shrink:0}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;position:relative}
.process-loop-svg{position:absolute;top:0;left:0;width:100%;height:56px;z-index:0;pointer-events:none;overflow:visible}
.process-steps .step-card{position:relative}
.step-track{display:flex;align-items:center;margin-bottom:1.75rem}
.process-steps .step-card:nth-child(2) .step-track{padding-left:0}
.process-steps .step-card:nth-child(3) .step-track{padding-left:calc(16.67% - 28px)}
.process-steps .step-card:nth-child(4) .step-track{padding-left:calc(33.33% - 28px)}
.process-steps .step-card:nth-child(5) .step-track{padding-left:calc(50% - 28px)}
.step-node{flex-shrink:0;width:56px;height:56px;border-radius:50%;background:#1b4332;border:1px solid rgba(255,255,255,0.20);display:flex;align-items:center;justify-content:center;position:relative;z-index:3;transition:background 0.4s,border-color 0.4s,transform 0.4s,box-shadow 0.4s}
.step-node-inner{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center}
.step-icon{font-size:1.19rem;font-weight:700;font-style:italic;color:rgba(255,255,255,0.85);letter-spacing:-0.02em;transition:color 0.4s}
.process-steps .step-card:last-child .step-node{border-color:rgba(201,168,76,0.4)}
.process-steps .step-card:last-child .step-node-inner{background:rgba(201,168,76,0.08)}
.process-steps .step-card:last-child .step-icon{color:rgba(201,168,76,0.7)}
.step-body{text-align:left}
.step-label{display:none}
.process-steps .step-title{font-size:1.4rem;font-weight:700;color:var(--white);margin-bottom:0.6rem;letter-spacing:-0.02em;transition:color 0.4s}
.process-steps .step-desc{font-size:0.85rem;color:rgba(255,255,255,0.5);line-height:1.7;transition:color 0.4s}

/* ── FAQ ─────────────────────────────────────────────────── */
#faq.section{padding:80px var(--page-px)}
.faq-grid{display:grid;grid-template-columns:5fr 7fr;gap:6rem;align-items:start;margin-top:4rem}
.faq-intro{position:sticky;top:120px}
.faq-intro .section-sub{margin-bottom:2rem}
.faq-items{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--border);transition:all 0.2s;border-radius:0}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-item:hover{background:rgba(26,56,40,0.04);padding:0 1rem;margin:0 -1rem;border-color:transparent;border-radius:12px}
.faq-item.open{background:rgba(26,56,40,0.05);padding:0 1rem;margin:0 -1rem;border-color:transparent;border-radius:12px}
.faq-q{width:100%;background:none;border:none;cursor:pointer;padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;font-family:'Source Serif 4',serif;font-size:1.2rem;font-weight:500;color:var(--text-dark);text-align:left;transition:color 0.2s;gap:2rem}
.faq-q:hover{color:var(--forest)}
.faq-icon{width:32px;height:32px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--forest);flex-shrink:0;transition:all 0.3s}
.faq-item.open .faq-icon{background:var(--forest);color:var(--white);border-color:var(--forest);transform:rotate(90deg)}
.faq-a{display:none;padding:0 3rem 1.5rem 0;font-size:1rem;color:var(--text-muted);line-height:1.75}
.faq-item.open .faq-a{display:block}

/* ── CTA ─────────────────────────────────────────────────── */
.cta-section{padding:100px var(--page-px);max-width:var(--page-max);margin:0 auto}
.cta-card{background:linear-gradient(135deg,#1b4332 0%,#1d4534 50%,#132e1c 100%);border-radius:20px;padding:4rem 5rem;text-align:center;position:relative;overflow:hidden;box-shadow:0 24px 60px rgba(26,56,40,0.28);width:80%;margin:0 auto}
.cta-card::before{content:'';position:absolute;top:-80px;right:-80px;width:280px;height:280px;background:rgba(255,255,255,0.03);border-radius:50%}
.cta-card::after{content:'';position:absolute;bottom:-60px;left:-60px;width:200px;height:200px;background:rgba(255,255,255,0.03);border-radius:50%}
.cta-tag{display:inline-block;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.55);font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;padding:0.35rem 1rem;border-radius:100px;margin-bottom:1.25rem;border:1px solid rgba(255,255,255,0.1)}
.cta-title{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;color:var(--white);letter-spacing:-0.02em;margin-bottom:0.875rem}
.cta-sub{font-size:0.95rem;color:rgba(255,255,255,0.5);margin-bottom:2rem;max-width:520px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── FOOTER ──────────────────────────────────────────────── */
footer{background:radial-gradient(ellipse 80% 60% at 10% 20%,rgba(138,173,148,0.18) 0%,transparent 55%),radial-gradient(ellipse 60% 50% at 90% 80%,rgba(201,168,76,0.14) 0%,transparent 55%),radial-gradient(ellipse 50% 40% at 50% 0%,rgba(255,255,255,0.07) 0%,transparent 50%),linear-gradient(160deg,#253d30 0%,#1b4332 40%,#132e1c 100%);color:rgba(255,255,255,0.7);position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,0.5),rgba(138,173,148,0.4),rgba(201,168,76,0.3),transparent)}
footer::after{content:'';position:absolute;top:0;left:-50%;width:200%;height:100%;background:linear-gradient(180deg,rgba(255,255,255,0.04) 0%,transparent 40%);pointer-events:none}
.footer-inner{max-width:var(--page-max);margin:0 auto;padding:4rem var(--page-px);display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1}
.footer-brand{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-start}
.footer-logo-img{height:35px;width:auto;display:block}
.footer-brand .logo{color:var(--white);display:block;margin-bottom:1rem;font-size:2.1rem!important}
.footer-brand p{font-size:0.875rem;line-height:1.7;color:rgba(255,255,255,0.5);max-width:320px}
.footer-col{position:relative;z-index:1}
.footer-col h4{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:rgba(255,255,255,0.55);margin-bottom:1.25rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:0.75rem}
.footer-col a{font-size:1rem;color:rgba(255,255,255,1);text-decoration:none;transition:color 0.2s}
.footer-col a:hover{color:var(--mint)}
.footer-bottom{border-top:1px solid rgba(201,168,76,0.15);position:relative;z-index:1}
.footer-bottom-inner{max-width:var(--page-max);margin:0 auto;padding:1.5rem var(--page-px);display:flex;justify-content:space-between;align-items:center;font-size:0.8rem;color:rgba(255,255,255,0.55)}
.footer-bottom-social{display:flex;align-items:center;gap:1.1rem}
.footer-bottom-social a{color:rgba(255,255,255,0.9);display:flex;align-items:center;transition:color 0.2s}
.footer-bottom-social a:hover{color:#ffffff}

/* ── REVEAL ──────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:all 0.7s cubic-bezier(0.22,1,0.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.10s}
.reveal-delay-2{transition-delay:0.20s}
.reveal-delay-3{transition-delay:0.30s}

/* ── ≤1024px ─────────────────────────────────────────────── */
@media(max-width:1024px){
  :root{--page-px:2rem}
  #mainNav{margin:0 2rem}
  .hero{padding-top:160px;padding-bottom:80px;gap:1.5rem}
  .process-header{gap:2.5rem}
  .cta-card{width:90%;padding:3.5rem 3.5rem}
}

/* ── ≤900px ──────────────────────────────────────────────── */
@media(max-width:900px){
  :root{--page-px:1.5rem}
  #mainNav{margin:0 1.5rem}
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-wrapper{padding:14px 0}
  .hamburger{display:flex}
  .mobile-menu-cta{max-width:480px}
  .mobile-menu-cta .btn-ghost,.mobile-menu-cta .btn-primary{flex:0 1 auto;min-width:140px;padding:0.65rem 1.5rem!important}
  .hero{grid-template-columns:1fr;padding-top:130px}
  .hero-visual{width:100%;overflow:hidden}
  .floating-chip{display:none}
  .cards-row{flex-wrap:wrap}
  .sc-card{flex:1 1 calc(50% - 0.5rem);transform:none!important;opacity:1!important}
  .process-steps{grid-template-columns:1fr 1fr}
  .process-loop-svg{display:none}
  .step-track{padding-left:0!important}
  .process-header{grid-template-columns:1fr;gap:2rem}
  .faq-grid{grid-template-columns:1fr;gap:2rem}
  .faq-intro{position:static}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .footer-brand{grid-column:auto}
  .cta-card{padding:3rem 2rem;width:100%}
  .page-hero{grid-template-columns:1fr;gap:3rem;padding-top:130px}
  .us-map-wrap{width:100%;margin-left:0}
  .map-footer-bar{margin-left:0;flex-direction:column;gap:0.5rem;align-items:flex-start}
  .programs-grid{grid-template-columns:1fr 1fr}
  .programs-header{grid-template-columns:1fr;gap:1.5rem}
}

/* ── ≤768px ──────────────────────────────────────────────── */
@media(max-width:768px){
  :root{--page-px:1.25rem}
  #mainNav{margin:0 1.25rem}
  .mobile-menu-cta{max-width:none}
  .mobile-menu-cta .btn-ghost,.mobile-menu-cta .btn-primary{flex:1}
  .section{padding-top:70px;padding-bottom:70px}
  .services-section{padding-top:70px;padding-bottom:40px}
  .hero{padding-top:110px;padding-bottom:50px}
  .hero-title{font-size:clamp(2rem,6vw,3rem)}
  .hero-sub{font-size:1rem}
  .process-section{padding-top:70px;padding-bottom:70px}
  .process-steps .step-title{font-size:1.2rem}
  .footer-col h4{font-size:0.875rem;margin-bottom:1rem}
  .footer-col a{font-size:0.9rem}
  .footer-bottom-inner{font-size:0.75rem}
  .cta-card{padding:2.5rem 1.75rem;border-radius:16px}
  .faq-q{font-size:1.1rem;gap:1.5rem}
  .trust-bar-track-wrap{border-radius:80px}
}

/* ── ≤600px ──────────────────────────────────────────────── */
@media(max-width:600px){
  :root{--page-px:1rem}
  #mainNav{margin:0 1rem}
  .mobile-menu a{padding:10px 1.5rem}
  .mobile-menu-cta{padding:0.75rem 1.5rem 0.5rem;flex-wrap:wrap}
  .floating-chip{display:none}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .footer-brand{grid-column:auto}
  .footer-bottom-inner{flex-direction:column;text-align:center;gap:0.75rem}
  .footer-bottom-social{justify-content:center}
  .trust-bar{padding:1rem 0}
  .trust-bar-track-wrap{border-radius:16px;margin:0 0.5rem}
  .sc-card{flex:1 1 100%}
  .process-steps{grid-template-columns:1fr 1fr;gap:1.25rem}
  .process-steps .step-title{font-size:1rem}
  .process-steps .step-desc{font-size:0.78rem}
  .step-node{width:44px;height:44px}
  .step-node-inner{width:32px;height:32px}
  .step-track{margin-bottom:1rem}
  .faq-q{font-size:1.05rem}
  .cta-card{padding:2.5rem 1.5rem;border-radius:14px}
  .cta-title{font-size:1.4rem}
  .hero{padding-top:100px;padding-bottom:32px}
  .hero-title{font-size:clamp(2rem,7vw,3rem)}
  .hero-sub{margin-bottom:1.75rem}
  .hero-actions{gap:0.5rem;flex-direction:column;align-items:stretch}
  .hero-actions .btn-xl{width:100%;text-align:center;font-size:0.9rem!important;padding:0.7rem 1.75rem!important;border-radius:10px!important}
  .hero-visual{margin-top:1.5rem}
  .dashboard-img{border-radius:12px;box-shadow:0 12px 32px rgba(26,56,40,0.12)}
  .section{padding-top:60px;padding-bottom:60px}
  .services-section{padding-top:60px;padding-bottom:40px}
  .process-section{padding-top:60px;padding-bottom:40px}
  #faq.section{padding-top:40px;padding-bottom:40px}
  .cta-section{padding-top:40px;padding-bottom:60px}
  .process-header{gap:1.5rem;margin-bottom:3rem}
  .pf-stat{font-size:2.25rem}
  .programs-grid{grid-template-columns:1fr}
  .programs-section{padding-top:60px;padding-bottom:60px}
  .page-hero{padding-top:100px;padding-bottom:40px;gap:2rem}
  .page-hero-stats{flex-wrap:nowrap}
  .trust-item{padding:0.85rem 0.75rem}
  .trust-num{font-size:1.25rem}
  .trust-label{font-size:0.6rem}
  .page-hero-title{font-size:clamp(1.75rem,6vw,2.4rem)}
  .page-hero-sub{font-size:1rem;margin-bottom:1.75rem}
}

/* ── ≤400px ──────────────────────────────────────────────── */
@media(max-width:400px){
  :root{--page-px:0.75rem}
  #mainNav{margin:0 0.75rem}
  .hero{padding-top:90px;padding-bottom:24px}
  .hero-title{font-size:1.75rem}
  .hero-sub{font-size:0.9rem;margin-bottom:1.5rem}
  .hero-badge{font-size:0.7rem;padding:0.3rem 0.75rem;margin-bottom:1rem}
  .hero-actions{flex-direction:column;align-items:stretch;gap:0.5rem}
  .hero-actions .btn-xl{text-align:center;width:100%;font-size:0.85rem!important;padding:0.65rem 1.5rem!important;border-radius:10px!important}
  .nav-inner{padding:0 1rem}
  .mobile-menu-cta{flex-direction:column;padding:0.75rem 1.25rem 0.5rem}
  .mobile-menu-cta .btn-ghost,.mobile-menu-cta .btn-primary{width:100%;text-align:center}
  .footer-col h4{font-size:0.8rem;margin-bottom:0.75rem}
  .footer-col a{font-size:0.85rem}
  .footer-bottom-inner{font-size:0.7rem}
  .cta-card{padding:2rem 1rem}
  .cta-title{font-size:1.25rem}
  .cta-sub{font-size:0.85rem}
  .btn-white,.btn-outline-white{padding:0.65rem 1.5rem;font-size:0.8rem}
  .section{padding-top:45px;padding-bottom:45px}
  .services-section{padding-top:45px;padding-bottom:30px}
  .section-title{font-size:clamp(1.6rem,6vw,2.2rem)}
  .section-sub{font-size:0.95rem}
  .process-section{padding-top:45px;padding-bottom:30px}
  #faq.section{padding-top:30px;padding-bottom:30px}
  .cta-section{padding-top:30px;padding-bottom:45px}
  .process-steps{gap:1.5rem}
  .process-steps .step-title{font-size:1.1rem}
  .step-node{width:46px;height:46px}
  .step-node-inner{width:34px;height:34px}
  .faq-q{font-size:0.95rem;padding:1.15rem 0;gap:1rem}
  .faq-icon{width:28px;height:28px;font-size:0.9rem}
  .faq-a{font-size:0.9rem}
  .trust-bar-track-wrap{border-radius:12px;margin:0 0.5rem}
  .sc-card{padding:1.75rem 1.25rem 1.5rem;min-height:260px}
  .page-hero-title{font-size:clamp(1.5rem,5.5vw,2rem)}
  .trust-item{padding:0.7rem 0.5rem}
  .trust-num{font-size:1.1rem}
  .trust-label{font-size:0.55rem;letter-spacing:0.01em}
}

/* ── SERVICES PAGE ───────────────────────────────────────── */
.page-hero{padding:180px var(--page-px) 100px;max-width:var(--page-max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;overflow:visible}
.page-hero>.us-map-wrap{overflow:visible}
.page-hero-left{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.page-hero-eyebrow{margin-bottom:1.25rem;display:inline-block}
.page-hero-title{font-size:clamp(2.6rem,5vw,3.8rem);font-weight:700;color:var(--text-dark);letter-spacing:-0.02em;line-height:1.1;margin-bottom:1.25rem}
.page-hero-title em{font-style:italic;color:var(--forest-mid)}
.page-hero-sub{font-size:1.1rem;color:var(--text-muted);line-height:1.7;max-width:500px;margin-bottom:2.5rem}
.page-hero-stats{display:flex;gap:0;align-items:stretch;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:rgba(255,255,255,0.6);backdrop-filter:blur(8px)}
.trust-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem 1.75rem;flex:1;border-right:1px solid var(--border);text-align:center}
.trust-item:last-child{border-right:none}
.trust-num{font-size:1.75rem;font-weight:700;color:var(--forest);line-height:1}
.trust-label{font-size:0.72rem;color:var(--text-muted);font-weight:500;margin-top:0.3rem;letter-spacing:0.03em;text-transform:uppercase}

/* US Map */
.us-map-wrap{position:relative;align-self:center;justify-self:end;width:120%;margin-right:0;margin-left:-20%}
.us-map-container{position:relative}
.us-map-svg{width:100%;height:auto;display:block}
.us-map-svg .st{fill:#edf2ee;stroke:rgba(27,67,50,0.25);stroke-width:1;stroke-linejoin:round;transition:fill 0.4s ease;cursor:default}
.us-map-svg .st:hover{fill:rgba(27,67,50,0.15)}
.us-map-svg .st.lit{fill:rgba(45,110,70,0.2)}
.us-map-svg .st.lit-gold{fill:rgba(201,168,76,0.28)}
.map-pins{position:absolute;inset:0;pointer-events:none;z-index:2}
.map-pin{position:absolute;width:14px;height:23px;transform:translate(-50%,-90%) scale(0);transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1)}
.map-pin.active{transform:translate(-50%,-90%) scale(1)}
.map-pin svg{width:100%;height:100%;overflow:visible}
.map-pin .pin-head{fill:var(--forest)}
.map-pin .pin-shine1{fill:rgba(255,255,255,0.55)}
.map-pin .pin-shine2{fill:rgba(255,255,255,0.3)}
.map-pin .pin-needle{fill:#888}
.map-pin .pin-needle-tip{fill:#666}
.map-pin.gold .pin-head{fill:#c9a84c}
.map-pin.lg{width:17px;height:28px}
.map-tip{position:absolute;background:var(--forest);color:#fff;font-size:0.7rem;font-weight:600;padding:0.25rem 0.6rem;border-radius:6px;pointer-events:none;opacity:0;transform:translateY(4px);transition:all 0.2s;white-space:nowrap;z-index:10;box-shadow:0 4px 12px rgba(27,67,50,0.25)}
.map-tip.visible{opacity:1;transform:translateY(0)}
.map-footer-bar{display:flex;align-items:center;justify-content:space-between;padding:0.75rem 0 0;margin-left:15%}
.map-counter{font-size:0.78rem;color:var(--text-muted)}
.map-counter strong{color:var(--forest)}
.map-legend{display:flex;gap:1.25rem;align-items:center}
.map-legend-item{display:flex;align-items:center;gap:0.35rem;font-size:0.68rem;font-weight:600;color:var(--text-muted)}
.map-legend-dot{width:8px;height:8px;border-radius:50%}
.map-legend-dot.green{background:var(--forest)}
.map-legend-dot.gold{background:rgba(201,168,76,0.95)}

/* Programs */
.programs-section{padding:100px var(--page-px);max-width:var(--page-max);margin:0 auto}
.programs-header{margin-bottom:4rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end}
.programs-header-note{font-size:0.95rem;color:var(--text-muted);line-height:1.7}
.programs-header-note strong{color:var(--forest);font-weight:600}
.category-tabs{display:flex;gap:0.5rem;margin-bottom:2.5rem;flex-wrap:wrap}
.cat-tab{padding:0.5rem 1.25rem;border-radius:100px;font-size:0.82rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border);color:var(--text-mid);background:none;font-family:'Source Serif 4',serif;transition:all 0.2s;letter-spacing:0.02em}
.cat-tab:hover{border-color:var(--forest);color:var(--forest)}
.cat-tab.active{background:var(--forest);border-color:var(--forest);color:var(--white)}
.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.program-card{background:rgba(255,255,255,0.65);border:1px solid var(--border);border-radius:18px;padding:1.75rem;backdrop-filter:blur(8px);transition:all 0.25s ease;cursor:default;display:none}
.program-card.visible{display:flex;flex-direction:column}
.program-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(26,56,40,0.2)}
.program-card-top{display:flex;align-items:center;gap:0.85rem;margin-bottom:1rem}
.program-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.program-icon.bg-green{background:#e8f5e9}
.program-icon.bg-yellow{background:#fff8e1}
.program-icon.bg-pink{background:#fce4ec}
.program-icon.bg-blue{background:#e3f2fd}
.program-icon.bg-purple{background:#f3e5f5}
.program-icon.bg-orange{background:#fff3e0}
.program-icon.bg-gray{background:#f5f5f5}
.program-name{font-size:1rem;font-weight:700;color:var(--text-dark);line-height:1.2}
.program-category{font-size:0.7rem;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:0.06em;font-weight:600}
.program-desc{font-size:0.85rem;color:var(--text-muted);line-height:1.65;flex:1;margin-bottom:1.25rem}
.program-footer{display:flex;align-items:center;justify-content:space-between}
.program-stat{font-size:0.78rem;color:var(--text-muted)}
.program-stat strong{color:var(--forest);font-weight:700}
.program-pill{font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;padding:0.25rem 0.7rem;border-radius:100px;background:rgba(45,90,61,0.08);color:var(--forest-mid)}
.program-card.coming-soon{opacity:0.55;border-style:dashed}
.program-card.coming-soon .program-pill{background:rgba(201,168,76,0.12);color:#8a6820}
