/* =============================================================
   SSM Theme — Main Stylesheet
   Lumos Digital · lumosdigital.co.uk
   ============================================================= */

/* Google Fonts loaded via non-blocking <link> tags in header.php */

/* ─── RESET & ROOT ─── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --blue:     #2979ff;
  --blue-d:   #1a5fd4;
  --blue-lt:  #e8f0ff;
  --dark:     #1a1a1a;
  --mid:      #3d3d3d;
  --subtle:   #717171;
  --rule:     #e4e4e4;
  --bg:       #ffffff;
  --bg2:      #f6f7f9;
  --bg3:      #eeeff1;
  --green:    #18a05a;
  --fh:       'Bebas Neue', sans-serif;
  --fb:       'DM Sans', sans-serif;
  --fm:       'Space Mono', monospace;
  --nav-h:    64px;
  --r:        6px;
  --sh:       0 2px 16px rgba(0,0,0,0.08);
  --sh2:      0 8px 40px rgba(0,0,0,0.13);
  --max:      1160px;
}

html { font-size: 16px; scroll-behavior: smooth; }
body { background: var(--bg); color: var(--dark); font-family: var(--fb); font-weight: 400; line-height: 1.6; overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }

/* ─── ANIMATIONS ─── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
/* scroll reveal — rules injected by main.js so elements degrade gracefully without JS */

