/* ============================================================
   London International — ACCA Dubai · v3 "Aurum"
   Palette + type sampled from cloud.lisrc.co.uk
   Deep navy #002248 · rich gold #E0AA4B · warm cream
   Inter (sans) + Instrument Serif (italic gold accent)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Instrument+Serif:ital@0;1&display=swap');

:root {
  /* navy */
  --navy: #002248; --navy-deep: #001328; --navy-mid: #062a5a; --navy-light: #033064; --cobalt: #1e3a8a;
  /* gold */
  --gold: #e0aa4b; --gold-deep: #c8943a; --gold-soft: #f4dca6; --gold-glow: rgba(224,170,75,.22);
  /* warm surfaces */
  --cream: #fffef9; --cream-2: #f8f6f0; --cream-3: #fff8e8; --paper: #f8fafc;
  /* ink */
  --ink: #0a1628; --ink-2: #334155; --ink-3: #475569; --ink-4: #64748b; --ink-5: #94a3b8;
  --border: #e8ecf2; --border-2: #dde3ee; --lav: #eef1fb;
  --emerald: #16a34a;
  /* geometry + motion */
  --maxw: 1200px; --r: 18px; --r-sm: 12px; --r-lg: 24px;
  --ease: cubic-bezier(.16,1,.3,1);
  --sh-sm: 0 1px 2px rgba(0,34,72,.05), 0 4px 12px -4px rgba(0,34,72,.08);
  --sh: 0 8px 24px -10px rgba(0,34,72,.14), 0 18px 50px -24px rgba(0,34,72,.18);
  --sh-lg: 0 24px 60px -22px rgba(0,19,40,.30), 0 10px 24px -14px rgba(0,34,72,.16);
  --sh-gold: 0 14px 32px -12px rgba(200,148,58,.5);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: 'Inter', system-ui, sans-serif; color: var(--ink); background: var(--cream); line-height: 1.65; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

h1,h2,h3,h4 { font-family: 'Inter', sans-serif; font-weight: 800; line-height: 1.08; letter-spacing: -0.025em; color: var(--ink); }
.serif { font-family: 'Instrument Serif', Georgia, serif; font-style: italic; font-weight: 400; letter-spacing: 0; color: var(--gold); }
.gold { color: var(--gold-deep); }
.eyebrow { font-size: .74rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--gold-deep); display: inline-flex; align-items: center; gap: 9px; }
.eyebrow::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 4px rgba(224,170,75,.18); }
.eyebrow.on-navy { color: var(--gold-soft); }
.eyebrow.on-navy::before { background: var(--gold); }

/* buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-family: 'Inter', sans-serif; font-weight: 600; font-size: .95rem; padding: 13px 25px; border-radius: 999px; border: 1px solid transparent; cursor: pointer; transition: transform .2s var(--ease), box-shadow .25s var(--ease), background .25s ease, border-color .25s ease, color .25s ease; white-space: nowrap; }
.btn:active { transform: scale(.97); }
.btn-gold { background: linear-gradient(135deg, var(--gold-soft), var(--gold) 45%, var(--gold-deep)); color: #3a2906; box-shadow: var(--sh-gold); }
.btn-gold:hover { box-shadow: 0 18px 40px -14px rgba(200,148,58,.62); filter: brightness(1.03); }
.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--navy-mid); }
.btn-wa { background: #1faf54; color: #fff; }
.btn-wa:hover { background: #25c462; }
.btn-outline { background: var(--cream); color: var(--ink); border-color: var(--border-2); }
.btn-outline:hover { border-color: var(--gold); color: var(--gold-deep); }
.btn-on-navy { background: rgba(255,255,255,.07); color: #fff; border-color: rgba(244,220,166,.3); }
.btn-on-navy:hover { background: rgba(255,255,255,.14); border-color: var(--gold-soft); }
.btn-lg { padding: 15px 32px; font-size: 1.02rem; }
.btn-block { width: 100%; }

/* topbar */
.topbar { background: linear-gradient(90deg, #00102400, #001226 8%, #002248 50%, #001226 92%, #00102400), #001022; color: #b9c6dc; font-size: .82rem; position: relative; }
.topbar::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(224,170,75,.55), transparent); }
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; height: 46px; gap: 12px; }
.topbar .tb-trust, .topbar .tb-contact { display: flex; align-items: center; }
.topbar .ti, .topbar .tb-contact a { display: inline-flex; align-items: center; gap: 8px; padding: 0 18px; position: relative; line-height: 1; white-space: nowrap; }
.topbar .ti:first-child { padding-left: 0; }
.topbar .tb-contact a:last-child { padding-right: 0; }
.topbar .ti:not(:last-child)::after, .topbar .tb-contact a:not(:last-child)::after { content: ''; position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 13px; background: rgba(255,255,255,.14); }
.topbar .ic { color: var(--gold); display: inline-flex; }
.topbar .ti b { color: #fff; font-weight: 700; }
.topbar .tb-contact a { color: #b9c6dc; transition: color .15s ease; }
.topbar .tb-contact a:hover { color: #fff; }
.topbar .tb-phone { color: var(--gold-soft); font-weight: 600; }
.topbar .tb-phone:hover { color: var(--gold); }

/* header */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,254,249,.9); backdrop-filter: blur(14px); border-bottom: 1px solid var(--border); transition: box-shadow .25s ease; }
.site-header.scrolled { box-shadow: var(--sh-sm); }
.nav { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 18px; }
.brand img { height: 52px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 28px; margin-left: auto; }
.nav-links a { font-size: .94rem; color: var(--ink-3); font-weight: 500; transition: color .18s ease; }
.nav-links a:hover { color: var(--gold-deep); }
.nav-cta { display: flex; align-items: center; gap: 10px; }
.nav-toggle { display: none; background: none; border: 0; font-size: 1.5rem; color: var(--ink); cursor: pointer; }

/* hero */
.hero { position: relative; background: linear-gradient(160deg, #001328 0%, #002248 48%, #033064 100%); color: #e6eefb; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(760px 420px at 80% -10%, var(--gold-glow), transparent 62%), radial-gradient(680px 380px at -6% 18%, rgba(30,58,138,.4), transparent 60%); pointer-events: none; }
.hero::after { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px); background-size: 52px 52px; mask-image: radial-gradient(900px 520px at 28% 24%, #000, transparent 76%); pointer-events: none; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.12fr .88fr; gap: 50px; align-items: center; padding: 60px 0 72px; }
.hero h1 { color: #fff; font-size: clamp(2.5rem, 4.8vw, 4rem); font-weight: 800; }
.hero h1 .serif { display: block; font-size: 1.06em; line-height: 1.05; margin-top: 2px; }
.hero .sub { font-size: 1.16rem; color: var(--gold-soft); font-weight: 500; margin: 18px 0 14px; }
.hero .lede { color: #b9c6dd; font-size: 1.05rem; max-width: 46ch; }
.hero-eyebrow { margin-bottom: 18px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 28px; }
.quote { border-left: 2px solid var(--gold); padding: 4px 0 4px 18px; margin-top: 26px; max-width: 44ch; }
.quote p { font-family: 'Instrument Serif', Georgia, serif; font-style: italic; font-size: 1.18rem; color: #d7e0f0; line-height: 1.4; }
/* hero stats */
.hero-stats { display: flex; gap: 36px; margin-top: 30px; }
.hero-stats .st b { font-size: 1.9rem; font-weight: 800; color: #fff; display: block; line-height: 1; }
.hero-stats .st b .serif { font-size: 1rem; color: var(--gold); }
.hero-stats .st span { font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: #8b9bb8; }
.hero-stats .st + .st { padding-left: 36px; border-left: 1px solid rgba(255,255,255,.1); }

/* lead form card */
.lead-card { background: linear-gradient(165deg, #fffef9, #f8f6f0); border-radius: var(--r-lg); box-shadow: var(--sh-lg); overflow: hidden; position: relative; border: 1px solid rgba(244,220,166,.4); }
.lead-card .secure { background: var(--navy-deep); color: #b9c6da; font-size: .76rem; text-align: center; padding: 10px; }
.lead-card .secure b { color: var(--gold-soft); }
.lead-card .body { padding: 26px 28px 26px; }
.lead-card h3 { font-size: 1.4rem; text-align: center; font-weight: 800; }
.lead-card h3 .serif { font-size: 1.1em; }
.lead-card .tagline { text-align: center; color: var(--ink-3); font-size: .92rem; margin: 6px 0 18px; }
.field { margin-bottom: 13px; }
.field label { display: block; font-size: .78rem; font-weight: 600; color: var(--ink-3); margin-bottom: 5px; letter-spacing: .01em; }
.field .inp { display: flex; align-items: center; gap: 10px; background: var(--lav); border: 1px solid #e2e7f5; border-radius: var(--r-sm); padding: 0 14px; transition: border-color .18s ease, box-shadow .18s ease, background .18s ease; }
.field .inp .ic { color: var(--ink-5); font-size: .95rem; }
.field .inp input, .field .inp select { flex: 1; width: 100%; padding: 12px 0; border: 0; background: transparent; font-family: inherit; font-size: .96rem; color: var(--ink); outline: none; }
.field .inp:focus-within { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(224,170,75,.18); background: #fff; }
.phone-row { display: grid; grid-template-columns: 84px 1fr; gap: 9px; }
.phone-row .prefix { display: flex; align-items: center; justify-content: center; gap: 5px; border: 1px solid #e2e7f5; border-radius: var(--r-sm); background: #fff; font-size: .9rem; font-weight: 600; color: var(--ink-2); }
.lead-card .form-note { text-align: center; font-size: .76rem; color: var(--ink-4); margin-top: 11px; }
.lead-card .badges { display: flex; justify-content: center; gap: 16px; padding: 13px; border-top: 1px solid var(--border); background: #fffdf6; font-size: .79rem; color: var(--ink-3); }
.lead-card .badges span { display: inline-flex; align-items: center; gap: 6px; }
.lead-card .badges .ic { color: var(--gold-deep); }

/* sections (warm) */
section { padding: 88px 0; }
.section-alt { background: var(--cream-2); }
.section-navy { background: linear-gradient(160deg, #001328, #002248); color: #e6eefb; border: 0; }
.section-head { max-width: 62ch; margin-bottom: 44px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head h2 { font-size: clamp(1.9rem, 3.4vw, 2.7rem); margin: 16px 0 14px; font-weight: 800; }
.section-head h2 .serif { font-size: 1.08em; }
.section-head p { color: var(--ink-3); font-size: 1.08rem; }
.lead-p { color: var(--ink-3); font-size: 1.05rem; max-width: 70ch; }
.lead-p + .lead-p { margin-top: 15px; }

.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 28px; align-items: start; }
.card { background: var(--cream); border: 1px solid var(--border); border-radius: var(--r); padding: 30px; box-shadow: var(--sh-sm); transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s ease; }
@media (hover:hover){ .card:hover { transform: translateY(-6px); box-shadow: var(--sh); border-color: var(--gold-soft); } }
.card .ic { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(150deg, var(--cream-3), #fbeecb); color: var(--gold-deep); margin-bottom: 18px; font-size: 1.4rem; box-shadow: inset 0 0 0 1px rgba(224,170,75,.3); }
.card h3 { font-size: 1.18rem; margin-bottom: 9px; font-weight: 700; }
.card p { color: var(--ink-3); font-size: .96rem; }

/* levels */
.levels { display: grid; gap: 16px; }
.level { display: grid; grid-template-columns: 76px 1fr; gap: 24px; align-items: start; background: var(--cream); border: 1px solid var(--border); border-left: 3px solid var(--gold); border-radius: var(--r); padding: 26px 28px; box-shadow: var(--sh-sm); }
.level .num { font-family: 'Instrument Serif', serif; font-style: italic; font-size: 2.6rem; color: var(--gold); font-weight: 400; line-height: 1; }
.level h3 { font-size: 1.15rem; margin-bottom: 6px; font-weight: 700; }
.level p { color: var(--ink-3); font-size: .95rem; }
.paper-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.chip { font-size: .8rem; padding: 5px 12px; border-radius: 8px; background: #fff; border: 1px solid var(--border-2); color: var(--ink-3); font-weight: 500; }
.callout { background: linear-gradient(120deg, var(--cream-3), #fdf3d8); border: 1px solid #f0dfb0; border-radius: var(--r); padding: 22px 26px; font-size: .98rem; color: var(--ink-2); margin-top: 26px; }
.callout b { color: var(--gold-deep); }

/* tables */
.table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--r); box-shadow: var(--sh-sm); background: var(--cream); }
table.data { width: 100%; border-collapse: collapse; min-width: 560px; }
table.data th, table.data td { padding: 15px 18px; text-align: left; font-size: .95rem; border-bottom: 1px solid var(--border); }
table.data thead th { background: var(--navy); color: #fff; font-weight: 700; }
table.data tbody tr:last-child td { border-bottom: 0; }
table.data tbody tr:nth-child(even) { background: var(--cream-2); }
table.data td b { color: var(--navy); }

/* fees */
.fee-hero { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; align-items: stretch; }
.fee-card { background: var(--cream); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 32px; box-shadow: var(--sh-sm); }
.fee-card.lead { border: 2px solid var(--gold); position: relative; box-shadow: var(--sh); }
.fee-card.lead::before { content: 'TRANSPARENT'; position: absolute; top: 18px; right: 18px; font-size: .66rem; font-weight: 700; letter-spacing: .12em; color: var(--gold-deep); background: var(--cream-3); padding: 4px 11px; border-radius: 999px; border: 1px solid #f0dfb0; }
.fee-card .price { font-weight: 800; font-size: 3rem; color: var(--navy); line-height: 1; letter-spacing: -.02em; }
.fee-card .price small { font-size: .92rem; color: var(--ink-4); font-weight: 500; }
.fee-card ul { list-style: none; margin: 20px 0 0; display: grid; gap: 11px; }
.fee-card ul li { display: flex; gap: 10px; font-size: .96rem; color: var(--ink-3); }
.tick { flex: none; width: 20px; height: 20px; border-radius: 50%; background: rgba(224,170,75,.16); color: var(--gold-deep); display: grid; place-items: center; font-size: .68rem; margin-top: 2px; }
.note { font-size: .85rem; color: var(--ink-4); border-left: 3px solid var(--gold); padding-left: 14px; margin-top: 16px; }

/* faq */
.faq { display: grid; gap: 12px; max-width: 860px; margin: 0 auto; }
.faq details { background: var(--cream); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 2px 24px; box-shadow: var(--sh-sm); transition: border-color .2s ease; }
.faq details[open] { border-color: #f0dfb0; }
.faq summary { cursor: pointer; list-style: none; padding: 19px 0; font-weight: 700; font-size: 1.05rem; color: var(--ink); display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: '+'; color: var(--gold); font-size: 1.6rem; font-weight: 300; transition: transform .25s var(--ease); }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { color: var(--ink-3); font-size: .97rem; padding: 0 0 20px; }

/* resources */
.res-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.res-grid a { display: flex; align-items: center; gap: 10px; padding: 16px 18px; border: 1px solid var(--border); border-radius: var(--r-sm); font-size: .94rem; color: var(--ink-3); background: var(--cream); transition: border-color .2s ease, color .2s ease, transform .2s var(--ease), box-shadow .2s ease; }
.res-grid a:hover { border-color: var(--gold); color: var(--gold-deep); transform: translateX(4px); box-shadow: var(--sh-sm); }
.res-grid a .arr { margin-left: auto; color: var(--gold); }

/* cta band */
.cta-band { background: linear-gradient(150deg, #001328, #002248 60%, #033064); color: #fff; border-radius: var(--r-lg); padding: 56px; text-align: center; position: relative; overflow: hidden; box-shadow: var(--sh-lg); }
.cta-band::after { content: ''; position: absolute; inset: 0; background: radial-gradient(540px 260px at 50% -20%, var(--gold-glow), transparent 62%); }
.cta-band h2 { color: #fff; font-size: clamp(1.8rem,3.2vw,2.5rem); margin-bottom: 14px; position: relative; font-weight: 800; }
.cta-band h2 .serif { color: var(--gold-soft); }
.cta-band p { color: #c0cde2; max-width: 56ch; margin: 0 auto 28px; position: relative; }
.cta-band .hero-cta { justify-content: center; position: relative; }

/* contact */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }
.contact-info .row { display: flex; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--border); }
.contact-info .row .ic { color: var(--gold-deep); font-size: 1.1rem; }
.contact-info .row b { display: block; font-weight: 700; }
.contact-info .row span { color: var(--ink-3); font-size: .95rem; }

/* footer */
footer { background: var(--navy-deep); color: #9fb0ca; padding: 60px 0 30px; }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 30px; }
.foot-brand img { height: 60px; margin-bottom: 16px; }
.foot-brand p { color: #7e90af; font-size: .9rem; max-width: 34ch; }
.foot-col h4 { font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 14px; }
.foot-col a { display: block; color: #9fb0ca; font-size: .92rem; padding: 5px 0; transition: color .18s ease; }
.foot-col a:hover { color: var(--gold); }
.foot-bottom { border-top: 1px solid rgba(255,255,255,.08); margin-top: 38px; padding-top: 24px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; color: #6b7f9d; font-size: .84rem; }

/* whatsapp float */
.wa-float { position: fixed; right: 22px; bottom: 22px; z-index: 60; width: 58px; height: 58px; border-radius: 50%; background: #1faf54; display: grid; place-items: center; box-shadow: 0 14px 30px -8px rgba(31,175,84,.6); transition: transform .2s var(--ease); }
.wa-float:hover { transform: scale(1.07); } .wa-float:active { transform: scale(.95); }
.wa-float svg { width: 30px; height: 30px; fill: #fff; }

/* reveal */
.reveal { opacity: 0; transform: translateY(18px); }
.reveal.in { opacity: 1; transform: none; transition: opacity .7s var(--ease), transform .7s var(--ease); }

/* responsive */
@media (max-width: 980px) {
  .hero-grid, .fee-hero, .contact-grid, .grid-2 { grid-template-columns: 1fr; }
  .hero-grid { gap: 38px; padding: 44px 0 58px; }
  .grid-3, .res-grid { grid-template-columns: 1fr 1fr; }
  .nav-links { display: none; } .nav-toggle { display: block; }
  .topbar .ti:nth-child(n+3) { display: none; }
  .lead-card { max-width: 470px; margin: 0 auto; }
}
@media (max-width: 560px) {
  .grid-3, .res-grid, .foot-grid { grid-template-columns: 1fr; }
  .level { grid-template-columns: 1fr; gap: 8px; }
  section { padding: 58px 0; }
  .cta-band { padding: 34px 22px; }
  .hero-stats { gap: 20px; } .hero-stats .st + .st { padding-left: 20px; }
  .topbar .ti:nth-child(n+2) { display: none; }
  .topbar .tb-contact a:not(.tb-phone) { display: none; }
  .nav-cta .btn-outline { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: opacity .2s ease; }
  .btn:active, .card:hover, .wa-float:hover { transform: none; }
}

/* ============ v4 — section flow & fee enquiry ============ */
/* curved divider: navy hero flows into cream */
.hero .hero-grid { padding-bottom: 116px; }
.hero-curve { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; line-height: 0; pointer-events: none; }
.hero-curve svg { display: block; width: 100%; height: 72px; }

/* bridging trust strip — ties hero to the first content block */
.bridge { background: var(--cream); position: relative; z-index: 3; }
.bridge .wrap { display: flex; align-items: center; justify-content: center; gap: 12px 30px; flex-wrap: wrap; padding: 28px 24px 2px; }
.bridge .b-item { display: inline-flex; align-items: center; gap: 9px; color: var(--ink-3); font-size: .93rem; font-weight: 500; }
.bridge .b-item .ic { color: var(--gold-deep); font-size: 1.05rem; }
.bridge .b-item b { color: var(--ink); font-weight: 700; }
.bridge .sep { width: 1px; height: 22px; background: var(--border-2); }

/* curved divider: cream flows into the deep-navy footer */
.foot-curve { line-height: 0; }
.foot-curve svg { display: block; width: 100%; height: 64px; }

/* fee ENQUIRY card (no price shown) */
.enquire .ph { display: flex; align-items: center; gap: 16px; margin: 10px 0 2px; }
.enquire .ph-badge { width: 58px; height: 58px; flex: none; border-radius: 16px; display: grid; place-items: center; background: linear-gradient(150deg, var(--cream-3), #fbeecb); color: var(--gold-deep); box-shadow: inset 0 0 0 1px rgba(224,170,75,.3); }
.enquire .ph-badge svg { width: 28px; height: 28px; }
.enquire .ph-t b { display: block; font-size: 1.4rem; font-weight: 800; color: var(--navy); line-height: 1.1; letter-spacing: -.02em; }
.enquire .ph-t span { font-size: .9rem; color: var(--ink-4); }
.enquire .micro { text-align: center; font-size: .79rem; color: var(--ink-4); margin-top: 11px; }

@media (max-width: 980px) {
  .hero .hero-grid { padding-bottom: 84px; }
  .bridge .sep { display: none; }
  .bridge .wrap { gap: 10px 18px; }
}

/* ============ v6 — bento, journey, salary, kw ============ */
/* keyword strip */
.kw-line { color: var(--ink-4); font-size: .95rem; margin-top: 14px; }
.kw-line b { color: var(--gold-deep); font-weight: 600; }

/* Why-us bento */
.bento { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.bento .card { margin: 0; }
.bento .b-feature { grid-column: span 2; background: linear-gradient(150deg, #002248, #062a5a); border-color: transparent; position: relative; overflow: hidden; }
.bento .b-feature::after { content: ''; position: absolute; inset: 0; background: radial-gradient(360px 200px at 88% -20%, var(--gold-glow), transparent 60%); }
.bento .b-feature h3 { color: #fff; font-size: 1.4rem; position: relative; }
.bento .b-feature p { color: #bcc9e0; position: relative; }
.bento .b-feature .ic { background: rgba(224,170,75,.16); color: var(--gold-soft); box-shadow: inset 0 0 0 1px rgba(224,170,75,.35); position: relative; }
.bento .b-wide { grid-column: span 3; display: flex; align-items: center; gap: 24px; }
.bento .b-wide .ic { margin-bottom: 0; flex: none; }
.bento .b-wide h3 { margin-bottom: 4px; }

/* Journey timeline */
.journey-track { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; position: relative; margin-top: 8px; }
.journey-track::before { content: ''; position: absolute; top: 27px; left: 10%; right: 10%; height: 2px; background: linear-gradient(90deg, var(--gold-soft), var(--gold), var(--gold-soft)); opacity: .55; z-index: 0; }
.j-step { text-align: center; position: relative; z-index: 1; }
.j-dot { width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 16px; display: grid; place-items: center; background: var(--cream); border: 2px solid var(--gold); color: var(--gold-deep); font-family: 'Instrument Serif', serif; font-style: italic; font-size: 1.5rem; box-shadow: var(--sh-sm); }
.j-step h4 { font-size: 1.02rem; font-weight: 700; margin-bottom: 5px; }
.j-step p { font-size: .88rem; color: var(--ink-4); }
.journey-cta { text-align: center; margin-top: 40px; }

/* Salary visual bars */
.sal { display: grid; gap: 13px; max-width: 920px; }
.sal-row { display: grid; grid-template-columns: 250px 1fr 124px; gap: 20px; align-items: center; }
.sal-row .role { font-weight: 600; color: var(--ink); font-size: .96rem; }
.sal-row .role small { display: block; color: var(--ink-4); font-weight: 500; font-size: .8rem; margin-top: 1px; }
.sal-track { height: 12px; border-radius: 999px; background: var(--paper-2); position: relative; overflow: hidden; box-shadow: inset 0 1px 2px rgba(0,34,72,.06); }
.sal-fill { position: absolute; top: 0; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--gold-soft), var(--gold)); }
.sal-amt { text-align: right; font-weight: 800; color: var(--navy); font-size: .95rem; white-space: nowrap; }

@media (max-width: 980px) {
  .bento { grid-template-columns: 1fr 1fr; }
  .bento .b-feature, .bento .b-wide { grid-column: span 2; }
  .journey-track { grid-template-columns: 1fr 1fr; gap: 30px 18px; }
  .journey-track::before { display: none; }
  .sal-row { grid-template-columns: 1fr; gap: 6px; }
  .sal-row .sal-amt { text-align: left; }
}
@media (max-width: 560px) {
  .bento, .bento .b-feature { grid-template-columns: 1fr; }
  .bento .b-feature, .bento .b-wide { grid-column: span 1; }
  .bento .b-wide { flex-direction: column; align-items: flex-start; }
  .journey-track { grid-template-columns: 1fr; }
}
