/* ============================================================
   THE SCALED BRICK — website mockup (hub)
   Theme-aware stylesheet. 4 colour identities, switchable.
   Design language: architectural draughting x editorial.
   ============================================================ */

/* ---- 1. Palette — Light + section colours (LOCKED) ------- */
body{
  --bg:#F6F4EF;              /* warm paper — page ground      */
  --surface:#FFFFFF;         /* white — cards, panels         */
  --surface-2:#EFECE4;       /* warm cream — footer, plates   */
  --text:#1C1D22;            /* near-black ink                */
  --dim:#3F4148;             /* darker mid grey — better legibility on light bg */
  --line:rgba(28,29,34,.14);
  --accent:#8F6410;          /* deep gold — text accent       */
  --on-accent:#FFFFFF;
  --c1:#8F6410;              /* gold   — The Work             */
  --c2:#574AAC;              /* violet — Everplenty           */
  --c3:#246E59;              /* teal   — Learn & Play         */
  --c4:#9F4A20;              /* ember  — Worlds & Games       */
  --c1-tint:#F4ECDC;         /* gold tint                     */
  --c2-tint:#ECE9F5;         /* violet tint                   */
  --c3-tint:#E1EEE9;         /* teal tint                     */
  --c4-tint:#F4E4D9;         /* ember tint                    */
  --logo:none; --shade:rgba(0,0,0,.08);
}

/* ---- 2. Reset -------------------------------------------- */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Open Sans','Helvetica Neue',Arial,sans-serif;
  font-size:17px;
  background:var(--bg);color:var(--text);line-height:1.7;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  transition:background .25s,color .25s;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
h1,h2,h3,h4,.brand .wm{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;}

/* ---- 3. Helpers ------------------------------------------ */
.wrap{max-width:1480px;margin:0 auto;padding:0 56px;}
.wrap.narrow{max-width:1100px;}
.section{padding:92px 0;position:relative;}
.section--tint-c1{background:linear-gradient(180deg,var(--c1-tint) 0%,var(--bg) 100%);}
.section--tint-c2{background:linear-gradient(180deg,var(--c2-tint) 0%,var(--bg) 100%);}
.section--tint-c3{background:linear-gradient(180deg,var(--c3-tint) 0%,var(--bg) 100%);}
.section--tint-c4{background:linear-gradient(180deg,var(--c4-tint) 0%,var(--bg) 100%);}
.rule{height:1px;background:var(--line);border:0;}
.tag{
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
}
.s-head{display:flex;align-items:baseline;gap:18px;margin-bottom:44px;}
.s-head .num{
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:12px;
  color:var(--accent);padding-top:6px;
}
.s-head h2{font-size:clamp(27px,3.3vw,40px);font-weight:600;
  letter-spacing:-.005em;line-height:1.06;}
.s-head .s-note{margin-left:auto;max-width:340px;font-size:15.5px;line-height:1.55;
  color:var(--dim);border-left:1px solid var(--line);padding-left:18px;}

/* ---- 4. Buttons ------------------------------------------ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:12px;letter-spacing:.13em;
  text-transform:uppercase;padding:14px 24px;cursor:pointer;
  border:1px solid var(--accent);transition:.18s ease;
}
.btn--primary{background:var(--text);color:var(--surface);border-color:var(--text);}
.btn--primary:hover{opacity:.86;}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--line);}
.btn--ghost:hover{border-color:var(--text);}

/* ---- 5. Palette switcher (mockup tool, not the site) ----- */
.switch{
  position:fixed;left:50%;transform:translateX(-50%);bottom:20px;z-index:90;
  background:#0d0d0fef;color:#fff;border:1px solid #ffffff26;
  display:flex;align-items:center;gap:6px;padding:9px 12px;border-radius:40px;
  box-shadow:0 8px 30px rgba(0,0,0,.4);
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
}
.switch b{font-size:9px;letter-spacing:.16em;color:#9a9a9a;
  text-transform:uppercase;padding:0 8px 0 4px;}
