/* ============================================================
   BJPC Landing Pages — Shared Stylesheet
   Matches the colour system used in the BJPC staging site
   prototypes (index/about/junior-college/kids-kastle PDFs).

   Two themes:
   - .theme-kk     — Kids Kastle (yellow hero, black sections)
   - .theme-arts   — HSC Arts (navy hero, cream sections)
   ============================================================ */

:root{
  --offwhite:#F5F2ED;
  --offwhite-2:#FAF7F2;
  --cream:#F4EFE5;
  --navy:#1A2744;
  --navy-2:#22324F;
  --navy-3:#0F1A30;
  --gold:#C8A96E;
  --gold-soft:#E8D8B5;
  --gold-deep:#B69356;
  --text:#1A2744;
  --muted:#6B7280;
  --border:rgba(26,39,68,.10);

  --kk-yellow:#F4C430;
  --kk-yellow-soft:#FCE9A1;
  --kk-yellow-deep:#E8B520;
  --kk-blue:#4FB6E8;
  --kk-blue-soft:#CFE9F8;
  --kk-black:#111213;
  --kk-cream:#FBF6E7;

  --shadow:0 6px 24px rgba(15,26,48,.06);
  --shadow-lg:0 18px 60px rgba(15,26,48,.12);
  --radius:14px;
  --radius-lg:22px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);background:var(--offwhite);
  -webkit-font-smoothing:antialiased;line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none}

h1,h2,h3,h4,h5{
  font-family:"Fraunces","Playfair Display",Georgia,serif;
  letter-spacing:-.01em;line-height:1.15;margin:0;font-weight:600;
}

.container{max-width:1180px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:920px;margin:0 auto;padding:0 24px}

.eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin-bottom:14px;display:inline-block;
}
.gold-bar{
  display:block;width:64px;height:3px;background:var(--gold);
  border-radius:2px;margin:16px 0 24px;
}
.note{font-size:12.5px;color:var(--muted);font-style:italic}

/* ============================================================
   Top campaign nav
   ============================================================ */
