/* International Driving School — modernized, brand-palette preserved */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  /* brand palette (preserved) */
  --navy:#1e3a7b;
  --navy-deep:#0f1f4f;
  --navy-ink:#0a1633;
  --olive:#7a6c1f;
  --olive-2:#665913;
  --gold:#c9a500;
  --gold-h:#b59100;
  --gold-soft:#f4e9b4;
  --cream:#faf6e8;
  --periwinkle:#dae3f2;     /* toned down — used as accent only */
  --periwinkle-2:#eef2fa;
  --red:#b3201b;
  /* neutrals */
  --bg:#ffffff;
  --bg-alt:#f8f9fb;
  --bg-card:#ffffff;
  --text:#1a1f36;
  --text-2:#4a536b;
  --text-3:#8a93a8;
  --border:#e6e9f0;
  --border-strong:#d4dae5;
  /* design tokens */
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:24px;
  --shadow-sm:0 1px 3px rgba(10,22,51,.06),0 1px 2px rgba(10,22,51,.04);
  --shadow:0 4px 12px rgba(10,22,51,.06),0 2px 4px rgba(10,22,51,.04);
  --shadow-lg:0 20px 40px -12px rgba(10,22,51,.15),0 8px 16px -8px rgba(10,22,51,.1);
  --shadow-xl:0 40px 80px -20px rgba(10,22,51,.2),0 20px 40px -20px rgba(10,22,51,.12);
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-display:'Playfair Display',Georgia,serif;
  --max:1200px;
  --nav-h:74px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.005em}
a{color:var(--navy);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold)}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
::selection{background:var(--gold-soft);color:var(--navy-ink)}

/* ── HEADER ── */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.header-top{max-width:var(--max);margin:0 auto;padding:1.1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:.9rem;text-decoration:none}
.brand:hover{color:inherit}
.brand-name{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--navy);letter-spacing:-.5px;line-height:1.1}
.brand-sub{font-family:var(--font-body);font-size:.72rem;color:var(--text-2);font-weight:500;letter-spacing:.8px;text-transform:uppercase;margin-top:.2rem}
.header-phone{display:flex;align-items:center;gap:.7rem;text-align:right;font-size:.82rem;color:var(--text-2)}
.header-phone-icon{width:36px;height:36px;border-radius:50%;background:var(--gold-soft);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.header-phone a{color:var(--navy);font-weight:700;font-size:.96rem;letter-spacing:-.3px}
.header-phone small{display:block;font-size:.72rem;font-weight:500;color:var(--text-3);letter-spacing:.4px;text-transform:uppercase}
@media(max-width:900px){
  .header-phone{display:none}
}

/* ── NAV ── */
.nav{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 1.5rem;display:flex;gap:.3rem;overflow-x:auto;scrollbar-width:none}
.nav-inner::-webkit-scrollbar{display:none}
.nav-inner a{position:relative;padding:1.1rem 1.3rem;color:var(--text-2);font-weight:600;font-size:.88rem;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;transition:color .2s}
.nav-inner a::after{content:"";position:absolute;left:1.3rem;right:1.3rem;bottom:-1px;height:3px;background:var(--gold);border-radius:3px 3px 0 0;transform:scaleX(0);transform-origin:center;transition:transform .25s ease}
.nav-inner a:hover{color:var(--navy)}
.nav-inner a:hover::after{transform:scaleX(.5)}
.nav-inner a.active{color:var(--navy)}
.nav-inner a.active::after{transform:scaleX(1)}
@media(max-width:720px){
  .nav-inner{padding:0 1rem}
  .nav-inner a{padding:1rem .9rem;font-size:.78rem}
}

/* ── IDS BADGE LOGO ── */
.ids-badge{width:60px;height:60px;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(10,22,51,0.1))}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.55rem;background:var(--navy);color:#fff;padding:.95rem 1.9rem;border-radius:999px;font-weight:600;font-size:.95rem;text-decoration:none;transition:all .2s;border:1px solid var(--navy);cursor:pointer;letter-spacing:-.1px;font-family:var(--font-body);box-shadow:var(--shadow-sm)}
.btn:hover{background:var(--navy-deep);border-color:var(--navy-deep);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow);text-decoration:none}
.btn-gold{background:var(--gold);color:var(--navy-ink);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-h);border-color:var(--gold-h);color:var(--navy-ink)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(10px)}
.btn-outline:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.7);color:#fff}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--border-strong)}
.btn-ghost:hover{background:var(--bg-alt);color:var(--navy)}
.btn-arrow::after{content:"→";transition:transform .2s}
.btn-arrow:hover::after{transform:translateX(3px)}

