/* MSM DRIVING SCHOOL — STYLE.CSS — V2 */


:root {
  --black: #0c0c0c;
  --black-light: #161616;
  --white: #ffffff;
  --off-white: #f4f5f7;
  --grey: #777;
  --grey-light: #dfe1e6;
  --red: #cc0e1f;
  --red-dark: #a80c19;
  --red-glow: rgba(204,14,31,0.12);
  --blue: #1a3f7a;
  --blue-light: #2555a0;
  --blue-glow: rgba(26,63,122,0.1);
  --font-heading: 'Outfit', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --max-width: 1200px;
  --radius: 8px;
  --radius-lg: 14px;
  --transition: 0.3s ease;
  --shadow: 0 4px 20px rgba(0,0,0,0.1);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.15);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--black);background:var(--white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:800;line-height:1.15;letter-spacing:-0.02em}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,4vw,2.4rem)}
h3{font-size:clamp(1.2rem,3vw,1.5rem)}
p{margin-bottom:1rem}
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 20px}
.text-red{color:var(--red)}
.text-blue{color:var(--blue)}
.text-white{color:var(--white)}
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-heading);font-weight:700;font-size:1rem;padding:14px 32px;border-radius:50px;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;letter-spacing:0.01em}
.btn-red{background:var(--red);color:var(--white)}
.btn-red:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(204,14,31,0.3)}
.btn-blue{background:var(--blue);color:var(--white)}
.btn-blue:hover{background:var(--blue-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,63,122,0.3)}
.btn-white{background:var(--white);color:var(--black)}
.btn-white:hover{background:var(--off-white);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--white);border:2px solid var(--white)}
.btn-outline:hover{background:var(--white);color:var(--black)}
.btn-outline-dark{background:transparent;color:var(--black);border:2px solid var(--black)}
.btn-outline-dark:hover{background:var(--black);color:var(--white)}
.btn-sm{padding:10px 22px;font-size:0.9rem}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--black);border-bottom:1px solid rgba(255,255,255,0.06);transition:var(--transition)}
.site-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,0.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px;max-width:var(--max-width);margin:0 auto;padding:0 20px}
.header-logo{display:flex;align-items:center;gap:10px}
.header-logo img{height:52px;width:52px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,0.1);background:var(--black)}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{color:rgba(255,255,255,0.75);font-family:var(--font-heading);font-weight:500;font-size:0.9rem;transition:var(--transition);position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:var(--transition)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.header-cta{display:flex;align-items:center;gap:14px}
.header-phone{color:var(--white);font-family:var(--font-heading);font-weight:700;font-size:0.95rem;display:flex;align-items:center;gap:6px}
.header-phone svg{flex-shrink:0}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1001}
.hamburger span{display:block;width:26px;height:2.5px;background:var(--white);border-radius:2px;transition:var(--transition)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--black);z-index:999;padding:100px 30px 40px;flex-direction:column;overflow-y:auto}
.mobile-nav.active{display:flex}
.mobile-nav a{color:var(--white);font-family:var(--font-heading);font-weight:700;font-size:1.3rem;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.06);display:block}
.mobile-nav a:hover{color:var(--red)}
.mobile-nav .mobile-cta{margin-top:28px;display:flex;flex-direction:column;gap:12px}
@media(max-width:960px){.nav-links{display:none}.header-cta .btn{display:none}.hamburger{display:flex}}
@media(max-width:480px){.header-phone span{display:none}}

/* Trust Bar */
.trust-bar{background:var(--blue);padding:12px 0}
.trust-bar-inner{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;max-width:var(--max-width);margin:0 auto;padding:0 20px}
.trust-item{display:flex;align-items:center;gap:6px;font-family:var(--font-heading);font-weight:600;font-size:0.82rem;color:var(--white);white-space:nowrap}
.trust-stars{color:#fbbf24;font-size:0.9rem}
@media(max-width:600px){.trust-bar-inner{gap:10px}.trust-item{font-size:0.72rem}}

/* Hero */
.hero{position:relative;background:var(--black);padding:140px 0 80px;overflow:hidden;min-height:520px;display:flex;align-items:center}
.hero::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,var(--red-glow),transparent 70%);border-radius:50%;pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-150px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,var(--blue-glow),transparent 70%);border-radius:50%;pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:660px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(204,14,31,0.1);border:1px solid rgba(204,14,31,0.25);color:var(--red);font-family:var(--font-heading);font-weight:600;font-size:0.82rem;padding:8px 16px;border-radius:50px;margin-bottom:22px}
.hero h1{color:var(--white);margin-bottom:18px}
.hero h1 .highlight{color:var(--red)}
.hero p{color:rgba(255,255,255,0.65);font-size:1.05rem;margin-bottom:30px;max-width:520px}
.hero-buttons{display:flex;gap:12px;flex-wrap:wrap}
.hero-image{position:absolute;right:5%;bottom:0;width:40%;max-width:420px;z-index:1;opacity:0.15;border-radius:var(--radius-lg)}
@media(max-width:768px){.hero{padding:120px 0 60px;min-height:auto}.hero-image{display:none}}