.switch button{
  cursor:pointer;border:1px solid #ffffff33;background:transparent;
  color:#cfcfcf;font-family:inherit;font-size:10.5px;letter-spacing:.04em;
  padding:7px 12px;border-radius:30px;transition:.15s;
}
.switch button:hover{border-color:#ffffff88;color:#fff;}
.switch button.on{background:#fff;color:#0d0d0f;border-color:#fff;}

/* ---- 6. Header / nav ------------------------------------- */
.site-head{
  position:sticky;top:0;z-index:50;background:var(--bg);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:30px;height:76px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:38px;width:auto;filter:var(--logo);}
.brand .wm{font-weight:600;font-size:15px;letter-spacing:.04em;
  text-transform:uppercase;line-height:1.1;}
.nav-links{display:flex;gap:26px;margin-left:auto;}
.nav-links a{
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11.5px;letter-spacing:.1em;
  text-transform:uppercase;padding:6px 0;color:var(--text);
}
.nav-links a:hover{color:var(--accent);}
.nav-social{display:flex;gap:14px;}
.nav-social a{font-size:12px;color:var(--dim);font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;}
.nav-social a:hover{color:var(--accent);}

/* ---- 7. Hero --------------------------------------------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:32px 32px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 80%);
          mask-image:linear-gradient(180deg,#000,transparent 80%);
  opacity:.7;
}
.hero-grid{position:relative;display:grid;grid-template-columns:1.2fr .8fr;
  gap:50px;padding:80px 0 88px;align-items:center;}
.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
.hero-eyebrow .dash{width:32px;height:1px;background:var(--accent);}
.hero h1{font-size:clamp(32px,4.3vw,50px);font-weight:600;line-height:1.12;
  letter-spacing:-.005em;margin-bottom:22px;}
.hero h1 em{font-style:normal;color:var(--accent);}
.hero .lede{font-size:19px;line-height:1.6;max-width:34em;color:var(--dim);margin-bottom:30px;}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;}
.hero-meta{margin-top:34px;display:flex;gap:24px;flex-wrap:wrap;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--dim);}
.hero-meta span{display:flex;align-items:center;gap:7px;}
.hero-meta span::before{content:"";width:5px;height:5px;background:var(--accent);}

.hero-plate{position:relative;border:1px solid var(--line);
  background:var(--surface);aspect-ratio:1/1.1;
  display:flex;align-items:center;justify-content:center;}
.hero-plate img{width:60%;filter:var(--logo);}
.hero-plate .corner{position:absolute;width:12px;height:12px;}
.hero-plate .corner::before,.hero-plate .corner::after{
  content:"";position:absolute;background:var(--accent);}
.hero-plate .corner::before{width:12px;height:1.5px;}
.hero-plate .corner::after{height:12px;width:1.5px;}
.hero-plate .tl{top:-1px;left:-1px;}
.hero-plate .tr{top:-1px;right:-1px;}
.hero-plate .tr::before{right:0;}.hero-plate .tr::after{right:0;}
.hero-plate .bl{bottom:-1px;left:-1px;}
.hero-plate .bl::before{bottom:0;}.hero-plate .bl::after{bottom:0;}
.hero-plate .br{bottom:-1px;right:-1px;}
.hero-plate .br::before{bottom:0;right:0;}.hero-plate .br::after{bottom:0;right:0;}
.hero-plate .titleblock{position:absolute;left:-1px;right:-1px;bottom:-1px;
  border-top:1px solid var(--line);display:flex;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:9px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--dim);}
.hero-plate .titleblock div{padding:8px 10px;border-right:1px solid var(--line);}
.hero-plate .titleblock div:last-child{border-right:0;margin-left:auto;}

/* ---- 8. Gateway grid (the doors) ------------------------- */
.gates{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.gate{
  background:var(--surface);border:1px solid var(--line);
  padding:30px 28px 26px;display:flex;flex-direction:column;min-height:280px;
  transition:.18s ease;position:relative;border-top:4px solid var(--ga,var(--accent));
}
.gate:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(28,29,34,.07);}
.gate .g-tag{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ga,var(--accent));
  padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:9px;}
.gate .g-tag::before{content:"";width:12px;height:12px;border:1.5px solid var(--ga,var(--accent));
  border-radius:50%;background:radial-gradient(circle at 50% 38%,var(--ga,var(--accent)) 0 4px,transparent 5px);}
.gate h3{font-size:22px;font-weight:600;letter-spacing:0;margin-bottom:10px;}
.gate p{font-size:16px;line-height:1.6;color:var(--dim);margin-bottom:20px;}
.gate .g-more{margin-top:auto;font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ga,var(--accent));font-weight:600;}
.gate:nth-child(1){--ga:var(--c1);}
.gate:nth-child(2){--ga:var(--c3);}
.gate:nth-child(3){--ga:var(--c2);}
.gate:nth-child(4){--ga:var(--c4);}

/* ---- 9. Featured work strip ------------------------------ */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.plate{
  border:1px solid var(--line);
  background:linear-gradient(135deg,var(--c1-tint) 0%,var(--surface-2) 100%);
  aspect-ratio:4/3;position:relative;display:flex;
  align-items:center;justify-content:center;
  overflow:hidden;
}
.plate::before{
  content:"";position:absolute;top:14px;right:14px;width:18px;height:18px;
  background:radial-gradient(circle at 50% 38%,var(--c1) 0 6px,transparent 7px);
  border:1.5px solid var(--c1);border-radius:50%;opacity:.55;
}
.plate::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--c1);
  opacity:.55;
}
.plate.p-c2{background:linear-gradient(135deg,var(--c2-tint) 0%,var(--surface-2) 100%);}
.plate.p-c2::before{background:radial-gradient(circle at 50% 38%,var(--c2) 0 6px,transparent 7px);border-color:var(--c2);}
.plate.p-c2::after{background:var(--c2);}
.plate.p-c3{background:linear-gradient(135deg,var(--c3-tint) 0%,var(--surface-2) 100%);}
.plate.p-c3::before{background:radial-gradient(circle at 50% 38%,var(--c3) 0 6px,transparent 7px);border-color:var(--c3);}
.plate.p-c3::after{background:var(--c3);}
.plate.p-c4{background:linear-gradient(135deg,var(--c4-tint) 0%,var(--surface-2) 100%);}
.plate.p-c4::before{background:radial-gradient(circle at 50% 38%,var(--c4) 0 6px,transparent 7px);border-color:var(--c4);}
.plate.p-c4::after{background:var(--c4);}
.plate .p-tag{position:absolute;top:13px;left:13px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:9px;letter-spacing:.14em;
  color:var(--text);font-weight:600;opacity:.75;}
