/* ============================================================
   DRIFT ACADEMY — MAIN STYLESHEET
   driftacademy.lt | D1Sport
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Roboto:wght@300;400;500;700&display=swap');

/* --- CSS Variables --- */
:root {
  --bg: #090909;
  --bg2: #111111;
  --bg3: #1a1a1a;
  --bg4: #222222;
  --accent: #e8401e;
  --accent2: #ff6b3d;
  --accent-dark: #c43418;
  --text: #f0f0f0;
  --text2: #aaaaaa;
  --text3: #666666;
  --border: #2a2a2a;
  --border2: #333333;
  --shadow: 0 4px 20px rgba(0,0,0,0.5);
  --shadow-red: 0 8px 40px rgba(232,64,30,0.35);
  --t: all 0.3s ease;
  --r: 8px;
  --r2: 14px;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Roboto',sans-serif;background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden}
a{color:var(--accent);text-decoration:none;transition:var(--t)}
a:hover{color:var(--accent2)}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
h1,h2,h3,h4{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.05em;line-height:1.15}

/* --- Layout --- */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-dark{background:var(--bg2)}
.section-title{text-align:center;margin-bottom:54px}
.section-title h2{font-size:clamp(1.8rem,4vw,2.6rem);color:var(--text);margin-bottom:12px}
.section-title h2 span{color:var(--accent)}
.section-title p{color:var(--text2);font-size:1.05rem;max-width:580px;margin:0 auto}
.title-line{width:54px;height:4px;background:var(--accent);margin:14px auto 18px;border-radius:2px}

/* Grid */
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.g-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}

