/* Strategic Sales Support — brand-locked styles
   Per official brand guidelines:
     · Ink   #101820  (RGB 16,24,32)   — primary
     · Stone #dbdcde  (RGB 219,220,222) — secondary
   Display: Killarney (substitute: DM Serif Display)
   Body:    Berlin   (substitute: Outfit)
*/

:root{
  --ink:#101820;
  --ink-2:#1c2733;       /* one nudge lighter for hover */
  --ink-deep:#0d1726;    /* deep navy for full-bleed dark sections */
  --stone:#dbdcde;
  --stone-2:#eef0f1;     /* subtle surface */
  --paper:#f7f7f8;       /* page tint */
  --line:#dbdcde;
  --muted:#5c6470;       /* derived neutral for body copy */
  --white:#ffffff;
  --gold:#c9a96e;        /* champagne/gold accent — used in italic display words */
  --gold-soft:#d8be88;
}
.text-gold{color:var(--gold)}
.bg-gold{background:var(--gold);color:var(--ink)}
em.gold,.gold-em,em.italic-accent{font-style:italic;color:var(--gold)}
/* Unified italic accent — used on display headings */
h1 em, h2 em, h3 em, .font-display em{font-style:italic;color:var(--gold)}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px}
[id]{scroll-margin-top:96px}

/* Focus states — keyboard-only outline */
:focus{outline:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.btn:focus-visible{outline-offset:3px}

/* Selection */
::selection{background:var(--gold);color:var(--ink)}

/* Image defaults */
img{max-width:100%;height:auto;display:block}
body{
  font-family:'Outfit','Berlin Sans FB',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* Display type */
h1,h2,h3,h4,.font-display{
  font-family:'DM Serif Display','Killarney',Georgia,serif;
  letter-spacing:-0.005em;
  color:var(--ink);
  font-weight:400;
  line-height:1.05;
}
h1{font-weight:400}
h3,h4{line-height:1.2}

.eyebrow{
  display:inline-block;
  font-family:'Outfit',sans-serif;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
  font-weight:600;
}

/* Section spacing */
.sec{padding:5.5rem 0}
@media (max-width:768px){.sec{padding:3.5rem 0}}
section[data-elementor-section]{position:relative}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--ink);
  color:var(--white);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.site-header a{color:var(--white)}
.site-header .logo-img{height:40px;width:auto;display:block}

/* Header lockup: icon mark + typeset wordmark */
.site-header .logo-mark{
  height:52px;width:auto;display:block;
  flex-shrink:0;
}
.site-header .logo-wordmark{
  display:flex;flex-direction:column;line-height:1;
  border-left:1px solid rgba(255,255,255,.18);
  padding-left:12px;
}
.site-header .logo-name{
  font-family:'DM Serif Display','Killarney',Georgia,serif;
  font-size:1rem;letter-spacing:.03em;
  color:#fff;line-height:1.05;
}
.site-header .logo-tagline{
  font-family:'Outfit',sans-serif;
  font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
  margin-top:5px;
  display:none; /* footer carries the tagline */
}
.nav-link{font-size:.78rem;letter-spacing:.07em}
@media (max-width:1280px){
  .nav-link{font-size:.75rem;letter-spacing:.05em}
  .site-header .logo-wordmark{display:none}
  .site-header .logo-mark{height:46px}
}
@media (max-width:1024px){
  .site-header .logo-mark{height:44px}
  .site-header .logo-wordmark{display:flex}
  .site-header .logo-name{font-size:.92rem}
}
.nav-link{
  font-family:'Outfit',sans-serif;
  font-size:.82rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:500;
  color:rgba(255,255,255,.78);
}
.nav-link:hover{color:#fff}
.nav-link.active{color:#fff;font-weight:600}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:.86rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  border-radius:0;                /* hard square — matches the brand block aesthetic */
  padding:.95rem 1.5rem;
  transition:transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space:nowrap;
  border:1px solid transparent;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:var(--ink-2);border-color:var(--ink-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-on-dark{background:#fff;color:var(--ink) !important;border-color:#fff}
.btn-on-dark:hover{background:var(--stone);border-color:var(--stone);color:var(--ink) !important}
/* Header has color:white on links — override for the Book a Call button */
.site-header .btn-on-dark{color:var(--ink) !important}
.site-header .btn-on-dark:hover{color:var(--ink) !important}

/* ============ CARDS ============ */
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:0;
  padding:1.75rem;
  transition:border-color .15s ease, transform .15s ease, background .15s ease;
}
.card:hover{border-color:var(--ink);transform:translateY(-2px)}
.card-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.card-dark h2,.card-dark h3,.card-dark h4{color:#fff}
.card-stone{background:var(--stone-2);border-color:var(--stone)}

/* ============ PILLS / BADGES ============ */
.pill{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:'Outfit',sans-serif;
  font-size:.68rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  padding:.35rem .7rem;
  background:var(--stone-2);color:var(--ink);
  border-radius:0;
  border:1px solid var(--stone);
}
.pill-ink{background:var(--ink);color:#fff;border-color:var(--ink)}
.pill-outline{background:transparent;color:var(--ink);border-color:var(--ink)}

/* ============ HERO BG ============ */
.hero-bg{
  background:
    linear-gradient(180deg,#fff 0%,var(--paper) 100%);
  position:relative;
  overflow:hidden;
}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(16,24,32,.06) 1px, transparent 0);
  background-size:28px 28px;
  pointer-events:none;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.4), rgba(0,0,0,0) 80%);
}

/* ============ LOGO STRIP ============ */
.logo-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;align-items:center;justify-items:center}
@media (min-width:640px){.logo-strip{grid-template-columns:repeat(3,1fr)}}
@media (min-width:1024px){.logo-strip{grid-template-columns:repeat(6,1fr)}}
.logo-tile{
  width:100%;aspect-ratio:5/2;
  background:var(--white);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  font-family:'Outfit',sans-serif;font-weight:500;
  font-size:.78rem;letter-spacing:.04em;
}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7)}
.site-footer a{color:rgba(255,255,255,.7)}
.site-footer a:hover{color:#fff}
.site-footer h5{
  color:#fff;
  font-family:'Outfit',sans-serif;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;
}
.site-footer .logo-img{height:60px;width:auto}

/* ============ FORM ============ */
.field{
  display:block;width:100%;
  padding:.85rem 1rem;
  border:1px solid var(--ink);
  background:#fff;
  font:400 .95rem/1.4 'Outfit',sans-serif;
  color:var(--ink);
  border-radius:0;
}
.field:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(16,24,32,.12)}
label.lbl{
  font-family:'Outfit',sans-serif;
  font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);display:block;margin-bottom:.5rem;
}