.plate .p-mid{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);text-align:center;
  padding:0 18px;line-height:1.55;}
.work-cap{margin-top:14px;}
.work-cap h4{font-size:17px;font-weight:600;margin-bottom:4px;}
.work-cap span{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:12.5px;color:var(--dim);}

/* ---- 10. Worlds band ------------------------------------- */
.worlds{background:var(--surface);border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);}
.worlds .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;
  align-items:center;}
.worlds h2{font-size:clamp(28px,3.5vw,44px);font-weight:600;
  letter-spacing:-.005em;line-height:1.07;margin:16px 0 18px;}
.worlds h2 em{font-style:normal;color:var(--accent);}
.worlds p{color:var(--dim);font-size:17px;line-height:1.6;max-width:34em;margin-bottom:26px;}
.worlds-plate{border:1px solid var(--line);aspect-ratio:4/3;
  background:linear-gradient(135deg,var(--c2-tint) 0%,var(--surface-2) 100%);
  position:relative;display:flex;
  align-items:center;justify-content:center;overflow:hidden;}
.worlds-plate::before{content:"";position:absolute;top:16px;right:16px;width:22px;height:22px;
  background:radial-gradient(circle at 50% 38%,var(--c2) 0 7px,transparent 8px);
  border:1.5px solid var(--c2);border-radius:50%;opacity:.6;}
.worlds-plate::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;
  background:var(--c2);opacity:.6;}
.worlds-plate .p-tag{position:absolute;top:14px;left:14px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:9px;letter-spacing:.13em;
  color:var(--text);font-weight:600;opacity:.75;}
.worlds-plate .p-mid{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);text-align:center;
  padding:0 24px;line-height:1.6;}

/* ---- 11. Learn & Play ------------------------------------ */
.lp-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.lp-card{background:var(--surface);border:1px solid var(--line);
  padding:34px 32px;display:flex;flex-direction:column;
  border-top:4px solid var(--la,var(--accent));transition:.18s ease;}
.lp-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(28,29,34,.07);}
.lp-card:nth-child(1){--la:var(--c3);}
.lp-card:nth-child(2){--la:var(--c4);}
.lp-card .c-tag{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--la,var(--accent));
  margin-bottom:14px;}
.lp-card h3{font-size:25px;font-weight:600;letter-spacing:0;margin-bottom:12px;}
.lp-card p{font-size:16px;line-height:1.6;color:var(--dim);margin-bottom:22px;}
.lp-card .c-foot{margin-top:auto;display:flex;justify-content:space-between;
  align-items:baseline;border-top:1px solid var(--line);padding-top:16px;}
.lp-card .price{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:12.5px;
  color:var(--dim);}
.lp-card .price b{font-size:18px;color:var(--text);font-weight:600;}
.lp-card .more{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);}

/* ---- 12. Journal ----------------------------------------- */
.jrn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.jrn{border-top:3px solid var(--ja,var(--accent));padding-top:18px;
  display:flex;flex-direction:column;transition:.15s ease;}
.jrn:hover h4{color:var(--ja,var(--accent));}
.jrn:nth-child(1){--ja:var(--c1);}
.jrn:nth-child(2){--ja:var(--c2);}
.jrn:nth-child(3){--ja:var(--c3);}
.jrn .j-meta{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ja,var(--accent));margin-bottom:9px;font-weight:600;}
.jrn h4{font-size:19px;font-weight:600;line-height:1.28;margin-bottom:10px;transition:.15s;}
.jrn p{font-size:15px;line-height:1.55;color:var(--dim);margin-bottom:14px;}
.jrn .j-more{margin-top:auto;font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ja,var(--accent));font-weight:600;}

/* ---- 13. About teaser ------------------------------------ */
.about{background:var(--surface);border-top:1px solid var(--line);}
.about .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;
  align-items:center;}
.about h2{font-size:clamp(26px,3vw,36px);font-weight:600;
  letter-spacing:-.005em;line-height:1.15;margin-bottom:20px;}
.about h2 em{font-style:normal;color:var(--accent);}
.about p{color:var(--dim);font-size:16.5px;line-height:1.65;margin-bottom:22px;}
.about-plate{border:1px solid var(--line);aspect-ratio:1/1;
  background:linear-gradient(135deg,var(--c4-tint) 0%,var(--surface-2) 100%);
  display:flex;align-items:center;
  justify-content:center;font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10px;
  letter-spacing:.13em;text-transform:uppercase;color:var(--dim);
  position:relative;overflow:hidden;}
.about-plate::before{content:"";position:absolute;top:18px;right:18px;width:22px;height:22px;
  background:radial-gradient(circle at 50% 38%,var(--c4) 0 7px,transparent 8px);
  border:1.5px solid var(--c4);border-radius:50%;opacity:.55;}
.about-plate::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;
  background:var(--c4);opacity:.55;}

