/* ── myCPC Sprint 2–6 Shared Improvement Layer ──
   Loaded alongside the base CSS on all improved pages.
   All rules are additive — nothing breaks existing booking logic. */

/* Mobile nav */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;color:var(--ink);flex-shrink:0}
.nav-toggle span{display:block;width:22px;height:2px;background:currentColor;margin:4px 0;transition:.2s ease}
.nav-open .nav-toggle span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-open .nav-toggle span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-open .nav-toggle span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Standard section spacing */
.sec{padding:32px 0}
.sec.banded{background:linear-gradient(180deg,#f1f6ff,#f8fbff);border-block:1px solid var(--line)}

/* Shared page hero */
.page-hero{padding:32px 0 0}
.page-hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:stretch}
.page-hero__text{padding:34px 36px;background:linear-gradient(160deg,#fff 60%,#f4f8ff 100%);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:center}
.page-hero__text .eyebrow{margin-bottom:14px}
.page-hero__text h1{margin-bottom:12px;font-size:clamp(2.2rem,4vw,3.4rem)}
.page-hero__text .lead{margin-bottom:20px;font-size:1.06rem;max-width:56ch}
.page-hero__panel{padding:24px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:12px}
.page-hero__panel h3{margin:0 0 4px}

/* Dark CTA band */
.cta-dark{background:linear-gradient(135deg,#0e2860,#112f72);border-radius:var(--radius);padding:34px 36px;display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center}
.cta-dark .eyebrow{color:rgba(255,255,255,.7)}
.cta-dark h2{color:#fff;margin-bottom:8px}
.cta-dark p{color:rgba(255,255,255,.8);margin:0;max-width:56ch}
.btn-white{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-weight:900;border:none;background:#fff;color:var(--blue-deep);box-shadow:0 10px 24px rgba(0,0,0,.18);transition:.2s;cursor:pointer}
.btn-white:hover{transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-weight:900;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.3);transition:.2s;cursor:pointer}
.btn-ghost:hover{background:rgba(255,255,255,.22)}

/* Checklist */
.check-list{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:9px}
.check-list li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem;color:var(--muted);line-height:1.5}
.check-list li::before{content:"✓";color:var(--green);font-weight:900;flex-shrink:0;margin-top:1px}

/* Process timeline */
.process-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.process-timeline::before{content:"";position:absolute;top:28px;left:calc(16.6% + 14px);right:calc(16.6% + 14px);height:2px;background:var(--line);z-index:0}
.process-step-v2{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 16px;position:relative;z-index:1}
.process-step-v2__num{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.2rem;color:var(--blue);background:#fff;border:2px solid var(--blue);margin-bottom:16px;box-shadow:var(--shadow-soft);flex-shrink:0}
.process-step-v2 h3{font-size:1.05rem;margin:0 0 8px}
.process-step-v2 p{font-size:.9rem;color:var(--muted);margin:0}

/* Sector tile grid */
.sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.sector-tile{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px 16px;text-align:center;box-shadow:var(--shadow-soft)}
.sector-tile__icon{font-size:1.6rem;margin-bottom:10px;display:block}
.sector-tile strong{display:block;font-size:.92rem;color:var(--ink);margin-bottom:4px}
.sector-tile span{font-size:.82rem;color:var(--muted)}

/* Enquiry form card */
.enquiry-card{background:linear-gradient(160deg,#fff 60%,#f4f8ff 100%);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.enquiry-card h2{margin-bottom:8px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.form-field{display:grid;gap:7px}
.form-field label{font-weight:800;font-size:.88rem;color:var(--ink)}
.form-field input,.form-field select,.form-field textarea{padding:13px 16px;border:1px solid var(--line);border-radius:16px;background:#fff;color:var(--ink);width:100%;font:inherit}
.form-field textarea{min-height:100px;resize:vertical}
.form-field--full{grid-column:1/-1}
.form-badge-row{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}
.form-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:var(--surface-alt);border:1px solid var(--line);font-size:.8rem;font-weight:800;color:var(--blue-deep)}

/* Decision pathway */
.decision-path{display:grid;gap:0}
.decision-step{display:grid;grid-template-columns:56px 1fr;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.decision-step:last-child{border-bottom:none;padding-bottom:0}
.decision-step:first-child{padding-top:0}
.decision-step__num{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;flex-shrink:0}
.decision-step__num--check{background:#eaf6ee;color:var(--green)}
.decision-step__num--route{background:#eef3ff;color:var(--blue)}
.decision-step__num--book{background:var(--blue);color:#fff}
.decision-step__body h3{margin:0 0 6px;font-size:1.05rem}
.decision-step__body p{margin:0;color:var(--muted);font-size:.92rem}
.decision-step__body .button{margin-top:12px}

/* Article cards (news index) */
.news-hero-card{background:linear-gradient(160deg,#0e2860,#112f72);border-radius:var(--radius);padding:32px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;margin-bottom:24px}
.news-hero-card__label{font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.6);margin-bottom:10px}
.news-hero-card__title{font-size:clamp(1.4rem,2.5vw,2rem);font-weight:900;color:#fff;line-height:1.15;margin:0 0 10px;max-width:36ch}
.news-hero-card__excerpt{color:rgba(255,255,255,.8);margin:0 0 18px;max-width:52ch;font-size:.95rem}
.news-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.news-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.news-card__thumb{background:linear-gradient(135deg,var(--surface-alt),#e0eaff);height:150px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line);position:relative}
.news-card__thumb-text{font-size:.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--blue-deep);opacity:.45}
.news-card__body{padding:18px;flex:1;display:flex;flex-direction:column;gap:8px}
.news-card__body h3{margin:0;font-size:1.05rem;line-height:1.3}
.news-card__body h3 a{color:var(--ink)}
.news-card__body h3 a:hover{color:var(--blue)}
.news-card__body p{margin:0;font-size:.88rem;color:var(--muted);flex:1}
.news-card__footer{padding:12px 18px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.read-more{font-size:.85rem;font-weight:900;color:var(--blue)}

/* Online Driver CPC trust section - compact single instance */
.trust-row-compact{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
.trust-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);font-size:.82rem;font-weight:800;color:var(--ink)}
.trust-chip img{width:24px;height:20px;object-fit:contain}

/* Booking page improvements */
.booking-tip{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:800;color:var(--muted);cursor:help;position:relative}
.booking-tip__icon{width:16px;height:16px;border-radius:50%;background:var(--surface-alt);border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--muted)}
.booking-tip__bubble{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--ink);color:#fff;font-size:.8rem;font-weight:700;padding:10px 14px;border-radius:14px;width:260px;line-height:1.5;z-index:10;pointer-events:none;opacity:0;transition:opacity .15s}
.booking-tip:hover .booking-tip__bubble{opacity:1}

/* Shared responsive */
@media(max-width:1080px){
  .page-hero__grid,.cta-dark{grid-template-columns:1fr}
  .process-timeline,.sector-grid{grid-template-columns:repeat(2,1fr)}
  .process-timeline::before{display:none}
  .news-card-grid{grid-template-columns:1fr 1fr}
  .news-hero-card{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
}
@media(max-width:760px){
  .headerbar__inner{min-height:68px!important;grid-template-columns:1fr auto auto!important}
  .nav-toggle{display:block}
  .mainnav{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:#fff;z-index:50;padding:20px;flex-direction:column;gap:4px;border-top:1px solid var(--line);overflow-y:auto}
  .mainnav.open{display:flex}
  .mainnav a{padding:14px 18px;border-radius:14px;font-size:1rem}
  .page-hero__grid{grid-template-columns:1fr}
  .process-timeline,.sector-grid,.news-card-grid{grid-template-columns:1fr}
  .cta-dark{padding:24px}
  .decision-step{grid-template-columns:40px 1fr}
}
