/* ============================================================
   THERAPY SOUND — THE BOARD · wall.css
   Grid model, wall surfaces, page chrome, SEO block
   Mobile-first. v3 brand system.
   ============================================================ */

:root{
  --cream:#e8dcc4;
  --cream-2:#f1e7d2;
  --cream-3:#d8c9a8;
  --terra:#c4623d;
  --terra-2:#8c3d23;
  --terra-3:#e08b65;
  --char:#0a0a0a;
  --char-2:#1a1714;
  --char-3:#3a342c;
  --teal:#6b9b94;
  --teal-2:#3f6a64;
  --ink-soft:#6a5f4a;
  --rule:rgba(10,10,10,.14);
  --postit:#e8c95a;

  /* board geometry — JS/tweaks override these */
  --cols:4;
  --gut:8px;
  --row-ratio:0.625;          /* row height = col width × ratio → 1×2 slot ≈ 4:5 */
  --tilt-mult:1;              /* imperfection intensity 0–2 */
  --density:1;                /* cell scale via max-width of wall */

  --f-head:'Archivo',sans-serif;
  --f-mono:'JetBrains Mono',monospace;
  --f-serif:'Instrument Serif',serif;
  --f-body:'Inter',sans-serif;
  --f-marker:'Caveat',cursive;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--char);font-family:var(--f-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}

.kicker{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.kicker.t{color:var(--teal-2)}
.kicker.r{color:var(--terra-2)}

/* outlined mono pill tag */
.tpill{display:inline-flex;align-items:center;line-height:1;border:1.5px solid currentColor;color:var(--teal-2);padding:5px 10px;border-radius:999px;font-family:var(--f-mono);font-weight:600;font-size:10px;letter-spacing:.2em;text-transform:uppercase;white-space:nowrap}
.tpill.terra{color:var(--terra-2)}
.tpill.char{color:var(--char)}
.tpill.cream{color:var(--cream)}

/* ============================================================
   GLOBAL NAV (only chrome on the page)
   ============================================================ */
.nav{position:sticky;top:0;z-index:60;background:var(--char);color:var(--cream);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 16px;border-bottom:1px solid rgba(232,220,196,.12)}
.nav .brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--cream)}
.nav .tmark{width:32px;height:32px;border-radius:50%;background:var(--teal);display:grid;place-items:center;color:var(--cream);font-family:var(--f-head);font-weight:900;font-size:18px;padding-bottom:2px;flex:none}
.nav .brand b{font-family:var(--f-head);font-weight:900;font-size:15px;letter-spacing:-.02em;text-transform:uppercase;line-height:1}
.nav .links{display:flex;gap:4px;align-items:center}
.nav .links a{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(232,220,196,.6);text-decoration:none;padding:8px 9px;font-weight:500;white-space:nowrap}
.nav .links a.on{color:var(--cream);border-bottom:2px solid var(--teal)}
@media (max-width:560px){.nav .links a.hide-s{display:none}}

/* ============================================================
   MASTHEAD — H1 over the wall
   ============================================================ */
