/* ============================================================
   Fly Cape Town — Website UI Kit · screen-specific styles
   (Courses, Weather, Shop, Tours, About, Blog)
   Loaded after site.css. Pairs with ../../colors_and_type.css
   ============================================================ */

/* ---- Generic inner page hero (non-photo) ---- */
.page-hero{padding:150px 40px 64px;background:var(--bg-ink);color:#fff;position:relative;overflow:hidden}
.page-hero .glow-tr{position:absolute;top:-180px;right:-160px;width:640px;height:640px;border-radius:50%;background:radial-gradient(circle,rgba(47,193,211,.26),transparent 70%);z-index:0}
.page-hero-inner{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.page-hero h1{font-family:var(--font-display);font-weight:900;font-stretch:120%;text-transform:uppercase;font-size:clamp(2.6rem,6vw,5rem);line-height:.95;letter-spacing:-.02em;margin:18px 0 0}
.page-hero h1 .cy{color:var(--accent)}
.page-hero .ph-lead{font-size:clamp(1.1rem,1.8vw,1.4rem);color:var(--fg-on-dark-soft);max-width:680px;line-height:1.55;margin-top:22px;text-wrap:pretty}
.page-hero .ph-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}

/* photo variant */
.page-hero.photo{background:var(--bg-ink)}
.page-hero.photo image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.page-hero.photo .ph-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(2,8,28,.92) 28%,rgba(2,8,28,.5) 62%,rgba(2,8,28,.25))}

