:root { --ink:#1e2d44; --ink-soft:#5b6b80; --brand:#00d6d7; --brand-deep:#0f8f93; --bg:#f8fbfc; --shadow-soft:0 12px 32px rgba(30,45,68,.08); --max:960px; }
    * { box-sizing:border-box; }
    body { margin:0; font-family:"Source Sans 3",sans-serif; color:var(--ink); background:linear-gradient(180deg,#fff 0%,var(--bg) 100%); }
    a { color:inherit; text-decoration:none; }
    img { display:block; max-width:100%; }
    .container { width:min(calc(100% - 32px), var(--max)); margin:0 auto; }
    .site-header { padding:18px 0 0; }
    .header-bar { display:flex; align-items:center; justify-content:space-between; gap:20px; padding:14px 20px; background:rgba(255,255,255,.96); border:1px solid rgba(30,45,68,.08); border-radius:16px; box-shadow:var(--shadow-soft); }
    .brand { font-family:"Montserrat",sans-serif; font-size:1.5rem; font-weight:700; color:var(--ink); }
    .brand span { color:var(--brand); }
    .nav { display:flex; gap:26px; color:var(--ink-soft); font-size:.95rem; font-weight:700; }
    .nav a.active, .nav a:hover { color:var(--ink); }
    .article-hero { padding:64px 0 28px; }
    .eyebrow { color:var(--brand-deep); font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
    h1,h2 { margin:0; font-family:"Montserrat",sans-serif; letter-spacing:-.03em; color:var(--ink); }
    h1 { margin-top:14px; font-size:clamp(2.2rem,5vw,3.7rem); line-height:1.05; }
    h2 { margin-top:34px; font-size:1.55rem; }
    .meta { margin-top:14px; color:var(--ink-soft); font-weight:700; }
    .hero-image { margin-top:28px; border-radius:22px; overflow:hidden; box-shadow:var(--shadow-soft); }
    .hero-image img { width:100%; height:420px; object-fit:cover; }
    .article-body { padding: 12px 0 86px; }
    .article-body p, .article-body li { color:var(--ink-soft); line-height:1.8; font-size:1.04rem; }
    .article-body ul { padding-left:20px; }
    .back-link { display:inline-flex; margin-top:18px; color:var(--brand-deep); font-weight:700; }
    @media (max-width:720px) { .header-bar { flex-wrap:wrap; justify-content:center; } .nav { width:100%; justify-content:center; flex-wrap:wrap; } .hero-image img { height:260px; } }
  
    /* HOME SHARED CHROME START */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 50;
      padding: 18px 0 0;
    }

    .header-bar {
      width: min(calc(100% - 32px), var(--max));
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      padding: 14px 20px;
      border: 1px solid rgba(30, 45, 68, 0.08);
      background: rgba(255, 255, 255, 0.96);
      border-radius: 16px;
      box-shadow: var(--shadow-soft);
    }

    .brand {
      display: flex;
      align-items: center;
      min-width: 0;
    }

    .brand-logo {
      font-family: "Montserrat", sans-serif;
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1;
      display: flex;
      align-items: center;
      flex: 0 0 auto;
    }

    .brand-logo .charter-text {
      color: var(--ink);
    }

    .brand-logo .mybus-text {
      color: var(--brand);
      margin-left: 0.3em;
    }

    .nav {
      display: flex;
      align-items: center;
      gap: 32px;
      color: var(--ink-soft);
      font-size: 0.95rem;
    }

    .nav a {
      white-space: nowrap;
      font-weight: 700;
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .header-actions .button,
    .header-actions button.button {
      padding: 12px 14px;
      font-family: "Source Sans 3", sans-serif;
      font-size: 0.88rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      white-space: nowrap;
    }

    .call-pill {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 12px 16px;
      border-radius: 10px;
      background: rgba(0, 214, 215, 0.1);
      color: var(--ink);
      font-size: 0.88rem;
      font-weight: 700;
      white-space: nowrap;
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 15px 22px;
      border-radius: 10px;
      border: 1px solid transparent;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      font-size: 0.88rem;
      transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .button:hover {
      transform: translateY(-2px);
      box-shadow: 0 18px 28px rgba(30, 45, 68, 0.12);
    }

    .button-primary {
      background: var(--brand);
      color: var(--ink);
      border-color: rgba(0, 214, 215, 0.25);
    }

    .footer {
      border-top: 1px solid rgba(30, 45, 68, 0.08);
      background: #ffffff;
    }

    .footer-content {
      display: grid;
      grid-template-columns: 1.5fr repeat(4, minmax(0, 1fr));
      gap: 28px;
      padding: 42px 0 24px;
    }

    .footer-section {
      min-width: 0;
    }

    .footer-heading {
      margin: 0 0 14px;
      font-family: "Montserrat", sans-serif;
      font-size: 1rem;
      color: var(--ink);
    }

    .footer-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 10px;
    }

    .footer-list a,
    .footer-bar,
    .footer-section p {
      color: var(--ink-soft);
      font-size: 0.92rem;
    }

    .footer-bar {
      display: flex;
      justify-content: space-between;
      gap: 16px;
      padding: 18px 0 28px;
      border-top: 1px solid rgba(30, 45, 68, 0.08);
    }

    .footer-links {
      display: flex;
      flex-wrap: wrap;
      gap: 18px;
    }

    @media (max-width: 1080px) {
      .footer-content {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 720px) {
      .header-bar {
        padding: 12px 14px;
        flex-wrap: wrap;
        justify-content: center;
      }

      .nav {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
      }

      .header-actions {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
      }

      .footer-content {
        grid-template-columns: 1fr;
      }

      .footer-bar {
        flex-direction: column;
        align-items: flex-start;
      }
    }
        .quote-modal[hidden] {
      display: none;
    }

    .quote-modal {
      position: fixed;
      inset: 0;
      z-index: 120;
      display: grid;
      place-items: center;
      padding: 20px;
    }

    .quote-modal__backdrop {
      position: absolute;
      inset: 0;
      background: rgba(16, 26, 38, 0.58);
      backdrop-filter: blur(8px);
    }

    .quote-modal__panel {
      position: relative;
      width: min(100%, 420px);
      max-height: calc(100vh - 40px);
      background:
        radial-gradient(circle at top right, rgba(0, 214, 215, 0.12), transparent 34%),
        linear-gradient(180deg, #ffffff 0%, #f3f9fb 100%);
      color: var(--ink);
      border: 1px solid rgba(30, 45, 68, 0.1);
      border-radius: 24px;
      box-shadow: 0 28px 70px rgba(30, 45, 68, 0.18);
      padding: 24px 20px 20px;
      overflow-y: auto;
    }

    .quote-modal__panel--hero {
      width: min(100%, 460px);
      max-height: none;
      padding: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
      overflow: visible;
    }

    .quote-modal__panel--hero .hero-quote-card {
      margin: 0;
      padding: clamp(16px, 4vw, 24px);
      max-height: calc(100vh - 40px);
      overflow-y: auto;
    }

    .quote-modal__panel--hero .quote-modal__close {
      z-index: 2;
    }

    .quote-modal__close {
      position: absolute;
      top: 16px;
      right: 16px;
      width: 38px;
      height: 38px;
      border: 1px solid rgba(30, 45, 68, 0.1);
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.8);
      color: transparent;
      font-size: 0;
      line-height: 1;
      cursor: pointer;
      transition: transform 180ms ease, background 180ms ease, border-color 180ms ease;
    }

    .quote-modal__close::before {
      content: "\00d7";
      color: var(--ink-soft);
      font-size: 1.3rem;
      line-height: 1;
    }

    .quote-modal__close:hover {
      transform: translateY(-1px);
      background: #ffffff;
      border-color: rgba(0, 214, 215, 0.24);
    }

    .quote-modal__close:hover::before {
      color: var(--ink);
    }

    .quote-modal__eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 10px;
      padding: 6px 10px;
      border-radius: 999px;
      background: rgba(0, 214, 215, 0.12);
      color: var(--brand-deep);
      font-size: 0.7rem;
      font-weight: 800;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .quote-modal__eyebrow::before {
      content: "";
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--brand);
    }

    .quote-modal__title {
      margin-bottom: 8px;
      color: var(--ink);
      font-size: 1.35rem;
      line-height: 1.15;
    }

    .quote-modal__intro {
      margin: 0 0 16px;
      color: var(--ink-soft);
      font-size: 0.88rem;
      line-height: 1.55;
    }

    .quote-toggle-group {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 16px;
    }

    .quote-toggle {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 14px;
      border: 1px solid rgba(30, 45, 68, 0.12);
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.88);
      color: var(--ink);
      font: inherit;
      font-size: 0.76rem;
      font-weight: 700;
      cursor: pointer;
      transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
    }

    .quote-toggle:hover {
      transform: translateY(-1px);
      border-color: rgba(0, 214, 215, 0.3);
      box-shadow: 0 10px 24px rgba(30, 45, 68, 0.08);
    }

    .quote-toggle.is-active {
      background: var(--brand);
      border-color: rgba(0, 214, 215, 0.28);
      color: var(--ink);
      box-shadow: 0 14px 28px rgba(0, 214, 215, 0.18);
    }

    .quote-form {
      display: grid;
      gap: 12px;
    }

    .quote-row {
      display: flex;
      gap: 12px;
    }

    .quote-field {
      width: 100%;
      min-height: 48px;
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(30, 45, 68, 0.12);
      background: rgba(255, 255, 255, 0.94);
      color: var(--ink);
      font: inherit;
      font-size: 0.82rem;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
      transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
    }

    .quote-field::placeholder {
      color: #74859a;
    }

    .quote-field:focus {
      outline: none;
      border-color: rgba(0, 214, 215, 0.45);
      box-shadow: 0 0 0 4px rgba(0, 214, 215, 0.14);
      background: #ffffff;
    }

    .quote-stop-wrap {
      padding: 2px 0 0;
    }

    .quote-meta {
      margin-top: 2px;
      color: #6c7d92;
      font-size: 0.72rem;
      line-height: 1.5;
    }

    .quote-submit {
      width: 100%;
      margin-top: 6px;
      min-height: 50px;
      padding: 12px 16px;
      border: 0;
      border-radius: 14px;
      background: linear-gradient(135deg, var(--brand) 0%, #42e7e7 100%);
      color: var(--ink);
      font: inherit;
      font-size: 0.82rem;
      font-weight: 800;
      cursor: pointer;
      box-shadow: 0 18px 30px rgba(0, 214, 215, 0.22);
      transition: transform 180ms ease, box-shadow 180ms ease;
    }

    .quote-submit:hover {
      transform: translateY(-1px);
      box-shadow: 0 22px 34px rgba(0, 214, 215, 0.26);
    }

    .quote-hidden {
      display: none;
    }

    body.modal-open {
      overflow: hidden;
    }

    .hero-quote-card {
      padding: 24px;
      border-radius: 24px;
      background: rgba(255, 255, 255, 0.96);
      color: var(--ink);
      box-shadow: 0 24px 54px rgba(11, 22, 35, 0.18);
      border: 1px solid rgba(255, 255, 255, 0.18);
      backdrop-filter: blur(10px);
    }

    .hero-quote-card .quote-modal__eyebrow {
      margin-bottom: 12px;
    }

    .hero-quote-card .quote-modal__title {
      margin-bottom: 10px;
    }

    .hero-quote-card .quote-modal__intro {
      margin-bottom: 18px;
    }

    .hero-quote-card .quote-form {
      gap: 12px;
    }

    .hero-quote-card .quote-meta {
      margin-top: 4px;
    }
    /* HOME SHARED CHROME END */
