/* ============================================================
   CONOR STEWART — DESIGN SYSTEM
   Lossiemouth, Scotland · mechanic, maker & author
   Core tokens + base + component styles. Single source of truth.
   Palette: warm paper · Scottish navy · saltire blue · deep beetroot · heritage gold
   Type: Spectral (display) + Hanken Grotesk (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Marcellus&family=Space+Grotesk:wght@400..700&family=Hanken+Grotesk:wght@400..800&family=Newsreader:ital,opsz,wght@0,6..72,400..600;1,6..72,400..500&display=swap');

/* ============ TOKENS ============ */
:root{
  --paper:#f6f3ec;        /* warm off-white */
  --paper-2:#efe9dd;      /* slightly deeper card */
  --ink:#15171c;          /* near-black text on paper */
  --ink-soft:#5b5d63;
  --navy:#0b1e3a;         /* Scottish deep navy */
  --navy-2:#0f2950;
  --saltire:#0065bd;      /* Scotland flag blue */
  --saltire-soft:#3d8ad6;
  --gold:#cba43e;        /* rich heritage gold for dark sections */
  --cream:#f6f3ec;
  --line:rgba(21,23,28,.12);
  --line-on-dark:rgba(255,255,255,.16);

  /* beetroot accent — deep, locked */
  --beet:#5a163d;
  --beet-deep:#3f0f2b;
  --beet-tint:rgba(90,22,61,.12);

  /* type — swapped via [data-type] */
  --font-display:'Spectral',Georgia,serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --display-weight:600;
  --display-tracking:0;
  --display-leading:1.02;
  --display-transform:none; /* @kind other */
}
[data-beet="deep"]{ --beet:#5a163d; --beet-deep:#3f0f2b; --beet-tint:rgba(90,22,61,.12); }
[data-beet="mid"]{  --beet:#762257; --beet-deep:#551840; --beet-tint:rgba(118,34,87,.12); }
[data-beet="bright"]{ --beet:#962e72; --beet-deep:#6f2154; --beet-tint:rgba(150,46,114,.13); }

[data-type="editorial"]{
  --font-display:'Spectral',Georgia,serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --display-weight:600; --display-tracking:0; --display-leading:1.02; --display-transform:none; /* @kind other */
}
[data-type="modern"]{
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --display-weight:600; --display-tracking:-0.02em; --display-leading:1.0; --display-transform:none; /* @kind other */
}
[data-type="classic"]{
  --font-display:'Marcellus',Georgia,serif;
  --font-body:'Newsreader',Georgia,serif;
  --display-weight:400; --display-tracking:0; --display-leading:1.04; --display-transform:none; /* @kind other */
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-body); font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3{ font-family:var(--font-display); font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking); line-height:var(--display-leading);
  text-transform:var(--display-transform); margin:0; }
a{color:inherit}
.wrap{ max-width:1180px; margin:0 auto; padding:0 clamp(22px, 5vw, 64px); }
.eyebrow{ font-family:var(--font-body); font-weight:700; font-size:.74rem;
  letter-spacing:.22em; text-transform:uppercase; }

/* ============ NAV ============ */
.nav{ position:sticky; top:0; z-index:40; background:rgba(11,30,58,.92);
  backdrop-filter:blur(10px); border-bottom:1px solid var(--line-on-dark); color:var(--cream); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:68px; }
.brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-display);
  font-weight:var(--display-weight); letter-spacing:var(--display-tracking); font-size:1.15rem;
  text-transform:var(--display-transform); white-space:nowrap; color:var(--gold); }
.brand-name{ opacity:0; transform:translateX(-6px); transition:opacity .35s ease, transform .35s ease; }
.nav.scrolled .brand-name{ opacity:1; transform:none; }
.saltire{ width:30px; height:20px; flex:none; border-radius:0; overflow:hidden;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 20' preserveAspectRatio='none'%3E%3Crect width='30' height='20' fill='%230065bd'/%3E%3Cg stroke='white' stroke-width='3.2'%3E%3Cline x1='0' y1='0' x2='30' y2='20'/%3E%3Cline x1='0' y1='20' x2='30' y2='0'/%3E%3C/g%3E%3C/svg%3E");
  background-size:100% 100%; background-repeat:no-repeat; }