/* ---- 14. Footer ------------------------------------------ */
.site-foot{background:var(--surface-2);border-top:1px solid var(--line);
  padding:60px 0 28px;}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:38px;
  padding-bottom:38px;border-bottom:1px solid var(--line);}
.foot-brand img{height:42px;margin-bottom:16px;filter:var(--logo);}
.foot-brand p{font-size:14.5px;line-height:1.55;max-width:26em;color:var(--dim);}
.foot-col h4{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--text);margin-bottom:14px;}
.foot-col a{display:block;font-size:14.5px;color:var(--dim);padding:5px 0;}
.foot-col a:hover{color:var(--accent);}
.foot-legal{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;
  padding-top:22px;font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11.5px;
  letter-spacing:.05em;color:var(--dim);line-height:1.8;}
.foot-legal .disc{max-width:64ch;}

/* ---- 14b. Inner pages ------------------------------------ */
.nav-links a.active{color:var(--accent);}

.page-head{position:relative;overflow:hidden;border-bottom:1px solid var(--line);}
.page-head::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:32px 32px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 88%);
          mask-image:linear-gradient(180deg,#000,transparent 88%);
  opacity:.6;
}
.page-head .wrap{position:relative;padding:64px 40px 58px;}
.page-head .ph-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.page-head .ph-eyebrow .dash{width:30px;height:1px;background:var(--accent);}
.page-head h1{font-size:clamp(32px,3.9vw,48px);font-weight:600;
  letter-spacing:-.005em;line-height:1.12;max-width:18ch;}
.page-head h1 em{font-style:normal;color:var(--accent);}
.page-head .ph-lede{margin-top:18px;font-size:18px;line-height:1.6;color:var(--dim);max-width:46ch;}

.prose{max-width:60ch;}
.prose p{margin-bottom:18px;color:var(--text);font-size:17px;line-height:1.7;}
.prose p.lead{font-size:19px;color:var(--text);}

/* alternating series row */
.series{display:grid;grid-template-columns:1fr 1fr;gap:44px;
  align-items:center;padding:54px 0;border-bottom:1px solid var(--line);}
.series:last-child{border-bottom:0;}
.series.flip .s-media{order:2;}
.series .s-num{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:12px;
  color:var(--accent);margin-bottom:12px;}
.series h3{font-size:clamp(22px,2.6vw,32px);font-weight:600;
  letter-spacing:0;margin-bottom:12px;}
.series h3 em{font-style:normal;color:var(--accent);}
.series p{color:var(--dim);font-size:16.5px;line-height:1.6;margin-bottom:20px;}
.series .s-media{border:1px solid var(--line);
  background:linear-gradient(135deg,var(--c3-tint) 0%,var(--surface-2) 100%);
  aspect-ratio:4/3;position:relative;display:flex;align-items:center;
  justify-content:center;overflow:hidden;}
.series .s-media::before{content:"";position:absolute;top:14px;right:14px;width:18px;height:18px;
  background:radial-gradient(circle at 50% 38%,var(--c3) 0 6px,transparent 7px);
  border:1.5px solid var(--c3);border-radius:50%;opacity:.55;}
.series .s-media::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;
  background:var(--c3);opacity:.55;}
.series .s-media.m-c4{background:linear-gradient(135deg,var(--c4-tint) 0%,var(--surface-2) 100%);}
.series .s-media.m-c4::before{background:radial-gradient(circle at 50% 38%,var(--c4) 0 6px,transparent 7px);border-color:var(--c4);}
.series .s-media.m-c4::after{background:var(--c4);}
.series .s-media .p-tag{position:absolute;top:13px;left:13px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:9px;letter-spacing:.14em;
  color:var(--text);font-weight:600;opacity:.75;}
.series .s-media .p-mid{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);}

/* meta pills */
.pills{display:flex;gap:8px;flex-wrap:wrap;}
.pill{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--dim);border:1px solid var(--line);
  padding:6px 11px;}

/* contact / booking panel */
.panel{background:var(--surface);border:1px solid var(--line);
  padding:40px 38px;}
.panel h3{font-size:25px;font-weight:600;letter-spacing:0;margin-bottom:12px;}
.panel p{color:var(--dim);font-size:16.5px;line-height:1.6;margin-bottom:22px;}

/* ---- 14c. Scales grid (Home) ----------------------------- */
.scales{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.scale-card{background:var(--surface);border:1px solid var(--line);
  padding:24px 20px;display:flex;flex-direction:column;gap:8px;
  transition:.18s ease;border-top:3px solid var(--sa,var(--accent));position:relative;}
.scale-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(28,29,34,.06);}
.scale-card .sc-no{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--sa,var(--accent));}
.scale-card h4{font-size:18px;font-weight:600;letter-spacing:0;}
.scale-card p{font-size:14.5px;color:var(--dim);line-height:1.6;}
.scale-card:nth-child(1){--sa:var(--c1);}
.scale-card:nth-child(2){--sa:var(--c2);}
.scale-card:nth-child(3){--sa:var(--c3);}
.scale-card:nth-child(4){--sa:var(--c4);}
.scale-card:nth-child(5){--sa:#1C1D22;}

/* ---- 14d. Footer subscribe ------------------------------- */
.foot-sub{padding:30px 0 34px;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;
  margin-bottom:38px;}
.foot-sub .fs-copy h4{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:17px;font-weight:600;margin-bottom:6px;letter-spacing:0;}
.foot-sub .fs-copy p{font-size:15px;line-height:1.55;color:var(--dim);}
.foot-sub form{display:flex;gap:8px;}
.foot-sub input[type=email]{flex:1;font-family:inherit;font-size:14px;
  background:var(--surface);border:1px solid var(--line);
  padding:13px 14px;color:var(--text);}
.foot-sub input[type=email]:focus{outline:none;border-color:var(--text);}
.foot-sub button{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  background:var(--text);color:var(--surface);border:1px solid var(--text);
  padding:13px 22px;cursor:pointer;}
.foot-sub button:hover{opacity:.86;}

/* ---- 14e. Filters (Work) --------------------------------- */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px;align-items:center;
  padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.filters .f-label{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);
  margin:0 6px 0 0;}
