/* ============================================================
   PARADIGM24 — main.css
   Design system tokens, components, layout
   ============================================================ */

:root {
  /* Colour tokens */
  --p24-navy:     #1F3A5F;
  --p24-blue:     #185FA5;
  --p24-blue-50:  #D4E6F7;
  --p24-pink:     #D4537E;
  --p24-pink-50:  #FBEAF0;
  --p24-pink-800: #993556;
  --p24-cream:    #FAF8F4;
  --p24-sand:     #F0ECE0;
  --p24-ink:      #1A1A1A;
  --p24-ink-60:   #555555;
  --p24-ink-40:   #888888;
  --p24-line:     #E6E2D8;
  --p24-white:    #FFFFFF;

  /* Spacing scale (8px base) */
  --p24-s-1: 8px;
  --p24-s-2: 16px;
  --p24-s-3: 24px;
  --p24-s-4: 32px;
  --p24-s-5: 48px;
  --p24-s-6: 64px;
  --p24-s-7: 96px;

  /* Radius */
  --p24-r-sm:   4px;
  --p24-r-md:   8px;
  --p24-r-lg:   10px;
  --p24-r-pill: 999px;

  /* Container width */
  --p24-w-content: 780px;
  --p24-w-wide:    1200px;
  --p24-w-edge:    24px;

  /* Type scale */
  --p24-fs-display:  clamp(36px, 5vw, 56px);
  --p24-fs-h2:       clamp(24px, 3vw, 32px);
  --p24-fs-h3:       18px;
  --p24-fs-body:     15px;
  --p24-fs-small:    13px;
  --p24-fs-xs:       11px;
}

/* ----- Reset / base ----- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--p24-cream);
  color: var(--p24-ink);
  font-family: 'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: var(--p24-fs-body);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--p24-blue); text-decoration: none; transition: color 0.15s ease; }
a:hover, a:focus { color: var(--p24-navy); text-decoration: underline; text-underline-offset: 4px; }

h1, h2, h3, h4 { color: var(--p24-navy); margin: 0 0 var(--p24-s-3); font-weight: 700; letter-spacing: -0.02em; }
h1 { font-size: var(--p24-fs-display); line-height: 1.05; letter-spacing: -0.025em; }
h2 { font-size: var(--p24-fs-h2);      line-height: 1.15; }
h3 { font-size: var(--p24-fs-h3);      line-height: 1.3; font-weight: 500; color: var(--p24-ink); }
p { margin: 0 0 var(--p24-s-3); }

/* ----- Layout primitives ----- */
.p24-container {
  width: 100%;
  max-width: var(--p24-w-wide);
  margin: 0 auto;
  padding: 0 var(--p24-w-edge);
}
.p24-container--narrow { max-width: var(--p24-w-content); }
.p24-section { padding: var(--p24-s-6) 0; }
.p24-section--bleed { padding: 0; }

@media (max-width: 768px) {
  .p24-section { padding: var(--p24-s-5) 0; }
  :root { --p24-w-edge: 16px; }
}

/* ----- Eyebrow label ----- */
.p24-eyebrow {
  font-size: var(--p24-fs-xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--p24-pink);
  margin-bottom: var(--p24-s-2);
}
.p24-eyebrow--navy { color: var(--p24-navy); }

/* ----- Buttons ----- */
.p24-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 20px;
  font-family: inherit; font-size: var(--p24-fs-small); font-weight: 700;
  letter-spacing: -0.01em;
  border-radius: var(--p24-r-md);
  cursor: pointer;
  transition: transform 0.12s ease, background-color 0.15s ease;
  text-decoration: none;
  border: none;
  white-space: nowrap;
}
.p24-btn:hover, .p24-btn:focus { text-decoration: none; }
.p24-btn:active { transform: scale(0.98); }