/* Page Hero */
.page-hero{background:var(--black);padding:120px 0 48px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:350px;height:350px;background:radial-gradient(circle,var(--blue-glow),transparent 70%);border-radius:50%;pointer-events:none}
.page-hero h1{color:var(--white);margin-bottom:10px;position:relative;z-index:2}
.page-hero p{color:rgba(255,255,255,0.6);font-size:1rem;max-width:580px;position:relative;z-index:2}

/* Breadcrumbs */
.breadcrumbs{padding:12px 0;background:var(--off-white);border-bottom:1px solid var(--grey-light)}
.breadcrumbs ol{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:0.82rem;color:var(--grey)}
.breadcrumbs a{color:var(--grey);transition:var(--transition)}
.breadcrumbs a:hover{color:var(--red)}
.breadcrumbs .sep{color:var(--grey-light)}
.breadcrumbs .current{color:var(--black);font-weight:500}

/* Sections */
.section{padding:65px 0}
.section-dark{background:var(--black);color:var(--white)}
.section-grey{background:var(--off-white)}
.section-blue{background:var(--blue);color:var(--white)}
.section-header{text-align:center;margin-bottom:45px}
.section-header .label{display:inline-block;color:var(--red);font-family:var(--font-heading);font-weight:700;font-size:0.82rem;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px}
.section-header h2{margin-bottom:14px}
.section-header p{color:var(--grey);max-width:540px;margin:0 auto}
.section-dark .section-header p,.section-blue .section-header p{color:rgba(255,255,255,0.55)}

/* Features */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.feature-card{background:var(--white);border:1px solid var(--grey-light);border-radius:var(--radius-lg);padding:28px 24px;transition:var(--transition)}
.feature-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.feature-icon{width:48px;height:48px;background:var(--red-glow);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feature-icon svg{width:22px;height:22px;color:var(--red)}
.feature-card h3{font-size:1.1rem;margin-bottom:6px}
.feature-card p{color:var(--grey);font-size:0.92rem;margin:0}

/* About Preview */
.about-preview{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about-image{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.about-image img{width:100%;height:380px;object-fit:cover}
.about-text h2{margin-bottom:18px}
.about-text .label{display:inline-block;color:var(--red);font-family:var(--font-heading);font-weight:700;font-size:0.82rem;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px}
.about-text p{color:#555}
.about-stats{display:flex;gap:36px;margin-top:24px;padding-top:24px;border-top:1px solid var(--grey-light)}
.stat-item strong{display:block;font-family:var(--font-heading);font-size:1.8rem;font-weight:900;color:var(--red)}
.stat-item span{font-size:0.82rem;color:var(--grey)}
@media(max-width:768px){.about-preview{grid-template-columns:1fr;gap:28px}.about-image img{height:260px}.about-stats{gap:20px}}

/* Testimonials */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.testimonial-card{background:var(--black-light);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius-lg);padding:28px 24px}
.testimonial-stars{color:#fbbf24;font-size:0.95rem;margin-bottom:14px;letter-spacing:2px}
.testimonial-card blockquote{color:rgba(255,255,255,0.8);font-size:0.92rem;font-style:italic;line-height:1.7;margin-bottom:18px}
.testimonial-author{display:flex;align-items:center;gap:10px}
.testimonial-avatar{width:38px;height:38px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;color:var(--white);font-family:var(--font-heading);font-weight:800;font-size:0.85rem}
.testimonial-name{font-family:var(--font-heading);font-weight:600;color:var(--white);font-size:0.9rem}
.testimonial-via{font-size:0.78rem;color:var(--grey)}

/* Pass Gallery */
.pass-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.pass-photo{border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;position:relative}
.pass-photo img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}
.pass-photo:hover img{transform:scale(1.05)}
@media(max-width:600px){.pass-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}}

/* Reviews Page */
.reviews-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}
.review-card{background:var(--white);border:1px solid var(--grey-light);border-radius:var(--radius-lg);padding:24px 22px;transition:var(--transition)}
.review-card:hover{box-shadow:var(--shadow)}
.review-stars{color:#fbbf24;margin-bottom:10px;letter-spacing:2px;font-size:0.9rem}
.review-card blockquote{color:#444;font-size:0.92rem;line-height:1.7;margin-bottom:14px;font-style:italic}
.review-meta{display:flex;align-items:center;gap:10px}
.review-initial{width:34px;height:34px;border-radius:50%;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:800;font-size:0.8rem}
.review-name{font-family:var(--font-heading);font-weight:600;font-size:0.88rem}
.review-source{font-size:0.78rem;color:var(--grey)}

/* Areas Grid */
.areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.area-card{display:flex;align-items:center;gap:10px;padding:18px;background:var(--white);border:1px solid var(--grey-light);border-radius:var(--radius);transition:var(--transition);font-family:var(--font-heading);font-weight:600;font-size:0.95rem}
.area-card:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow)}
.area-card svg{color:var(--red);flex-shrink:0}

/* CTA */
.cta-section{background:var(--black);padding:65px 0;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,var(--red-glow),transparent 70%);border-radius:50%;pointer-events:none}
.cta-content{position:relative;z-index:2}
.cta-section h2{color:var(--white);margin-bottom:14px}
.cta-section p{color:rgba(255,255,255,0.55);margin-bottom:28px;max-width:480px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-family:var(--font-heading);font-weight:600;font-size:0.88rem;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 16px;font-family:var(--font-body);font-size:0.95rem;border:1px solid var(--grey-light);border-radius:var(--radius);background:var(--white);color:var(--black);transition:var(--transition)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}
.form-group textarea{height:130px;resize:vertical}
.contact-info-card{background:var(--black);color:var(--white);border-radius:var(--radius-lg);padding:36px 28px}
.contact-info-item{display:flex;gap:14px;margin-bottom:24px}
.contact-info-item:last-child{margin-bottom:0}
.contact-info-icon{width:42px;height:42px;min-width:42px;background:rgba(255,255,255,0.07);border-radius:10px;display:flex;align-items:center;justify-content:center}
.contact-info-icon svg{color:var(--red)}
.contact-info-item h3{font-size:0.92rem;margin-bottom:3px}
.contact-info-item p{color:rgba(255,255,255,0.55);font-size:0.88rem;margin:0}
.contact-info-item a{color:var(--white);text-decoration:underline;text-underline-offset:3px}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;gap:28px}}