/* ─── NAV ─── */
nav.ssm-nav {
  position: sticky; top: 0; z-index: 100;
  height: var(--nav-h);
  background: var(--dark);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 2.5rem;
  box-shadow: 0 2px 12px rgba(0,0,0,0.25);
}
.nav-logo { font-family: var(--fh); font-size: 1.55rem; letter-spacing: 0.04em; color: #fff; }
.nav-logo span { color: var(--blue); }
.nav-links-wrap { display: flex; align-items: center; gap: 2rem; }
.nav-links-wrap ul.nav-menu { display: flex; gap: 2rem; list-style: none; margin: 0; padding: 0; }
.nav-links-wrap ul.nav-menu li a { color: rgba(255,255,255,0.68); font-size: 0.85rem; font-weight: 500; transition: color 0.2s; }
.nav-links-wrap ul.nav-menu li a:hover,
.nav-links-wrap ul.nav-menu li.current-menu-item a { color: #fff; }
.nav-right { display: flex; align-items: center; gap: 1.75rem; }
.nav-phone { text-align: right; line-height: 1.3; }
.nav-phone span { display: block; font-family: var(--fm); font-size: 0.6rem; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.4); }
.nav-phone strong { font-family: var(--fm); font-size: 0.9rem; color: #fff; font-weight: 700; }
.nav-cta { background: var(--blue); color: #fff; font-weight: 700; font-size: 0.82rem; padding: 0.65rem 1.35rem; border-radius: var(--r); transition: background 0.15s, transform 0.1s; white-space: nowrap; display: inline-block; }
.nav-cta:hover { background: var(--blue-d); transform: translateY(-1px); color: #fff; }
.nav-toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 4px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: #fff; transition: 0.3s; }

/* ─── DROPDOWN MENUS ─── */
.nav-menu li.menu-item-has-children { position: relative; }
.nav-menu li.menu-item-has-children > a::after {
  content: '';
  display: inline-block;
  margin-left: 5px;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid rgba(255,255,255,0.55);
  vertical-align: middle;
  transition: transform 0.2s;
}
.nav-menu li.menu-item-has-children:hover > a::after { border-top-color: #fff; }
.nav-chevron { display: none; }
.nav-menu .sub-menu {
  display: none;
  position: absolute;
  top: 100%;           /* flush — no gap, no dead zone */
  left: 50%;
  transform: translateX(-50%);
  min-width: 230px;
  background: var(--dark);
  border-top: 2px solid var(--blue);
  border-radius: 0 0 var(--r) var(--r);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  z-index: 9999;
  list-style: none;
  padding: 0.4rem 0 0.6rem;
  margin: 0;
}
/* Bridge: a thin invisible extension above the dropdown catches the mouse
   as it travels from the nav link down into the sub-menu */
.nav-menu .sub-menu::before {
  content: '';
  position: absolute;
  top: -8px;
  left: 0;
  right: 0;
  height: 8px;
}
.nav-menu li.menu-item-has-children:hover > .sub-menu,
.nav-menu li.menu-item-has-children:focus-within > .sub-menu { display: block; }
.nav-menu .sub-menu li a {
  display: block;
  padding: 0.65rem 1.35rem;
  font-size: 0.83rem;
  color: rgba(255,255,255,0.7);
  white-space: nowrap;
  transition: color 0.15s, background 0.15s;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.nav-menu .sub-menu li:last-child a { border-bottom: none; }
.nav-menu .sub-menu li a:hover { color: #fff; background: rgba(255,255,255,0.08); padding-left: 1.6rem; }
/* Mobile — sub-menus hidden by default, toggled via JS */
@media (max-width: 900px) {
  .nav-menu li.menu-item-has-children > a::after { display: none; }
  .nav-menu li.menu-item-has-children > a { display: flex; align-items: center; justify-content: space-between; }
  .nav-menu li.menu-item-has-children > a .nav-chevron {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px; flex-shrink: 0;
    border: 1px solid rgba(255,255,255,0.15); border-radius: 4px;
    font-size: 0.7rem; color: rgba(255,255,255,0.6); transition: transform 0.25s;
  }
  .nav-menu li.menu-item-has-children.open > a .nav-chevron { transform: rotate(180deg); color: var(--blue); border-color: var(--blue); }
  .nav-menu .sub-menu { position: static; transform: none; box-shadow: none; border-top: none; border-left: 2px solid var(--blue); margin: 0 0 0.5rem 1rem; padding: 0; background: transparent; display: none; }
  .nav-menu li.menu-item-has-children.open > .sub-menu { display: block; }
  .nav-menu .sub-menu li a { padding: 0.6rem 0.85rem; font-size: 0.82rem; border-bottom: 1px solid rgba(255,255,255,0.05); }
  .nav-menu .sub-menu li a:hover { padding-left: 0.85rem; background: rgba(255,255,255,0.04); }
  .nav-menu .sub-menu::before { display: none; }
}

/* ─── TRUST BAR ─── */
.trust-bar {
  background: var(--blue);
  padding: 0.55rem 0;
  overflow: hidden;
}
.trust-track {
  display: flex;
  width: max-content;
  animation: ticker 32s linear infinite;
}
.trust-track:hover { animation-play-state: paused; }
.trust-item {
  display: flex; align-items: center; gap: 0.5rem;
  white-space: nowrap; font-size: 0.79rem; font-weight: 600;
  color: #fff; padding: 0 2.25rem;
  border-right: 1px solid rgba(255,255,255,0.2);
}
.trust-item:last-child { border-right: none; }
.trust-tick { width: 16px; height: 16px; background: rgba(255,255,255,0.25); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.55rem; flex-shrink: 0; color: #fff; }
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─── BUTTONS ─── */
.btn-primary { background: var(--blue); color: #fff; font-weight: 700; font-size: 0.95rem; padding: 0.9rem 2rem; border-radius: var(--r); border: 2px solid var(--blue); display: inline-block; transition: background 0.15s, transform 0.1s; }
.btn-primary:hover { background: var(--blue-d); border-color: var(--blue-d); transform: translateY(-1px); color: #fff; }
.btn-outline { color: var(--dark); font-weight: 600; font-size: 0.92rem; padding: 0.88rem 1.75rem; border-radius: var(--r); border: 2px solid var(--dark); display: inline-block; transition: all 0.15s; }
.btn-outline:hover { background: var(--dark); color: #fff; }
.btn-white { background: #fff; color: var(--blue); font-weight: 700; font-size: 1rem; padding: 1rem 2.25rem; border-radius: var(--r); display: inline-block; transition: background 0.15s; white-space: nowrap; }
.btn-white:hover { background: #f0f5ff; color: var(--blue); }
.btn-dark { background: var(--dark); color: #fff; font-weight: 700; font-size: 0.95rem; padding: 0.9rem 2rem; border-radius: var(--r); display: inline-block; transition: background 0.15s; }
.btn-dark:hover { background: #333; color: #fff; }
.btn-sm { font-size: 0.88rem; padding: 0.75rem 1.5rem; }

/* ─── HERO V2 — Compact, above-the-fold ─── */
.hero { background: var(--bg2); border-bottom: 3px solid var(--blue); padding: 2.5rem 0 3rem; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; background: var(--blue-lt); color: var(--blue-d); font-family: var(--fm); font-size: 0.66rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.35rem 0.9rem; border-radius: 2px; margin-bottom: 1rem; border: 1px solid rgba(41,121,255,0.2); }
.rating-stars { color: #f59e0b; font-size: 0.9rem; letter-spacing: 0.04em; }

/* Top section — eyebrow + H1 only (no sub copy, no rating line) */
.hero-v2-top { text-align: center; margin-bottom: 1.75rem; }
.hero-v2-h1 { font-family: var(--fh); font-size: clamp(2.4rem, 6vw, 4.5rem); line-height: 0.98; color: var(--dark); margin: 0; letter-spacing: 0.01em; }

/* 3-card pricing row — compact */
.hero-v2-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-bottom: 1rem; }

.hero-v2-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.4rem 1.4rem 1.25rem; display: flex; flex-direction: column; position: relative; transition: box-shadow 0.2s, transform 0.2s; }
.hero-v2-card:hover { box-shadow: var(--sh2); transform: translateY(-2px); }
.hero-v2-card-featured { border-color: var(--blue); border-width: 2px; box-shadow: 0 6px 24px rgba(41,121,255,0.13); }
.hero-v2-card-featured::before { content: 'Most Popular'; position: absolute; top: -11px; left: 50%; transform: translateX(-50%); background: var(--blue); color: #fff; font-family: var(--fm); font-size: 0.58rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.22rem 0.85rem; border-radius: 20px; white-space: nowrap; box-shadow: 0 2px 8px rgba(41,121,255,0.3); }

.hero-v2-card-badge { font-family: var(--fm); font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--subtle); margin-bottom: 0.35rem; }
.hero-v2-card-name { font-family: var(--fh); font-size: 1.55rem; color: var(--dark); line-height: 1; margin-bottom: 0.55rem; letter-spacing: 0.01em; }

.hero-v2-card-price-row { display: flex; align-items: baseline; gap: 0.3rem; margin-bottom: 0.85rem; }
.hero-v2-card-price { font-family: var(--fh); font-size: 2.3rem; line-height: 1; color: var(--dark); }
.hero-v2-card-period { font-size: 0.72rem; color: var(--subtle); }

/* Capacity block — emphasised "Up to N items" between price and free-boxes line */
.hero-v2-card-capacity {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--bg2);
    border: 1.5px solid var(--rule);
    border-radius: 8px;
    padding: 0.7rem 0.85rem;
    margin-bottom: 0.85rem;
    transition: background 0.15s, border-color 0.15s;
}
.hero-v2-card-capacity-text {
    flex: 1;
    font-family: var(--fh);
    font-size: 1rem;
    line-height: 1.15;
    color: var(--dark);
    letter-spacing: 0.01em;
}
.hero-v2-card-featured .hero-v2-card-capacity {
    background: var(--blue-lt);
    border-color: rgba(41,121,255,0.25);
}
.hero-v2-card-featured .hero-v2-card-capacity-text { color: var(--blue-d); }

.hero-v2-card-incl { font-size: 0.72rem; font-weight: 600; color: var(--green); display: flex; align-items: center; gap: 0.35rem; margin-bottom: 0.85rem; padding-bottom: 0.85rem; border-bottom: 1px solid var(--bg3); }
.hero-v2-card-incl i { font-size: 0.65rem; }

.hero-v2-card-features { list-style: none; margin: 0 0 1rem; padding: 0; flex: 1; }
.hero-v2-card-features li { display: flex; align-items: flex-start; gap: 0.45rem; font-size: 0.78rem; color: var(--mid); padding: 0.32rem 0; line-height: 1.4; }
.hero-v2-card-features li > i.fa-check { color: var(--green); font-size: 0.65rem; flex-shrink: 0; margin-top: 4px; }
.hero-v2-feature-text { flex: 1; }

/* Tooltip — appears next to the "Up to X items" line, hover/tap reveals examples */
.hero-v2-tooltip { position: relative; display: inline-flex; align-items: center; flex-shrink: 0; cursor: help; outline: none; padding: 0 0.15rem; }
.hero-v2-tooltip > i { color: var(--blue); font-size: 0.85rem; opacity: 0.55; transition: opacity 0.15s; margin-top: 1px; }
.hero-v2-tooltip:hover > i,
.hero-v2-tooltip:focus > i,
.hero-v2-tooltip:focus-within > i { opacity: 1; }
.hero-v2-tooltip-content {
    position: absolute;
    bottom: calc(100% + 8px);
    right: -8px;
    background: var(--dark);
    color: #fff;
    font-size: 0.74rem;
    line-height: 1.45;
    padding: 0.6rem 0.8rem;
    border-radius: 6px;
    width: 220px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.18);
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.15s, transform 0.15s;
    z-index: 5;
    font-weight: 400;
    text-align: left;
}
/* Triangle pointer */
.hero-v2-tooltip-content::after {
    content: '';
    position: absolute;
    top: 100%;
    right: 14px;
    border: 6px solid transparent;
    border-top-color: var(--dark);
}
.hero-v2-tooltip:hover .hero-v2-tooltip-content,
.hero-v2-tooltip:focus .hero-v2-tooltip-content,
.hero-v2-tooltip:focus-within .hero-v2-tooltip-content {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
/* Mobile: tooltip stays open via focus until tapped elsewhere */
@media (max-width: 768px) {
    .hero-v2-tooltip-content { width: 200px; right: -4px; font-size: 0.78rem; }
}

.hero-v2-card-btn { display: block; text-align: center; background: var(--bg2); color: var(--dark); font-weight: 700; font-size: 0.85rem; padding: 0.75rem; border-radius: var(--r); border: 2px solid var(--rule); text-decoration: none; transition: all 0.15s; margin-top: auto; }
.hero-v2-card-btn:hover { background: var(--bg3); border-color: #bbb; color: var(--dark); }
.hero-v2-card-featured .hero-v2-card-btn { background: var(--blue); color: #fff; border-color: var(--blue); }
.hero-v2-card-featured .hero-v2-card-btn:hover { background: var(--blue-d); border-color: var(--blue-d); }

/* Bespoke quote banner — compact */
.hero-v2-bespoke { display: flex; align-items: center; gap: 1rem; background: var(--dark); color: #fff; border-radius: 10px; padding: 0.85rem 1.5rem; text-decoration: none; margin-bottom: 1rem; transition: background 0.15s; }
.hero-v2-bespoke:hover { background: #2a2a2a; color: #fff; }
.hero-v2-bespoke-icon { font-size: 1.1rem; color: var(--blue); flex-shrink: 0; width: 34px; height: 34px; background: rgba(41,121,255,0.15); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.hero-v2-bespoke-text { flex: 1; font-size: 0.85rem; line-height: 1.4; }
.hero-v2-bespoke-text strong { display: block; font-size: 0.95rem; margin-bottom: 0.1rem; font-family: var(--fh); letter-spacing: 0.01em; font-weight: 400; }
.hero-v2-bespoke-arrow { font-size: 0.9rem; color: rgba(255,255,255,0.5); flex-shrink: 0; }

/* USP tablet row — equal-width 5 across, full container width */
.hero-v2-usp-tablets { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.6rem; margin-bottom: 1rem; width: 100%; }
.hero-v2-usp { background: #fff; border: 1.5px solid var(--rule); border-radius: 8px; padding: 0.7rem 0.6rem; display: flex; align-items: center; gap: 0.55rem; text-align: left; transition: border-color 0.2s, box-shadow 0.2s; min-height: 56px; }
.hero-v2-usp:hover { border-color: var(--blue); box-shadow: 0 2px 8px rgba(41,121,255,0.08); }
.hero-v2-usp-icon { width: 30px; height: 30px; background: var(--blue-lt); color: var(--blue); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.82rem; flex-shrink: 0; }
.hero-v2-usp-text { font-size: 0.74rem; font-weight: 600; color: var(--dark); line-height: 1.25; }
/* Highlighted USP tablet (e.g. 5-star rating) */
.hero-v2-usp-highlight { background: linear-gradient(135deg, #fff7e6 0%, #fff 100%); border-color: #fbbf24; }
.hero-v2-usp-highlight .hero-v2-usp-icon { background: #fef3c7; color: #f59e0b; }
.hero-v2-usp-highlight:hover { border-color: #f59e0b; box-shadow: 0 2px 8px rgba(245,158,11,0.15); }

/* Footer message + T&Cs — compact */
.hero-v2-footer-msg { text-align: center; margin-top: 0.25rem; }
.hero-v2-incl-msg { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--subtle); line-height: 1.6; margin: 0 0 0.25rem; }
.hero-v2-tcs { font-size: 0.66rem; color: var(--subtle); opacity: 0.7; font-style: italic; margin: 0; }

/* ─── BOOKING CARD (used on University pages) ─── */
.hero-booking-card { background: #fff; border-radius: 12px; box-shadow: var(--sh2); border-top: 4px solid var(--blue); position: sticky; top: calc(var(--nav-h) + 1.5rem); overflow: hidden; }
.hbc-header { padding: 1.5rem 1.75rem 1.25rem; border-bottom: 1px solid var(--rule); }
.hbc-title { font-family: var(--fh); font-size: 1.65rem; color: var(--dark); letter-spacing: 0.02em; margin-bottom: 0.2rem; }
.hbc-sub { font-size: 0.8rem; color: var(--subtle); }
.hbc-section-label { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--subtle); padding: 1.25rem 1.75rem 0.75rem; }
.hbc-tiers { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; border-bottom: 1px solid var(--rule); }
.hbc-tier { display: flex; flex-direction: column; align-items: center; padding: 1rem 0.5rem; border-right: 1px solid var(--rule); text-align: center; text-decoration: none; color: inherit; transition: background 0.15s; cursor: pointer; }
.hbc-tier:last-child { border-right: none; }
.hbc-tier:hover { background: var(--bg2); }
.hbc-tier.hbc-tier-featured { background: var(--blue); color: #fff; }
.hbc-tier.hbc-tier-featured:hover { background: var(--blue-d); }
.hbc-tier-name { font-family: var(--fm); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: inherit; opacity: 0.7; margin-bottom: 0.3rem; }
.hbc-tier.hbc-tier-featured .hbc-tier-name { opacity: 0.8; }
.hbc-tier-price { font-family: var(--fh); font-size: 1.5rem; line-height: 1; color: inherit; letter-spacing: 0.01em; }
.hbc-tier-price span { font-family: var(--fb); font-size: 0.62rem; font-weight: 400; opacity: 0.7; }
.hbc-tier-desc { font-size: 0.66rem; color: inherit; opacity: 0.65; margin-top: 0.25rem; line-height: 1.3; }
.hbc-btn-primary { display: flex; align-items: center; justify-content: center; gap: 0.6rem; width: calc(100% - 3.5rem); margin: 1.25rem 1.75rem 0.75rem; background: var(--blue); color: #fff; font-weight: 700; font-size: 1rem; padding: 1rem; border-radius: var(--r); text-decoration: none; transition: background 0.15s; }
.hbc-btn-primary:hover { background: var(--blue-d); color: #fff; }
.hbc-btn-call { display: flex; align-items: center; justify-content: center; gap: 0.6rem; width: calc(100% - 3.5rem); margin: 0 1.75rem 1.25rem; background: #fff; color: var(--dark); font-weight: 600; font-size: 0.95rem; padding: 0.9rem; border-radius: var(--r); text-decoration: none; border: 2px solid var(--rule); transition: all 0.15s; }
.hbc-btn-call:hover { border-color: var(--dark); color: var(--dark); }
.hbc-trust { padding: 1rem 1.75rem; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); display: flex; flex-direction: column; gap: 0.45rem; }
.hbc-trust-item { display: flex; align-items: center; gap: 0.55rem; font-size: 0.84rem; color: var(--mid); }
.hbc-trust-item i { color: var(--green); font-size: 0.75rem; flex-shrink: 0; }
.hbc-stars { padding: 1rem 1.75rem; text-align: center; }
.hbc-stars-row { color: #f59e0b; font-size: 0.95rem; letter-spacing: 0.06em; display: block; margin-bottom: 0.2rem; }
.hbc-stars-label { font-size: 0.75rem; color: var(--subtle); }

/* ─── FORM FIELDS (used on booking/contact pages) ─── */
.fg { margin-bottom: 1rem; }
.fg label { display: block; font-size: 0.77rem; font-weight: 600; color: var(--mid); margin-bottom: 0.3rem; }
.fg input, .fg select, .fg textarea { width: 100%; padding: 0.7rem 0.9rem; border: 1.5px solid var(--rule); border-radius: var(--r); font-family: var(--fb); font-size: 0.9rem; color: var(--dark); background: #fff; transition: border-color 0.2s; -webkit-appearance: none; }
.fg input:focus, .fg select:focus, .fg textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(41,121,255,0.12); }
.fr { display: grid; grid-template-columns: 1fr 1fr; gap: 0.85rem; }
.btn-form { width: 100%; background: var(--blue); color: #fff; font-weight: 700; font-size: 1rem; padding: 0.95rem; border: none; border-radius: var(--r); cursor: pointer; margin-top: 0.25rem; transition: background 0.15s; }
.btn-form:hover { background: var(--blue-d); }

/* ─── STATS BAND ─── */
.stats-band { background: var(--dark); padding: 2.75rem 2.5rem; }
.stats-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; text-align: center; }
.stat-num { font-family: var(--fh); font-size: 3rem; color: var(--blue); line-height: 1; margin-bottom: 0.2rem; }
.stat-label { font-size: 0.85rem; color: rgba(255,255,255,0.55); font-weight: 400; }

/* ─── SECTION BASE ─── */
.ssm-section { padding: 5.5rem 2.5rem; }
.ssm-section-alt { background: var(--bg2); }
.con { max-width: var(--max); margin: 0 auto; }
.section-label { font-family: var(--fm); font-size: 0.67rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--subtle); margin-bottom: 0.7rem; }
.section-title { font-family: var(--fh); font-size: clamp(2.2rem, 4.5vw, 3.8rem); line-height: 0.97; color: var(--dark); margin-bottom: 0.9rem; letter-spacing: 0.01em; }
.section-sub { font-size: 1rem; color: var(--subtle); max-width: 52ch; line-height: 1.75; margin-bottom: 3.5rem; }
.section-header-row { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 1rem; margin-bottom: 3rem; }

/* ─── HOW IT WORKS ─── */
.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); border: 1.5px solid var(--rule); border-radius: 8px; overflow: hidden; }
.step-card { padding: 2.25rem 1.75rem; border-right: 1.5px solid var(--rule); background: #fff; transition: background 0.2s; }
.step-card:last-child { border-right: none; }
.step-card:hover { background: var(--bg2); }
.step-num { font-family: var(--fh); font-size: 2.75rem; color: var(--blue); line-height: 1; margin-bottom: 0.85rem; }
.step-title { font-family: var(--fh); font-size: 1.3rem; color: var(--dark); margin-bottom: 0.45rem; letter-spacing: 0.02em; }
.step-body { font-size: 0.86rem; color: var(--subtle); line-height: 1.65; }
.step-tag { display: inline-block; margin-top: 1rem; background: var(--blue-lt); color: var(--blue-d); font-family: var(--fm); font-size: 0.59rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.22rem 0.65rem; border-radius: 2px; }

/* ─── PRICING ─── */
.pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.price-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 2rem; position: relative; transition: box-shadow 0.2s; display: flex; flex-direction: column; }
.price-card:hover { box-shadow: var(--sh2); }
.price-card.featured { border-color: var(--blue); border-width: 2px; box-shadow: var(--sh2); }
.price-card.featured::before { content: 'Most Popular'; position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--blue); color: #fff; font-family: var(--fm); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.25rem 0.9rem; border-radius: 20px; white-space: nowrap; }
.price-badge { font-family: var(--fm); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--subtle); margin-bottom: 0.65rem; }
.price-name { font-family: var(--fh); font-size: 1.5rem; color: var(--dark); margin-bottom: 0.4rem; }
.price-amount-row { display: flex; align-items: baseline; gap: 0.3rem; margin-bottom: 0.2rem; }
.price-big { font-family: var(--fh); font-size: 3.5rem; color: var(--dark); line-height: 1; }
.price-period { font-size: 0.82rem; color: var(--subtle); }
.price-incl { font-size: 0.78rem; color: var(--green); font-weight: 600; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.35rem; }
.price-features { list-style: none; margin-bottom: 1.75rem; flex: 1; }
.price-features li { display: flex; align-items: flex-start; gap: 0.6rem; font-size: 0.86rem; color: var(--mid); padding: 0.42rem 0; border-bottom: 1px solid var(--bg3); }
.price-features li:last-child { border-bottom: none; }
.price-features li .gt { color: var(--green); font-size: 0.78rem; flex-shrink: 0; margin-top: 2px; }
.btn-book { display: block; text-align: center; background: var(--bg2); color: var(--dark); font-weight: 700; font-size: 0.9rem; padding: 0.85rem; border-radius: var(--r); border: 2px solid var(--rule); transition: all 0.15s; margin-top: auto; }
.btn-book:hover { background: var(--bg3); border-color: #bbb; color: var(--dark); }
.price-card.featured .btn-book { background: var(--blue); color: #fff; border-color: var(--blue); }
.price-card.featured .btn-book:hover { background: var(--blue-d); border-color: var(--blue-d); }
.beat-bar { margin-top: 2rem; background: var(--dark); border-radius: 8px; padding: 1.4rem 2rem; display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; }
.beat-bar strong { font-family: var(--fh); font-size: 1.45rem; color: var(--blue); letter-spacing: 0.02em; flex-shrink: 0; }
.beat-bar p { font-size: 0.87rem; color: rgba(255,255,255,0.65); flex: 1; min-width: 180px; }

/* ─── WHY US ─── */
.why-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.why-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.75rem; transition: box-shadow 0.2s, border-color 0.2s; }
.why-card:hover { box-shadow: var(--sh); border-color: #ccc; }
.why-icon { width: 46px; height: 46px; background: var(--blue-lt); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.15rem; margin-bottom: 1rem; color: var(--blue); }
.why-title { font-family: var(--fh); font-size: 1.2rem; color: var(--dark); margin-bottom: 0.35rem; letter-spacing: 0.02em; }
.why-body { font-size: 0.86rem; color: var(--subtle); line-height: 1.65; }

/* ─── UNIVERSITIES ─── */
.unis-section { padding: 3.5rem 2.5rem; border-top: 1.5px solid var(--rule); border-bottom: 1.5px solid var(--rule); background: #fff; }
.unis-label { font-family: var(--fm); font-size: 0.67rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--subtle); margin-bottom: 1.5rem; text-align: center; }
.unis-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.7rem; max-width: var(--max); margin: 0 auto; }
.uni-tag { background: var(--bg2); border: 1.5px solid var(--rule); border-radius: 40px; padding: 0.5rem 1.2rem; font-size: 0.87rem; font-weight: 500; color: var(--mid); transition: all 0.15s; cursor: default; }
.uni-tag:hover { background: var(--blue); border-color: var(--blue); color: #fff; }
.unis-cta { text-align: center; margin-top: 1.25rem; font-size: 0.82rem; color: var(--subtle); }
.unis-cta a { color: var(--blue); font-weight: 600; border-bottom: 1px solid rgba(41,121,255,0.3); }

/* ─── ABOUT / EDITORIAL ─── */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4.5rem; align-items: center; }
.about-img-wrap { position: relative; border-radius: 10px; overflow: hidden; background: var(--bg3); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; font-size: 4rem; color: rgba(0,0,0,0.15); }
.about-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.about-img-badge { position: absolute; bottom: 1rem; left: 1rem; background: var(--blue); color: #fff; font-family: var(--fh); font-size: 1.1rem; padding: 0.5rem 1.1rem; border-radius: 4px; letter-spacing: 0.02em; }
.about-placeholder { font-size: 4rem; color: rgba(0,0,0,0.12); }
.about-body { display: flex; flex-direction: column; gap: 1rem; }
.about-body p { font-size: 0.95rem; color: var(--mid); line-height: 1.8; }
.pull-quote { border-left: 4px solid var(--blue); padding: 0.4rem 0 0.4rem 1.35rem; font-family: var(--fh); font-size: 1.3rem; color: var(--dark); line-height: 1.25; letter-spacing: 0.01em; margin: 0.25rem 0; }
.about-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 0.25rem; }

/* ─── REVIEWS ─── */
.reviews-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.review-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.75rem; }
.review-stars { color: #f59e0b; font-size: 0.85rem; letter-spacing: 0.06em; margin-bottom: 0.75rem; }
.review-text { font-size: 0.9rem; color: var(--mid); line-height: 1.75; margin-bottom: 1rem; font-style: italic; }
.review-author { font-size: 0.8rem; font-weight: 600; color: var(--dark); }
.review-source { font-size: 0.72rem; color: var(--subtle); }
.reviews-footer { margin-top: 2rem; background: var(--bg2); border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.5rem 2rem; display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; }
.reviews-score { text-align: center; flex-shrink: 0; }
.reviews-score-num { font-family: var(--fh); font-size: 3rem; color: var(--dark); line-height: 1; }
.reviews-score-label { font-size: 0.77rem; color: var(--subtle); }
.reviews-score-stars { color: #f59e0b; font-size: 1rem; }

/* ─── BLOG FEED ─── */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.blog-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: box-shadow 0.2s; }
.blog-card:hover { box-shadow: var(--sh2); }
.blog-img-wrap { height: 175px; background: var(--bg3); display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
.blog-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.blog-card:hover .blog-img-wrap img { transform: scale(1.04); }
.blog-img-placeholder { font-size: 2.5rem; color: rgba(0,0,0,0.18); }
.blog-card-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.blog-cat-tag { display: inline-block; background: var(--blue-lt); color: var(--blue-d); font-family: var(--fm); font-size: 0.58rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.2rem 0.6rem; border-radius: 2px; margin-bottom: 0.6rem; }
.blog-title { font-family: var(--fh); font-size: 1.2rem; color: var(--dark); line-height: 1.2; margin-bottom: 0.45rem; letter-spacing: 0.01em; }
.blog-excerpt { font-size: 0.84rem; color: var(--subtle); line-height: 1.65; flex: 1; }
.blog-meta { font-size: 0.74rem; color: var(--subtle); margin-top: 0.8rem; }
.view-all-link { font-size: 0.87rem; font-weight: 600; color: var(--blue); border-bottom: 1.5px solid rgba(41,121,255,0.3); transition: border-color 0.2s; }
.view-all-link:hover { border-color: var(--blue); }

/* ─── CTA BAND ─── */
.cta-band { background: var(--blue); padding: 5.5rem 2.5rem; }
.cta-inner { max-width: var(--max); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 3rem; flex-wrap: wrap; }
.cta-title { font-family: var(--fh); font-size: clamp(2.2rem, 4.5vw, 4.2rem); color: #fff; line-height: 0.97; letter-spacing: 0.01em; max-width: 15ch; }
.cta-actions { display: flex; flex-direction: column; gap: 1rem; align-items: flex-start; flex-shrink: 0; }
.cta-phone { font-family: var(--fh); font-size: 1.7rem; color: rgba(255,255,255,0.9); letter-spacing: 0.02em; border-bottom: 2px solid rgba(255,255,255,0.3); }

/* ─── FOOTER ─── */
.ssm-footer { background: var(--dark); color: #fff; padding: 4.5rem 2.5rem 2rem; }
.footer-inner { max-width: var(--max); margin: 0 auto; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.footer-brand { font-family: var(--fh); font-size: 1.85rem; margin-bottom: 0.75rem; letter-spacing: 0.03em; }
.footer-brand span { color: var(--blue); }
.footer-tagline { font-size: 0.87rem; color: rgba(255,255,255,0.5); line-height: 1.7; max-width: 30ch; margin-bottom: 1.5rem; }
.footer-contact { font-size: 0.85rem; color: rgba(255,255,255,0.55); line-height: 2.1; }
.footer-contact a { color: var(--blue); }
.footer-col-heading { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-bottom: 1rem; }
.footer-links { display: flex; flex-direction: column; gap: 0.6rem; }
.footer-links a { font-size: 0.87rem; color: rgba(255,255,255,0.6); transition: color 0.15s; }
.footer-links a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding-top: 1.5rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.footer-bottom p, .footer-bottom a { font-size: 0.77rem; color: rgba(255,255,255,0.3); }
.footer-bottom div { display: flex; gap: 2rem; }

/* ─── INNER PAGE HERO ─── */
.page-hero { background: var(--bg2); border-bottom: 3px solid var(--blue); padding: 5rem 2.5rem 4rem; margin-top: 0; }
.page-hero-inner { max-width: var(--max); margin: 0 auto; }
.page-hero-eyebrow { font-family: var(--fm); font-size: 0.67rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--blue); margin-bottom: 0.85rem; }
.page-hero h1 { font-family: var(--fh); font-size: clamp(2.8rem, 6vw, 5.5rem); line-height: 0.95; color: var(--dark); max-width: 16ch; }
.page-hero p { font-size: 1.05rem; color: var(--mid); max-width: 52ch; line-height: 1.75; margin-top: 1rem; }

/* ─── SINGLE POST ─── */
.single-hero { background: var(--bg2); border-bottom: 3px solid var(--blue); padding: 4rem 2.5rem; }
.single-hero-inner { max-width: 820px; margin: 0 auto; }
.single-meta { font-family: var(--fm); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--subtle); margin-bottom: 1rem; }
.single-meta a { color: var(--blue); }
.single-hero h1 { font-family: var(--fh); font-size: clamp(2.5rem, 5vw, 4.5rem); line-height: 0.97; color: var(--dark); }
.single-featured-img { border-bottom: 1.5px solid var(--rule); }
.single-featured-img img { width: 100%; max-height: 500px; object-fit: cover; }
.single-content-wrap { max-width: 820px; margin: 0 auto; padding: 4rem 2.5rem; }
.entry-content { font-size: 1rem; line-height: 1.85; color: var(--mid); }
.entry-content h2 { font-family: var(--fh); font-size: 2rem; color: var(--dark); margin: 2.5rem 0 0.85rem; letter-spacing: 0.01em; }
.entry-content h3 { font-family: var(--fh); font-size: 1.5rem; color: var(--dark); margin: 2rem 0 0.7rem; }
.entry-content p { margin-bottom: 1.25rem; }
.entry-content a { color: var(--blue); border-bottom: 1px solid rgba(41,121,255,0.3); }
.entry-content img { margin: 2rem 0; border-radius: 8px; border: 1.5px solid var(--rule); }
.entry-content ul, .entry-content ol { margin: 1rem 0 1.25rem 1.5rem; list-style: revert; }
.entry-content li { margin-bottom: 0.4rem; }
.entry-content blockquote { border-left: 4px solid var(--blue); padding-left: 1.5rem; margin: 2rem 0; font-family: var(--fh); font-size: 1.5rem; line-height: 1.2; color: var(--dark); }
.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-top: 3rem; border: 1.5px solid var(--rule); border-radius: 8px; overflow: hidden; }
.post-nav a { padding: 1.5rem 2rem; text-decoration: none; color: inherit; transition: background 0.2s; display: block; }
.post-nav a:first-child { border-right: 1.5px solid var(--rule); }
.post-nav a:hover { background: var(--bg2); }
.post-nav-label { font-family: var(--fm); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--subtle); margin-bottom: 0.4rem; }
.post-nav-title { font-family: var(--fh); font-size: 1.2rem; color: var(--dark); line-height: 1.2; }

/* ─── ARCHIVE ─── */
.archive-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: 3rem; }
.archive-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: box-shadow 0.2s; }
.archive-card:hover { box-shadow: var(--sh2); }
.archive-thumb { height: 200px; background: var(--bg3); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.archive-thumb img { width: 100%; height: 100%; object-fit: cover; }
.archive-thumb i { font-size: 2.5rem; color: rgba(0,0,0,0.18); }
.archive-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }

/* ─── PAGINATION ─── */
.ssm-pagination { display: flex; gap: 0; margin-top: 3rem; }
.ssm-pagination a, .ssm-pagination span { padding: 0.75rem 1.1rem; border: 1.5px solid var(--rule); margin-right: -1.5px; font-family: var(--fm); font-size: 0.68rem; letter-spacing: 0.06em; color: var(--subtle); text-decoration: none; transition: all 0.15s; }
.ssm-pagination a:hover { background: var(--bg2); color: var(--dark); z-index: 1; }
.ssm-pagination .current { background: var(--blue); color: #fff; border-color: var(--blue); z-index: 1; }
.ssm-pagination :first-child { border-radius: var(--r) 0 0 var(--r); }
.ssm-pagination :last-child { border-radius: 0 var(--r) var(--r) 0; }

/* ─── 404 ─── */
.error-404 { max-width: var(--max); margin: 0 auto; padding: 8rem 2.5rem; }
.error-404 h1 { font-family: var(--fh); font-size: clamp(5rem,14vw,14rem); color: var(--bg3); line-height: 1; }
.error-404 p { font-size: 1.1rem; color: var(--mid); margin: 1.5rem 0 2rem; }

/* ─── FAQ ACCORDION ─── */
.faq-list { border: 1.5px solid var(--rule); border-radius: 10px; overflow: hidden; }
details.faq-item { border-bottom: 1.5px solid var(--rule); }
details.faq-item:last-child { border-bottom: none; }
details.faq-item summary { padding: 1.35rem 1.75rem; cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 1rem; font-family: var(--fh); font-size: 1.25rem; color: var(--dark); letter-spacing: 0.01em; background: #fff; transition: background 0.15s; user-select: none; }
details.faq-item summary:hover { background: var(--bg2); }
details.faq-item summary::-webkit-details-marker { display: none; }
.faq-icon { font-size: 0.85rem; color: var(--blue); flex-shrink: 0; width: 24px; height: 24px; background: var(--blue-lt); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: transform 0.25s; }
details[open] .faq-icon { transform: rotate(45deg); }
.faq-answer { padding: 0 1.75rem 1.5rem; font-size: 0.92rem; color: var(--mid); line-height: 1.85; border-top: 1px solid var(--rule); padding-top: 1.25rem; background: #fff; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .hero { padding: 3rem 0 3.5rem; }
  .hero-v2-cards { grid-template-columns: 1fr; gap: 1rem; }
  .hero-v2-card-featured { order: -1; }
  .hero-v2-usp-tablets { grid-template-columns: repeat(3, 1fr); }
  .quote-card { position: static; }
  .stats-inner { grid-template-columns: repeat(2,1fr); }
  .steps-grid { grid-template-columns: 1fr 1fr; }
  .step-card:nth-child(2) { border-right: none; }
  .step-card:nth-child(3) { border-right: 1.5px solid var(--rule); border-top: 1.5px solid var(--rule); }
  .step-card:nth-child(4) { border-right: none; border-top: 1.5px solid var(--rule); }
  .pricing-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .reviews-grid { grid-template-columns: 1fr 1fr; }
  .reviews-grid .review-card:last-child { display: none; }
  .blog-grid { grid-template-columns: 1fr 1fr; }
  .blog-grid .blog-card:last-child { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .archive-grid { grid-template-columns: 1fr; }
  .post-nav { grid-template-columns: 1fr; }
  .post-nav a:first-child { border-right: none; border-bottom: 1.5px solid var(--rule); }
}
@media (max-width: 768px) {
  :root { --nav-h: 60px; }
  .nav-links-wrap, .nav-phone { display: none; }
  .nav-links-wrap.open { display: flex; flex-direction: column; position: absolute; top: var(--nav-h); left: 0; right: 0; background: var(--dark); padding: 1rem 2rem 1.5rem; gap: 0; border-top: 1px solid rgba(255,255,255,0.1); }
  .nav-links-wrap.open ul.nav-menu { flex-direction: column; gap: 0; }
  .nav-links-wrap.open ul.nav-menu li a { display: block; padding: 0.75rem 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .nav-toggle { display: flex; }
  .trust-bar { gap: 0; }
  .trust-item { padding: 0 0.85rem; font-size: 0.72rem; }
  .hero, .ssm-section, .ssm-section.ssm-section-alt { padding-left: 0; padding-right: 0; }
  .hero .con { padding-left: 1.25rem; padding-right: 1.25rem; }
  .hero-v2-usp-tablets { grid-template-columns: repeat(2, 1fr); }
  .hero-v2-bespoke { flex-direction: column; text-align: center; gap: 0.75rem; padding: 1.25rem; }
  .hero-v2-bespoke-arrow { display: none; }
  .ssm-section { padding-top: 4rem; padding-bottom: 4rem; }
  .steps-grid { grid-template-columns: 1fr; }
  .step-card { border-right: none !important; border-top: 1.5px solid var(--rule); }
  .step-card:first-child { border-top: none; }
  .why-grid, .reviews-grid, .blog-grid { grid-template-columns: 1fr; }
  .reviews-grid .review-card:last-child, .blog-grid .blog-card:last-child { display: flex; }
  .stats-inner { grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
  .footer-grid { grid-template-columns: 1fr; }
  .cta-band { padding: 4rem 1.25rem; }
  .cta-inner { flex-direction: column; align-items: flex-start; }
  .page-hero, .single-hero { padding: 3rem 1.25rem; }
  .single-content-wrap { padding: 3rem 1.25rem; }
  .unis-section { padding: 3rem 1.25rem; }
  .ssm-footer { padding: 3.5rem 1.25rem 2rem; }
}

/* ═══════════════════════════════════════════════
   BOOKING WIZARD
═══════════════════════════════════════════════ */
.wizard-nav{background:var(--dark);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,0.25)}
.wizard-nav-logo{font-family:var(--fh);font-size:1.4rem;color:#fff;letter-spacing:0.04em;text-decoration:none}
.wizard-nav-logo span{color:var(--blue)}
.wizard-nav-back{color:rgba(255,255,255,0.6);font-size:0.82rem;display:flex;align-items:center;gap:0.4rem;text-decoration:none;transition:color 0.2s}
.wizard-nav-back:hover{color:#fff}
.wizard-nav-phone{font-family:var(--fm);font-size:0.78rem;color:rgba(255,255,255,0.6)}
.wizard-nav-phone strong{color:#fff}

/* Progress */
.wiz-progress{background:#fff;border-bottom:1px solid var(--rule);padding:1.25rem 2rem}
.wiz-progress-inner{max-width:900px;margin:0 auto;display:flex;align-items:center}
.wiz-dot{display:flex;flex-direction:column;align-items:center;gap:0.35rem;flex:1;position:relative}
.wiz-dot::before{content:'';position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--rule);z-index:0;transition:background 0.3s}
.wiz-dot:last-child::before{display:none}
.wiz-dot-circle{width:28px;height:28px;border-radius:50%;background:#fff;border:2px solid var(--rule);display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:700;font-family:var(--fm);color:var(--subtle);z-index:1;transition:all 0.3s}
.wiz-dot.active .wiz-dot-circle{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-dot.done .wiz-dot-circle{background:var(--green);border-color:var(--green);color:#fff}
.wiz-dot.done::before,.wiz-dot.active::before{background:var(--blue)}
.wiz-dot-label{font-family:var(--fm);font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--subtle);white-space:nowrap;transition:color 0.3s}
.wiz-dot.active .wiz-dot-label{color:var(--blue)}
.wiz-dot.done .wiz-dot-label{color:var(--green)}

/* Layout */
.wiz-wrap{max-width:1080px;margin:0 auto;padding:2.5rem 2rem;display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}
.wiz-main{background:#fff;border-radius:12px;box-shadow:var(--sh);overflow:hidden}
.wiz-step{display:none;padding:2.5rem}
.wiz-step.active{display:block}
.wiz-step-title{font-family:var(--fh);font-size:2rem;color:var(--dark);margin-bottom:0.35rem;letter-spacing:0.01em}
.wiz-step-sub{font-size:0.9rem;color:var(--subtle);margin-bottom:2rem;line-height:1.6}

/* Type toggle */
.wiz-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}
.wiz-type{border:2px solid var(--rule);border-radius:var(--r);padding:1.5rem;text-align:center;cursor:pointer;transition:all 0.2s}
.wiz-type:hover{border-color:#bbb}
.wiz-type.selected{border-color:var(--blue);background:var(--blue-lt)}
.wiz-type i{font-size:2rem;color:var(--subtle);margin-bottom:0.75rem;display:block;transition:color 0.2s}
.wiz-type.selected i{color:var(--blue)}
.wiz-type-name{font-family:var(--fh);font-size:1.2rem;color:var(--dark);margin-bottom:0.2rem;letter-spacing:0.02em}
.wiz-type-sub{font-size:0.78rem;color:var(--subtle)}

/* Duration */
.wiz-duration{margin-bottom:2rem}
.wiz-duration-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.75rem}
.wiz-duration-lhs .wiz-label{font-size:0.88rem;font-weight:600;color:var(--dark);display:block;margin-bottom:0.2rem}
.wiz-duration-lhs .wiz-sublabel{font-size:0.78rem;color:var(--subtle)}
.wiz-dur-badge{background:var(--blue);color:#fff;font-family:var(--fh);font-size:1.3rem;min-width:44px;height:44px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;padding:0 0.5rem;letter-spacing:0.02em}
input[type=range]{width:100%;accent-color:var(--blue);cursor:pointer;margin:0.5rem 0}
.wiz-range-labels{display:flex;justify-content:space-between;font-family:var(--fm);font-size:0.62rem;color:var(--subtle)}

/* Counter rows */
.wiz-counter-list{display:flex;flex-direction:column;gap:0.6rem}
.wiz-counter-row{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 1rem;background:var(--bg2);border-radius:6px;border:1px solid var(--rule)}
.wiz-counter-name{font-size:0.9rem;font-weight:500;color:var(--dark)}
.wiz-counter-sub{font-size:0.74rem;color:var(--subtle)}
.wiz-counter{display:flex;align-items:center}
.wiz-cnt-btn{width:34px;height:34px;border:1.5px solid var(--rule);background:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all 0.15s;color:var(--mid);font-weight:700}
.wiz-cnt-btn:first-child{border-radius:6px 0 0 6px}
.wiz-cnt-btn:last-child{border-radius:0 6px 6px 0}
.wiz-cnt-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-cnt-val{width:38px;height:34px;border-top:1.5px solid var(--rule);border-bottom:1.5px solid var(--rule);border-left:none;border-right:none;display:flex;align-items:center;justify-content:center;font-family:var(--fm);font-size:0.88rem;font-weight:700;background:#fff}

/* Size cards */
.wiz-size-cards{display:flex;flex-direction:column;gap:0.85rem}
.wiz-size-card{border:2px solid var(--rule);border-radius:var(--r);padding:1.1rem 1.25rem;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:1.25rem}
.wiz-size-card:hover{border-color:#bbb}
.wiz-size-card.selected{border-color:var(--blue);background:var(--blue-lt)}
.wiz-size-icon{width:42px;height:42px;background:var(--bg2);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--subtle);flex-shrink:0;transition:all 0.2s}
.wiz-size-card.selected .wiz-size-icon{background:var(--blue);color:#fff}
.wiz-size-name{font-family:var(--fh);font-size:1.1rem;color:var(--dark);letter-spacing:0.02em}
.wiz-size-desc{font-size:0.78rem;color:var(--subtle);margin-top:0.1rem}
.wiz-size-price{font-family:var(--fh);font-size:1.5rem;color:var(--dark);text-align:right;flex-shrink:0;line-height:1}
.wiz-size-price span{display:block;font-family:var(--fb);font-size:0.7rem;color:var(--subtle);font-weight:400}

/* Calendar */
.wiz-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.wiz-cal-month{font-family:var(--fh);font-size:1.5rem;color:var(--dark);letter-spacing:0.02em}
.wiz-cal-btn{width:36px;height:36px;border:1.5px solid var(--rule);background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;color:var(--mid)}
.wiz-cal-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:0.5rem;margin-bottom:0.5rem}
.wiz-day-headers span{text-align:center;font-family:var(--fm);font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--subtle)}
.wiz-date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0.5rem;margin-bottom:1.75rem}
.wiz-date-cell{aspect-ratio:1;border:1.5px solid var(--rule);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;cursor:pointer;transition:all 0.15s;font-weight:500}
.wiz-date-cell:hover{border-color:var(--blue);background:var(--blue-lt);color:var(--blue)}
.wiz-date-cell.selected{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-date-cell.disabled{opacity:0.3;cursor:default;pointer-events:none}
.wiz-date-cell.empty{border:none;cursor:default;pointer-events:none}
.wiz-time-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem}
.wiz-time-slot{border:1.5px solid var(--rule);border-radius:6px;padding:0.75rem;text-align:center;cursor:pointer;transition:all 0.15s}
.wiz-time-slot:hover{border-color:var(--blue);background:var(--blue-lt)}
.wiz-time-slot.selected{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-time-name{font-family:var(--fh);font-size:1.1rem;letter-spacing:0.02em}
.wiz-time-label{font-size:0.72rem;opacity:0.7;margin-top:0.1rem}

/* Confirm */
.wiz-confirm-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--rule)}
.wiz-confirm-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.wiz-confirm-label{font-family:var(--fm);font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--subtle);margin-bottom:0.75rem;display:flex;align-items:center;justify-content:space-between}
.wiz-confirm-label a{color:var(--blue);cursor:pointer;font-size:0.62rem;text-decoration:none}
.wiz-confirm-row{display:flex;justify-content:space-between;font-size:0.9rem;margin-bottom:0.35rem}
.wiz-confirm-check{display:flex;align-items:flex-start;gap:0.65rem;font-size:0.83rem;color:var(--mid);margin-bottom:0.5rem}
.wiz-confirm-check i{color:var(--green);margin-top:2px;flex-shrink:0}

/* Footer buttons */
.wiz-footer{padding:1.75rem 2.5rem;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff}
.wiz-btn-back{color:var(--subtle);font-size:0.88rem;font-weight:500;cursor:pointer;background:none;border:none;display:flex;align-items:center;gap:0.4rem;transition:color 0.2s;padding:0}
.wiz-btn-back:hover{color:var(--dark)}
.wiz-btn-continue{background:var(--blue);color:#fff;font-weight:700;font-size:1rem;padding:0.9rem 2.5rem;border:none;border-radius:6px;cursor:pointer;transition:background 0.15s;display:flex;align-items:center;gap:0.5rem}
.wiz-btn-continue:hover{background:var(--blue-d)}
.wiz-btn-submit{background:var(--green);color:#fff;font-weight:700;font-size:1rem;padding:0.9rem 2.5rem;border:none;border-radius:6px;cursor:pointer;transition:background 0.15s;display:flex;align-items:center;gap:0.5rem}
.wiz-btn-submit:hover{background:#159a52}

/* Success */
.wiz-success{display:none;padding:3.5rem 2.5rem;text-align:center}
.wiz-success.active{display:block}
.wiz-success-icon{width:80px;height:80px;background:#e6f9ef;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--green);margin:0 auto 1.5rem}
.wiz-success-title{font-family:var(--fh);font-size:2.5rem;color:var(--dark);margin-bottom:0.75rem}
.wiz-success-sub{font-size:1rem;color:var(--subtle);max-width:38ch;margin:0 auto 2rem;line-height:1.7}

/* Sidebar */
.wiz-sidebar{position:sticky;top:calc(60px + 1.5rem);display:flex;flex-direction:column;gap:1rem}
.wiz-summary{background:#fff;border-radius:12px;box-shadow:var(--sh);padding:1.5rem;border-top:3px solid var(--blue)}
.wiz-summary-title{font-family:var(--fh);font-size:1.4rem;color:var(--dark);margin-bottom:1.25rem;letter-spacing:0.02em}
.wiz-sum-row{display:flex;justify-content:space-between;padding:0.6rem 0;border-bottom:1px solid var(--rule);font-size:0.88rem}
.wiz-sum-row:last-child{border-bottom:none}
.wiz-sum-lbl{color:var(--subtle)}
.wiz-sum-val{font-weight:600;color:var(--dark)}
.wiz-sum-total{display:flex;justify-content:space-between;align-items:baseline;padding:0.85rem 0 0;margin-top:0.5rem;border-top:2px solid var(--dark)}
.wiz-sum-total-lbl{font-family:var(--fh);font-size:1.2rem;letter-spacing:0.02em}
.wiz-sum-total-val{font-family:var(--fh);font-size:1.6rem;color:var(--blue);letter-spacing:0.02em}
.wiz-sum-note{font-size:0.72rem;color:var(--subtle);margin-top:0.5rem;line-height:1.5}
.wiz-trust{background:#fff;border-radius:12px;box-shadow:var(--sh);padding:1.25rem}
.wiz-trust-row{display:flex;align-items:center;gap:0.65rem;padding:0.5rem 0;font-size:0.84rem;color:var(--mid)}
.wiz-trust-row i{color:var(--green);width:16px;text-align:center;flex-shrink:0}

/* Responsive */
@media(max-width:900px){
  .wiz-wrap{grid-template-columns:1fr}
  .wiz-sidebar{position:static}
  .wiz-time-slots{grid-template-columns:repeat(2,1fr)}
  .wiz-type-toggle{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .wiz-step,.wiz-footer{padding:1.5rem}
  .wiz-type-toggle{grid-template-columns:1fr}
  .wizard-nav-phone{display:none}
}

/* ─── BOOKING CONFIRMED PAGE ─── */
.booking-confirmed-wrap { background: var(--bg2); min-height: 70vh; padding: 4rem 1.5rem; }
.bc-inner { max-width: 640px; margin: 0 auto; }
.bc-icon { font-size: 4rem; color: var(--green); text-align: center; margin-bottom: 1rem; }
.bc-ref { font-family: var(--fm); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--subtle); text-align: center; margin-bottom: 0.5rem; }
.bc-title { font-family: var(--fh); font-size: 3rem; color: var(--dark); text-align: center; margin-bottom: 0.75rem; letter-spacing: 0.02em; }
.bc-sub { font-size: 1rem; color: var(--subtle); text-align: center; max-width: 42ch; margin: 0 auto 2.5rem; line-height: 1.7; }
.bc-summary { background: #fff; border-radius: 10px; box-shadow: var(--sh); padding: 1.75rem; margin-bottom: 2rem; }
.bc-summary-title { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--subtle); margin-bottom: 1rem; }
.bc-row { display: flex; justify-content: space-between; padding: 0.65rem 0; border-bottom: 1px solid var(--rule); font-size: 0.9rem; }
.bc-row span:first-child { color: var(--subtle); }
.bc-row span:last-child { font-weight: 500; color: var(--dark); text-align: right; max-width: 60%; }
.bc-row-total { border-top: 2px solid var(--dark); border-bottom: none; margin-top: 0.25rem; padding-top: 0.85rem; }
.bc-row-total span { font-family: var(--fh); font-size: 1.3rem; letter-spacing: 0.02em; }
.bc-row-total span:last-child { color: var(--blue); }
.bc-next { background: #fff; border-radius: 10px; box-shadow: var(--sh); padding: 1.75rem; margin-bottom: 2rem; }
.bc-next-title { font-family: var(--fh); font-size: 1.4rem; color: var(--dark); margin-bottom: 1.25rem; letter-spacing: 0.02em; }
.bc-step { display: flex; align-items: flex-start; gap: 1rem; padding: 0.85rem 0; border-bottom: 1px solid var(--rule); }
.bc-step:last-child { border-bottom: none; }
.bc-step-icon { width: 36px; height: 36px; background: var(--blue-lt); border-radius: 6px; display: flex; align-items: center; justify-content: center; color: var(--blue); flex-shrink: 0; font-size: 0.95rem; }
.bc-step strong { display: block; font-size: 0.9rem; color: var(--dark); margin-bottom: 0.2rem; }
.bc-step p { font-size: 0.82rem; color: var(--subtle); margin: 0; line-height: 1.6; }
.bc-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.bc-actions .btn-primary, .bc-actions .btn-outline { flex: 1; text-align: center; }

/* ─── BOOKING CONFIRMED — OR DIVIDER ─── */
.bc-step-or { display:flex; align-items:center; gap:0.75rem; margin:0.5rem 0; }
.bc-step-or::before, .bc-step-or::after { content:''; flex:1; height:1px; background:var(--rule); }
.bc-step-or span { font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--subtle); }


/* ═══════════════════════════════════════════════════════
   UNIVERSITY LANDING PAGE
═══════════════════════════════════════════════════════ */

/* Hero override */
/* uni-page-hero — inherits .hero base, adds image overlay variant */
.uni-page-hero { position: relative; }
.uni-page-hero--img { background-size: cover !important; background-position: center !important; }
.uni-page-hero--img .hero-eyebrow { background: rgba(41,121,255,0.25); color: #fff; border-color: rgba(255,255,255,0.25); }
.hero-eyebrow--light { background: rgba(41,121,255,0.25) !important; color: #fff !important; border-color: rgba(255,255,255,0.25) !important; }
.uni-h1--light { color: #fff !important; }
.uni-h1--light span { color: var(--blue) !important; }
.hero-sub--light { color: rgba(255,255,255,0.82) !important; }
.hero-usp--light { color: #fff !important; }
.hero-rating--light { color: rgba(255,255,255,0.65) !important; }
.btn-outline { background: transparent; color: var(--blue); border: 2px solid var(--blue); font-weight: 700; font-size: 0.95rem; padding: 0.9rem 2rem; border-radius: var(--r); display: inline-block; transition: background 0.15s; text-decoration: none; }
.btn-outline:hover { background: var(--blue-lt); color: var(--blue); }
.btn-outline--light { color: #fff !important; border-color: rgba(255,255,255,0.6) !important; }
.btn-outline--light:hover { background: rgba(255,255,255,0.1) !important; }

/* Stats strip */
.uni-stats-bar { background: var(--dark); border-bottom: 3px solid var(--blue); padding: 2.25rem 2.5rem; }
.uni-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; max-width: var(--max); margin: 0 auto; }
.uni-stat-item { text-align: center; padding: 0.5rem; }
.uni-stat-num { font-family: var(--fh); font-size: 2.6rem; color: var(--blue); line-height: 1; letter-spacing: 0.02em; }
.uni-stat-label { font-family: var(--fm); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.55); margin-top: 0.4rem; }

/* About grid */
.uni-about-grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: 4rem; align-items: start; }
.uni-about-text { display: flex; flex-direction: column; gap: 1.25rem; }
.body-copy { font-size: 0.97rem; color: var(--mid); line-height: 1.8; }

/* Included card */
.uni-included-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.5rem; }
.uni-included-row { display: flex; align-items: center; gap: 0.75rem; padding: 0.6rem 0; border-bottom: 1px solid var(--rule); font-size: 0.88rem; color: var(--dark); }
.uni-included-row:last-of-type { border-bottom: none; }
.uni-included-icon { width: 28px; height: 28px; background: var(--blue-lt); border-radius: 6px; display: flex; align-items: center; justify-content: center; color: var(--blue); flex-shrink: 0; font-size: 0.75rem; }

/* Halls grid */
.uni-halls-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-bottom: 2.5rem; }
.uni-hall-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.5rem; }
.uni-hall-icon { font-size: 1.3rem; color: var(--blue); margin-bottom: 0.75rem; }
.uni-hall-name { font-family: var(--fh); font-size: 1.05rem; color: var(--dark); margin-bottom: 0.4rem; letter-spacing: 0.01em; }
.uni-hall-desc { font-size: 0.85rem; color: var(--mid); line-height: 1.6; margin: 0; }
.uni-halls-also { margin-top: 1rem; }
.uni-hall-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.5rem; }
.uni-hall-tag { background: var(--bg2); border: 1px solid var(--rule); border-radius: 20px; padding: 0.3rem 0.85rem; font-size: 0.8rem; color: var(--mid); }

/* Courses & Areas two-col */
.uni-two-col-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.uni-course-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; }
.uni-course-chip { background: var(--blue-lt); color: var(--blue); border-radius: 4px; padding: 0.35rem 0.85rem; font-size: 0.82rem; font-weight: 500; }
.uni-highlights-list { list-style: none; padding: 0; margin: 1rem 0 0; display: flex; flex-direction: column; gap: 0.6rem; }
.uni-highlights-list li { display: flex; align-items: flex-start; gap: 0.65rem; font-size: 0.9rem; color: var(--mid); line-height: 1.5; }
.uni-highlights-list li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--blue); flex-shrink: 0; margin-top: 0.45rem; }

/* Storage section */


/* Other universities bar */
.uni-other-bar { background: var(--bg2); border-top: 1.5px solid var(--rule); padding: 1.25rem 2.5rem; }
.uni-other-bar .con { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; max-width: var(--max); margin: 0 auto; }
.uni-other-label { font-family: var(--fm); font-size: 0.65rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--subtle); flex-shrink: 0; }
.uni-other-links { display: flex; gap: 1rem; flex-wrap: wrap; }
.uni-other-link { font-size: 0.88rem; color: var(--blue); font-weight: 500; text-decoration: none; transition: opacity 0.15s; }
.uni-other-link:hover { opacity: 0.7; }

/* Responsive */
@media (max-width: 900px) {
  .uni-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .uni-about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .uni-halls-grid { grid-template-columns: repeat(2, 1fr); }
  .uni-two-col-grid { grid-template-columns: 1fr; gap: 3rem; }
  .uni-storage-grid { grid-template-columns: 1fr; gap: 2.5rem; }
}
@media (max-width: 600px) {
  .uni-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .uni-halls-grid { grid-template-columns: 1fr; }
  .uni-stats-bar, .uni-storage-section, .uni-other-bar { padding-left: 1.25rem; padding-right: 1.25rem; }
}


/* ═══════════════════════════════════════════════════════
   CONTACT PAGE
═══════════════════════════════════════════════════════ */
.contact-hero { background: var(--dark); padding: 5rem 2.5rem 4rem; border-bottom: 3px solid var(--blue); }
.contact-hero .con { max-width: var(--max); margin: 0 auto; }
.contact-hero-phone { display: inline-flex; align-items: center; gap: 0.75rem; background: var(--blue); color: #fff; font-family: var(--fh); font-size: 1.6rem; padding: 0.6rem 1.5rem; border-radius: var(--r); letter-spacing: 0.04em; text-decoration: none; transition: background 0.15s; }
.contact-hero-phone:hover { background: var(--blue-d); color: #fff; }
.contact-methods-strip { background: var(--bg2); border-bottom: 1.5px solid var(--rule); padding: 0; }
.contact-methods-grid { display: grid; grid-template-columns: repeat(3,1fr); max-width: var(--max); margin: 0 auto; }
.contact-method-card { padding: 2rem 2.5rem; border-right: 1.5px solid var(--rule); }
.contact-method-card:last-child { border-right: none; }
.contact-method-icon { width: 40px; height: 40px; background: var(--blue-lt); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--blue); font-size: 1rem; margin-bottom: 0.75rem; }
.contact-method-label { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--subtle); margin-bottom: 0.35rem; }
.contact-method-value { font-family: var(--fh); font-size: 1.25rem; color: var(--dark); letter-spacing: 0.02em; text-decoration: none; display: block; transition: color 0.15s; }
a.contact-method-value:hover { color: var(--blue); }
.contact-method-note { font-size: 0.8rem; color: var(--subtle); margin-top: 0.25rem; }
.contact-layout { display: grid; grid-template-columns: 1.15fr 1fr; gap: 4rem; align-items: start; }
.contact-form-col { }
/* Form */
.contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.cf-row { display: flex; flex-direction: column; gap: 1.25rem; }
.cf-row-2 { flex-direction: row; gap: 1.25rem; }
.cf-row-2 .cf-field { flex: 1; }
.cf-field { display: flex; flex-direction: column; gap: 0.45rem; }
.cf-label { font-size: 0.82rem; font-weight: 600; color: var(--dark); }
.cf-req { color: var(--blue); }
.cf-input { border: 1.5px solid var(--rule); border-radius: var(--r); padding: 0.75rem 1rem; font-size: 0.92rem; color: var(--dark); background: #fff; font-family: var(--fb); width: 100%; transition: border-color 0.15s; }
.cf-input:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px var(--blue-lt); }
.cf-input::placeholder { color: var(--subtle); }
textarea.cf-input { resize: vertical; min-height: 130px; }
.cf-status { display: flex; align-items: center; gap: 0.65rem; padding: 0.85rem 1rem; border-radius: var(--r); font-size: 0.88rem; }
.cf-status-ok { background: #e8f5e9; color: #2e7d32; border: 1px solid #a5d6a7; }
.cf-status-err { background: #ffebee; color: #c62828; border: 1px solid #ef9a9a; }
.cf-submit { display: flex; align-items: center; gap: 0.75rem; cursor: pointer; width: fit-content; }
/* Sidebar */
.contact-sidebar { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-sidebar-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.5rem; }
.contact-book-card { background: var(--dark); border-color: transparent; }
.contact-faq-item { border-bottom: 1px solid var(--rule); padding: 0.85rem 0; cursor: pointer; }
.contact-faq-item:last-of-type { border-bottom: none; }
.contact-faq-item summary { font-size: 0.88rem; font-weight: 600; color: var(--dark); list-style: none; cursor: pointer; }
.contact-faq-item summary::-webkit-details-marker { display: none; }
.contact-faq-answer { font-size: 0.83rem; color: var(--mid); line-height: 1.65; margin-top: 0.6rem; }
.contact-hours-row { display: flex; justify-content: space-between; align-items: center; padding: 0.55rem 0; border-bottom: 1px solid var(--rule); font-size: 0.87rem; }
.contact-hours-row:last-of-type { border-bottom: none; }
/* Trust bar */
.contact-trust-bar { background: var(--bg2); border-top: 1.5px solid var(--rule); padding: 2rem 2.5rem; }
.contact-trust-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; max-width: var(--max); margin: 0 auto; }
.contact-trust-item { display: flex; align-items: center; gap: 1rem; }
.contact-trust-icon { width: 40px; height: 40px; background: var(--blue-lt); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--blue); flex-shrink: 0; }


/* ═══════════════════════════════════════════════════════
   BLOG ARCHIVE
═══════════════════════════════════════════════════════ */
.archive-cat-nav { background: #fff; border-bottom: 1.5px solid var(--rule); padding: 0 2.5rem; overflow-x: auto; }
.archive-cat-nav .con { display: flex; gap: 0; max-width: var(--max); margin: 0 auto; }
.archive-cat-link { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--subtle); text-decoration: none; padding: 1rem 1.25rem; border-bottom: 2px solid transparent; white-space: nowrap; transition: color 0.15s, border-color 0.15s; }
.archive-cat-link:hover, .archive-cat-link.active { color: var(--blue); border-bottom-color: var(--blue); }
/* Featured post */
.archive-featured { display: grid; grid-template-columns: 1fr 1fr; gap: 0; background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; overflow: hidden; text-decoration: none; color: inherit; transition: box-shadow 0.2s; margin-bottom: 0.5rem; }
.archive-featured:hover { box-shadow: var(--sh2); }
.archive-featured-img { height: 380px; overflow: hidden; position: relative; }
.archive-featured-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.archive-featured:hover .archive-featured-img img { transform: scale(1.03); }
.archive-featured-placeholder { width: 100%; height: 100%; background: var(--bg3); display: flex; align-items: center; justify-content: center; font-size: 3rem; color: rgba(0,0,0,0.15); }
.archive-featured-body { padding: 2.5rem; display: flex; flex-direction: column; justify-content: center; gap: 1rem; }
.archive-featured-title { font-family: var(--fh); font-size: clamp(1.8rem,3vw,2.8rem); color: var(--dark); line-height: 1.05; letter-spacing: 0.01em; }
.archive-featured-excerpt { font-size: 0.95rem; color: var(--mid); line-height: 1.75; }
.archive-featured-meta { font-size: 0.8rem; color: var(--subtle); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0.5rem; margin-top: auto; }
.archive-read-more { color: var(--blue); font-weight: 600; font-size: 0.85rem; }
.ssm-pagination { display: flex; gap: 0.5rem; justify-content: center; margin-top: 3rem; flex-wrap: wrap; }
.ssm-pagination .page-numbers { padding: 0.5rem 0.9rem; border: 1.5px solid var(--rule); border-radius: var(--r); font-size: 0.85rem; color: var(--mid); text-decoration: none; transition: all 0.15s; }
.ssm-pagination .page-numbers:hover, .ssm-pagination .page-numbers.current { background: var(--blue); border-color: var(--blue); color: #fff; }


/* ═══════════════════════════════════════════════════════
   SINGLE POST
═══════════════════════════════════════════════════════ */
.single-meta { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; font-size: 0.82rem; color: var(--subtle); margin-bottom: 1rem; }
.single-meta .single-cat-tag, .single-cat-tag { background: var(--blue); color: #fff; font-family: var(--fm); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.25rem 0.65rem; border-radius: 3px; text-decoration: none; }
.single-meta span::before { content: '·'; margin-right: 0.75rem; }
.single-meta span:first-of-type::before { content: ''; margin: 0; }
.single-featured-img { width: 100%; max-height: 500px; overflow: hidden; }
.single-featured-img img { width: 100%; max-height: 500px; object-fit: cover; display: block; }
.single-wrap { padding: 4rem 2.5rem; }
.single-wrap .con { max-width: var(--max); }
.single-layout { display: grid; grid-template-columns: 1fr 320px; gap: 4rem; align-items: start; }
.single-cta-inline { background: var(--dark); border-radius: 10px; padding: 1.75rem; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin: 2.5rem 0; }
.single-sidebar { display: flex; flex-direction: column; gap: 1.5rem; position: sticky; top: 80px; }
.single-sidebar-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.5rem; }
.single-sidebar-book { background: var(--dark); border-color: transparent; }
.single-sidebar-feature { display: flex; align-items: center; gap: 0.75rem; padding: 0.55rem 0; border-bottom: 1px solid var(--rule); }
.single-sidebar-feature:last-child { border-bottom: none; }
.single-cat-pill { display: inline-block; background: var(--blue-lt); color: var(--blue); font-size: 0.78rem; font-weight: 600; padding: 0.3rem 0.75rem; border-radius: 20px; margin: 0.25rem 0.25rem 0 0; text-decoration: none; }
.post-nav-bar { background: var(--bg2); border-top: 1.5px solid var(--rule); border-bottom: 1.5px solid var(--rule); padding: 2rem 2.5rem; }
.post-nav-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; max-width: var(--max); margin: 0 auto; }
.post-nav-item { text-decoration: none; display: flex; flex-direction: column; gap: 0.35rem; }
.post-nav-next { text-align: right; align-items: flex-end; }
.post-nav-dir { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--blue); }
.post-nav-t { font-family: var(--fh); font-size: 1.2rem; color: var(--dark); line-height: 1.15; letter-spacing: 0.01em; }


/* ═══════════════════════════════════════════════════════
   FAQ PAGE ADDITIONS
═══════════════════════════════════════════════════════ */
.faq-cat-nav { background: #fff; border-bottom: 1.5px solid var(--rule); padding: 0 2.5rem; overflow-x: auto; }
.faq-cat-nav .con { display: flex; gap: 0; max-width: var(--max); margin: 0 auto; }
.faq-cat-nav-link { font-family: var(--fm); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--subtle); text-decoration: none; padding: 1rem 1.25rem; border-bottom: 2px solid transparent; white-space: nowrap; transition: color 0.15s, border-color 0.15s; }
.faq-cat-nav-link:hover { color: var(--blue); border-bottom-color: var(--blue); }
.faq-con { max-width: 820px; }
.faq-category { margin-bottom: 3.5rem; }
.faq-category-label { font-family: var(--fh); font-size: 1.5rem; color: var(--dark); letter-spacing: 0.02em; padding-bottom: 0.75rem; border-bottom: 2px solid var(--blue); margin-bottom: 0; }
.faq-cta-card { background: var(--bg2); border: 1.5px solid var(--rule); border-radius: 10px; padding: 2rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; margin-top: 1rem; }
.faq-seo-copy { color: var(--mid); line-height: 1.8; display: flex; flex-direction: column; gap: 1rem; margin-top: 1.5rem; }
.faq-seo-copy a { color: var(--blue); }


/* ═══════════════════════════════════════════════════════
   HOW IT WORKS / USEFUL INFO
═══════════════════════════════════════════════════════ */
.how-timeline { display: flex; flex-direction: column; max-width: 800px; margin-top: 2.5rem; }
.how-timeline-item { display: flex; gap: 0; }
.how-timeline-left { display: flex; flex-direction: column; align-items: center; width: 72px; flex-shrink: 0; }
.how-timeline-num { font-family: var(--fh); font-size: 2rem; color: var(--blue); line-height: 1; padding-top: 1.25rem; }
.how-timeline-line { width: 2px; background: var(--rule); flex: 1; margin-top: 0.5rem; min-height: 24px; }
.how-timeline-item:last-child .how-timeline-line { display: none; }
.how-timeline-body { display: flex; align-items: flex-start; gap: 1.25rem; padding: 1.25rem 0 2.5rem; flex: 1; }
.how-timeline-icon { width: 44px; height: 44px; background: var(--blue-lt); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--blue); flex-shrink: 0; font-size: 1rem; margin-top: 0.15rem; }
.how-timeline-title { font-family: var(--fh); font-size: 1.3rem; color: var(--dark); letter-spacing: 0.01em; margin-bottom: 0.4rem; }
.how-timeline-text { font-size: 0.92rem; color: var(--mid); line-height: 1.7; margin-bottom: 0.65rem; }
.how-timeline-text a { color: var(--blue); }
.how-seo-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 5rem; align-items: start; }
.how-guide-item { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--rule); text-decoration: none; transition: opacity 0.15s; }
.how-guide-item:last-child { border-bottom: none; }
.how-guide-item:hover { opacity: 0.75; }


/* ═══════════════════════════════════════════════════════
   UNIVERSITY STORAGE HUB
═══════════════════════════════════════════════════════ */
.hub-uni-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 2.5rem; }
.hub-uni-card { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.75rem; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: box-shadow 0.2s, border-color 0.2s; }
.hub-uni-card:hover { box-shadow: var(--sh2); border-color: var(--blue); }
.hub-uni-card-top { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 0.75rem; }
.hub-uni-icon { width: 40px; height: 40px; background: var(--blue-lt); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--blue); flex-shrink: 0; font-size: 1rem; }
.hub-uni-name { font-family: var(--fh); font-size: 1.2rem; color: var(--dark); letter-spacing: 0.01em; line-height: 1.2; }
.hub-uni-count { font-family: var(--fm); font-size: 0.6rem; letter-spacing: 0.1em; color: var(--blue); margin-top: 0.2rem; }
.hub-uni-desc { font-size: 0.85rem; color: var(--mid); line-height: 1.65; flex: 1; margin-bottom: 1rem; }
.hub-uni-link { font-size: 0.83rem; color: var(--blue); font-weight: 600; margin-top: auto; }


/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media (max-width: 1000px) {
  .single-layout { grid-template-columns: 1fr; }
  .single-sidebar { position: static; }
  .contact-layout { grid-template-columns: 1fr; }
  .how-seo-grid { grid-template-columns: 1fr; gap: 3rem; }
}
@media (max-width: 900px) {
  .archive-featured { grid-template-columns: 1fr; }
  .archive-featured-img { height: 260px; }
  .contact-methods-grid { grid-template-columns: 1fr; }
  .contact-method-card { border-right: none; border-bottom: 1.5px solid var(--rule); }
  .contact-method-card:last-child { border-bottom: none; }
  .contact-trust-grid { grid-template-columns: repeat(2,1fr); }
  .hub-uni-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 600px) {
  .cf-row-2 { flex-direction: column; }
  .post-nav-grid { grid-template-columns: 1fr; }
  .contact-hero { padding: 3rem 1.25rem; }
  .archive-cat-nav { padding: 0 1.25rem; }
  .hub-uni-grid { grid-template-columns: 1fr; }
  .contact-trust-grid { grid-template-columns: 1fr 1fr; }
  .single-wrap { padding: 2.5rem 1.25rem; }
}


/* ═══════════════════════════════════════════════════════
   UNIVERSITY PAGE — FACILITY IMAGE + LIGHT STORAGE
═══════════════════════════════════════════════════════ */

/* About grid: flip to image left when facility image is set */
.uni-about-grid { display: grid; grid-template-columns: 1fr 1.35fr; gap: 4rem; align-items: start; }
.uni-about-media { order: -1; }

/* Facility image */
.uni-facility-img-wrap { position: relative; border-radius: 10px; overflow: hidden; border: 1.5px solid var(--rule); }
.uni-facility-img-wrap img { width: 100%; height: 420px; object-fit: cover; display: block; }
.uni-facility-badge { position: absolute; bottom: 1rem; left: 1rem; background: var(--blue); color: #fff; font-family: var(--fm); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.4rem 0.9rem; border-radius: 3px; display: flex; align-items: center; gap: 0.5rem; }

/* Included checklist inline (when image shows above) */
.uni-included-inline { display: flex; flex-direction: column; gap: 0; margin-top: 1.5rem; background: var(--bg2); border: 1.5px solid var(--rule); border-radius: 10px; padding: 1rem 1.25rem; }
.uni-included-inline .uni-included-row { padding: 0.5rem 0; }

/* Storage section — light background version */
.uni-storage-light { background: var(--bg2); }
.uni-storage-light-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 4rem; align-items: start; }
.uni-storage-checklist { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 1.75rem; }
.uni-storage-check-row { display: flex; align-items: center; gap: 0.85rem; padding: 0.75rem 0; border-bottom: 1px solid var(--rule); font-size: 0.9rem; color: var(--dark); }
.uni-storage-check-row:last-of-type { border-bottom: none; }
.uni-storage-check-icon { width: 26px; height: 26px; background: #e8f5e9; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--green); flex-shrink: 0; font-size: 0.7rem; }

/* Responsive */
@media (max-width: 900px) {
  .uni-about-grid { grid-template-columns: 1fr; }
  .uni-about-media { order: 0; }
  .uni-facility-img-wrap img { height: 280px; }
  .uni-storage-light-grid { grid-template-columns: 1fr; }
}


/* Prices page — SEO copy grid */
.prices-seo-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: start; }
@media (max-width: 860px) { .prices-seo-grid { grid-template-columns: 1fr; } }

/* ─── AUTHOR BIO CARD (single.php) ─── */
.author-bio-card {
    background: var(--bg2);
    border-left: 3px solid var(--blue);
    border-radius: 0 var(--r) var(--r) 0;
    padding: 1.25rem 1.5rem;
    margin: 2.5rem 0;
}
.author-bio-name {
    font-family: var(--fm);
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--subtle);
    margin-bottom: 0.5rem;
}
.author-bio-text {
    font-size: 0.9rem;
    color: var(--mid);
    line-height: 1.7;
    margin: 0;
}