.lp-nav{
  position:sticky;top:0;z-index:60;
  background:var(--navy);color:#fff;
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:box-shadow .15s;
}
.lp-nav .inner{
  max-width:1280px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.lp-logo{
  font-family:"Fraunces",serif;font-weight:600;font-size:18px;
  letter-spacing:.02em;color:#fff;display:inline-flex;align-items:center;gap:14px;
}
.lp-logo-img{
  height:44px;width:auto;display:block;flex:0 0 auto;
  background:#fff;border-radius:6px;padding:3px;
}
.lp-logo-text{display:inline-flex;align-items:center;gap:14px}
.lp-logo .est{
  font-family:"Inter",sans-serif;font-size:10px;letter-spacing:.20em;
  text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500;
  padding-left:14px;border-left:1px solid rgba(255,255,255,.18);
}
.lp-nav-actions{display:flex;align-items:center;gap:12px}
.lp-call{
  color:rgba(255,255,255,.85);font-size:13px;font-weight:500;
  display:inline-flex;align-items:center;gap:6px;
}
.lp-call:hover{color:var(--gold)}
.lp-nav-cta{
  background:var(--gold);color:var(--navy);
  padding:10px 18px;border-radius:8px;font-weight:600;font-size:13px;
  transition:background .15s;
}
.lp-nav-cta:hover{background:#d6b97c}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;border-radius:10px;
  font-weight:600;font-size:14.5px;
  transition:transform .15s, background .15s, box-shadow .15s;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:#d6b97c}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:#243557}
.btn-ghost{background:#fff;color:var(--navy);border:1px solid var(--border)}
.btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.btn-ghost-light:hover{background:rgba(255,255,255,.08)}
.btn-lg{padding:16px 28px;font-size:15px}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-arrow::after{content:"→";margin-left:2px;font-weight:400}

/* ============================================================
   Sections
   ============================================================ */
section.block{padding:84px 0}
section.block.tight{padding:60px 0}
section.block.navy{background:var(--navy);color:#fff}
section.block.navy .eyebrow{color:var(--gold)}
section.block.cream{background:var(--offwhite-2)}
section.block.dark{background:var(--kk-black);color:#fff}
section.block.dark .eyebrow{color:var(--kk-yellow)}
section.block h2{font-size:38px;letter-spacing:-.015em}
section.block.navy h2,
section.block.dark h2{color:rgba(255,255,255,.85)}
section.block p.body{font-size:16.5px;color:#3d4760;max-width:680px;line-height:1.7}
section.block.navy p.body,
section.block.dark p.body{color:rgba(255,255,255,.78)}

.section-head{max-width:700px;margin-bottom:36px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head.center .gold-bar{margin-left:auto;margin-right:auto}

/* ============================================================
   Grids
   ============================================================ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.two-col{display:grid;grid-template-columns:1.1fr 1fr;gap:54px;align-items:start}

/* ============================================================
   Generic cards
   ============================================================ */
.card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);transition:transform .2s, box-shadow .2s;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.card h3{font-size:18px;margin:6px 0 8px;font-weight:600;color:var(--navy)}
.card p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.6}
.card .num{
  font-family:"Fraunces",serif;font-size:28px;color:var(--gold);
  font-weight:500;display:block;line-height:1;margin-bottom:8px;
}
.card .ico{
  width:38px;height:38px;border-radius:9px;background:var(--gold-soft);
  color:var(--navy);display:inline-flex;align-items:center;justify-content:center;
  font-size:16px;margin-bottom:14px;font-weight:600;
}

/* ============================================================
   Photo placeholders
   ============================================================ */
.photo-box{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg, #e8e1d2 0%, #d8cdb9 100%);
  border-radius:var(--radius);
  min-height:300px;
  display:flex;align-items:center;justify-content:center;
  color:#a39a89;font-size:11px;letter-spacing:.20em;text-transform:uppercase;
  text-align:center;padding:20px;
}
.photo-box.tall{min-height:420px}
.photo-box.short{min-height:200px}
.photo-box > img,
.kk-hero-photo > img,
.arts-hero-photo > img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
}

/* ============================================================
   Checklist (numbered list with dots)
   ============================================================ */
.checklist{display:flex;flex-direction:column;gap:18px}
.checklist .item{display:flex;gap:14px;align-items:flex-start}
.checklist .item .dot{
  width:26px;height:26px;border-radius:50%;background:var(--gold);
  color:var(--navy);display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;margin-top:2px;
}
.checklist .item h4{font-size:16px;margin:0 0 4px;font-weight:600;color:var(--navy)}
.checklist .item p{font-size:14px;color:var(--muted);margin:0;line-height:1.55}

/* ============================================================
   Quote / testimonial cards
   ============================================================ */
.quote-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 26px;position:relative;box-shadow:var(--shadow);
}
.quote-card .qmark{
  font-family:"Fraunces",serif;font-size:44px;color:var(--gold);
  line-height:1;display:block;margin-bottom:8px;
}
.quote-card p{font-size:15.5px;color:var(--navy);line-height:1.65;margin:0 0 18px;font-style:italic}
.quote-card .who{display:flex;flex-direction:column}
.quote-card .who strong{font-size:14px;color:var(--navy);font-weight:600}
.quote-card .who span{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ============================================================
   FAQ
   ============================================================ */
.faq{display:flex;flex-direction:column;gap:12px}
.faq details{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:0;overflow:hidden;transition:box-shadow .15s;
}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{
  padding:20px 22px;cursor:pointer;font-weight:600;font-size:16px;
  color:var(--navy);display:flex;justify-content:space-between;align-items:center;
  list-style:none;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:22px;color:var(--gold);font-weight:400;line-height:1;
  flex-shrink:0;
}
.faq details[open] summary::after{content:"−"}
.faq .answer{padding:0 22px 22px;color:#3d4760;font-size:14.5px;line-height:1.7}

/* ============================================================
   Form
   ============================================================ */
.form-wrap{
  background:#fff;border-radius:var(--radius-lg);
  padding:36px;box-shadow:var(--shadow-lg);border:1px solid var(--border);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.input,.select,.textarea{
  width:100%;padding:13px 16px;border:1px solid var(--border);
  border-radius:10px;font-family:inherit;font-size:14.5px;color:var(--navy);
  background:var(--offwhite-2);transition:border .15s, background .15s;
}
.input:focus,.select:focus,.textarea:focus{
  outline:none;border-color:var(--gold);background:#fff;
}
.textarea{min-height:110px;resize:vertical}
.label{
  display:block;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:6px;
}
.field{margin-top:14px}
.consent{
  display:flex;gap:10px;align-items:flex-start;margin-top:18px;
  font-size:13px;color:var(--muted);line-height:1.5;
}
.consent input{margin-top:3px}

.form-status{
  margin-top:16px;padding:14px 18px;border-radius:10px;
  font-size:14px;font-weight:500;display:none;
}
.form-status.ok{display:block;background:#e8f5e9;color:#1b5e20;border:1px solid #a5d6a7}
.form-status.err{display:block;background:#ffebee;color:#b71c1c;border:1px solid #ef9a9a}
.form-status.loading{display:block;background:#e3f2fd;color:#0d47a1;border:1px solid #90caf9}

.form-side h3{font-size:24px;margin-bottom:10px;color:var(--navy)}
.form-side .body{font-size:15px;color:var(--muted);line-height:1.7}
.contact-strip{
  margin-top:20px;padding-top:20px;border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:10px;
}
.contact-strip .row{display:flex;align-items:center;gap:10px;font-size:14px}
.contact-strip .row strong{
  color:var(--gold);font-weight:600;width:74px;font-size:12.5px;
  letter-spacing:.08em;text-transform:uppercase;
}

/* ============================================================
   CTA strip
   ============================================================ */
.cta-strip{padding:48px 0;background:var(--gold);color:var(--navy)}
.cta-strip .inner{
  max-width:1180px;margin:0 auto;padding:0 24px;
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
}
.cta-strip h3{font-size:24px;font-weight:600;margin:0;letter-spacing:-.01em}
.cta-strip p{margin:6px 0 0;font-size:14.5px;color:rgba(26,39,68,.78)}

/* ============================================================
   Sticky mobile CTA
   ============================================================ */
.sticky-mobile-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:var(--navy);padding:12px 16px;z-index:50;
  border-top:1px solid rgba(255,255,255,.06);box-shadow:0 -4px 20px rgba(0,0,0,.18);
}
.sticky-mobile-cta .row{display:flex;gap:10px}
.sticky-mobile-cta a{flex:1;text-align:center;font-size:14px;padding:13px 12px;border-radius:8px;font-weight:600}
.sticky-mobile-cta .call{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.20)}
.sticky-mobile-cta .enquire{background:var(--gold);color:var(--navy)}

/* ============================================================
   Footer
   ============================================================ */
.lp-footer{background:var(--navy-3);color:rgba(255,255,255,.7);padding:48px 0 28px}
.lp-footer .grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;
  padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.08);
}
.lp-footer h5{
  font-family:"Inter",sans-serif;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);margin:0 0 14px;font-weight:600;
}
.lp-footer ul{list-style:none;padding:0;margin:0}
.lp-footer ul li{margin-bottom:8px}
.lp-footer ul li a{font-size:14px;color:rgba(255,255,255,.7)}
.lp-footer ul li a:hover{color:#fff}
.lp-footer p{font-size:13.5px;line-height:1.7;margin:0}
.lp-footer .legal{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding-top:20px;font-size:12.5px;color:rgba(255,255,255,.45);
}
.lp-footer .brand-foot{
  font-family:"Fraunces",serif;font-size:20px;color:#fff;font-weight:600;
  display:block;margin-bottom:10px;
}

.tag-pill{
  display:inline-block;background:var(--gold-soft);color:var(--navy);
  font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  padding:5px 11px;border-radius:999px;
}
.text-link{color:var(--navy);font-weight:500;font-size:14px;display:inline-flex;align-items:center;gap:4px}
.text-link:hover{color:var(--gold-deep)}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:920px){
  section.block{padding:60px 0}
  section.block h2{font-size:28px}
  .two-col{grid-template-columns:1fr;gap:36px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:18px}
  .grid-5{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .form-wrap{padding:24px 22px}
  .cta-strip .inner{flex-direction:column;align-items:flex-start;text-align:left}
  .lp-footer .grid{grid-template-columns:1fr;gap:24px}
  .lp-footer .legal{flex-direction:column;align-items:flex-start;gap:8px}
  .sticky-mobile-cta{display:block}
  body{padding-bottom:74px}
  .lp-call{display:none}
  .lp-logo .est{display:none}
}


/* ============================================================
   THEME: KIDS KASTLE
   Yellow hero, black sections, blue/yellow accent
   ============================================================ */

/* Yellow hero — matches PDF */
.theme-kk .kk-hero{
  background:var(--kk-yellow);
  color:var(--navy);
  padding:80px 0 88px;position:relative;overflow:hidden;
}
.theme-kk .kk-hero .container{position:relative;z-index:1}
.theme-kk .kk-hero-grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;
}
.theme-kk .kk-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--navy);color:#fff;padding:10px 18px;border-radius:999px;
  font-size:12.5px;letter-spacing:.04em;font-weight:500;margin-bottom:20px;
}
.theme-kk .kk-pill .star{color:var(--kk-yellow);font-size:14px}
.theme-kk .kk-hero h1{
  font-size:56px;color:var(--navy);font-weight:600;letter-spacing:-.02em;
  line-height:1.1;
}
.theme-kk .kk-hero h1 .hl{
  background:var(--kk-blue);color:var(--navy);
  padding:2px 16px;border-radius:8px;display:inline-block;
  margin-top:6px;
}
.theme-kk .kk-hero .lead{
  color:rgba(26,39,68,.82);font-size:17.5px;
  max-width:520px;margin-top:18px;line-height:1.6;
}
.theme-kk .kk-hero .btn-row{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.theme-kk .kk-hero .badge-row{margin-top:24px}
.theme-kk .kk-hero .legacy-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.55);color:var(--navy);
  border-radius:999px;padding:8px 16px;font-size:13px;font-weight:500;
}
.theme-kk .kk-hero .legacy-pill::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--navy);
}
.theme-kk .kk-hero-photo{
  position:relative;overflow:hidden;
  background:rgba(255,255,255,.45);
  border-radius:var(--radius-lg);min-height:380px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(26,39,68,.50);font-size:11px;letter-spacing:.20em;text-transform:uppercase;
  text-align:center;padding:24px;
}