.filters .f-grp{display:flex;gap:6px;flex-wrap:wrap;margin-right:18px;}
.filter-chip{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  background:var(--surface);border:1px solid var(--line);padding:7px 12px;
  cursor:pointer;color:var(--text);transition:.15s;}
.filter-chip:hover{border-color:var(--text);}
.filter-chip.on{background:var(--text);color:var(--surface);border-color:var(--text);}
.hide{display:none!important;}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.port{display:flex;flex-direction:column;}
.port .plate{margin-bottom:14px;}

/* ---- 14f. Form fields ----------------------------------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field.full{grid-column:1/-1;}
.field label{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);}
.field input,.field select,.field textarea{font-family:inherit;font-size:14.5px;
  background:var(--surface);border:1px solid var(--line);padding:12px 14px;
  color:var(--text);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;
  border-color:var(--text);}
.field textarea{min-height:140px;resize:vertical;}

/* ---- 14g. Acknowledgement of Country -------------------- */
.aoc{background:var(--surface);border:1px solid var(--line);padding:34px 32px;
  text-align:center;border-top:3px solid var(--c4);}
.aoc .aoc-mark{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--c4);margin-bottom:14px;}
.aoc h3{font-size:18px;font-weight:600;line-height:1.45;max-width:52ch;
  margin:0 auto 12px;color:var(--text);}
.aoc p{font-size:13.5px;color:var(--dim);max-width:56ch;margin:0 auto;}

/* ---- 14h. Calendar & events (Enrol) --------------------- */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);margin-bottom:36px;}
.cal-h{background:var(--surface-2);padding:9px 6px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--dim);text-align:center;}
.cal-day{background:var(--surface);padding:8px 9px 12px;min-height:108px;
  position:relative;font-size:12px;overflow:hidden;}
.cal-day .d-no{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;color:var(--dim);margin-bottom:5px;}
.cal-day.out{background:var(--bg);}
.cal-day .ev{display:block;font-size:10px;background:var(--surface-2);
  border-left:2px solid var(--accent);padding:3px 5px;margin-top:3px;
  line-height:1.25;color:var(--text);
  word-break:break-word;overflow-wrap:anywhere;hyphens:auto;}
.cal-day .ev.cal-in{border-left-color:var(--c3);background:var(--c3-tint);}
.cal-day .ev.cal-out{border-left-color:var(--c4);background:var(--c4-tint);}

.events{display:flex;flex-direction:column;border-top:1px solid var(--line);}
.event{display:grid;grid-template-columns:130px 1fr 110px;gap:18px;
  padding:20px 0;border-bottom:1px solid var(--line);align-items:center;}
.event .ev-date{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:14px;color:var(--text);font-weight:500;}
.event .ev-date small{display:block;font-size:10.5px;letter-spacing:.12em;
  color:var(--dim);text-transform:uppercase;margin-top:3px;font-weight:400;}
.event .ev-title h4{font-size:16px;font-weight:600;margin-bottom:4px;}
.event .ev-title span{font-size:12.5px;color:var(--dim);}
.event .ev-badge{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 10px;border:1px solid var(--line);text-align:center;
  white-space:nowrap;}
.event .ev-badge.in{color:var(--c3);border-color:var(--c3);}
.event .ev-badge.out{color:var(--c4);border-color:var(--c4);}

.legend{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:24px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);}
.legend span{display:flex;align-items:center;gap:8px;}
.legend span::before{content:"";width:10px;height:10px;}
.legend .lg-in::before{background:var(--c3);}
.legend .lg-out::before{background:var(--c4);}

/* ---- 14i. The Scaled Times (Journal) -------------------- */
.times-mast{border-top:6px double var(--text);border-bottom:1px solid var(--text);
  padding:24px 0 16px;margin-bottom:34px;text-align:center;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;}
.times-mast .mast-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:8px;}
.times-mast .mast-title{font-size:clamp(34px,4.6vw,50px);font-weight:600;
  letter-spacing:.02em;line-height:1;color:var(--text);}
.times-mast .mast-meta{margin-top:10px;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--dim);display:flex;justify-content:center;
  gap:18px;flex-wrap:wrap;}
.times-lead{display:grid;grid-template-columns:1.6fr 1fr;gap:42px;
  padding-bottom:42px;border-bottom:1px solid var(--line);margin-bottom:42px;
  align-items:start;}