.nav-links{ display:flex; gap:30px; align-items:center; }
.nav-links a{ font-size:.9rem; font-weight:600; text-decoration:none; color:var(--gold); opacity:.86; letter-spacing:.01em; white-space:nowrap; }
.nav-links a:hover{ opacity:1; }
.nav-links .pill{ opacity:1; background:var(--beet); color:var(--gold); padding:9px 18px; border-radius:999px; }
.nav-links .pill:hover{ background:var(--beet-deep); }
@media(max-width:760px){ .nav-links a:not(.pill){ display:none; } }

/* ============ HERO ============ */
.hero{ background:var(--navy); color:var(--cream); position:relative; overflow:hidden; }
.hero::after{ content:""; position:absolute; right:-12%; top:-30%; width:60%; height:160%;
  background:radial-gradient(closest-side, rgba(0,101,189,.30), transparent 70%); pointer-events:none; }
.hero .wrap{ display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:center;
  padding-top:88px; padding-bottom:88px; position:relative; z-index:1; }
.hero .eyebrow{ color:var(--gold); margin-bottom:22px; display:flex; align-items:center; gap:12px; }
.hero .eyebrow::before{ content:""; width:17px; height:2px; background:var(--gold); }
.hero h1{ font-size:clamp(2.3rem,6vw,4.6rem); margin-bottom:16px; padding-bottom:.04em; white-space:nowrap; color:var(--gold); }
.hero .roles{ font-family:var(--font-display); font-weight:var(--display-weight);
  font-size:clamp(1.2rem,2.6vw,1.9rem); line-height:1.15; letter-spacing:var(--display-tracking);
  text-transform:var(--display-transform); margin:18px 0 26px; color:var(--gold); }
.hero .roles .beet{ color:var(--gold); }
.hero p.lead{ font-size:1.16rem; line-height:1.65; color:var(--gold); max-width:34em; margin:0 0 34px; }
.hero p.lead b{ color:var(--gold); font-weight:600; }
.cta-row{ display:flex; gap:14px; flex-wrap:wrap; }
.btn{ font-family:var(--font-body); font-weight:700; font-size:.98rem; text-decoration:none;
  padding:15px 26px; border-radius:10px; display:inline-flex; align-items:center; gap:9px;
  transition:transform .15s ease, background .15s ease; }
.btn:hover{ transform:translateY(-2px); }
.btn-beet{ background:var(--beet); color:var(--gold); }
.btn-beet:hover{ background:var(--beet-deep); }
.btn-ghost{ background:transparent; color:var(--gold); border:1.5px solid var(--line-on-dark); }
.btn-ghost:hover{ border-color:var(--saltire-soft); }
.portrait{ aspect-ratio:4/5; border-radius:14px; border:1px solid var(--line-on-dark); overflow:hidden; }
.portrait img{ width:100%; height:100%; object-fit:cover; object-position:8% 45%; display:block; }

/* placeholder imagery */
.ph{ position:relative; display:grid; place-items:center; overflow:hidden;
  background:
    repeating-linear-gradient(45deg, rgba(127,127,127,.10) 0 10px, rgba(127,127,127,0) 10px 20px),
    var(--paper-2); }
.ph.dark{ background:
    repeating-linear-gradient(45deg, rgba(255,255,255,.06) 0 10px, rgba(255,255,255,0) 10px 20px),
    rgba(255,255,255,.04); }
.ph span{ font-family:ui-monospace,Menlo,monospace; font-size:.66rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-soft); background:var(--paper);
  padding:6px 12px; border-radius:999px; border:1px solid var(--line); }
.ph.dark span{ color:#aebbcf; background:rgba(11,30,58,.7); border-color:var(--line-on-dark); }

/* ============ TICKER ============ */
.ticker{ background:var(--beet); color:#fff; overflow:hidden; border-top:3px solid var(--beet-deep);
  border-bottom:3px solid var(--beet-deep); }
.ticker .track{ display:flex; gap:0; white-space:nowrap; animation:scroll 32s linear infinite; }
.ticker .track span{ font-family:'Newsreader',Georgia,serif; font-weight:500; font-style:italic;
  text-transform:none; letter-spacing:.01em; font-size:1.2rem; padding:15px 0; color:var(--gold); }
.ticker .track span::after{ content:"✦"; padding:0 30px; color:rgba(203,164,62,.55); font-size:.6em; font-style:normal; vertical-align:middle; }
@keyframes scroll{ to{ transform:translateX(-50%); } }
@media(prefers-reduced-motion:reduce){ .ticker .track{ animation:none; justify-content:center; } }

/* ============ SECTION SHELL ============ */
section.block{ padding:96px 0; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px;
  margin-bottom:48px; flex-wrap:wrap; }
.section-head .eyebrow{ color:var(--beet); margin-bottom:14px; }
.section-head h2{ font-size:clamp(2.1rem,4.6vw,3.4rem); max-width:14ch; }
.section-head p{ color:var(--ink-soft); max-width:32ch; margin:0; font-size:1.04rem; }

/* ============ PILLARS ============ */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px){ .pillars{ grid-template-columns:1fr; } }
.card{ background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .18s ease, box-shadow .18s ease;
  text-decoration:none; color:inherit; }