.p24-btn--primary { background: var(--p24-navy); color: var(--p24-white); }
.p24-btn--primary:hover { background: #142B49; color: var(--p24-white); }

.p24-btn--secondary { background: transparent; color: var(--p24-navy); border: 0.5px solid var(--p24-navy); }
.p24-btn--secondary:hover { background: var(--p24-sand); color: var(--p24-navy); }

.p24-btn--pink { background: var(--p24-pink); color: var(--p24-white); }
.p24-btn--pink:hover { background: var(--p24-pink-800); color: var(--p24-white); }

.p24-btn--ghost { background: transparent; color: var(--p24-blue); padding: 8px 14px; text-decoration: underline; text-underline-offset: 4px; font-weight: 500; }

/* ----- Pills, badges ----- */
.p24-pill {
  display: inline-flex; align-items: center;
  padding: 5px 12px;
  font-size: var(--p24-fs-xs);
  font-weight: 500;
  border-radius: var(--p24-r-pill);
}
.p24-pill--available { background: var(--p24-blue-50); color: var(--p24-blue); }
.p24-pill--booked    { background: var(--p24-pink-50); color: var(--p24-pink-800); }
.p24-pill--neutral   { background: var(--p24-sand); color: var(--p24-navy); }
.p24-pill--inverted  { background: var(--p24-navy); color: var(--p24-white); }
.p24-pill--dashed    { background: transparent; border: 0.5px dashed #aaa; color: var(--p24-ink-60); }

/* ----- Cards ----- */
.p24-card {
  background: var(--p24-white);
  border: 0.5px solid var(--p24-line);
  border-radius: var(--p24-r-lg);
  padding: var(--p24-s-3);
}
.p24-card--sand   { background: var(--p24-sand); border: none; }
.p24-card--navy   { background: var(--p24-navy); color: var(--p24-white); border: none; }
.p24-card--navy h1, .p24-card--navy h2, .p24-card--navy h3 { color: var(--p24-white); }

/* Stat card */
.p24-stat .p24-stat__num {
  font-size: 30px; font-weight: 700; color: var(--p24-navy);
  letter-spacing: -0.02em; line-height: 1; margin: 0;
}
.p24-stat .p24-stat__label {
  font-size: var(--p24-fs-small); color: var(--p24-ink-60); margin-top: 4px;
}

/* ----- Header ----- */
.p24-header {
  background: var(--p24-cream);
  border-bottom: 0.5px solid var(--p24-line);
  position: sticky; top: 0; z-index: 100;
}
.p24-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 0;
}
.p24-header__logo {
  font-weight: 700; font-size: 17px; letter-spacing: -0.02em;
  color: var(--p24-navy); text-decoration: none;
}
.p24-header__logo span { color: var(--p24-blue); }
.p24-header__logo:hover { text-decoration: none; color: var(--p24-navy); }

.p24-nav { display: flex; gap: 28px; align-items: center; }
.p24-nav a { font-size: 13px; color: var(--p24-ink-60); }
.p24-nav a:hover { color: var(--p24-navy); }
.p24-nav .current-menu-item a, .p24-nav .current_page_item a { color: var(--p24-navy); font-weight: 500; }

.p24-header__cta {
  background: var(--p24-navy); color: var(--p24-white);
  padding: 8px 16px; border-radius: var(--p24-r-pill); font-size: 12px; font-weight: 700;
  text-decoration: none;
}
.p24-header__cta:hover { background: #142B49; color: var(--p24-white); }

@media (max-width: 768px) {
  .p24-nav { display: none; }
}

/* ----- Hero ----- */
.p24-hero {
  padding: var(--p24-s-6) 0 var(--p24-s-5);
  background: linear-gradient(180deg, var(--p24-cream) 0%, var(--p24-sand) 100%);
}
.p24-hero__grid {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--p24-s-5);
  align-items: start;
}
.p24-hero h1 { max-width: 540px; margin-bottom: var(--p24-s-3); }
.p24-hero p.lead {
  font-size: var(--p24-fs-h3);
  color: var(--p24-ink-60); max-width: 420px; margin-bottom: var(--p24-s-4);
  line-height: 1.5;
}
.p24-hero__meta {
  display: flex; gap: var(--p24-s-3);
  font-size: var(--p24-fs-xs); color: var(--p24-ink-60);
  padding-top: var(--p24-s-2);
  border-top: 0.5px solid var(--p24-line);
}
.p24-hero__meta-item { display: inline-flex; align-items: center; gap: 6px; }
.p24-hero__meta-dot { width: 6px; height: 6px; background: var(--p24-blue); border-radius: 50%; }

@media (max-width: 768px) {
  .p24-hero__grid { grid-template-columns: 1fr; gap: var(--p24-s-4); }
}

/* ----- Colour blocks (3-up) ----- */
.p24-colours { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.p24-colour {
  aspect-ratio: 1.4;
  padding: var(--p24-s-2);
  display: flex; flex-direction: column; justify-content: space-between;
  color: var(--p24-white);
}
.p24-colour--navy { background: var(--p24-navy); color: #cfdaeb; }
.p24-colour--blue { background: var(--p24-blue); color: #d4e6f7; }
.p24-colour--pink { background: var(--p24-pink); color: var(--p24-pink-50); }

.p24-colour__num { font-size: var(--p24-fs-xs); letter-spacing: 0.15em; text-transform: uppercase; }
.p24-colour__title { font-size: 20px; font-weight: 700; line-height: 1.1; color: inherit; margin: 0; }

@media (max-width: 768px) {
  .p24-colours { grid-template-columns: 1fr; }
  .p24-colour { aspect-ratio: 16/9; }
}

/* ----- The journey strip ----- */
.p24-journey {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--p24-s-1);
  padding: var(--p24-s-3) 0;
  border-top: 0.5px solid var(--p24-line);
}
.p24-journey__step { text-align: center; }
.p24-journey__num {
  font-size: var(--p24-fs-xs); color: var(--p24-blue); font-style: italic; margin-bottom: 4px;
}
.p24-journey__label { font-size: 10px; color: var(--p24-ink-60); line-height: 1.3; }

@media (max-width: 768px) {
  .p24-journey { grid-template-columns: repeat(2, 1fr); gap: var(--p24-s-2); }
}

/* ----- Stat band ----- */
.p24-stat-band {
  background: var(--p24-sand);
  padding: var(--p24-s-4) var(--p24-w-edge);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--p24-s-2);
}
@media (max-width: 768px) {
  .p24-stat-band { grid-template-columns: repeat(2, 1fr); gap: var(--p24-s-3); }
}

/* ----- Booking ----- */
.p24-booking { display: grid; grid-template-columns: 1.4fr 1fr; gap: 0; }
.p24-booking__picker { background: var(--p24-cream); padding: var(--p24-s-4); border-right: 0.5px solid var(--p24-line); }
.p24-booking__summary { background: var(--p24-white); padding: var(--p24-s-4); }

.p24-colour-tile {
  border: 0.5px solid #ccc; padding: 10px; border-radius: var(--p24-r-md);
  text-align: center; background: var(--p24-white); cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.p24-colour-tile:hover { border-color: var(--p24-navy); }
.p24-colour-tile--selected {
  border: 2px solid var(--p24-navy); background: var(--p24-sand); padding: 9px;
}
.p24-colour-tile__swatch { height: 50px; border-radius: var(--p24-r-md); margin-bottom: 8px; }
.p24-colour-tile__name { font-size: var(--p24-fs-xs); font-weight: 500; }
.p24-colour-tile__status { font-size: 10px; color: var(--p24-ink-40); margin-top: 2px; }

@media (max-width: 768px) {
  .p24-booking { grid-template-columns: 1fr; }
  .p24-booking__picker { border-right: none; border-bottom: 0.5px solid var(--p24-line); }
}

/* ----- Calendar ----- */
.p24-cal { background: var(--p24-white); border: 0.5px solid var(--p24-line); border-radius: var(--p24-r-lg); padding: var(--p24-s-2); }
.p24-cal__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--p24-s-2); }
.p24-cal__title { font-weight: 700; font-size: 14px; color: var(--p24-ink); }
.p24-cal__nav { display: flex; gap: 6px; }
.p24-cal__nav button { font-size: 12px; color: var(--p24-navy); padding: 4px 8px; border: 0.5px solid #ccc; border-radius: var(--p24-r-md); background: transparent; cursor: pointer; }
.p24-cal__weekdays, .p24-cal__days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; text-align: center; }
.p24-cal__weekday { font-size: 10px; color: var(--p24-ink-40); font-weight: 500; padding-bottom: 6px; }
.p24-cal__day { padding: 9px 0; font-size: 12px; color: #444; border-radius: var(--p24-r-sm); }
.p24-cal__day--out { color: #ccc; }
.p24-cal__day--booked { background: var(--p24-pink-50); color: var(--p24-pink-800); }
.p24-cal__day--selected { background: var(--p24-blue); color: var(--p24-white); font-weight: 700; }
.p24-cal__day--in-range { background: var(--p24-blue-50); color: var(--p24-blue); font-weight: 500; }
.p24-cal__legend { display: flex; gap: var(--p24-s-2); font-size: var(--p24-fs-xs); color: var(--p24-ink-60); margin-top: var(--p24-s-2); padding-top: var(--p24-s-2); border-top: 0.5px solid var(--p24-line); flex-wrap: wrap; }
.p24-cal__legend-item { display: flex; align-items: center; gap: 6px; }
.p24-cal__legend-swatch { width: 10px; height: 10px; border-radius: 2px; }

/* ----- Footer ----- */
.p24-footer {
  background: var(--p24-navy); color: #cfdaeb;
  padding: var(--p24-s-5) 0 var(--p24-s-3);
  margin-top: var(--p24-s-6);
}
.p24-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--p24-s-4); }
.p24-footer h4 { color: var(--p24-white); font-size: var(--p24-fs-xs); letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: var(--p24-s-2); }
.p24-footer ul { list-style: none; padding: 0; margin: 0; }
.p24-footer li { margin-bottom: 8px; }
.p24-footer a { color: #cfdaeb; font-size: var(--p24-fs-small); }
.p24-footer a:hover { color: var(--p24-white); text-decoration: underline; }
.p24-footer__bottom {
  margin-top: var(--p24-s-4); padding-top: var(--p24-s-3);
  border-top: 0.5px solid rgba(255,255,255,0.1);
  display: flex; justify-content: space-between; font-size: var(--p24-fs-xs); color: rgba(255,255,255,0.5);
}

@media (max-width: 768px) {
  .p24-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--p24-s-3); }
  .p24-footer__bottom { flex-direction: column; gap: 8px; }
}