/* ── HERO ── */
.hero{position:relative;background:linear-gradient(135deg,var(--olive-2) 0%,var(--olive) 50%,var(--navy-deep) 120%);color:var(--cream);padding:7rem 1.5rem 8rem;overflow:hidden;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(201,165,0,.18),transparent 50%),radial-gradient(circle at 80% 80%,rgba(30,58,123,.35),transparent 50%);pointer-events:none;z-index:-1}
.hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,0) 95%,rgba(250,246,232,.03) 95%),linear-gradient(90deg,rgba(0,0,0,0) 95%,rgba(250,246,232,.03) 95%);background-size:40px 40px;pointer-events:none;z-index:-1;opacity:.5}
.hero-inner{max-width:var(--max);margin:0 auto;position:relative}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(250,246,232,.1);color:var(--gold-soft);padding:.5rem 1rem;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;border:1px solid rgba(250,246,232,.2);backdrop-filter:blur(10px);margin-bottom:2rem}
.hero-badge-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-tagline{font-family:var(--font-display);font-weight:400;line-height:1.1;letter-spacing:-1.5px;max-width:900px}
.hero-line{display:block;margin:.3rem 0}
.hero-line.first{font-size:clamp(1.8rem,4.5vw,3.4rem);font-style:italic;color:#fff;opacity:.95;font-weight:400}
.hero-line.mid{font-size:clamp(2.4rem,6vw,4.8rem);font-weight:600;color:#fff;margin-left:clamp(0px,4vw,3rem);letter-spacing:-2px}
.hero-line.last{font-size:clamp(1.8rem,4.5vw,3.4rem);font-style:italic;color:var(--cream);opacity:.85;margin-left:clamp(0px,8vw,6rem);font-weight:400}
.hero-cta-row{margin-top:3rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-left:clamp(0px,8vw,6rem)}
.hero-meta{margin-top:3.5rem;display:flex;gap:3rem;flex-wrap:wrap;border-top:1px solid rgba(250,246,232,.15);padding-top:2rem;margin-left:clamp(0px,8vw,6rem);max-width:720px}
.hero-meta-item strong{display:block;font-family:var(--font-display);font-size:2rem;color:var(--gold);font-weight:600;letter-spacing:-.5px;line-height:1}
.hero-meta-item span{display:block;font-size:.85rem;color:rgba(250,246,232,.7);margin-top:.3rem;letter-spacing:.3px}
@media(max-width:720px){
  .hero{padding:4rem 1.5rem 5rem}
  .hero-line.mid,.hero-line.last{margin-left:0}
  .hero-cta-row,.hero-meta{margin-left:0}
  .hero-meta{gap:1.5rem}
}

/* ── SECTION BASICS ── */
section{padding:6rem 1.5rem}
.section-inner{max-width:var(--max);margin:0 auto}
.section-head{text-align:center;max-width:680px;margin:0 auto 3.5rem}
.section-head.left{text-align:left;margin-left:0}
.eyebrow{display:inline-block;color:var(--olive);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem;position:relative;padding-left:2.5rem}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2rem;height:2px;background:var(--gold)}
.section-head h2{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:600;line-height:1.1;letter-spacing:-1.2px;margin-bottom:1rem;color:var(--navy-ink)}
.section-head h2 em{font-style:italic;color:var(--olive);font-weight:400}
.section-head p{color:var(--text-2);font-size:1.1rem;line-height:1.7;max-width:580px;margin:0 auto}

main{max-width:var(--max);margin:0 auto;padding:5rem 1.5rem}
h1{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:600;letter-spacing:-1.5px;line-height:1.1;margin-bottom:1.5rem;color:var(--navy-ink)}
h1+.intro{margin-top:2rem}
h2{font-family:var(--font-display);font-size:clamp(1.7rem,3.5vw,2.3rem);font-weight:600;margin:3.5rem 0 1.2rem;color:var(--navy-ink);letter-spacing:-.8px;line-height:1.15}
h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin:1.8rem 0 .6rem;color:var(--navy);letter-spacing:-.3px}
p{margin-bottom:1.1rem;color:var(--text);line-height:1.75;font-size:1.02rem}
.intro p{font-size:1.15rem;color:var(--text-2);line-height:1.7;max-width:70ch}
.intro strong{color:var(--navy-ink);font-weight:600}
ul,ol{margin:1.2rem 0 1.4rem 1.4rem}
ul li,ol li{margin-bottom:.6rem;line-height:1.7;color:var(--text)}
ul li strong{color:var(--navy-ink);font-weight:600}