.card:hover{ transform:translateY(-4px); box-shadow:0 22px 50px -28px rgba(11,30,58,.5); }
.card .media{ aspect-ratio:16/11; }
.media img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.card .body{ padding:26px 26px 30px; display:flex; flex-direction:column; gap:10px; flex:1; }
.card .kicker{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.card .tag{ font-family:var(--font-body); font-weight:700; font-size:.66rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; }
.card .badge{ font-family:var(--font-body); font-weight:700; font-size:.62rem; letter-spacing:.12em;
  text-transform:uppercase; color:#fff; background:var(--beet); padding:4px 9px; border-radius:999px; white-space:nowrap; }
.card h3{ font-size:1.7rem; }
.card p{ margin:0; color:var(--ink-soft); font-size:1rem; line-height:1.55; flex:1; }
.card .go{ font-weight:700; color:var(--beet); display:inline-flex; align-items:center; gap:7px;
  font-size:.96rem; margin-top:6px; }
.card.book{ background:#efe7d8; } /* warm nod to the book */
.card.book .tag,.card.book p{ color:#6b5a45; }
.card.book .go{ color:#8a5a2b; }
.card.book .badge{ background:#8a5a2b; }

/* ============ STORY ============ */
.story{ background:var(--paper-2); }
.story .grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:64px; align-items:center; }
@media(max-width:900px){ .story .grid{ grid-template-columns:1fr; gap:40px; } }
.story .media{ aspect-ratio:1/1; border-radius:16px; position:sticky; top:100px; align-self:start; overflow:hidden; }
@media(max-width:900px){ .story .media{ position:static; } }
.story h2{ font-size:clamp(2rem,4.4vw,3rem); margin-bottom:8px; }
.story .eyebrow{ color:var(--beet); margin-bottom:18px; }
.story p{ color:var(--ink-soft); margin:0 0 18px; font-size:1.08rem; }
.story p b{ color:var(--ink); font-weight:600; }
.facts{ display:flex; gap:34px; margin-top:30px; flex-wrap:wrap; }
.facts .n{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:2.3rem;
  color:var(--navy); line-height:1; letter-spacing:var(--display-tracking); text-transform:var(--display-transform); }
.facts .l{ font-size:.8rem; color:var(--ink-soft); margin-top:6px; letter-spacing:.04em; }

/* ============ WATCH ============ */
.watch{ background:var(--paper); }
.watch .section-head{ flex-direction:column; align-items:center; text-align:center; gap:0; margin-bottom:38px; }
.watch .section-head h2{ max-width:none; }
.watch .section-head p{ max-width:56ch; margin:14px auto 0; }
.video-frame{ max-width:920px; margin:0 auto; border-radius:16px; overflow:hidden;
  border:1px solid var(--line); background:var(--navy);
  box-shadow:0 30px 70px -34px rgba(11,30,58,.55); }
.video-frame .ratio{ position:relative; width:100%; aspect-ratio:16/9; }
.video-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; }
.watch .video-cap{ text-align:center; color:var(--ink-soft); font-size:.86rem; margin:18px 0 0; }

/* ============ CONTACT ============ */
.contact{ background:var(--navy); color:var(--cream); }
.contact .eyebrow{ color:var(--gold); margin-bottom:18px; }
.contact h2{ font-size:clamp(2.2rem,5vw,3.6rem); max-width:24ch; margin-bottom:20px; color:var(--gold); }
.contact p{ color:var(--gold); max-width:42ch; font-size:1.1rem; margin:0 0 34px; }

/* contact: form + links side by side */
.contact-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:start; }
@media(max-width:880px){ .contact-grid{ grid-template-columns:1fr; gap:38px; } }

.contact-form{ display:flex; flex-direction:column; gap:16px; }
.contact-form .field{ display:flex; flex-direction:column; gap:7px; }
.contact-form .two{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:480px){ .contact-form .two{ grid-template-columns:1fr; } }
.contact-form label{ font-family:var(--font-body); font-weight:700; font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gold); opacity:.85; }
.contact-form .input{ font-family:var(--font-body); font-size:1rem; color:var(--cream);
  background:rgba(255,255,255,.05); border:1px solid var(--line-on-dark); border-radius:11px;
  padding:13px 15px; width:100%; transition:border-color .15s ease, background .15s ease; }
.contact-form .input::placeholder{ color:rgba(246,243,236,.45); }
.contact-form .input:focus{ outline:none; border-color:var(--saltire-soft); background:rgba(255,255,255,.09); }
.contact-form textarea.input{ min-height:130px; resize:vertical; line-height:1.5; }
.contact-form .btn{ align-self:flex-start; border:0; cursor:pointer; margin-top:4px; }
.contact-form .form-note{ font-size:.8rem; color:var(--gold); opacity:.6; margin:2px 0 0; }
.contact-form .form-status{ font-size:.95rem; line-height:1.5; margin:10px 0 0; }
.contact-form .form-status:empty{ display:none; }
.contact-form .form-status.ok{ color:#86d6a6; }
.contact-form .form-status.err{ color:#f3a9a0; }
.contact-form .form-status a{ color:var(--gold); text-decoration:underline; }

.contact-aside .aside-label{ font-family:var(--font-body); font-weight:700; font-size:.7rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--gold); opacity:.85; margin:0 0 14px; }
.links{ display:grid; grid-template-columns:1fr; gap:12px; }
.link-card > span:not(.lc-ic){ order:1; }
.link-card .lc-ic{ order:0; }
.link-card{ display:flex; align-items:center; gap:13px; text-decoration:none; color:var(--gold);
  background:rgba(255,255,255,.05); border:1px solid var(--line-on-dark); border-radius:12px;
  padding:16px 20px; min-width:0; transition:border-color .15s ease, background .15s ease; }
.link-card:hover{ border-color:var(--saltire-soft); background:rgba(255,255,255,.09); }
.link-card .lc-ic{ width:38px; height:38px; border-radius:9px; flex:none; display:grid; place-items:center;
  background:var(--beet); font-family:var(--font-body); font-weight:700; letter-spacing:.01em; color:#fff; font-size:.98rem; }
.link-card .lc-t{ font-weight:700; font-size:.98rem; }
.link-card .lc-s{ font-size:.8rem; color:var(--gold); opacity:.75; overflow-wrap:anywhere; }

/* ============ FOOTER ============ */
footer{ background:#081730; color:var(--gold); padding:40px 0; border-top:1px solid var(--line-on-dark); }
footer .wrap{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; }
footer .brand{ color:var(--gold); }
footer .small{ font-size:.85rem; }

/* ============ TWEAKS ============ */
#tweaks{ position:fixed; right:18px; bottom:18px; z-index:90; width:264px; display:none;
  background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 16px 18px;
  box-shadow:0 24px 60px -22px rgba(11,30,58,.55); font-family:var(--font-body); }
#tweaks.on{ display:block; }
#tweaks h4{ font-family:var(--font-body); font-weight:800; font-size:.7rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink); margin:0 0 14px; }
#tweaks .grp{ margin-bottom:16px; }
#tweaks .lab{ font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px; font-weight:700; }
#tweaks .opts{ display:flex; gap:7px; flex-wrap:wrap; }
#tweaks button.opt{ font-family:var(--font-body); font-size:.82rem; font-weight:600; cursor:pointer;
  border:1px solid var(--line); background:var(--paper); color:var(--ink); padding:8px 12px; border-radius:8px; }
#tweaks button.opt[aria-pressed="true"]{ background:var(--navy); color:#fff; border-color:var(--navy); }
#tweaks .sw{ width:30px; height:30px; border-radius:7px; border:2px solid transparent; cursor:pointer; padding:0; }
#tweaks .sw[aria-pressed="true"]{ border-color:var(--ink); }

/* ============ RESPONSIVE ============ */
@media(max-width:820px){
  .hero .wrap{ grid-template-columns:1fr; gap:30px; padding-top:52px; padding-bottom:58px; }
  .portrait{ width:100%; max-width:460px; margin:0 auto; }
}
@media(max-width:600px){
  .wrap{ padding:0 20px; }
  section.block{ padding:58px 0; }
  .section-head{ margin-bottom:30px; }
  .hero p.lead{ font-size:1.05rem; }
  .ticker .track span{ font-size:1.05rem; }
}