/* ---- Licence ladder ---- */
.ladder{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.rung{background:#fff;border:1px solid var(--border);border-radius:18px;padding:26px 24px;position:relative;overflow:hidden}
.rung .step{font-family:var(--font-display);font-weight:900;font-size:13px;letter-spacing:.1em;color:var(--accent)}
.rung h3{font-family:var(--font-display);font-weight:800;font-size:1.35rem;margin:6px 0 8px;color:var(--fg1)}
.rung p{font-size:14px;line-height:1.55;color:var(--fg3)}
.rung .bar{position:absolute;left:0;bottom:0;height:5px;background:var(--primary);border-radius:0}
.rung[data-r="1"] .bar{width:25%;background:var(--fct-cyan-300)}
.rung[data-r="2"] .bar{width:50%;background:var(--fct-cyan-400)}
.rung[data-r="3"] .bar{width:75%;background:var(--fct-cyan-500)}
.rung[data-r="4"] .bar{width:100%;background:var(--fct-cyan-600)}

/* ---- Course list rows ---- */
.course-cats{display:flex;flex-direction:column;gap:48px}
.course-cat h2{font-family:var(--font-display);font-weight:800;font-size:2rem;letter-spacing:-.02em;margin-bottom:6px}
.course-cat .cat-sub{font-size:15px;color:var(--fg3);margin-bottom:24px}
.course-list{display:flex;flex-direction:column;gap:16px}
.course-row{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:20px;padding:26px 30px;transition:transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s,border-color .2s}
.course-row:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--fct-cyan-200)}
.course-row .dur{display:flex;flex-direction:column;align-items:center;justify-content:center;width:104px;height:104px;border-radius:18px;background:var(--fct-cyan-050);flex:none}
.course-row .dur .n{font-family:var(--font-display);font-weight:900;font-size:2.6rem;line-height:.85;color:var(--primary);letter-spacing:-.02em}
.course-row .dur .u{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--primary-press);margin-top:6px}
.course-row .info h3{font-family:var(--font-display);font-weight:700;font-size:1.4rem;margin-bottom:8px;color:var(--fg1)}
.course-row .info p{font-size:15px;line-height:1.6;color:var(--fg3);font-weight:450;max-width:640px}
.course-row .info .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.course-row .info .ctag{font-size:12px;font-weight:700;color:var(--fg2);background:var(--bg-muted);padding:5px 11px;border-radius:999px}
.course-row .go{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;border:1.5px solid var(--border-strong);color:var(--primary);flex:none;transition:all .2s}
.course-row:hover .go{background:var(--primary);border-color:var(--primary);color:#fff}
.course-row .go .lic{width:20px;height:20px}

/* ---- Requirement chips ---- */
.req-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.req{background:#fff;border:1px solid var(--border);border-radius:18px;padding:26px}
.req .ic{width:46px;height:46px;border-radius:13px;background:var(--fct-cyan-050);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.req .ic .lic{width:23px;height:23px;color:var(--primary)}
.req h4{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-bottom:6px}
.req p{font-size:13.5px;line-height:1.55;color:var(--fg3)}

/* ---- Enquiry form panel ---- */
.enquire{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border-radius:28px;overflow:hidden;box-shadow:var(--shadow-lg)}
.enquire .side{background:linear-gradient(155deg,var(--fct-cyan-600),var(--bg-ink));color:#fff;padding:52px 46px;position:relative;overflow:hidden}
.enquire .side .glow{position:absolute;top:-80px;right:-80px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(47,193,211,.4),transparent 70%)}
.enquire .side h2{font-family:var(--font-display);font-weight:900;font-stretch:110%;text-transform:uppercase;font-size:2.2rem;line-height:1;letter-spacing:-.02em;position:relative}
.enquire .side p{font-size:15.5px;line-height:1.6;color:var(--fg-on-dark-soft);margin-top:18px;position:relative}
.enquire .side ul{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:14px;position:relative}
.enquire .side li{display:flex;gap:12px;align-items:center;font-size:15px;font-weight:600}
.enquire .side li .lic{width:20px;height:20px;color:var(--accent);flex:none}
.enquire .form{background:#fff;padding:46px}

/* ---- Product / shop grid ---- */
.shop-cat-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px;justify-content:center}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product{background:#fff;border:1px solid var(--border);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s}
.product:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.product .pic{width:100%;aspect-ratio:4/3;background:var(--bg-muted);position:relative}
.product .pic image-slot{width:100%;height:100%}
.product .pbadge{position:absolute;top:12px;left:12px;background:var(--fg1);color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:5px 11px;border-radius:999px;z-index:3}
.product .pbody{padding:20px;display:flex;flex-direction:column;flex:1}
.product .cat{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary)}
.product h3{font-family:var(--font-display);font-weight:700;font-size:1.2rem;margin:5px 0 6px;color:var(--fg1)}
.product p{font-size:13px;line-height:1.5;color:var(--fg3);flex:1}
.product .prow{display:flex;align-items:center;justify-content:space-between;margin-top:18px}
.product .price{font-family:var(--font-display);font-weight:900;font-size:1.5rem;color:var(--fg1);letter-spacing:-.02em}
.product .price .cur{font-size:.85rem;color:var(--fg3);vertical-align:super}
.product .price.poa{font-size:1.1rem;color:var(--primary)}
.product .add{width:42px;height:42px;border-radius:50%;background:var(--fct-cyan-050);color:var(--primary);display:flex;align-items:center;justify-content:center;transition:all .2s}
.product .add:hover{background:var(--primary);color:#fff}
.product .add .lic{width:20px;height:20px}

/* ---- Tours ---- */
.tour-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tour{border-radius:22px;overflow:hidden;position:relative;min-height:380px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.tour image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.tour .tscrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 35%,rgba(2,8,28,.9))}
.tour .tbody{position:relative;z-index:2;padding:28px}
.tour .tkicker{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}
.tour h3{font-family:var(--font-display);font-weight:800;font-size:1.5rem;margin:8px 0 8px}
.tour p{font-size:14px;line-height:1.55;color:rgba(255,255,255,.85)}

/* ---- About ---- */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-split image-slot{width:100%;height:520px}
.about-split h2{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,3.5vw,2.8rem);letter-spacing:-.02em;line-height:1.08;margin-bottom:22px}
.about-split p{font-size:16.5px;line-height:1.7;color:var(--fg2);margin-bottom:16px}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value{padding:6px}
.value .ic{width:54px;height:54px;border-radius:15px;background:rgba(47,193,211,.16);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.value .ic .lic{width:27px;height:27px;color:var(--accent)}
.value h3{font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-bottom:10px;color:#fff}
.value p{font-size:14.5px;line-height:1.6;color:var(--fg-on-dark-soft)}

/* ---- Blog ---- */
.blog-feature{display:grid;grid-template-columns:1.3fr 1fr;gap:0;border:1px solid var(--border);border-radius:24px;overflow:hidden;margin-bottom:40px;background:#fff}
.blog-feature image-slot{width:100%;height:100%;min-height:380px}
.blog-feature .bf-body{padding:48px}
.blog-feature .bcat{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--primary)}
.blog-feature h2{font-family:var(--font-display);font-weight:800;font-size:2.2rem;line-height:1.1;letter-spacing:-.02em;margin:12px 0 16px}
.blog-feature p{font-size:16px;line-height:1.65;color:var(--fg2);margin-bottom:24px}
.blog-meta{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--fg3);font-weight:600}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.bpost{display:flex;flex-direction:column;cursor:pointer}
.bpost .bpic{width:100%;aspect-ratio:16/10;border-radius:16px;overflow:hidden;margin-bottom:18px}
.bpost .bpic image-slot{width:100%;height:100%}
.bpost .bcat{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary)}
.bpost h3{font-family:var(--font-display);font-weight:700;font-size:1.35rem;line-height:1.2;margin:8px 0 10px;color:var(--fg1);transition:color .2s}
.bpost:hover h3{color:var(--primary)}
.bpost p{font-size:14px;line-height:1.55;color:var(--fg3);margin-bottom:14px}

/* ---- Contact strip (shared footer-of-page CTA) ---- */
.info-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
.info-card{display:flex;gap:16px;align-items:flex-start;background:var(--bg-subtle);border:1px solid var(--border);border-radius:18px;padding:24px}
.info-card .ic{width:46px;height:46px;border-radius:13px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex:none}
.info-card .ic .lic{width:22px;height:22px;color:var(--primary)}
.info-card .it{font-weight:700;font-size:14px;color:var(--fg1);margin-bottom:3px}
.info-card .iv{font-size:14px;color:var(--fg3);line-height:1.5}

@media (max-width:920px){
  .ladder,.req-grid,.product-grid,.value-grid,.info-bar{grid-template-columns:1fr 1fr}
  .course-row{grid-template-columns:auto 1fr;gap:18px}
  .course-row .go{display:none}
  .enquire,.about-split,.blog-feature,.tour-grid,.blog-grid{grid-template-columns:1fr}
  .about-split image-slot{height:340px}
}


/* ===== Responsive layer — phone (screens.css selectors) ===== */
@media (max-width:640px){
  .page-hero{padding:104px 20px 48px}
  .ladder,.req-grid,.value-grid,.info-bar,.product-grid{grid-template-columns:1fr}
  .course-row{grid-template-columns:1fr;text-align:center;gap:16px;padding:24px}
  .course-row .dur{margin:0 auto}
  .course-row .info .tags{justify-content:center}
  .enquire .side,.enquire .form{padding:34px 22px}
  .blog-feature .bf-body{padding:30px 22px}
  .blog-feature image-slot{min-height:240px}
  .tour{min-height:320px}
  .about-split{gap:36px}
  .about-split image-slot{height:300px}
  .blog-meta{flex-wrap:wrap}
  .bpost .bpic{aspect-ratio:16/9}
}