/* --- Navbar --- */
.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(9,9,9,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:var(--t)}
.navbar.scrolled{background:rgba(9,9,9,.98);box-shadow:0 2px 24px rgba(0,0,0,.9)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo{display:flex;align-items:center}
.logo-txt{font-family:'Oswald',sans-serif;font-size:1.35rem;font-weight:700;color:var(--text);letter-spacing:.08em;text-transform:uppercase}
.logo-txt span{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-family:'Oswald',sans-serif;font-size:.88rem;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.07em;position:relative;transition:var(--t)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:var(--t)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.lang-sw{display:flex;gap:6px}
.lang-sw a{font-family:'Oswald',sans-serif;font-size:.78rem;font-weight:600;color:var(--text3);text-transform:uppercase;padding:4px 7px;border-radius:4px;border:1px solid transparent;transition:var(--t)}
.lang-sw a:hover,.lang-sw a.cur{color:var(--text);border-color:var(--accent);background:rgba(232,64,30,.1)}
.btn-nav{font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:600;color:#fff!important;background:var(--accent);padding:9px 18px;border-radius:var(--r);text-transform:uppercase;letter-spacing:.08em;transition:var(--t);white-space:nowrap}
.btn-nav:hover{background:var(--accent2);color:#fff!important;transform:translateY(-1px)}
.btn-nav::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px;background:transparent;border:none}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);transition:var(--t)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
.mob-nav{display:none;position:fixed;top:68px;left:0;width:100%;background:var(--bg);border-bottom:1px solid var(--border);padding:16px 24px;z-index:998}
.mob-nav.open{display:block}
.mob-nav a{display:block;font-family:'Oswald',sans-serif;font-size:1rem;color:var(--text2);padding:11px 0;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.07em}
.mob-nav a:hover{color:var(--accent)}
.mob-langs{display:flex;gap:10px;padding:14px 0 4px}

/* --- Hero --- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('../images/hero-bg.jpg') center/cover no-repeat;filter:brightness(.35);transform:scale(1.04)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(9,9,9,.85) 0%,rgba(232,64,30,.07) 50%,rgba(9,9,9,.92) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;max-width:860px;padding:0 20px}
.hero-badge{display:inline-block;font-family:'Oswald',sans-serif;font-size:.8rem;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;padding:5px 15px;border:1px solid rgba(232,64,30,.5);border-radius:20px;margin-bottom:22px}
.hero-h1{font-size:clamp(2.8rem,7vw,5.8rem);font-weight:700;color:var(--text);line-height:1.05;margin-bottom:8px}
.hero-h1 span{color:var(--accent)}
.hero-sub{font-family:'Oswald',sans-serif;font-size:clamp(1.1rem,2.5vw,1.7rem);color:var(--text2);font-weight:400;letter-spacing:.12em;margin-bottom:24px}
.hero-desc{font-size:1.05rem;color:var(--text2);max-width:580px;margin:0 auto 38px;line-height:1.75}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;cursor:pointer}
.hero-scroll-arrow{display:block;width:22px;height:22px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(45deg);margin:auto;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:rotate(45deg) translateY(0)}50%{transform:rotate(45deg) translateY(8px)}}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Oswald',sans-serif;font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding:14px 30px;border-radius:var(--r);border:2px solid transparent;cursor:pointer;transition:var(--t);white-space:nowrap;line-height:1}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent2);border-color:var(--accent2);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-red)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--border2)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-accent-outline{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-accent-outline:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.btn-lg{font-size:1.05rem;padding:17px 38px}
.btn-sm{font-size:.82rem;padding:9px 18px}
.btn-wa{background:#25d366;border-color:#25d366;color:#fff}
.btn-wa:hover{background:#20b857;border-color:#20b857;color:#fff;transform:translateY(-2px)}

/* Floating CTA */
.float-wa{position:fixed;bottom:28px;right:28px;z-index:997;width:58px;height:58px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff;box-shadow:0 4px 20px rgba(37,211,102,.45);transition:var(--t);animation:pulse 2.5s infinite}
.float-wa:hover{background:#20b857;color:#fff;transform:scale(1.1)}
.float-tel{position:fixed;bottom:96px;right:28px;z-index:997;width:58px;height:58px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;box-shadow:0 4px 20px rgba(232,64,30,.45);transition:var(--t)}
.float-tel:hover{background:var(--accent2);color:#fff;transform:scale(1.1)}
@keyframes pulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 40px rgba(37,211,102,.75)}}

/* --- Stats Bar --- */
.stats-bar{background:var(--accent);padding:22px 0}
.stats-inner{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:20px}
.stat-item{text-align:center;color:#fff}
.stat-num{font-family:'Oswald',sans-serif;font-size:2.1rem;font-weight:700;display:block;line-height:1}
.stat-lbl{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;opacity:.88;margin-top:4px;display:block}

/* --- Service Cards --- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:26px}
.svc-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:var(--t);display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-8px);border-color:var(--accent);box-shadow:var(--shadow-red)}
.svc-img{height:195px;overflow:hidden;background:var(--bg2);position:relative}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.svc-card:hover .svc-img img{transform:scale(1.07)}
.svc-icon{position:absolute;bottom:-28px;right:20px;width:56px;height:56px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;border:3px solid var(--bg3)}
.svc-body{padding:38px 24px 26px;flex:1;display:flex;flex-direction:column}
.svc-body h3{font-size:1.45rem;color:var(--text);margin-bottom:10px}
.svc-body p{color:var(--text2);font-size:.93rem;line-height:1.65;margin-bottom:18px;flex:1}
.svc-price{margin-bottom:20px}
.svc-price .from{font-size:.8rem;color:var(--text3);display:block;margin-bottom:2px}
.svc-price .amount{font-family:'Oswald',sans-serif;font-size:2rem;font-weight:700;color:var(--accent)}
.svc-price .per{font-size:.82rem;color:var(--text3)}

/* --- Car Cards --- */
.car-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:var(--t)}
.car-card:hover{border-color:var(--accent);box-shadow:var(--shadow-red)}
.car-img{height:215px;overflow:hidden;background:var(--bg2)}
.car-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.car-card:hover .car-img img{transform:scale(1.05)}
.car-body{padding:24px}
.car-name{font-size:1.4rem;color:var(--text);margin-bottom:6px}
.car-class{display:inline-block;font-family:'Oswald',sans-serif;font-size:.72rem;color:var(--accent);background:rgba(232,64,30,.1);border:1px solid rgba(232,64,30,.3);padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.car-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.spec-box{text-align:center;padding:10px 6px;background:var(--bg2);border-radius:var(--r);border:1px solid var(--border)}
.spec-val{font-family:'Oswald',sans-serif;font-size:1.3rem;font-weight:700;color:var(--accent);display:block}
.spec-lbl{font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.car-desc{color:var(--text2);font-size:.88rem;margin-bottom:18px;line-height:1.6}

/* --- Instructor Cards --- */
.inst-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);text-align:center;padding:30px 22px;transition:var(--t)}
.inst-card:hover{border-color:var(--accent);transform:translateY(-5px)}
.inst-photo{width:130px;height:130px;border-radius:50%;overflow:hidden;margin:0 auto 18px;border:3px solid var(--accent)}
.inst-photo img{width:100%;height:100%;object-fit:cover}
.inst-photo-placeholder{width:130px;height:130px;border-radius:50%;background:var(--bg2);margin:0 auto 18px;border:3px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--text3)}
.inst-name{font-size:1.25rem;color:var(--text);margin-bottom:5px}
.inst-role{font-size:.8rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.inst-bio{color:var(--text2);font-size:.88rem;line-height:1.6}

/* --- Pricing --- */
.pricing-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:24px;max-width:980px;margin:0 auto}
.price-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:32px 28px;text-align:center;position:relative;transition:var(--t)}
.price-card:hover:not(.featured){transform:translateY(-5px)}
.price-card.featured{border-color:var(--accent);box-shadow:var(--shadow-red)}
.price-card.featured::before{content:'POPULIARIAUSIA';position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-family:'Oswald',sans-serif;font-size:.7rem;letter-spacing:.12em;padding:4px 14px;border-radius:20px}
.p-name{font-size:1.05rem;color:var(--text2);margin-bottom:22px;text-transform:uppercase;letter-spacing:.1em}
.p-price{font-family:'Oswald',sans-serif;font-size:3.2rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:4px}
.p-price .cur{font-size:1.5rem;vertical-align:top;margin-top:8px;display:inline-block}
.p-period{color:var(--text3);font-size:.83rem;display:block;margin-bottom:28px}
.p-features{text-align:left;margin-bottom:28px}
.p-features li{padding:8px 0;border-bottom:1px solid var(--border);color:var(--text2);font-size:.88rem;display:flex;align-items:flex-start;gap:10px}
.p-features li::before{content:'✓';color:var(--accent);font-weight:700;flex-shrink:0;margin-top:1px}