/* ----- Editorial split ----- */
.p24-editorial {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--p24-s-4);
  align-items: end;
  padding: var(--p24-s-6) 0 var(--p24-s-4);
}
.p24-editorial h2 { max-width: 520px; }
.p24-editorial p { font-size: var(--p24-fs-small); color: var(--p24-ink-60); line-height: 1.7; max-width: 460px; }

@media (max-width: 768px) {
  .p24-editorial { grid-template-columns: 1fr; gap: var(--p24-s-3); padding: var(--p24-s-4) 0 var(--p24-s-3); }
}

/* ----- Forms ----- */
input[type="text"], input[type="email"], input[type="tel"], textarea, select {
  width: 100%; padding: 11px 14px;
  font-family: inherit; font-size: var(--p24-fs-small);
  border: 0.5px solid #ccc; border-radius: var(--p24-r-md);
  background: var(--p24-white); color: var(--p24-ink);
  transition: border-color 0.15s ease;
}
input:focus, textarea:focus, select:focus {
  outline: none; border-color: var(--p24-navy);
  box-shadow: 0 0 0 3px rgba(31,58,95,0.08);
}
label { font-size: var(--p24-fs-small); font-weight: 500; color: var(--p24-ink); display: block; margin-bottom: 6px; }

/* ----- Helpers ----- */
.p24-mt-0 { margin-top: 0 !important; }
.p24-mt-1 { margin-top: var(--p24-s-1); }
.p24-mt-2 { margin-top: var(--p24-s-2); }
.p24-mt-3 { margin-top: var(--p24-s-3); }
.p24-mt-4 { margin-top: var(--p24-s-4); }
.p24-mt-5 { margin-top: var(--p24-s-5); }

.p24-text-pink { color: var(--p24-pink); }
.p24-text-navy { color: var(--p24-navy); }
.p24-text-muted { color: var(--p24-ink-60); }
.p24-text-small { font-size: var(--p24-fs-small); }
.p24-text-xs { font-size: var(--p24-fs-xs); }

/* ----- Print ----- */
@media print {
  .p24-header, .p24-footer, .p24-header__cta { display: none; }
  body { background: white; }
}