/* ============ TABS / CHIPS ============ */
.tab-bar{display:flex;gap:.5rem;overflow-x:auto;border-bottom:1px solid var(--line);padding-bottom:.5rem}
.tab{
  padding:.7rem 1.1rem;
  font-family:'Outfit',sans-serif;font-weight:600;font-size:.78rem;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);background:transparent;
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
}
.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.tab:not(.active):hover{color:var(--ink)}

.chip{
  padding:.5rem .85rem;
  font-family:'Outfit',sans-serif;font-weight:500;font-size:.74rem;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);background:#fff;border:1px solid var(--ink);
  cursor:pointer;
}
.chip.active{background:var(--ink);color:#fff}

/* ============ STEP NUMBERS ============ */
.step-num{
  width:42px;height:42px;
  background:var(--ink);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-weight:400;font-size:1.1rem;
  flex-shrink:0;
}

/* ============ BOOKINGS FRAME ============ */
.bookings-frame{
  width:100%;min-height:780px;
  background:#fff;border:1px dashed var(--ink);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);text-align:center;padding:2rem;
}

/* ============ MOBILE NAV ============ */
.mobile-nav{display:none}
.mobile-nav.open{display:block}
.mobile-nav .nav-link{padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.08)}

/* ============ ELEMENTOR MAP MARKER ============ */
body.show-map section[data-elementor-section]::before{
  content:attr(data-elementor-section);
  position:absolute;top:.5rem;left:.5rem;z-index:10;
  font:600 11px/1 'Outfit',monospace;
  background:var(--ink);color:#fff;padding:5px 9px;
  letter-spacing:.06em;
  pointer-events:none;opacity:.92
}