.times-lead .ld-plate{border:1px solid var(--line);
  background:linear-gradient(135deg,var(--c1-tint) 0%,var(--surface-2) 100%);
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;color:var(--dim);position:relative;overflow:hidden;}
.times-lead .ld-plate::before{content:"";position:absolute;top:16px;right:16px;width:22px;height:22px;
  background:radial-gradient(circle at 50% 38%,var(--c1) 0 7px,transparent 8px);
  border:1.5px solid var(--c1);border-radius:50%;opacity:.6;}
.times-lead .ld-plate::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;
  background:var(--c1);opacity:.6;}
.times-lead .ld-body .meta{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px;}
.times-lead .ld-body h3{font-size:clamp(22px,2.6vw,30px);font-weight:600;
  letter-spacing:0;margin-bottom:12px;line-height:1.2;}
.times-lead .ld-body p.lead{font-size:15.5px;color:var(--text);margin-bottom:10px;}
.times-lead .ld-body p{font-size:14px;color:var(--dim);margin-bottom:10px;}
.times-cols{column-count:3;column-gap:36px;column-rule:1px solid var(--line);}
.times-cols .article{break-inside:avoid;padding-bottom:24px;margin-bottom:24px;
  border-bottom:1px solid var(--line);}
.times-cols .article:last-child{border-bottom:0;}
.times-cols .article .a-meta{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--aa,var(--accent));margin-bottom:6px;font-weight:600;}
.times-cols .article h4{font-size:17px;font-weight:600;line-height:1.25;margin-bottom:6px;}
.times-cols .article h4 a{color:inherit;background-image:linear-gradient(var(--aa,var(--accent)),var(--aa,var(--accent)));
  background-size:0 1.5px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .25s;padding-bottom:1px;}
.times-cols .article h4 a:hover{background-size:100% 1.5px;}
.times-cols .article p{font-size:13px;color:var(--dim);line-height:1.5;margin-bottom:8px;}
.times-cols .article .a-more{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--aa,var(--accent));font-weight:600;}
.times-cols .article:nth-child(3n+1){--aa:var(--c1);}
.times-cols .article:nth-child(3n+2){--aa:var(--c2);}
.times-cols .article:nth-child(3n+3){--aa:var(--c3);}

/* ---- 14l. Essay (article reading page) ----------------- */
.essay{max-width:760px;margin:0 auto;padding:20px 0 30px;}
.essay .e-meta{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;}
.essay .e-meta .dot{width:5px;height:5px;background:var(--accent);border-radius:50%;}
.essay h1{font-size:clamp(28px,3.6vw,42px);font-weight:600;line-height:1.18;
  letter-spacing:-.005em;margin-bottom:18px;}
.essay .e-stand{font-size:18px;color:var(--text);line-height:1.55;margin-bottom:22px;
  font-style:italic;}
.essay .e-byline{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:34px;
  padding-bottom:18px;border-bottom:1px solid var(--line);}
.essay .e-hero{margin:0 0 30px;border:1px solid var(--line);aspect-ratio:16/9;
  background:linear-gradient(135deg,var(--c1-tint) 0%,var(--surface-2) 100%);
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--dim);}
.essay .e-hero::before{content:"";position:absolute;top:18px;right:18px;width:22px;height:22px;
  background:radial-gradient(circle at 50% 38%,var(--c1) 0 7px,transparent 8px);
  border:1.5px solid var(--c1);border-radius:50%;opacity:.6;}
.essay .e-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;
  background:var(--c1);opacity:.6;}
.essay .e-body p{font-size:18px;line-height:1.75;color:var(--text);margin-bottom:20px;}
.essay .e-body p.lead{font-size:19.5px;}
.essay .e-body p.lead::first-line{font-variant:small-caps;letter-spacing:.04em;}
.essay .e-body h2{font-size:24px;font-weight:600;margin:36px 0 14px;letter-spacing:-.003em;}
.essay .e-body blockquote{margin:28px 0;padding:20px 26px;border-left:3px solid var(--c1);
  background:var(--c1-tint);font-style:italic;font-size:17px;line-height:1.6;color:var(--text);}
.essay .e-tags{display:flex;gap:10px;flex-wrap:wrap;margin:36px 0 18px;}
.essay .e-tags .pill{color:var(--accent);border-color:var(--accent);}
.essay .e-foot{border-top:1px solid var(--line);padding-top:24px;margin-top:30px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;}
.essay .e-foot a{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11px;
  letter-spacing:.13em;text-transform:uppercase;color:var(--accent);font-weight:600;}

/* ---- 14k. Safe-to-sit-at trust band --------------------- */
.safe{background:var(--surface);border-top:3px solid var(--c3);
  border-bottom:1px solid var(--line);}
.safe .wrap{padding:56px 40px;}
.safe .s-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.safe .s-eyebrow .dash{width:30px;height:1px;background:var(--c3);}
.safe .s-eyebrow .tag{color:var(--c3);}
.safe h2{font-size:clamp(24px,2.6vw,32px);font-weight:600;
  letter-spacing:-.005em;margin-bottom:32px;max-width:30ch;}