/* FAQ */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--grey-light)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:20px 0;cursor:pointer;font-family:var(--font-heading);font-weight:700;font-size:1.02rem;gap:14px;transition:var(--transition)}
.faq-question:hover{color:var(--red)}
.faq-icon{width:26px;height:26px;min-width:26px;border-radius:50%;background:var(--off-white);display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:1.1rem;line-height:1}
.faq-item.active .faq-icon{background:var(--red);color:var(--white);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-item.active .faq-answer{max-height:500px;padding-bottom:20px}
.faq-answer p{color:#555;font-size:0.92rem;line-height:1.8}

/* Content Pages */
.content-section{padding:55px 0}
.content-body{max-width:760px}
.content-body h2{margin-top:32px;margin-bottom:14px}
.content-body h3{margin-top:24px;margin-bottom:10px}
.content-body p{color:#444;line-height:1.8}
.content-body ul{margin:14px 0;padding-left:22px}
.content-body ul li{list-style:disc;color:#444;margin-bottom:6px;line-height:1.7}
.content-layout{display:grid;grid-template-columns:1fr 300px;gap:44px}
.content-sidebar{position:sticky;top:100px}
.sidebar-card{background:var(--off-white);border-radius:var(--radius-lg);padding:24px 22px;margin-bottom:20px}
.sidebar-card h3{font-size:1.05rem;margin-bottom:14px}
.sidebar-card a{display:block;padding:8px 0;color:var(--black);font-weight:500;border-bottom:1px solid var(--grey-light);transition:var(--transition);font-size:0.92rem}
.sidebar-card a:hover{color:var(--red);padding-left:6px}
.sidebar-card a:last-child{border-bottom:none}
@media(max-width:900px){.content-layout{grid-template-columns:1fr}.content-sidebar{position:static}}

/* Car placeholder */
.car-placeholder{background:var(--off-white);border:2px dashed var(--grey-light);border-radius:var(--radius-lg);padding:60px 20px;text-align:center;color:var(--grey);font-family:var(--font-heading);font-weight:600}

/* Map */
.map-wrapper{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--grey-light);height:320px}
.map-wrapper iframe{width:100%;height:100%;border:none}

/* Footer */
.site-footer{background:var(--black);color:rgba(255,255,255,0.65);padding:55px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,0.06)}
.footer-brand img{height:60px;width:60px;border-radius:50%;object-fit:cover;margin-bottom:14px}
.footer-brand p{font-size:0.88rem;line-height:1.7;max-width:280px}
.footer-col h4{color:var(--white);font-size:0.95rem;margin-bottom:16px}
.footer-col a{display:block;color:rgba(255,255,255,0.55);font-size:0.88rem;padding:4px 0;transition:var(--transition)}
.footer-col a:hover{color:var(--white);padding-left:4px}
.footer-social{display:flex;gap:10px;margin-top:14px}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.07);display:flex;align-items:center;justify-content:center;transition:var(--transition);padding:0}
.footer-social a:hover{background:var(--red)}
.footer-social a svg{width:17px;height:17px;color:var(--white)}
.footer-bottom{padding:22px 0;text-align:center;font-size:0.8rem;color:rgba(255,255,255,0.35)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* WhatsApp Float */
.whatsapp-float{position:fixed;bottom:22px;right:22px;z-index:998;width:54px;height:54px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,0.4);transition:var(--transition)}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(37,211,102,0.5)}
.whatsapp-float svg{width:26px;height:26px;color:var(--white)}

/* Form success */
.form-success{background:#25d366;color:white;padding:16px;border-radius:var(--radius);text-align:center;font-family:var(--font-heading);font-weight:600;display:none}
.form-success.show{display:block}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-up{opacity:0;animation:fadeUp 0.5s ease forwards}
.fade-up-d1{animation-delay:0.1s}.fade-up-d2{animation-delay:0.2s}.fade-up-d3{animation-delay:0.3s}