/* Age groups bar — white cards on white background */
.theme-kk .age-bar{background:#fff;padding:22px 0;border-bottom:1px solid var(--border)}
.theme-kk .age-bar .container{display:flex;gap:32px;justify-content:center;flex-wrap:wrap}
.theme-kk .age-card{display:flex;align-items:center;gap:14px}
.theme-kk .age-card .badge{
  width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:var(--navy);
}
.theme-kk .age-card.n .badge{background:var(--kk-yellow)}
.theme-kk .age-card.j .badge{background:var(--kk-blue);color:#fff}
.theme-kk .age-card.s .badge{background:var(--navy);color:#fff}
.theme-kk .age-card strong{display:block;font-size:15.5px;color:var(--navy)}
.theme-kk .age-card span{font-size:13px;color:var(--muted)}

/* About + cream section */
.theme-kk section.block.cream{background:var(--offwhite-2)}
.theme-kk .photo-box.kk-cream{background:linear-gradient(135deg, #FCE9A1 0%, #F4C430 100%);color:rgba(26,39,68,.40)}

/* Six areas — BLACK section */
.theme-kk section.block.dark{background:var(--kk-black);color:#fff}
.theme-kk section.block.dark .eyebrow{color:var(--kk-yellow)}
.theme-kk section.block.dark h2{color:rgba(255,255,255,.55)}
.theme-kk section.block.dark .gold-bar{background:var(--kk-yellow)}
.theme-kk .area-card{
  background:#fff;border-radius:var(--radius);padding:28px;
  border-top:4px solid var(--kk-yellow);
}
.theme-kk .area-card.alt{border-top-color:var(--kk-blue)}
.theme-kk .area-card .num{
  font-family:"Fraunces",serif;font-size:32px;color:var(--kk-yellow);
  font-weight:500;line-height:1;display:block;margin-bottom:10px;
}
.theme-kk .area-card.alt .num{color:var(--kk-blue)}
.theme-kk .area-card h3{font-size:18px;color:var(--navy);margin-bottom:8px}
.theme-kk .area-card p{font-size:14.5px;color:var(--muted);line-height:1.6;margin:0}

/* Day at Kids Kastle — alternating colour timeline */
.theme-kk .timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:18px}
.theme-kk .timeline .step{
  background:#fff;border-radius:var(--radius);padding:22px 18px;text-align:center;
  border:1px solid var(--border);transition:transform .15s;
}
.theme-kk .timeline .step:nth-child(1){background:var(--kk-yellow-soft);border-color:transparent}
.theme-kk .timeline .step:nth-child(3){background:var(--kk-blue);border-color:transparent}
.theme-kk .timeline .step:nth-child(3) h4,
.theme-kk .timeline .step:nth-child(3) p,
.theme-kk .timeline .step:nth-child(3) .time{color:#fff}
.theme-kk .timeline .step:nth-child(5){background:var(--kk-yellow);border-color:transparent}
.theme-kk .timeline .step:hover{transform:translateY(-2px)}
.theme-kk .timeline .step .time{
  display:inline-block;background:rgba(26,39,68,.10);color:var(--navy);
  font-family:"Inter",sans-serif;font-size:12px;font-weight:600;
  padding:5px 12px;border-radius:999px;margin-bottom:12px;letter-spacing:.04em;
}
.theme-kk .timeline .step:nth-child(3) .time{background:rgba(255,255,255,.25);color:#fff}
.theme-kk .timeline .step h4{font-size:15px;color:var(--navy);margin:4px 0 6px;font-weight:600}
.theme-kk .timeline .step p{font-size:12.5px;color:var(--muted);margin:0;line-height:1.45}

/* Facilities — NAVY section */
.theme-kk .facilities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.theme-kk .facility-card{
  background:#fff;border-radius:var(--radius);padding:24px;text-align:center;
}
.theme-kk .facility-card .ico{
  width:42px;height:42px;border-radius:9px;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:14px;font-size:18px;font-weight:700;
}
.theme-kk .facility-card:nth-child(odd) .ico{background:var(--kk-yellow);color:var(--navy)}
.theme-kk .facility-card:nth-child(even) .ico{background:var(--kk-blue);color:#fff}
.theme-kk .facility-card h3{font-size:15.5px;color:var(--navy);margin:6px 0 8px;font-weight:600}
.theme-kk .facility-card p{font-size:13px;color:var(--muted);margin:0;line-height:1.55}

/* Testimonials section — BLACK */
.theme-kk .test-card{
  background:#fff;border-radius:var(--radius);padding:28px 26px;
  border-top:4px solid var(--kk-yellow);
}
.theme-kk .test-card.alt{border-top-color:var(--kk-blue)}
.theme-kk .test-card .qmark{
  font-family:"Fraunces",serif;font-size:36px;line-height:1;color:var(--kk-yellow);
  display:block;margin-bottom:8px;
}
.theme-kk .test-card.alt .qmark{color:var(--kk-blue)}
.theme-kk .test-card p{font-size:15px;color:var(--navy);line-height:1.65;margin:0 0 18px;font-style:italic}
.theme-kk .test-card .who strong{font-size:14px;color:var(--navy);font-weight:600;display:block}
.theme-kk .test-card .who span{font-size:12.5px;color:var(--muted)}

/* Admissions side card */
.theme-kk .adm-list{display:flex;flex-direction:column;gap:10px}
.theme-kk .adm-row{
  background:#fff;border-radius:10px;padding:14px 18px;
  display:flex;justify-content:space-between;align-items:center;
  border:1px solid var(--border);
}
.theme-kk .adm-row strong{font-size:15px;color:var(--navy);font-weight:600}
.theme-kk .adm-row span{font-size:14px;color:var(--muted)}
.theme-kk .adm-process{
  background:var(--kk-yellow-soft);border-radius:var(--radius);padding:28px 26px;
}
.theme-kk .adm-process .eyebrow{color:var(--navy)}

/* CTA strip on KK */
.theme-kk .cta-strip{background:var(--kk-yellow);color:var(--navy)}
.theme-kk .cta-strip .btn-navy{background:var(--navy);color:#fff}
.theme-kk .lp-nav-cta{background:var(--kk-yellow);color:var(--navy)}
.theme-kk .lp-nav-cta:hover{background:var(--kk-yellow-deep)}
.theme-kk .btn-gold{background:var(--kk-yellow);color:var(--navy)}
.theme-kk .btn-gold:hover{background:var(--kk-yellow-deep)}
.theme-kk .sticky-mobile-cta .enquire{background:var(--kk-yellow);color:var(--navy)}
.theme-kk .eyebrow{color:var(--kk-yellow-deep)}
.theme-kk section.block.cream .eyebrow,
.theme-kk section.block:not(.dark):not(.navy) .eyebrow{color:#A88410}
.theme-kk .gold-bar{background:var(--kk-yellow)}
.theme-kk .faq summary::after{color:var(--kk-blue)}
.theme-kk .input:focus,
.theme-kk .select:focus,
.theme-kk .textarea:focus{border-color:var(--kk-blue)}
.theme-kk .quote-card .qmark{color:var(--kk-yellow)}

@media (max-width:920px){
  .theme-kk .kk-hero{padding:54px 0 64px}
  .theme-kk .kk-hero h1{font-size:38px}
  .theme-kk .kk-hero-grid{grid-template-columns:1fr;gap:32px}
  .theme-kk .kk-hero-photo{min-height:240px}
  .theme-kk .age-bar .container{flex-direction:column;gap:14px;align-items:flex-start}
  .theme-kk .timeline{grid-template-columns:repeat(2,1fr);gap:12px}
  .theme-kk .facilities-grid{grid-template-columns:1fr 1fr}
}


/* ============================================================
   THEME: HSC ARTS / JUNIOR COLLEGE
   Navy hero, cream sections, gold accent
   ============================================================ */

.theme-arts{background:var(--offwhite)}

.theme-arts .arts-hero{
  background:var(--navy);color:#fff;
  padding:80px 0 90px;position:relative;overflow:hidden;
}
.theme-arts .arts-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 800px 600px at 80% 25%, rgba(200,169,110,.14), transparent 60%);
  pointer-events:none;
}
.theme-arts .arts-hero-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:54px;align-items:center;
  position:relative;z-index:1;
}
.theme-arts .arts-hero h1{
  font-size:60px;font-weight:600;letter-spacing:-.02em;line-height:1.05;
}
.theme-arts .arts-hero h1 .accent{color:var(--gold)}
.theme-arts .arts-hero .lead{
  color:rgba(255,255,255,.82);font-size:17.5px;
  max-width:540px;margin-top:20px;line-height:1.6;
}
.theme-arts .arts-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.theme-arts .arts-pill{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#fff;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:500;
}
.theme-arts .arts-hero .btn-row{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.theme-arts .arts-hero-photo{
  position:relative;overflow:hidden;
  background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.18);
  border-radius:var(--radius-lg);min-height:420px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.40);font-size:11px;letter-spacing:.20em;text-transform:uppercase;
  text-align:center;padding:24px;
}

/* Stream cards on Arts page */
.theme-arts .stream-card{
  background:#fff;border-radius:var(--radius);padding:26px;
  border:1px solid var(--border);box-shadow:var(--shadow);
}
.theme-arts .stream-card .tag{
  display:inline-block;background:var(--gold-soft);color:var(--navy);
  font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  padding:5px 11px;border-radius:999px;margin-bottom:14px;
}
.theme-arts .stream-card h3{font-size:21px;margin-bottom:8px;color:var(--navy)}
.theme-arts .stream-card .sub{font-size:13px;color:var(--muted);margin:0 0 12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.theme-arts .stream-card ul{padding-left:18px;margin:0;color:var(--muted);font-size:14.5px;line-height:1.85}
.theme-arts .stream-card ul li{margin-bottom:2px}
.theme-arts .stream-card.dark{background:var(--navy-2);color:#fff;border:1px solid rgba(255,255,255,.10)}
.theme-arts .stream-card.dark .tag{background:rgba(200,169,110,.22);color:var(--gold)}
.theme-arts .stream-card.dark h3{color:#fff}
.theme-arts .stream-card.dark ul{color:rgba(255,255,255,.82)}

/* Approach cards */
.theme-arts .approach-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);
}
.theme-arts .approach-card .num{
  font-family:"Fraunces",serif;font-size:30px;color:var(--gold);
  font-weight:500;display:block;line-height:1;margin-bottom:8px;
}
.theme-arts .approach-card h3{font-size:17.5px;color:var(--navy);margin-bottom:8px;font-weight:600}
.theme-arts .approach-card p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.6}

/* Faculty stats strip */
.theme-arts .fac-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.theme-arts .fac-stat{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 24px;text-align:center;
}
.theme-arts .fac-stat .big{
  font-family:"Fraunces",serif;font-size:42px;color:var(--gold);font-weight:500;
  line-height:1;display:block;margin-bottom:8px;
}
.theme-arts .fac-stat .lbl{
  font-size:12px;color:var(--muted);letter-spacing:.10em;text-transform:uppercase;
}

/* Results cards */
.theme-arts .res-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 22px;text-align:center;
}
.theme-arts .res-card .big{
  font-family:"Fraunces",serif;font-size:42px;color:var(--gold);font-weight:500;
  line-height:1;display:block;margin-bottom:8px;
}
.theme-arts .res-card .lbl{font-size:14px;color:var(--navy);font-weight:600;display:block;margin-bottom:4px}
.theme-arts .res-card .sub{font-size:12px;color:var(--muted);font-style:italic}

/* College life cards on navy */
.theme-arts section.block.navy .life-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:24px;
}
.theme-arts section.block.navy .life-card .ico{
  width:38px;height:38px;border-radius:9px;background:rgba(200,169,110,.18);
  color:var(--gold);display:inline-flex;align-items:center;justify-content:center;
  font-size:16px;margin-bottom:14px;font-weight:600;
}
.theme-arts section.block.navy .life-card h3{font-size:17px;color:#fff;margin-bottom:6px;font-weight:600}
.theme-arts section.block.navy .life-card p{font-size:14px;color:rgba(255,255,255,.72);margin:0;line-height:1.55}

/* Admissions block */
.theme-arts .adm-list{display:flex;flex-direction:column;gap:10px}
.theme-arts .adm-row{
  background:#fff;border-radius:10px;padding:14px 18px;
  display:flex;justify-content:space-between;align-items:center;
  border:1px solid var(--border);
}
.theme-arts .adm-row strong{font-size:15px;color:var(--navy);font-weight:600}
.theme-arts .adm-row span{font-size:14px;color:var(--muted)}
.theme-arts .adm-process{background:var(--gold-soft);border-radius:var(--radius);padding:28px 26px}

/* Cream sections */
.theme-arts section.block.cream{background:var(--offwhite-2)}

@media (max-width:920px){
  .theme-arts .arts-hero{padding:54px 0 64px}
  .theme-arts .arts-hero h1{font-size:38px}
  .theme-arts .arts-hero-grid{grid-template-columns:1fr;gap:32px}
  .theme-arts .arts-hero-photo{min-height:240px}
  .theme-arts .fac-stats{grid-template-columns:1fr}
}