/* ── WELCOME STRIP (refined) ── */
.welcome-strip{background:var(--navy-ink);color:var(--gold-soft);text-align:center;padding:1.1rem 1.5rem;font-family:var(--font-display);font-style:italic;font-size:1.1rem;font-weight:400;letter-spacing:.3px;position:relative}
.welcome-strip::before,.welcome-strip::after{content:"◆";color:var(--gold);margin:0 1rem;font-size:.7rem;vertical-align:middle}

/* ── COURSE CARDS (modernized) ── */
.courses{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin:3rem auto;max-width:var(--max)}
.course-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2.2rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}
.course-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold),var(--olive));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.course-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.course-card:hover::before{transform:scaleX(1)}
.course-card.featured{border-color:var(--gold);background:linear-gradient(135deg,var(--cream) 0%,#fff 50%)}
.course-card.featured::before{transform:scaleX(1)}
.course-tag{position:absolute;top:1.2rem;right:1.2rem;background:var(--gold);color:var(--navy-ink);padding:.25rem .7rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.course-icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--navy-deep));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}
.course-card h3{margin:0 0 .7rem;font-size:1.4rem}
.course-card p{color:var(--text-2);font-size:.98rem;margin-bottom:1.3rem;line-height:1.6}
.course-list{list-style:none !important;margin:0 0 1.8rem !important;padding:0}
.course-list li{padding:.5rem 0;padding-left:1.8rem;position:relative;font-size:.92rem;color:var(--text);margin-bottom:0}
.course-list li::before{content:"";position:absolute;left:0;top:.85rem;width:14px;height:14px;border-radius:50%;background:var(--gold-soft);border:2px solid var(--gold)}
.course-list li::after{content:"";position:absolute;left:4px;top:1rem;width:6px;height:3px;border-left:2px solid var(--navy);border-bottom:2px solid var(--navy);transform:rotate(-45deg)}
.course-card .btn{margin-top:auto;align-self:flex-start}
@media(max-width:820px){.courses{grid-template-columns:1fr}}

/* ── ESTABLISHED CALLOUT (modern) ── */
.established{position:relative;margin:5rem auto;padding:4.5rem 2rem;background:linear-gradient(135deg,var(--navy-ink) 0%,var(--navy) 100%);color:#fff;border-radius:var(--radius-lg);text-align:center;overflow:hidden;max-width:var(--max);box-shadow:var(--shadow-xl)}
.established::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(201,165,0,.25),transparent 60%),radial-gradient(circle at 80% 50%,rgba(201,165,0,.12),transparent 60%);pointer-events:none}
.established::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;background:radial-gradient(circle,transparent 40%,rgba(201,165,0,.05) 41%,rgba(201,165,0,.05) 42%,transparent 43%);pointer-events:none}
.established-inner{position:relative;z-index:1}
.established .year{font-family:var(--font-display);font-size:clamp(4.5rem,10vw,7rem);font-weight:600;color:var(--gold);line-height:1;letter-spacing:-4px;font-style:italic}
.established .label{text-transform:uppercase;letter-spacing:5px;font-size:.8rem;margin-top:.8rem;color:var(--gold-soft);font-weight:600}
.established p{color:rgba(255,255,255,.82);margin:1.5rem auto 0;max-width:540px;font-size:1.05rem;line-height:1.7}

/* ── CREDENTIALS (modern list) ── */
.creds{list-style:none !important;margin:2rem 0 !important;padding:0;display:grid;grid-template-columns:1fr;gap:1rem}
.creds li{display:block;padding:1.6rem 1.8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.98rem;color:var(--text-2);line-height:1.65;transition:all .2s;position:relative;overflow:hidden}
.creds li::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--gold),var(--olive));transform:scaleY(0);transform-origin:top;transition:transform .3s}
.creds li:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateX(3px)}
.creds li:hover::before{transform:scaleY(1)}
.creds li strong{color:var(--navy-ink);display:block;margin-bottom:.35rem;font-size:1.05rem;font-family:var(--font-display);font-weight:600;letter-spacing:-.2px}