/* --- Events --- */
.event-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.event-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:28px 22px;text-align:center;transition:var(--t)}
.event-card:hover{border-color:var(--accent);transform:translateY(-5px)}
.ev-icon{font-size:2.8rem;margin-bottom:14px;display:block}
.event-card h3{font-size:1.2rem;color:var(--text);margin-bottom:10px}
.event-card p{color:var(--text2);font-size:.88rem;line-height:1.6}

/* --- Video --- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.video-wrap{border-radius:var(--r2);overflow:hidden;aspect-ratio:16/9;border:1px solid var(--border)}
.video-wrap iframe{width:100%;height:100%;border:none}

/* --- Contact --- */
.contact-wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:40px;align-items:start}
.ci-list{}
.ci-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.ci-icon{width:40px;height:40px;background:rgba(232,64,30,.1);border:1px solid rgba(232,64,30,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.1rem;flex-shrink:0}
.ci-lbl{font-size:.73rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:3px}
.ci-val{font-size:.97rem;color:var(--text)}
.ci-val a{color:var(--text);transition:var(--t)}
.ci-val a:hover{color:var(--accent)}
.contact-form-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:34px}
.contact-form-box h3{font-size:1.4rem;margin-bottom:24px;color:var(--text)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-g{margin-bottom:18px}
.form-g label{display:block;font-size:.78rem;color:var(--text2);margin-bottom:7px;text-transform:uppercase;letter-spacing:.05em}
.form-g input,.form-g select,.form-g textarea{width:100%;background:var(--bg2);border:1px solid var(--border2);color:var(--text);padding:12px 15px;border-radius:var(--r);font-family:'Roboto',sans-serif;font-size:.93rem;transition:var(--t)}
.form-g input:focus,.form-g select:focus,.form-g textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,64,30,.1)}
.form-g textarea{height:110px;resize:vertical}
.form-g select option{background:var(--bg3)}