.safe-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;}
.safe-item{border-left:2px solid var(--c3);padding-left:18px;}
.safe-item .si-label{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--c3);margin-bottom:9px;}
.safe-item h4{font-size:16.5px;font-weight:600;line-height:1.3;margin-bottom:8px;}
.safe-item p{font-size:14.5px;color:var(--dim);line-height:1.6;}

/* ---- 14j. Timeline (About) ------------------------------ */
.timeline{position:relative;padding-left:24px;border-left:1px solid var(--line);}
.tl-item{position:relative;padding:16px 0 16px 18px;}
.tl-item::before{content:"";position:absolute;left:-29px;top:22px;
  width:9px;height:9px;background:var(--accent);border-radius:50%;}
.tl-item .tl-year{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;letter-spacing:.14em;color:var(--accent);
  text-transform:uppercase;margin-bottom:5px;}
.tl-item h4{font-size:18px;font-weight:600;margin-bottom:6px;}
.tl-item p{font-size:15.5px;line-height:1.55;color:var(--dim);}

/* ---- 14m. Commissions band (Home) + page --------------- */
.commish{background:linear-gradient(180deg,var(--c4-tint) 0%,var(--surface) 100%);
  border-top:3px solid var(--c4);border-bottom:1px solid var(--line);}
.commish .wrap{padding:80px 56px;}
.commish-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;}
.commish h2{font-size:clamp(28px,3.4vw,42px);font-weight:600;letter-spacing:-.005em;
  line-height:1.08;margin:14px 0 18px;}
.commish h2 em{font-style:normal;color:var(--c4);}
.commish p{color:var(--dim);font-size:17px;line-height:1.6;max-width:36em;margin-bottom:20px;}
.commish-plate{border:1px solid var(--line);aspect-ratio:4/3;
  background:linear-gradient(135deg,var(--c4-tint) 0%,var(--surface-2) 100%);
  position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.commish-plate::before{content:"";position:absolute;top:16px;right:16px;width:22px;height:22px;
  background:radial-gradient(circle at 50% 38%,var(--c4) 0 7px,transparent 8px);
  border:1.5px solid var(--c4);border-radius:50%;opacity:.6;}
.commish-plate::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;
  background:var(--c4);opacity:.6;}
.commish-plate .p-tag{position:absolute;top:14px;left:14px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:9px;letter-spacing:.13em;
  color:var(--text);font-weight:600;opacity:.75;}
.commish-plate .p-mid{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);text-align:center;
  padding:0 24px;line-height:1.6;}
.commish-process{display:flex;gap:18px;flex-wrap:wrap;margin:18px 0 24px;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--c4);}
.commish-process span{display:flex;align-items:center;gap:8px;font-weight:600;}
.commish-process span::after{content:"→";color:var(--dim);opacity:.5;}
.commish-process span:last-child::after{display:none;}

/* commission pipeline (full page) */
.cm-pipe{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:36px 0 24px;}
.cm-step{background:var(--surface);border:1px solid var(--line);padding:24px 22px;
  border-top:3px solid var(--c4);position:relative;}
.cm-step .cm-no{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--c4);margin-bottom:8px;font-weight:600;}
.cm-step h4{font-size:18px;font-weight:600;margin-bottom:8px;}
.cm-step p{font-size:15px;color:var(--dim);line-height:1.6;}

.cm-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:18px 0 0;}
.cm-tier{background:var(--surface);border:1px solid var(--line);padding:30px 28px;
  display:flex;flex-direction:column;border-top:4px solid var(--ta,var(--c4));}
.cm-tier:nth-child(1){--ta:var(--c3);}
.cm-tier:nth-child(2){--ta:var(--c1);}
.cm-tier:nth-child(3){--ta:var(--c4);}
.cm-tier .t-tag{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ta);margin-bottom:12px;font-weight:600;}
.cm-tier h3{font-size:23px;font-weight:600;margin-bottom:12px;}
.cm-tier p.t-lede{color:var(--dim);font-size:15.5px;line-height:1.55;margin-bottom:16px;}
.cm-tier ul{display:flex;flex-direction:column;gap:8px;font-size:15px;line-height:1.5;color:var(--text);}
.cm-tier ul li{padding-left:18px;position:relative;}
.cm-tier ul li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;
  border:1.5px solid var(--ta);border-radius:50%;
  background:radial-gradient(circle at 50% 38%,var(--ta) 0 3px,transparent 4px);}
.cm-tier .t-from{margin-top:auto;padding-top:18px;border-top:1px solid var(--line);
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:12.5px;color:var(--dim);}
.cm-tier .t-from b{font-size:18px;color:var(--text);font-weight:600;}

/* ---- 14n. Work card + work index ------------------------ */
.work-card{display:flex;flex-direction:column;color:inherit;text-decoration:none;
  transition:.18s ease;}
.work-card:hover{transform:translateY(-3px);}
.work-card:hover .plate{box-shadow:0 14px 36px rgba(28,29,34,.1);}
.work-meta{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 0;
  font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:10.5px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--dim);}
.work-meta .badge-bdp{color:var(--c2);border:1px solid var(--c2);
  padding:2px 8px;letter-spacing:.14em;font-weight:600;}