/* ── NOTICE ── */
.notice{display:flex;gap:1rem;align-items:flex-start;background:linear-gradient(135deg,var(--gold-soft),var(--cream));border:1px solid var(--gold);border-radius:var(--radius);padding:1.4rem 1.8rem;margin:2.5rem 0;color:var(--navy-ink);line-height:1.65}
.notice::before{content:"★";color:var(--gold);font-size:1.5rem;flex-shrink:0;line-height:1}
.notice strong{color:var(--navy-ink);font-weight:700}
.notice a{color:var(--navy);font-weight:600;text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}

/* ── CONTACT GRID ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:2rem;margin:2.5rem 0}
.contact-info{background:var(--bg-card);padding:2.2rem;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.contact-info h3{margin-top:0;margin-bottom:1.4rem;font-size:1.4rem}
.contact-info dl{margin:0}
.contact-info dt{font-weight:600;color:var(--text-3);margin-top:1.2rem;font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px}
.contact-info dt:first-child{margin-top:0}
.contact-info dd{color:var(--text);margin:.3rem 0 0;font-size:1rem;line-height:1.6}
.contact-info dd a{font-weight:600;color:var(--navy)}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text-2);margin-bottom:.45rem;text-transform:uppercase;letter-spacing:.8px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.9rem 1.1rem;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-family:inherit;font-size:.97rem;background:#fff;color:var(--text);transition:all .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 4px rgba(30,58,123,.1)}
.form-group select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%231e3a7b'%3E%3Cpath d='M8 12L2 6h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:3rem}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ── LINKS PAGE ── */
.link-list{list-style:none !important;margin:1.8rem 0 !important;padding:0}
.link-list li{border:1px solid var(--border);border-radius:var(--radius);padding:1.3rem 1.6rem;margin-bottom:.8rem;transition:all .2s;background:var(--bg-card)}
.link-list li:hover{border-color:var(--gold);transform:translateX(4px);box-shadow:var(--shadow)}
.link-list a{display:flex;flex-direction:column;color:var(--navy-ink);font-weight:600;font-size:1.05rem;text-decoration:none;font-family:var(--font-display);letter-spacing:-.2px}
.link-list a::after{content:"↗";font-family:var(--font-body);margin-left:.5rem;color:var(--gold);font-weight:700;align-self:flex-start;position:absolute;right:1.6rem;top:1.3rem;font-size:1.1rem;transition:transform .2s}
.link-list li{position:relative;padding-right:3rem}
.link-list li:hover a::after{transform:translate(3px,-3px)}
.link-list a small{display:block;color:var(--text-2);font-weight:400;font-size:.9rem;margin-top:.4rem;font-family:var(--font-body);line-height:1.55}

/* ── FOOTER ── */
footer{background:var(--navy-ink);color:rgba(255,255,255,.7);padding:4rem 1.5rem 2rem;margin-top:5rem;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--olive),var(--gold),var(--olive))}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand .brand-name{color:#fff;margin-bottom:.3rem;font-size:1.2rem}
.footer-brand .brand-sub{color:var(--gold);margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.6);max-width:420px;font-size:.95rem;line-height:1.7}
footer h5{color:#fff;font-weight:700;margin-bottom:1.2rem;font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;font-family:var(--font-body)}
footer ul{list-style:none;margin:0;padding:0}
footer li{padding:.35rem 0;margin:0}
footer a{color:rgba(255,255,255,.7);font-size:.95rem;transition:color .2s}
footer a:hover{color:var(--gold)}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:rgba(255,255,255,.5)}
.social{display:flex;gap:.6rem}
.social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--gold);border-radius:10px;font-weight:700;font-size:.95rem;text-decoration:none;transition:all .2s}
.social a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy-ink);transform:translateY(-2px)}
.zabley-watermark{text-align:center;padding:1rem;background:#050b1f;color:#5a6580;font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase}
.zabley-watermark strong{color:#8899bb;font-weight:700}
@media(max-width:720px){.footer-inner{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;text-align:center}}

/* ── RESPONSIVE MAIN PADDING ── */
@media(max-width:720px){
  main{padding:3rem 1.5rem}
  section{padding:4rem 1.5rem}
  .established{padding:3rem 1.5rem;margin:3rem 1rem}
}