.mast{background:var(--char);color:var(--cream);padding:34px 16px 26px;position:relative;overflow:hidden}
.mast .in{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.mast .toptags{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.mast h1{font-family:var(--f-head);font-weight:900;font-size:clamp(38px,9vw,92px);line-height:.88;letter-spacing:-.03em;text-transform:uppercase;max-width:14ch}
.mast h1 em{font-style:normal;color:var(--teal);font-weight:900;text-transform:uppercase;letter-spacing:inherit}
.mast .sub{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap}
.mast .lede{max-width:46ch;color:rgba(232,220,196,.72);font-size:14px}
.mast .wallmeta{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,220,196,.55);font-weight:500;display:flex;gap:16px;flex-wrap:wrap}
.mast .wallmeta b{color:var(--cream);font-weight:600}

/* ============================================================
   THE WALL
   ============================================================ */
.wall-zone{position:relative;padding:18px 10px 30px;transition:background .3s}
.wall-zone .wall-head{max-width:1280px;margin:0 auto 12px;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0 4px}
.wall-zone h2.wall-h{font-family:var(--f-head);font-weight:900;font-size:13px;letter-spacing:.04em;text-transform:uppercase}

/* — surfaces — */
.wall-zone[data-surface="charcoal"]{background:#161311;color:var(--cream)}
.wall-zone[data-surface="cork"]{background:#a87d52;color:var(--char)}
.wall-zone[data-surface="cream"]{background:#ddcfae;color:var(--char)}

.wall{position:relative;max-width:calc(1280px * var(--density));margin:0 auto;container-type:inline-size;border-radius:3px;padding:14px;transition:background .3s}
@media (min-width:900px){
  :root{--cols:6;--gut:14px}
  .wall{padding:22px}
  .wall-zone{padding:24px 24px 44px}
}

/* surface inner texture */
.wall::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;border-radius:inherit;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.16;mix-blend-mode:overlay}
.wall::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;border-radius:inherit;
  background:radial-gradient(ellipse at 50% 0%,rgba(255,255,255,.05),transparent 55%),radial-gradient(ellipse at 50% 115%,rgba(0,0,0,.34),transparent 60%)}

[data-surface="charcoal"] .wall{background:#1c1916;box-shadow:inset 0 0 0 1px rgba(232,220,196,.07), inset 0 2px 26px rgba(0,0,0,.55)}
[data-surface="cork"] .wall{background:
  radial-gradient(circle at 18% 22%,rgba(80,50,24,.28) 0 2px,transparent 3px),
  radial-gradient(circle at 64% 11%,rgba(255,230,190,.2) 0 1.6px,transparent 2.6px),
  radial-gradient(circle at 41% 57%,rgba(80,50,24,.24) 0 2.4px,transparent 3.4px),
  radial-gradient(circle at 86% 44%,rgba(255,230,190,.16) 0 1.4px,transparent 2.4px),
  radial-gradient(circle at 9% 81%,rgba(80,50,24,.26) 0 2px,transparent 3px),
  radial-gradient(circle at 73% 86%,rgba(60,36,16,.3) 0 2.2px,transparent 3.2px),
  #b58a5c;
  background-size:67px 53px,49px 71px,83px 61px,59px 47px,71px 89px,91px 67px,auto;
  box-shadow:inset 0 0 0 1px rgba(60,36,16,.4), inset 0 2px 22px rgba(60,36,16,.5)}
[data-surface="cork"] .wall{border:10px solid #6e4a26;border-radius:4px}
[data-surface="cream"] .wall{background:#e3d6b6;box-shadow:inset 0 0 0 1px rgba(10,10,10,.12), inset 0 2px 20px rgba(106,95,74,.3)}

/* — the slot grid — */
.grid{position:relative;z-index:1;display:grid;
  grid-template-columns:repeat(var(--cols),1fr);
  gap:var(--gut);
  --colw:calc((100cqw - 28px - (var(--cols) - 1) * var(--gut)) / var(--cols));
  grid-auto-rows:calc(var(--colw) * var(--row-ratio));
}
@media (min-width:900px){
  .grid{--colw:calc((100cqw - 44px - (var(--cols) - 1) * var(--gut)) / var(--cols))}
}

/* empty slot — gap that invites filling */
.slot-empty{position:relative;border-radius:2px;cursor:pointer;transition:box-shadow .2s, background .2s}
.slot-empty::after{content:"";position:absolute;left:50%;top:50%;width:6px;height:6px;border-radius:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.55);box-shadow:inset 0 1px 2px rgba(0,0,0,.8), 0 1px 0 rgba(255,255,255,.07);opacity:.7}
.slot-empty:hover{background:rgba(127,127,127,.09)}
.slot-empty:hover::after{opacity:1}

/* move mode — open slots glow */
body.moving .slot-empty{background:rgba(107,155,148,.13);box-shadow:inset 0 0 0 1.5px var(--teal);animation:slotpulse 1.4s ease-in-out infinite}
body.moving .slot-empty::after{opacity:0}
@keyframes slotpulse{0%,100%{box-shadow:inset 0 0 0 1.5px rgba(107,155,148,.9)}50%{box-shadow:inset 0 0 0 1.5px rgba(107,155,148,.35)}}
body.moving .pin-wrap:not(.is-moving){opacity:.4;filter:saturate(.6)}
body.moving .pin-wrap.is-moving{z-index:40}
body.moving .pin-wrap.is-moving .pin-obj{outline:2px dashed var(--teal);outline-offset:4px}

/* move banner */
.move-bar{position:fixed;left:50%;bottom:86px;transform:translateX(-50%);z-index:70;background:var(--char);color:var(--cream);display:none;align-items:center;gap:14px;padding:10px 12px 10px 16px;border-radius:999px;box-shadow:0 14px 34px rgba(0,0,0,.4);font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;white-space:nowrap}
body.moving .move-bar{display:flex}
.move-bar button{border:1.5px solid rgba(232,220,196,.4);border-radius:999px;padding:7px 12px;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);font-weight:600}

/* wall progress / archive note */
.wall-foot{max-width:1280px;margin:14px auto 0;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:0 4px;flex-wrap:wrap}
.wall-foot .fillbar{flex:1;min-width:120px;max-width:300px;height:4px;background:rgba(127,127,127,.25);border-radius:99px;overflow:hidden}
.wall-foot .fillbar i{display:block;height:100%;background:var(--teal);border-radius:99px}
[data-surface="charcoal"] .wall-foot .kicker{color:rgba(232,220,196,.55)}
[data-surface="cork"] .wall-foot .kicker{color:rgba(40,24,8,.75)}

/* ============================================================
   FAB — pin something
   ============================================================ */
/* fab — replaced by .pinbar (board/pinbar.css); kept for spec sheet only */
.fab{display:none}

/* ============================================================
   BELOW THE WALL — crawlable text
   ============================================================ */
.below{max-width:1100px;margin:0 auto;padding:54px 18px 0}
.below section{margin-bottom:56px}
.below h2{font-family:var(--f-head);font-weight:900;font-size:clamp(26px,4.6vw,44px);line-height:.95;letter-spacing:-.025em;text-transform:uppercase;margin-bottom:16px}
.below h2 em{font-style:normal;color:var(--teal-2);font-weight:900;text-transform:uppercase}
.below .secrow{display:flex;align-items:baseline;gap:14px;border-bottom:1px solid var(--rule);padding-bottom:14px;margin-bottom:20px}
.below .secrow .num{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;color:var(--teal-2);font-weight:600}
.below p{max-width:62ch;color:var(--char-2);margin-bottom:12px;font-size:14.5px;line-height:1.65;text-wrap:pretty}

/* how to pin steps */
.steps{display:grid;grid-template-columns:1fr;gap:14px;counter-reset:st}
@media (min-width:760px){.steps{grid-template-columns:repeat(3,1fr)}}
.steps li{list-style:none;counter-increment:st;background:var(--cream-2);border:1px solid var(--rule);padding:20px;position:relative}
.steps li::before{content:"0" counter(st);font-family:var(--f-head);font-weight:900;font-size:30px;letter-spacing:-.03em;color:var(--teal-2);display:block;margin-bottom:10px}
.steps li b{font-family:var(--f-head);font-weight:900;font-size:16px;text-transform:uppercase;letter-spacing:-.01em;display:block;margin-bottom:6px}
.steps li span{font-size:13px;color:var(--ink-soft);line-height:1.55;display:block}

/* house rules */
.rules{display:flex;flex-direction:column}
.rules li{list-style:none;display:flex;gap:14px;align-items:baseline;padding:13px 2px;border-bottom:1px solid var(--rule);font-family:var(--f-head);font-weight:900;font-size:clamp(16px,2.6vw,22px);letter-spacing:-.015em;text-transform:uppercase;line-height:1.1}
.rules li i{font-family:var(--f-mono);font-style:normal;font-size:10px;letter-spacing:.18em;color:var(--teal-2);font-weight:600;flex:none}
.rules li em{font-style:normal;color:var(--teal-2)}

/* journal rail — one row, 1.5 cards visible, arrow scrolls */
.jrail-wrap{position:relative}
.journal{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
.journal::-webkit-scrollbar{display:none}
.jcard{flex:0 0 62%;max-width:340px;scroll-snap-align:start;background:var(--char);color:var(--cream);padding:18px;display:flex;flex-direction:column;gap:12px;min-height:200px;text-decoration:none;transition:transform .15s}
@media (min-width:760px){.jcard{flex-basis:300px}}
.jcard:hover{transform:translateY(-3px)}
.jrail-next{position:absolute;right:-6px;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;background:var(--teal-2);color:var(--cream);display:grid;place-items:center;font-family:var(--f-head);font-weight:900;font-size:18px;box-shadow:0 8px 20px rgba(0,0,0,.35);cursor:pointer;transition:transform .12s,opacity .2s}
.jrail-next:active{transform:translateY(-50%) scale(.92)}
.jrail-next.hidden{opacity:0;pointer-events:none}
.jcard .ph{height:96px;background:#241f1a;position:relative;overflow:hidden}
.jcard .ph::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent 0 7px,rgba(232,220,196,.05) 7px 9px)}
.jcard .ph::after{content:attr(data-label);position:absolute;left:10px;bottom:8px;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,220,196,.4);font-weight:500}
.jcard h3{font-family:var(--f-head);font-weight:900;font-size:19px;line-height:1;letter-spacing:-.02em;text-transform:uppercase}
.jcard h3 em{font-style:normal;color:var(--teal);font-weight:900;text-transform:uppercase}
.jcard .jm{margin-top:auto;display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,220,196,.5);font-weight:500}

/* footer */
.foot{background:var(--char);color:var(--cream);margin-top:64px;padding:44px 18px 110px}
.foot .in{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.foot .blurb{font-family:var(--f-serif);font-style:italic;font-size:clamp(18px,3.4vw,26px);line-height:1.3;color:var(--cream);max-width:30ch;letter-spacing:-.01em}
.foot .legal{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;border-top:1px solid rgba(232,220,196,.12);padding-top:18px;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,220,196,.45);font-weight:500}