/* ============ UTILITIES ============ */
.text-muted{color:var(--muted)}
.bg-stone{background:var(--stone-2)}
.bg-ink{background:var(--ink);color:#fff}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}
.text-ink{color:var(--ink)}
.text-stone{color:var(--stone)}
/* Ensure all text on dark surfaces stays light, even when font-display
   or heading color rules would otherwise win the cascade */
.bg-ink, .card-dark, .site-footer{color:#fff}
.bg-ink p, .bg-ink li, .bg-ink span:not(.pill):not(.eyebrow):not([style*="color"]),
.card-dark p, .card-dark li{color:#fff}
.bg-ink h1, .bg-ink h2, .bg-ink h3, .bg-ink h4, .bg-ink .font-display,
.card-dark h1, .card-dark h2, .card-dark h3, .card-dark h4, .card-dark .font-display{color:#fff}
.bg-ink em, .card-dark em{color:var(--gold)}
.border-ink{border-color:var(--ink)}
.border-line{border-color:var(--line)}

/* Drop large display weights for body content */
p,li{font-family:'Outfit',sans-serif}

/* Smooth fade-in for images */
img.fade-in{opacity:0;transition:opacity .35s ease}
img.fade-in.loaded{opacity:1}

/* Better link defaults */
a{transition:color .15s ease, opacity .15s ease}

/* Form fix: ensure dark surface inputs read white text on dark */
.bg-ink .field, .card-dark .field{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.2);
  color:#fff;
}
.bg-ink .field::placeholder, .card-dark .field::placeholder{color:rgba(255,255,255,.45)}
.bg-ink .field:focus, .card-dark .field:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,110,.2)}
.bg-ink .lbl, .card-dark .lbl{color:#fff}

/* FAQ details indicator polish */
details > summary::-webkit-details-marker{display:none}
details > summary{list-style:none}

/* Print */
@media print{
  .site-header,.site-footer,.btn,.bookings-frame,.tab-bar,.chip,.pill{display:none !important}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:none}
  section{break-inside:avoid;page-break-inside:avoid}
  img{max-width:60mm}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,::before,::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
}

/* ==========================================================================
   MOTION — scroll-triggered reveals, count-up, hover micro-animations
   Purely additive. No colour, no font, no copy changes.
   ========================================================================== */

/* Fade-up base state */
[data-animate]{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .65s cubic-bezier(.16,.84,.32,1), transform .65s cubic-bezier(.16,.84,.32,1);
  will-change:opacity, transform;
}
[data-animate].in-view{opacity:1;transform:translateY(0)}

/* Staggered fade-up — used on grids of 3-8 items */
[data-animate="fade-up-1"]{transition-delay:.06s}
[data-animate="fade-up-2"]{transition-delay:.14s}
[data-animate="fade-up-3"]{transition-delay:.22s}
[data-animate="fade-up-4"]{transition-delay:.30s}
[data-animate="fade-up-5"]{transition-delay:.38s}
[data-animate="fade-up-6"]{transition-delay:.46s}
[data-animate="fade-up-7"]{transition-delay:.54s}
[data-animate="fade-up-8"]{transition-delay:.62s}

@media (prefers-reduced-motion: reduce){
  [data-animate]{opacity:1;transform:none;transition:none}
}

/* Hero spotlight — soft gold radial in the top-right.
   Uses existing brand gold (--gold) at 8% opacity.
   ::after overlays the existing ::before dot pattern without altering it. */
.hero-bg::after{
  content:"";
  position:absolute;
  top:-15%;right:-12%;
  width:60%;height:90%;
  background:radial-gradient(closest-side, rgba(201,169,110,0.10), rgba(201,169,110,0) 70%);
  pointer-events:none;
  z-index:0;
}
.hero-bg > *{position:relative;z-index:1}

/* Button arrow micro-animation (CSS only, scoped to <svg> inside .btn) */
.btn svg{transition:transform .22s ease}
.btn:hover svg{transform:translateX(4px)}

/* Subtle hover refinement on trust-strip tiles (no colour change) */
.logo-tile{transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease}
.logo-tile:hover{transform:translateY(-2px);border-color:var(--ink);box-shadow:0 6px 24px rgba(16,24,32,.06)}

/* Value-prop card hover sharpening (composes with existing .card:hover) */
.card[data-animate]:hover{box-shadow:0 8px 32px rgba(16,24,32,.07)}