/* ---- 14o. Single work template -------------------------- */
.work-detail{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;padding:18px 0 30px;}
.work-detail .wd-hero{border:1px solid var(--line);aspect-ratio:4/3;overflow:hidden;
  background:linear-gradient(135deg,var(--c1-tint) 0%,var(--surface-2) 100%);
  position:relative;display:flex;align-items:center;justify-content:center;}
.work-detail .wd-hero img{width:100%;height:100%;object-fit:cover;display:block;}
.work-detail .wd-meta .wd-tag{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);
  margin-bottom:14px;font-weight:600;}
.work-detail .wd-meta h1{font-size:clamp(28px,3.4vw,40px);font-weight:600;
  letter-spacing:-.005em;line-height:1.12;margin-bottom:14px;}
.work-detail .wd-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  margin:22px 0;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.work-detail .wd-stat .lbl{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);margin-bottom:4px;}
.work-detail .wd-stat .val{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:18px;color:var(--text);font-weight:600;}
.work-detail .wd-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px;}
.work-detail .wd-links a{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;
  font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);
  border:1px solid var(--line);padding:8px 12px;}
.work-detail .wd-links a:hover{border-color:var(--accent);}
.work-body{max-width:760px;margin:0 auto;padding:30px 0;}
.work-body p,.work-body li{font-size:16.5px;line-height:1.75;color:var(--text);margin-bottom:16px;}
.work-body h2{font-size:24px;font-weight:600;margin:34px 0 14px;}
.work-body h3{font-size:20px;font-weight:600;margin:28px 0 10px;}
.work-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;
  margin:30px 0;}
.work-gallery a{border:1px solid var(--line);aspect-ratio:4/3;overflow:hidden;display:block;
  background:var(--surface-2);}
.work-gallery img{width:100%;height:100%;object-fit:cover;display:block;
  transition:.25s ease;}
.work-gallery a:hover img{transform:scale(1.03);}

/* ---- 14p. YouTube embed + markdown images -------------- */
.yt-embed{position:relative;width:100%;padding-bottom:56.25%;margin:24px 0;
  border:1px solid var(--line);background:#000;}
.yt-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;display:block;}
.md-img{margin:24px 0;border:1px solid var(--line);background:var(--surface);}
.md-img img{width:100%;height:auto;display:block;}
.md-img figcaption{font-family:'Exo 2','Helvetica Neue',Arial,sans-serif;font-size:11.5px;
  letter-spacing:.04em;color:var(--dim);padding:10px 14px;border-top:1px solid var(--line);
  background:var(--surface-2);}

/* Responsive add-ons */
@media(max-width:980px){
  .commish-wrap{grid-template-columns:1fr;gap:30px;}
  .cm-pipe{grid-template-columns:1fr 1fr;}
  .cm-tiers{grid-template-columns:1fr;}
  .work-detail{grid-template-columns:1fr;gap:24px;}
}

/* ---- 15. Responsive -------------------------------------- */
@media(max-width:980px){
  .hero-grid,.worlds .wrap,.about .wrap{grid-template-columns:1fr;gap:38px;}
  .gates{grid-template-columns:repeat(2,1fr);}
  .work-grid,.jrn-grid{grid-template-columns:1fr;}
  .lp-grid{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr;}
  .nav-links,.nav-social{display:none;}
  .s-head{flex-wrap:wrap;}.s-head .s-note{margin-left:0;}
  .series{grid-template-columns:1fr;gap:26px;}
  .series.flip .s-media{order:0;}
  .scales{grid-template-columns:repeat(2,1fr);}
  .foot-sub{grid-template-columns:1fr;}
  .port-grid{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
  .times-lead{grid-template-columns:1fr;gap:24px;}
  .times-cols{column-count:1;}
  .event{grid-template-columns:90px 1fr;gap:10px 14px;}
  .event .ev-badge{grid-column:1/-1;justify-self:start;}
  .cal{font-size:10px;}
  .cal-day{padding:6px 5px;min-height:64px;}
  .cal-day .ev{font-size:9px;}
  .safe-grid{grid-template-columns:repeat(2,1fr);gap:18px;}
}


/* ---- 16. Small-screen typography + spacing -------------- */
@media(max-width:760px){
  body{font-size:16.5px;line-height:1.65;}
  .wrap{padding:0 22px;}
  .section{padding:64px 0;}
  .hero .lede,.page-head .ph-lede{font-size:17px;}
  .gate p,.lp-card p,.panel p,.series p,.worlds p,.commish p,.about p{font-size:16px;}
  .prose p{font-size:16.5px;}
  .essay .e-body p{font-size:17px;}
  .scale-card p{font-size:14.5px;}
  .safe-item p,.foot-brand p,.foot-col a{font-size:14.5px;}
  .scales{grid-template-columns:1fr;}
  .commish .wrap{padding:54px 22px;}
}

@media(max-width:480px){
  body{font-size:16px;}
  .wrap{padding:0 18px;}
  .section{padding:52px 0;}
  .hero h1{font-size:32px;line-height:1.15;}
  .page-head h1{font-size:30px;line-height:1.15;}
  .hero .lede,.page-head .ph-lede{font-size:16.5px;}
  .gates{grid-template-columns:1fr;}
  .hero-cta{flex-wrap:wrap;}
  .btn{padding:11px 18px;}
}
