/* Kensington English — shared chrome CSS
   Extracted from Homepage.html
   Used by all pages via base.njk layout */

  :root{
    --navy:#292662;
    --navy-ink:#1a1846;
    --navy-10:#eceaf3;
    --orange:#F04F25;
    --orange-600:#d8411a;
    --cream:#FCEFE8;
    --cream-soft:#FBF7F3;
    --paper:#ffffff;
    --line:#e6e1d9;
    --line-strong:#1a1846;
    --ink:#141329;
    --muted:#5b5870;
    --display: "Fraunces", "Times New Roman", serif;
    --sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:var(--sans);
    color:var(--ink);
    background:var(--paper);
    font-size:16px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}

  .container{
    max-width:1320px;
    margin:0 auto;
    padding:0 40px;
  }
  @media (max-width:720px){ .container{padding:0 22px} }

  /* ─────────────── ANNOUNCEMENT BAR ─────────────── */
  .announce{
    background:var(--navy);
    color:#fff;
    font-size:13px;
    letter-spacing:.01em;
  }
  .announce-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:40px;
    gap:24px;
  }
  .announce-left{
    display:flex;
    align-items:center;
    gap:10px;
    opacity:.95;
  }
  .announce-dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--orange);
    box-shadow:0 0 0 4px rgba(240,79,37,.18);
  }
  .announce-right{
    display:flex;
    gap:28px;
    align-items:center;
  }
  .announce-right a{
    display:inline-flex;align-items:center;gap:8px;
    opacity:.85;
    transition:opacity .2s;
  }
  .announce-right a:hover{opacity:1}
  .announce-right svg{width:14px;height:14px}
  .lang-switch{
    display:inline-flex;align-items:center;gap:6px;
    padding:4px 10px;
    border:1px solid rgba(255,255,255,.22);
    border-radius:999px;
    font-size:12px;
    font-weight:500;
  }
  @media (max-width:820px){
    .announce-left span:nth-child(3){display:none}
    .announce-right .hide-sm{display:none}
    .lang-flag{display:none}
  }

  /* ─────────────── HEADER / NAV ─────────────── */
  header.site{
    position:sticky;
    top:0;
    z-index:50;
    background:rgba(255,255,255,.92);
    backdrop-filter:saturate(140%) blur(10px);
    -webkit-backdrop-filter:saturate(140%) blur(10px);
    border-bottom:1px solid var(--line);
  }
  .nav-row{
    display:grid;
    grid-template-columns: 1fr auto 1fr;
    align-items:center;
    height:84px;
    gap:40px;
  }
  .brand{
    display:inline-flex;
    align-items:center;
    gap:12px;
  }
  .brand img{height:44px;width:auto}
  .brand-lock{
    display:flex;flex-direction:column;line-height:1;
  }
  .brand-lock .kw{
    font-family:var(--display);
    font-weight:600;
    font-variation-settings:"opsz" 72;
    font-size:22px;
    letter-spacing:.02em;
    color:var(--navy);
  }
  .brand-lock .en{
    font-family:var(--sans);
    font-weight:500;
    font-size:10.5px;
    letter-spacing:.42em;
    text-transform:uppercase;
    color:var(--orange);
    margin-top:5px;
  }

  nav.main{
    justify-self:center;
    display:flex;
    align-items:center;
    gap:4px;
  }
  nav.main > a, nav.main > .has-menu > button, nav.main > .has-menu > a{
    appearance:none;
    background:transparent;
    border:0;
    cursor:pointer;
    font:inherit;
    color:var(--ink);
    padding:10px 14px;
    font-size:14.5px;
    font-weight:500;
    letter-spacing:.005em;
    border-radius:8px;
    display:inline-flex;align-items:center;gap:6px;
    position:relative;
    transition:color .2s, background .2s;
  }
  nav.main > a:hover, nav.main > .has-menu > button:hover, nav.main > .has-menu > a:hover{
    color:var(--navy);
    background:var(--cream-soft);
  }
  nav.main > a.active::after{
    content:"";
    position:absolute; left:14px; right:14px; bottom:2px;
    height:2px; background:var(--orange);
    border-radius:2px;
  }
  nav.main .caret{
    width:10px;height:10px;
    transition:transform .25s;
  }
  .has-menu{position:relative}
  .has-menu[data-open="true"] .caret{transform:rotate(180deg)}
  .has-menu[data-open="true"] > button{color:var(--navy); background:var(--cream-soft)}
  .has-menu[data-open="true"] > a{color:var(--navy); background:var(--cream-soft)}

  /* Mega menu */
  .mega{
    position:absolute;
    top:calc(100% + 10px);
    left:50%;
    transform:translateX(-50%) translateY(-6px);
    width:min(860px, 86vw);
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:16px;
    box-shadow:
      0 1px 0 rgba(20,19,41,.04),
      0 24px 48px -12px rgba(20,19,41,.18),
      0 8px 16px -8px rgba(20,19,41,.08);
    padding:24px;
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease, transform .22s ease;
  }
  .has-menu[data-open="true"] .mega{
    opacity:1;pointer-events:auto;
    transform:translateX(-50%) translateY(0);
  }
  .mega-grid{
    display:grid;
    grid-template-columns: 1.15fr 1fr;
    gap:28px;
  }
  .mega-col h5{
    margin:4px 0 14px;
    font-family:var(--sans);
    font-size:11px;
    font-weight:600;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--muted);
  }
  .mega-list{display:flex;flex-direction:column;gap:2px}
  .mega-item{
    display:grid;
    grid-template-columns:36px 1fr auto;
    align-items:center;
    gap:14px;
    padding:12px 12px;
    border-radius:10px;
    transition:background .15s;
  }
  .mega-item:hover{background:var(--cream-soft)}
  .mega-icon{
    width:36px;height:36px;
    border-radius:8px;
    background:var(--cream);
    color:var(--navy);
    display:grid;place-items:center;
    font-family:var(--display);
    font-weight:600;
    font-size:15px;
  }
  .mega-item:hover .mega-icon{background:var(--navy);color:#fff}
  .mega-title{
    font-weight:600; font-size:14.5px; color:var(--ink);
    line-height:1.2;
  }
  .mega-sub{
    font-size:12.5px;color:var(--muted);margin-top:3px;
  }
  .mega-arrow{
    width:14px;height:14px;opacity:0;transition:opacity .2s, transform .2s;
    color:var(--orange);
  }
  .mega-item:hover .mega-arrow{opacity:1;transform:translateX(2px)}

  .mega-feature{
    background:var(--navy);
    color:#fff;
    border-radius:12px;
    padding:22px;
    display:flex;flex-direction:column;justify-content:space-between;
    min-height:220px;
    position:relative;
    overflow:hidden;
  }
  .mega-feature::before{
    content:""; position:absolute; inset:auto -30px -40px auto;
    width:180px;height:180px;
    background:var(--orange);
    border-radius:2px;
    transform:rotate(45deg);
    opacity:.9;
  }
  .mega-feature::after{
    content:""; position:absolute; right:18px; bottom:14px;
    width:70px;height:70px;border-radius:50%;
    background:var(--navy);
    opacity:1;
    z-index:1;
  }
  .mega-feature > *{position:relative;z-index:2}
  .mega-feature .tag{
    font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--orange); font-weight:600;
  }
  .mega-feature h4{
    font-family:var(--display);
    font-weight:400;
    font-size:24px;
    line-height:1.15;
    margin:10px 0 0;
    letter-spacing:-.01em;
  }
  .mega-feature p{
    font-size:13.5px; opacity:.8; margin:10px 0 0;
    max-width:70%;
  }
  .mega-feature a.ghost{
    display:inline-flex;align-items:center;gap:8px;
    margin-top:16px;
    font-size:13px;font-weight:600;
    color:#fff; align-self:flex-start;
    border-bottom:1px solid rgba(255,255,255,.35);
    padding-bottom:2px;
  }

  .nav-right{
    justify-self:end;
    display:flex;align-items:center;gap:12px;
  }

  .btn{
    appearance:none;border:0;cursor:pointer;font:inherit;
    display:inline-flex;align-items:center;gap:8px;
    padding:11px 18px;
    border-radius:999px;
    font-size:13.5px;font-weight:600;
    letter-spacing:.01em;
    transition:transform .15s, background .15s, box-shadow .15s, color .15s, border-color .15s;
    white-space:nowrap;
  }
  .btn svg{width:14px;height:14px}
  .btn-ghost{
    background:transparent;color:var(--ink);
    border:1px solid var(--line);
  }
  .btn-ghost:hover{border-color:var(--navy); color:var(--navy)}
  .btn-primary{
    background:var(--navy); color:#fff;
  }
  .btn-primary:hover{background:var(--navy-ink); transform:translateY(-1px)}
  .btn-orange{
    background:var(--orange); color:#fff;
  }
  .btn-orange:hover{background:var(--orange-600); transform:translateY(-1px)}
  .btn-lg{padding:15px 26px; font-size:14.5px}

  .burger{
    display:none;
    width:44px;height:44px;
    border-radius:10px;
    border:1px solid var(--line);
    background:#fff;
    align-items:center;justify-content:center;
  }
  .burger svg{width:18px;height:18px;color:var(--navy)}

  @media (max-width:1060px){
    nav.main{display:none}
    .nav-row{grid-template-columns:auto 1fr auto; gap:16px}
    nav.main, .nav-right .btn-ghost, .nav-right .btn-orange{display:none}
    .burger{display:inline-flex}
  }

  /* ─────────────── MOBILE DRAWER ─────────────── */
  .mobile-nav{
    display:none;
    flex-direction:column;
    background:#fff;
    border-top:1px solid var(--line);
    padding:16px 0 24px;
  }
  .mobile-nav.open{display:flex}
  .mobile-nav a{
    padding:13px 22px;
    font-size:15px;
    font-weight:500;
    color:var(--ink);
    border-bottom:1px solid var(--line);
  }
  .mobile-nav a:last-child{border-bottom:none}
  .mobile-nav a:hover{background:var(--cream-soft)}
  .mobile-nav a.active{color:var(--navy);font-weight:600}
  .mobile-nav .mobile-cta{
    margin:16px 22px 0;
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .mobile-nav .mobile-cta a{
    padding:12px 20px;
    border-radius:10px;
    text-align:center;
    font-weight:600;
    border:none;
  }

/* Skip-to-content link */
  .ke-skip{position:absolute;top:-40px;left:0;background:#292662;color:#fff;padding:8px 16px;z-index:10000;text-decoration:none;border-radius:0 0 8px 0;font-weight:600;font-size:14px}
  .ke-skip:focus{top:0;outline:2px solid #F04F25;outline-offset:2px}