/* --- FAQ --- */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;overflow:hidden}
.faq-q{padding:18px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:'Oswald',sans-serif;font-size:1rem;color:var(--text);transition:var(--t);user-select:none}
.faq-q:hover{color:var(--accent)}
.faq-q .faq-ic{color:var(--accent);font-size:1.3rem;transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-ic{transform:rotate(45deg)}
.faq-a{display:none;padding:0 22px 18px;color:var(--text2);font-size:.92rem;line-height:1.72}
.faq-item.open .faq-a{display:block}

/* --- CTA Section --- */
.cta-sec{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);padding:80px 0;text-align:center}
.cta-sec h2{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;margin-bottom:14px}
.cta-sec p{color:rgba(255,255,255,.88);font-size:1.05rem;max-width:580px;margin:0 auto 34px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* --- Page Header --- */
.page-hdr{padding:120px 0 56px;background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);text-align:center;position:relative;overflow:hidden}
.page-hdr::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.page-hdr h1{font-size:clamp(2rem,5vw,3.2rem);color:var(--text);margin-bottom:12px}
.page-hdr h1 span{color:var(--accent)}
.page-hdr p{color:var(--text2);font-size:1.05rem;max-width:580px;margin:0 auto}
.breadcrumb{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:18px;font-size:.83rem}
.breadcrumb a{color:var(--text3)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .bc-sep{color:var(--text3)}
.breadcrumb .bc-cur{color:var(--accent)}

/* --- Footer --- */
.footer{background:#040404;border-top:1px solid var(--border);padding:60px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:40px}
.ft-brand .ft-logo{font-family:'Oswald',sans-serif;font-size:1.4rem;font-weight:700;color:var(--text);display:block;margin-bottom:10px}
.ft-brand .ft-logo span{color:var(--accent)}
.ft-brand p{color:var(--text3);font-size:.88rem;line-height:1.7;margin-bottom:20px}
.ft-social{display:flex;gap:8px}
.ft-social a{width:34px;height:34px;background:var(--bg3);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:.85rem;transition:var(--t)}
.ft-social a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.ft-title{font-family:'Oswald',sans-serif;font-size:.88rem;color:var(--text);text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.ft-links li{margin-bottom:7px}
.ft-links a{color:var(--text3);font-size:.87rem;transition:var(--t)}
.ft-links a:hover{color:var(--accent)}
.ft-ci{display:flex;gap:10px;margin-bottom:11px;color:var(--text3);font-size:.86rem}
.ft-ci .ic{color:var(--accent)}
.footer-bottom{border-top:1px solid var(--border);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{color:var(--text3);font-size:.82rem}
.footer-bottom a{color:var(--text3);transition:var(--t)}
.footer-bottom a:hover{color:var(--accent)}
.ft-langs{display:flex;gap:14px}
.ft-langs a{color:var(--text3);font-size:.82rem}
.ft-langs a:hover,.ft-langs a.cur{color:var(--accent)}

/* --- Misc --- */
.highlight{background:rgba(232,64,30,.07);border:1px solid rgba(232,64,30,.2);border-radius:var(--r2);padding:28px}
.notice{background:rgba(232,64,30,.1);border-left:4px solid var(--accent);padding:14px 18px;border-radius:0 var(--r) var(--r) 0;color:var(--text2);font-size:.92rem;margin:20px 0}
.info-list li{padding:9px 0;border-bottom:1px solid var(--border);color:var(--text2);display:flex;gap:10px;align-items:flex-start}
.info-list li::before{content:'▸';color:var(--accent);flex-shrink:0;margin-top:2px}
.tag{display:inline-block;font-family:'Oswald',sans-serif;font-size:.7rem;color:var(--accent);background:rgba(232,64,30,.1);border:1px solid rgba(232,64,30,.3);padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.1em}

/* Animations */
.fade{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.fade.vis{opacity:1;transform:none}
.fade-l{opacity:0;transform:translateX(-28px);transition:opacity .6s ease,transform .6s ease}
.fade-l.vis{opacity:1;transform:none}
.fade-r{opacity:0;transform:translateX(28px);transition:opacity .6s ease,transform .6s ease}
.fade-r.vis{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* Utilities */
.text-accent{color:var(--accent)}
.text-muted{color:var(--text2)}
.text-center{text-align:center}
.mt-10{margin-top:10px}.mt-20{margin-top:20px}.mt-30{margin-top:30px}
.mb-10{margin-bottom:10px}.mb-20{margin-bottom:20px}.mb-30{margin-bottom:30px}
.gap-10{gap:10px}.gap-20{gap:20px}
.fw-7{font-weight:700}

/* --- Responsive --- */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links,.btn-nav{display:none}
  .hamburger{display:flex}
  .hero-h1{font-size:2.6rem}
  .section{padding:56px 0}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .stats-inner{display:grid;grid-template-columns:repeat(2,1fr)}
  .hero-btns{flex-direction:column;align-items:center}
  .form-row{grid-template-columns:1fr}
  .float-wa{bottom:20px;right:16px;width:52px;height:52px}
  .float-tel{bottom:82px;right:16px;width:52px;height:52px}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .contact-form-box{padding:22px 18px}
  .price-card{padding:26px 20px}
}
