/* ============================================================
   Best One Driving School — Shared Stylesheet
   bestonedrivingschool.com
   ============================================================ */

/* --- Variables & Reset --- */
:root {
    --primary: #0056b3;
    --primary-dark: #004494;
    --secondary: #1a252f;
    --accent: #f1c40f;
    --text-dark: #333;
    --text-light: #666;
    --white: #ffffff;
    --light-bg: #f4f7f6;
    --shadow: 0 5px 15px rgba(0,0,0,0.1);
    --transition: all 0.3s ease;
}

* { margin:0; padding:0; box-sizing:border-box; font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif; }
html { scroll-behavior:smooth; }
body { overflow-x:hidden; color:var(--text-dark); padding-top:100px; background-color:var(--white); }

/* --- Animations --- */
.reveal { opacity:0; transform:translateY(30px); transition:all 0.8s ease; }
.reveal.active { opacity:1; transform:translateY(0); }
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.05)} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(40px)} to{opacity:1;transform:translateY(0)} }

/* --- Header --- */
header {
    position:fixed; top:0; left:0; right:0; z-index:1000;
    background:rgba(255,255,255,0.97); height:100px;
    box-shadow:0 2px 20px rgba(0,0,0,0.1); backdrop-filter:blur(10px);
    border-bottom:3px solid var(--primary);
}
header .container { height:100%; display:flex; align-items:center; }
nav { display:flex; align-items:center; justify-content:space-between; width:100%; }
.logo img { height:110px; width:auto; display:block; }
.nav-links { display:flex; list-style:none; align-items:center; gap:5px; }
.nav-links a { text-decoration:none; color:var(--text-dark); font-weight:600; font-size:0.9rem; padding:8px 10px; border-radius:8px; transition:var(--transition); }
.nav-links a:hover { color:var(--primary); background:var(--light-bg); }
.btn-nav { background:var(--primary)!important; color:white!important; padding:10px 20px!important; border-radius:25px!important; }
.btn-nav:hover { background:var(--primary-dark)!important; }
.header-whatsapp-btn { display:flex; align-items:center; gap:8px; background:#25D366; color:white!important; padding:10px 18px!important; border-radius:25px!important; font-size:0.9rem!important; }
.header-whatsapp-btn:hover { background:#1ebe57!important; }
.header-socials { display:flex; align-items:center; gap:12px; padding-left:10px; border-left:1px solid #eee; }
.header-socials a.social-icon { display:flex; align-items:center; justify-content:center; width:28px; height:28px; transition:var(--transition); }
.header-socials a.social-icon:hover { transform:scale(1.15); }
.mobile-controls { display:none; align-items:center; gap:12px; }
.hamburger { background:none; border:none; cursor:pointer; padding:8px; }
.hamburger-icon { font-size:1.5rem; color:var(--text-dark); }

/* --- Container --- */
.container { max-width:1200px; margin:0 auto; padding:0 20px; }

/* --- Hero --- */
.hero {
    min-height:90vh; display:flex; align-items:center;
    background:linear-gradient(135deg,#0056b3 0%,#004494 50%,#1a252f 100%);
    position:relative; overflow:hidden; padding:60px 0;
}
.hero::before { content:''; position:absolute; top:0; left:0; right:0; bottom:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.hero-content { position:relative; z-index:2; max-width:650px; animation:fadeInUp 0.8s ease; }
.mobile-hero-branding { display:none; flex-direction:column; align-items:center; margin-bottom:20px; }
.mobile-hero-branding img { height:80px; width:auto; background:rgba(255,255,255,0.9); padding:8px; border-radius:10px; margin-bottom:8px; }
.mobile-hero-branding h2 { color:white; font-size:1.1rem; text-align:center; }
.hero h1 { font-size:3rem; font-weight:800; color:white; line-height:1.2; margin-bottom:20px; }
.hero p { font-size:1.1rem; color:rgba(255,255,255,0.9); margin-bottom:30px; line-height:1.7; }
.hero-cta-group { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:20px; }
.hero-btn { display:inline-flex; align-items:center; gap:8px; background:var(--accent); color:#1a252f; padding:16px 32px; border-radius:50px; font-size:1.1rem; font-weight:700; text-decoration:none; transition:var(--transition); box-shadow:0 5px 20px rgba(241,196,15,0.4); }
.hero-btn:hover { transform:translateY(-3px); box-shadow:0 8px 25px rgba(241,196,15,0.5); }
.hero-btn-call { display:inline-flex; align-items:center; gap:8px; background:#25D366; color:white; padding:16px 32px; border-radius:50px; font-size:1.1rem; font-weight:700; text-decoration:none; transition:var(--transition); box-shadow:0 5px 20px rgba(37,211,102,0.4); }
.hero-btn-call:hover { transform:translateY(-3px); background:#1ebe57; }
.hero-trust-badges { display:flex; gap:20px; flex-wrap:wrap; margin-top:10px; }
.hero-badge { display:flex; align-items:center; gap:8px; color:rgba(255,255,255,0.85); font-size:0.88rem; }
.hero-badge::before { content:'✓'; color:var(--accent); font-weight:900; font-size:1rem; }
.hero-logo-overlay { position:absolute; right:60px; top:50%; transform:translateY(-50%); z-index:1; display:none; }
.hero-logo-overlay img { height:280px; width:auto; opacity:0.15; filter:brightness(10); }
@media(min-width:992px){ .hero-logo-overlay{display:block} }

/* --- Section Headers --- */
.section-header { text-align:center; margin-bottom:60px; }
.section-header h2 { font-size:2.2rem; font-weight:800; color:var(--secondary); margin-bottom:15px; }
.section-header p { font-size:1.05rem; color:var(--text-light); max-width:700px; margin:0 auto; }

/* --- Features --- */
.features { padding:100px 0; background:var(--light-bg); }
.features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:30px; }
.feature-card { background:var(--white); padding:40px 30px; border-radius:20px; box-shadow:var(--shadow); transition:var(--transition); text-align:center; border-top:4px solid var(--primary); }
.feature-card:hover { transform:translateY(-10px); box-shadow:0 15px 35px rgba(0,0,0,0.15); }
.feature-icon { font-size:2.5rem; color:var(--primary); margin-bottom:20px; }
.feature-card h3 { font-size:1.3rem; font-weight:700; color:var(--secondary); margin-bottom:15px; }
.feature-card p { color:var(--text-light); line-height:1.7; }

/* --- Areas Section --- */
.areas-section { padding:100px 0; background:var(--white); }
.areas-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:25px; }
.area-card { background:var(--white); padding:30px; border-radius:15px; box-shadow:0 5px 15px rgba(0,0,0,0.05); transition:var(--transition); border-left:4px solid var(--primary); }
.area-card:hover { transform:translateY(-5px); box-shadow:0 10px 25px rgba(0,0,0,0.1); }
.area-card h3 { color:var(--secondary); font-size:1.1rem; margin-bottom:12px; padding-bottom:10px; border-bottom:1px solid #eee; }
.area-list { list-style:none; }
.area-list li { margin-bottom:8px; color:var(--text-light); display:flex; align-items:center; font-size:0.95rem; }
.area-list li::before { content:'•'; color:var(--primary); font-weight:bold; margin-right:10px; }
.area-list a,.city-link { color:inherit; text-decoration:none; font-weight:600; }
.area-list a:hover,.city-link:hover { color:var(--primary); text-decoration:underline; }

/* --- Test Centre Section --- */
.test-centre { padding:80px 0; background:var(--light-bg); }
.test-centre-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:30px; margin-top:40px; }
.test-centre-card { background:var(--white); padding:30px; border-radius:15px; box-shadow:var(--shadow); border-top:4px solid var(--accent); }
.test-centre-card h3 { font-size:1.15rem; font-weight:700; color:var(--secondary); margin-bottom:12px; }
.test-centre-card p { color:var(--text-light); line-height:1.7; font-size:0.95rem; }

/* --- Nearby Areas Links --- */
.nearby-areas { padding:60px 0; background:var(--white); }
.nearby-areas h2 { font-size:1.6rem; font-weight:700; color:var(--secondary); text-align:center; margin-bottom:30px; }
.nearby-grid { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.nearby-link { display:inline-flex; align-items:center; gap:8px; padding:12px 22px; background:var(--light-bg); border:2px solid var(--primary); border-radius:50px; color:var(--primary); text-decoration:none; font-weight:600; font-size:0.95rem; transition:var(--transition); }
.nearby-link:hover { background:var(--primary); color:white; transform:translateY(-2px); }

/* --- Pricing --- */
.pricing { padding:100px 0; background:var(--white); }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:40px; max-width:1100px; margin:0 auto; }
.price-card { background:var(--white); border-radius:20px; padding:50px 30px; text-align:center; box-shadow:var(--shadow); transition:var(--transition); position:relative; overflow:hidden; border:1px solid #eee; }
.price-card:hover { transform:translateY(-15px); box-shadow:0 20px 40px rgba(0,0,0,0.15); }
.price-card.featured { background:var(--primary); color:white; transform:scale(1.05); border:none; z-index:2; }
.price-card.featured:hover { transform:scale(1.05) translateY(-15px); }
.price-card h3 { font-size:1.5rem; margin-bottom:20px; font-weight:700; }
.price { font-size:3.5rem; font-weight:800; color:var(--primary); margin-bottom:10px; }
.price-card.featured .price { color:var(--white); }
.price span { font-size:1rem; color:#999; font-weight:400; }
.price-card.featured .price span { color:#e0e0e0; }
.price-card ul { list-style:none; margin:30px 0; text-align:left; }
.price-card ul li { margin-bottom:15px; padding-left:30px; position:relative; color:var(--text-light); }
.price-card.featured ul li { color:#f8f9fa; }
.price-card ul li::before { content:'✓'; color:var(--primary); position:absolute; left:0; font-weight:bold; }
.price-card.featured ul li::before { color:var(--accent); }
.btn-price { display:inline-block; padding:15px 35px; border:2px solid var(--primary); color:var(--primary); text-decoration:none; border-radius:50px; font-weight:bold; transition:var(--transition); }
.btn-price:hover { background:var(--primary); color:white; }
.price-card.featured .btn-price { background:var(--white); color:var(--primary); border-color:var(--white); }
.price-card.featured .btn-price:hover { background:var(--light-bg); color:var(--primary-dark); }

/* --- Gallery --- */
.gallery-section { padding:100px 0; background:var(--light-bg); }
.gallery-container { position:relative; padding:0 40px; }
.gallery-scroll-wrapper { display:flex; overflow-x:auto; gap:20px; padding:20px 0; scroll-behavior:smooth; scrollbar-width:none; }
.gallery-scroll-wrapper::-webkit-scrollbar { display:none; }
.gallery-item { flex:0 0 auto; width:220px; height:220px; border-radius:15px; overflow:hidden; cursor:pointer; box-shadow:var(--shadow); transition:var(--transition); }
.gallery-item:hover { transform:scale(1.05); box-shadow:0 10px 25px rgba(0,0,0,0.2); }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.gallery-item:hover img { transform:scale(1.1); }
.gallery-nav-btn { position:absolute; top:50%; transform:translateY(-50%); width:50px; height:50px; border-radius:50%; background:white; border:none; box-shadow:0 5px 15px rgba(0,0,0,0.2); cursor:pointer; z-index:10; color:var(--primary); font-size:1.2rem; transition:var(--transition); }
.gallery-nav-btn:hover { background:var(--primary); color:white; }
.gallery-prev { left:-10px; }
.gallery-next { right:-10px; }
.view-full-gallery-btn { display:block; width:fit-content; margin:40px auto 0; padding:15px 40px; background:var(--primary); color:white; text-decoration:none; border-radius:50px; font-weight:bold; transition:var(--transition); box-shadow:var(--shadow); }
.view-full-gallery-btn:hover { background:var(--primary-dark); transform:translateY(-3px); }

/* --- Testimonials --- */
.testimonials { padding:100px 0; background:var(--white); }
.custom-google-badge { display:flex; align-items:center; justify-content:space-between; background:#ffffff; padding:15px 20px; border-radius:40px; box-shadow:0 4px 20px rgba(0,0,0,0.08); width:fit-content; margin:0 auto 50px auto; border:1px solid #eaeaea; gap:25px; }
.cgb-left { display:flex; align-items:center; gap:20px; }
.cgb-logo { width:40px; height:40px; display:flex; align-items:center; justify-content:center; }
.cgb-logo img { width:100%; height:auto; }
.cgb-score { font-size:1.8rem; font-weight:900; color:#202124; line-height:1; }
.cgb-stars { color:#fbbc04; font-size:1.2rem; letter-spacing:2px; }
.cgb-text { font-size:0.85rem; color:#5f6368; margin-top:4px; }
.cgb-btn { background:#1a73e8; color:white; text-decoration:none; padding:12px 24px; border-radius:8px; font-weight:600; font-size:0.95rem; transition:background 0.2s; text-align:center; line-height:1.2; }
.cgb-btn:hover { background:#1557b0; }
.testimonial-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:30px; }
.review-card { background:var(--light-bg); padding:30px; border-radius:15px; box-shadow:0 5px 15px rgba(0,0,0,0.05); transition:var(--transition); border-left:4px solid var(--primary); }
.review-card:hover { transform:translateY(-5px); }
.reviewer { display:flex; align-items:center; gap:15px; margin-bottom:15px; }
.reviewer-avatar { width:50px; height:50px; border-radius:50%; background:var(--primary); color:white; display:flex; align-items:center; justify-content:center; font-size:1.3rem; font-weight:700; flex-shrink:0; }
.review-meta h4 { font-size:1rem; font-weight:700; color:var(--secondary); }
.review-card p { color:var(--text-light); line-height:1.7; font-style:italic; }

/* --- Contact --- */
.contact { padding:100px 0; background:var(--secondary); }
.contact-container { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contact-info h3 { font-size:2rem; font-weight:800; color:white; margin-bottom:20px; }
.contact-info p { color:#95a5a6; line-height:1.7; }
.contact-item { display:flex; align-items:center; gap:15px; margin-top:20px; }
.contact-icon { width:40px; height:40px; background:rgba(255,255,255,0.1); display:inline-flex; align-items:center; justify-content:center; border-radius:50%; flex:0 0 40px; transition:var(--transition); }
.contact-icon img { width:22px; height:22px; object-fit:contain; }
.contact-item:hover .contact-icon { background:var(--primary); }
.contact-item a { color:#bdc3c7; text-decoration:none; transition:var(--transition); font-size:1rem; }
.contact-item a:hover { color:var(--primary); }
.contact-form-placeholder { background:rgba(255,255,255,0.05); padding:40px; border-radius:20px; border:1px solid rgba(255,255,255,0.1); }
.contact-form-placeholder h4 { color:white; font-size:1.4rem; margin-bottom:8px; }
.seo-p1 { color:#95a5a6; margin-bottom:20px!important; }
.seo-p2 { margin-top:10px; font-weight:bold; color:#ffffff; }
.contact-form-placeholder input,
.contact-form-placeholder textarea { width:100%; padding:14px 18px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15); border-radius:10px; color:white; font-size:0.95rem; margin-bottom:15px; transition:var(--transition); font-family:inherit; }
.contact-form-placeholder input::placeholder,
.contact-form-placeholder textarea::placeholder { color:#7f8c8d; }
.contact-form-placeholder input:focus,
.contact-form-placeholder textarea:focus { outline:none; border-color:var(--primary); background:rgba(255,255,255,0.12); }
.contact-form-placeholder textarea { resize:vertical; }
.contact-form-placeholder button { width:100%; padding:16px; background:var(--primary); color:white; border:none; border-radius:10px; font-size:1.1rem; font-weight:700; cursor:pointer; transition:var(--transition); font-family:inherit; }
.contact-form-placeholder button:hover { background:var(--primary-dark); transform:translateY(-2px); }
#cf-status { display:none; padding:12px 16px; border-radius:8px; margin-top:12px; font-size:0.95rem; font-weight:500; }

/* --- Footer --- */
footer { background:var(--secondary); padding:60px 0 0; border-top:4px solid var(--primary); }
.footer-content { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:40px; margin-bottom:40px; }
.footer-col h3 { color:white; margin-bottom:20px; font-size:1.3rem; position:relative; padding-bottom:10px; }
.footer-col h3::after { content:''; position:absolute; left:0; bottom:0; width:40px; height:3px; background:var(--primary); }
.footer-logo { max-width:180px; margin-bottom:20px; background:rgba(255,255,255,0.9); padding:15px; border-radius:10px; }
.footer-col p { color:#95a5a6; line-height:1.7; font-size:0.95rem; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:12px; }
.footer-links a { color:#95a5a6; text-decoration:none; transition:var(--transition); display:inline-block; font-size:0.95rem; }
.footer-links a:hover { color:var(--primary); transform:translateX(5px); }
.footer-socials { display:flex; gap:15px; margin-top:20px; }
.footer-socials a { display:flex; align-items:center; justify-content:center; width:46px; height:46px; background:rgba(255,255,255,0.1); color:white; border-radius:50%; font-size:1.2rem; transition:var(--transition); text-decoration:none; }
.footer-socials a:hover { background:var(--primary); transform:translateY(-3px); }
.footer-socials img { width:24px; height:24px; object-fit:contain; }
.footer-whatsapp-btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; background:#25D366; color:white; padding:15px 30px; border-radius:15px; text-decoration:none; font-size:1.1rem; font-weight:bold; margin-top:15px; transition:var(--transition); box-shadow:0 5px 15px rgba(37,211,102,0.3); width:100%; max-width:300px; }
.footer-whatsapp-btn:hover { background:#1ebe57; transform:translateY(-3px); color:white; }
.footer-whatsapp-btn img { width:24px; height:24px; }
.footer-bottom { text-align:center; padding:20px 0; border-top:1px solid #2c3e50; font-size:0.9rem; color:#7f8c8d; }
.footer-bottom p { margin-bottom:5px; }
.created-with-love { color:#bdc3c7!important; margin-top:10px; }
.created-with-love span { color:#e74c3c; animation:pulse 1.5s infinite; display:inline-block; }
.created-with-love a { color:#bdc3c7; text-decoration:none; font-weight:bold; transition:var(--transition); }
.created-with-love a:hover { color:var(--primary); }

/* --- Floating Widget --- */
.floating-widget { position:fixed; bottom:30px; right:30px; display:flex; flex-direction:column; align-items:center; gap:15px; z-index:999; }
.floating-menu { display:flex; flex-direction:column; gap:15px; opacity:0; visibility:hidden; transform:translateY(20px); transition:all 0.3s ease; }
.floating-menu.active { opacity:1; visibility:visible; transform:translateY(0); }
.float-btn { width:60px; height:60px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:white; text-decoration:none; font-size:1.8rem; box-shadow:0 5px 20px rgba(0,0,0,0.3); transition:var(--transition); border:none; cursor:pointer; }
.float-btn:hover { transform:scale(1.1); }
.float-toggle { background:#4285F4; animation:pulse 2s infinite; }
.float-toggle.active { animation:none; background:#4285F4; transform:rotate(90deg); }
.float-whatsapp { background:#25D366; }
.float-phone { background:var(--primary); }
.float-email { background:#e74c3c; }
.float-btn img { width:28px; height:28px; object-fit:contain; }
.float-email img { filter:brightness(0) invert(1); }

/* --- Lightbox --- */
.lightbox { display:none; position:fixed; z-index:2000; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.95); justify-content:center; align-items:center; backdrop-filter:blur(5px); }
.lightbox img { max-width:90%; max-height:90%; border-radius:10px; box-shadow:0 0 30px rgba(0,0,0,0.5); }
@keyframes zoomIn { from{transform:scale(0.8);opacity:0} to{transform:scale(1);opacity:1} }
.lightbox-close { position:absolute; top:30px; right:40px; color:white; font-size:3rem; cursor:pointer; transition:var(--transition); }
.lightbox-close:hover { color:var(--primary); transform:rotate(90deg); }

/* --- SVG Icons --- */
.social-svg,.icon-svg { display:block; width:24px; height:24px; object-fit:contain; }

/* --- Responsive --- */
@media(min-width:992px){ .hero-logo-overlay{display:block} }
@media(max-width:1200px){
    header{height:80px}
    body{padding-top:80px}
    .logo img{height:85px}
    .mobile-hero-branding{display:flex}
    .hero h1{font-size:2.8rem;text-align:center}
    .hero p{text-align:center}
    .hero-content{text-align:center;margin:0 auto}
    .hero-cta-group{justify-content:center}
    .hero-trust-badges{justify-content:center}
    .mobile-controls{display:flex!important}
    .nav-links{position:fixed;top:80px;right:-100%;width:100%;height:calc(100vh - 80px);background:white;flex-direction:column;justify-content:center;transition:right 0.4s cubic-bezier(0.77,0,0.175,1);box-shadow:-5px 0 20px rgba(0,0,0,0.1);z-index:1000;overflow-y:auto;padding:20px 0}
    .nav-links.active{right:0}
    .nav-links li{margin:12px 0;opacity:0;transform:translateX(20px);transition:all 0.3s ease}
    .nav-links.active li{opacity:1;transform:translateX(0)}
    .header-socials{border:none;margin:15px 0;gap:20px}
    .header-socials a.social-icon{font-size:1.8rem}
    .nav-links.active li:nth-child(1){transition-delay:0.1s}
    .nav-links.active li:nth-child(2){transition-delay:0.15s}
    .nav-links.active li:nth-child(3){transition-delay:0.2s}
    .nav-links.active li:nth-child(4){transition-delay:0.25s}
    .nav-links.active li:nth-child(5){transition-delay:0.3s}
    .nav-links.active li:nth-child(6){transition-delay:0.35s}
    .nav-links.active li:nth-child(7){transition-delay:0.4s}
    .nav-links.active li:nth-child(8){transition-delay:0.45s}
    .nav-links.active li:nth-child(9){transition-delay:0.5s}
    .custom-google-badge{flex-direction:column;gap:15px;text-align:center;padding:20px}
    .cgb-left{flex-direction:column;gap:10px}
    .contact-container{grid-template-columns:1fr}
}
@media(max-width:768px){
    .hero h1{font-size:2rem}
    .hero p{font-size:1rem}
    .section-header h2{font-size:1.7rem}
    .pricing-grid{gap:20px}
    .price-card.featured{transform:scale(1)}
    .price-card.featured:hover{transform:translateY(-15px)}
    .contact-form-placeholder{padding:25px 20px}
    .hero-cta-group{flex-direction:column;align-items:center}
    .hero-btn,.hero-btn-call{width:100%;max-width:300px;justify-content:center}
}
