/* ===========================================================
   Samuel Murray — site-wide design system
   One file, shared across all pages. Each section sets its
   own palette via the body[data-section] hooks at the bottom.
   =========================================================== */

:root{
  --bg:#FAF8F3;
  --ink:#1A1A1A;
  --slate:#3D4A52;
  --muted:#6E6E66;
  --rule:rgba(26,26,26,.14);
  --red:#D62828;
  --ochre:#E09F3E;
  --sans:"Futura","Avenir Next","Avenir","Segoe UI",sans-serif;
  --serif:"Palatino","Palatino Linotype","Book Antiqua",Georgia,serif;
  --mono:ui-monospace,Menlo,Consolas,monospace;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

/* ---------- shared utility / nav bar (interior pages) ---------- */
.bar{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 32px;border-bottom:1px solid var(--rule);
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
}
.bar .home{
  display:inline-flex;align-items:center;gap:8px;font-weight:500;
  border:2px solid var(--ink);padding:7px 14px;border-radius:2px;
  transition:background .2s,color .2s;
}
.bar .home:hover,.bar .home:focus-visible{background:var(--ink);color:var(--bg);outline:none;}
.bar .crumb{color:var(--muted);display:inline-flex;align-items:center;gap:10px;}
.bar .bar-logo{height:26px;width:auto;display:inline-block;vertical-align:middle;}

.wrap{max-width:1100px;margin:0 auto;padding:0 32px;}
.wrap-narrow{max-width:720px;margin:0 auto;padding:0 28px;}

/* ---------- shared section label (small ruled heading) ---------- */
.sect-label{display:flex;align-items:center;gap:14px;margin:46px 0 18px;}
.sect-label .sq{width:18px;height:18px;background:var(--accent,var(--red));}
.sect-label h2{font-size:13px;letter-spacing:2.5px;text-transform:uppercase;font-weight:500;}
.sect-label .rule{flex:1;height:2px;background:var(--ink);}

.ph{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:.9em;}

/* ===========================================================
   HOME — Suprematist floating composition
   =========================================================== */
.home-masthead{padding:26px 44px 0;}
.home-masthead .nm{font-size:22px;font-weight:500;letter-spacing:.3px;}
.home-masthead .ttl{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px;line-height:1.5;margin-top:4px;}
.home-masthead .hint{float:right;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#B8B2A6;margin-top:6px;}

.stage{position:relative;width:100%;max-width:1120px;margin:0 auto;height:min(80vh,660px);min-height:540px;}
.stage .diagonal{position:absolute;left:6%;right:6%;top:4%;bottom:0;pointer-events:none;}
.stage .diagonal svg{width:100%;height:100%;display:block;}
.stage .enddot{position:absolute;right:7%;top:9%;width:16px;height:16px;border-radius:50%;background:var(--ink);}

.form{
  position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;cursor:pointer;transform:rotate(-18deg);will-change:transform;outline:none;
  transition:transform .3s cubic-bezier(.2,.7,.3,1), box-shadow .3s, letter-spacing .3s;
}
.form:hover,.form:focus-visible{transform:rotate(0deg) scale(1.06);box-shadow:0 16px 38px rgba(26,26,26,.24);z-index:5;}
.form:focus-visible{outline:3px solid var(--ink);outline-offset:5px;}
.form .lab{font-weight:500;letter-spacing:1px;text-transform:uppercase;line-height:1.1;}
.form:hover .lab,.form:focus-visible .lab{letter-spacing:2px;}

.f-philo{width:120px;height:120px;border-radius:50%;background:var(--red);color:#fff;left:8%;top:46%;}
.f-philo .lab{font-size:14px;}
.f-psych{width:160px;height:110px;background:var(--ink);color:#fff;left:23%;top:50%;}
.f-psych .lab{font-size:16px;}
.f-blog{width:104px;height:52px;background:var(--slate);color:#EAF0F2;left:27%;top:36%;}
.f-blog .lab{font-size:14px;letter-spacing:2px;}
.f-teaching{width:94px;height:90px;background:var(--bg);border:3px solid var(--ink);color:var(--ink);left:45%;top:27%;}
.f-teaching .lab{font-size:14px;}
.f-camp{width:134px;height:68px;background:var(--ochre);color:#3A2806;left:60%;top:20%;}
.f-camp .lab{font-size:15px;}

/* mobile stacked nav (shared by home) */
.home-mobile{display:none;}
@media (max-width:780px){
  .stage{display:none;}
  .home-masthead .hint{display:none;}
  .home-mobile{display:block;padding:6px 22px 44px;max-width:540px;margin:0 auto;}
  .home-mobile .m-link{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;margin-bottom:12px;
    border-radius:6px;font-weight:500;letter-spacing:1px;text-transform:uppercase;font-size:16px;}
  .home-mobile .m-philo{background:var(--red);color:#fff;}
  .home-mobile .m-psych{background:var(--ink);color:#fff;}
  .home-mobile .m-blog{background:var(--slate);color:#EAF0F2;}
  .home-mobile .m-teach{background:var(--bg);border:3px solid var(--ink);color:var(--ink);}
  .home-mobile .m-camp{background:var(--ochre);color:#3A2806;}
  .home-mobile .m-sub{font-family:var(--serif);font-style:italic;font-size:12px;text-transform:none;letter-spacing:0;opacity:.85;display:block;margin-top:2px;}
}

/* ===========================================================
   PSYCH / NEURO — Bauhaus
   =========================================================== */
body[data-section="psych"]{--bg:#F3EFE6;--accent:#D63A2E;}
.bau-blue{background:#1E5BA8;} .bau-yellow{background:#F0C020;} .bau-red{background:#D63A2E;}

.hero-bau{display:grid;gap:6px;margin:30px 0;grid-template-columns:repeat(12,1fr);grid-auto-rows:96px;
  background:var(--ink);border:6px solid var(--ink);}
.hero-bau .blk{position:relative;overflow:hidden;padding:18px 20px;display:flex;flex-direction:column;}
.hero-bau .b-title{grid-column:1/8;grid-row:1/3;background:#1E5BA8;color:#fff;justify-content:center;}
.hero-bau .b-title h1{font-size:clamp(26px,4vw,40px);font-weight:500;line-height:1.02;letter-spacing:.5px;}
.hero-bau .b-title .deck{font-family:var(--serif);font-style:italic;font-size:15px;opacity:.92;margin-top:8px;max-width:32ch;}
.hero-bau .b-circle{grid-column:8/13;grid-row:1/3;background:#F0C020;align-items:center;justify-content:center;padding:10px;}
.hero-bau .lab-emblem{max-height:170px;max-width:90%;width:auto;height:auto;object-fit:contain;display:block;}
.hero-bau .disc{width:118px;height:118px;border-radius:50%;background:var(--ink);color:#F0C020;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;}
.hero-bau .disc .big{font-size:30px;font-weight:500;}
.hero-bau .disc .cap{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;opacity:.85;}
.hero-bau .b-strip{grid-column:1/13;grid-row:3/4;background:var(--bg);flex-direction:row;align-items:center;gap:16px;flex-wrap:wrap;}
.hero-bau .b-strip .tag{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}
.hero-bau .b-strip .chip{border:2px solid var(--ink);border-radius:2px;padding:5px 12px;font-size:13px;font-weight:500;}

.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.area{border:3px solid var(--ink);border-radius:2px;background:var(--bg);min-height:200px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;}
.area:hover{transform:translateY(-3px);box-shadow:6px 6px 0 var(--ink);}
.area .cap{height:64px;display:flex;align-items:center;padding:0 18px;}
.area .cap .geo{width:26px;height:26px;margin-right:12px;flex:none;}
.area .cap h3{font-size:16px;font-weight:500;color:#fff;letter-spacing:.5px;}
.area .body{padding:16px 18px;font-size:14px;color:#33322D;line-height:1.55;}
.a1 .cap{background:#1E5BA8;} .a1 .cap .geo{border-radius:50%;background:#F0C020;}
.a2 .cap{background:#D63A2E;} .a2 .cap .geo{background:var(--ink);}
.a3 .cap{background:#F0C020;} .a3 .cap h3{color:var(--ink);}
.a3 .cap .geo{width:0;height:0;background:none;border-left:13px solid transparent;border-right:13px solid transparent;border-bottom:26px solid #1E5BA8;}

.pubs{margin-top:14px;border-top:3px solid var(--ink);}
.pub{display:grid;grid-template-columns:54px 1fr auto;gap:18px;align-items:start;padding:18px 6px;border-bottom:2px solid rgba(26,26,26,.18);}
.pub .yr{font-size:22px;font-weight:500;color:#1E5BA8;}
.pub .t{font-size:15px;font-weight:500;}
.pub .v{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--muted);margin-top:3px;}
.pub .go{align-self:center;font-size:12px;letter-spacing:1px;text-transform:uppercase;border:2px solid var(--ink);padding:6px 12px;border-radius:2px;white-space:nowrap;transition:background .2s,color .2s;}
.pub .go:hover{background:var(--ink);color:var(--bg);}

.affil{display:grid;grid-template-columns:repeat(12,1fr);gap:6px;margin:48px 0 40px;background:var(--ink);border:6px solid var(--ink);}
.affil div{padding:16px 18px;font-size:13px;}
.affil .af1{grid-column:1/5;background:#D63A2E;color:#fff;}
.affil .af2{grid-column:5/9;background:var(--bg);}
.affil .af3{grid-column:9/13;background:#1E5BA8;color:#fff;}
.affil .k{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;opacity:.85;margin-bottom:4px;}
.affil .vv{font-weight:500;}

/* ===========================================================
   PHILOSOPHY — Suprematist (interior variant)
   =========================================================== */
body[data-section="philosophy"]{--accent:#D62828;}
.hero-sup{position:relative;height:340px;margin:24px 0 8px;overflow:hidden;border:1px solid var(--rule);background:var(--bg);}
.hero-sup .diag{position:absolute;inset:0;pointer-events:none;}
.hero-sup .diag svg{width:100%;height:100%;}
.hero-sup h1{position:absolute;left:40px;top:46%;transform:rotate(-18deg);transform-origin:left center;
  font-size:clamp(30px,5vw,52px);font-weight:500;line-height:1;letter-spacing:.5px;}
.hero-sup .shape{position:absolute;}
.hero-sup .s-red{width:90px;height:90px;border-radius:50%;background:var(--red);right:18%;top:18%;transform:rotate(-18deg);}
.hero-sup .s-blk{width:120px;height:70px;background:var(--ink);right:8%;top:46%;transform:rotate(-18deg);}
.hero-sup .s-out{width:64px;height:64px;border:3px solid var(--ink);right:30%;top:54%;transform:rotate(-18deg);}
.hero-sup .deck{margin:18px 2px 0;font-family:var(--serif);font-size:17px;line-height:1.6;color:#33322D;max-width:62ch;}

.themes{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:8px;}
.theme{border:1px solid var(--rule);border-radius:2px;padding:22px 22px 24px;background:var(--bg);transition:transform .2s,box-shadow .2s;}
.theme:hover{transform:translateY(-3px);box-shadow:5px 5px 0 var(--ink);}
.theme .mk{display:block;width:30px;height:30px;margin:0 0 18px;}
.theme.t-circ .mk{border-radius:50%;background:var(--red);}
.theme.t-sq .mk{background:var(--ink);}
.theme.t-tri .mk{width:0;height:0;background:none;border-left:15px solid transparent;border-right:15px solid transparent;border-bottom:26px solid var(--slate);margin-bottom:22px;}
.theme.t-bar .mk{width:34px;height:12px;margin-bottom:30px;background:var(--ochre);}
.theme h3{font-size:18px;font-weight:500;letter-spacing:.3px;}
.theme p{font-family:var(--serif);font-size:15px;line-height:1.6;color:#3A3A34;margin-top:8px;}

/* ===========================================================
   TEACHING — Mondrian
   =========================================================== */
body[data-section="teaching"]{--bg:#F4F1EA;--accent:#B5532F;}
.hero-mond{display:grid;gap:8px;margin:28px 0;grid-template-columns:repeat(8,1fr);grid-auto-rows:84px;
  background:var(--ink);border:8px solid var(--ink);}
.hero-mond .m{padding:16px 18px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;}
.hero-mond .m-name{grid-column:1/6;grid-row:1/3;background:#3D4A52;color:var(--bg);justify-content:center;}
.hero-mond .m-name h1{font-size:clamp(26px,4vw,40px);font-weight:500;line-height:1.04;}
.hero-mond .m-name .deck{font-family:var(--serif);font-style:italic;font-size:14px;color:#AEB8BD;margin-top:8px;}
.hero-mond .m-red{grid-column:6/9;grid-row:1/2;background:#B5532F;}
.hero-mond .m-white{grid-column:6/9;grid-row:2/3;background:var(--bg);}
.hero-mond .m-yellow{grid-column:1/3;grid-row:3/4;background:#C28A3A;}
.hero-mond .m-blue{grid-column:3/9;grid-row:3/4;background:#3D4A52;color:var(--bg);}
.hero-mond .k{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;opacity:.85;}
.hero-mond .v{font-weight:500;font-size:15px;margin-top:3px;}

.courses{display:grid;grid-template-columns:1fr;gap:0;border-top:3px solid var(--ink);margin-top:6px;}
.course{display:grid;grid-template-columns:90px 1fr auto;gap:18px;align-items:center;padding:18px 8px;border-bottom:2px solid rgba(26,26,26,.16);}
.course .code{font-weight:500;font-size:14px;letter-spacing:.5px;border:2px solid var(--ink);border-radius:2px;padding:6px 10px;text-align:center;}
.course .ti{font-size:16px;font-weight:500;}
.course .meta{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--muted);margin-top:2px;}
.course .term{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}

/* ===========================================================
   CaMP LAB — Russian Constructivist
   =========================================================== */
body[data-section="camp"]{--bg:#F2EDE3;--accent:#C8102E;}
.hero-con{position:relative;background:var(--ink);color:var(--bg);overflow:hidden;margin:24px 0;padding:46px 36px 52px;border:6px solid var(--ink);}
.hero-con .bardiag{position:absolute;right:-60px;top:-40px;width:340px;height:520px;background:#C8102E;transform:rotate(28deg);}
.hero-con .barblk{position:absolute;right:60px;top:-30px;width:60px;height:520px;background:var(--bg);transform:rotate(28deg);opacity:.16;}
.hero-con h1{position:relative;font-size:clamp(30px,6vw,58px);font-weight:500;line-height:.98;letter-spacing:1px;color:#F2EDE3;max-width:14ch;}
.hero-con .deck{position:relative;font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.55;margin-top:16px;max-width:46ch;color:#E8E4DA;}
.hero-con .stat{position:relative;display:inline-flex;align-items:baseline;gap:10px;margin-top:24px;
  background:#C8102E;color:#fff;padding:8px 16px;transform:rotate(-2deg);}
.hero-con .stat b{font-size:26px;font-weight:500;}
.hero-con .stat span{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;}

/* funders grid — slots sized for logo images; show styled name until a logo is added */
.funders{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:8px 0 10px;}
.funder{border:3px solid var(--ink);border-radius:2px;background:#fff;min-height:128px;
  display:flex;align-items:center;justify-content:center;text-align:center;padding:16px;
  transition:transform .2s,box-shadow .2s;}
.funder:hover{transform:translateY(-3px);box-shadow:5px 5px 0 var(--ink);}
.funder img{max-width:100%;max-height:80px;width:auto;height:auto;object-fit:contain;display:block;}
.funder .wordmark{font-weight:500;font-size:14px;line-height:1.3;color:#1A1A1A;letter-spacing:.2px;}
.funder .short{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#C8102E;margin-top:6px;}

.projects{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:3px solid var(--ink);margin-top:8px;}
.project{padding:24px 22px;border-right:3px solid var(--ink);border-bottom:3px solid var(--ink);position:relative;transition:background .2s,color .2s;}
.project:nth-child(2n){border-right:none;}
.project:hover{background:var(--ink);color:var(--bg);}
.project .num{font-size:12px;letter-spacing:2px;color:#C8102E;font-weight:500;}
.project:hover .num{color:#FF6B6B;}
.project h3{font-size:19px;font-weight:500;margin:8px 0 6px;letter-spacing:.3px;}
.project p{font-family:var(--serif);font-size:14px;line-height:1.55;color:inherit;opacity:.9;}
.project .yrs{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:12px;}
.project:hover .yrs{color:#C9C5BB;}

/* ===========================================================
   BLOG — Para que no se me olvide (signature-only art)
   =========================================================== */
body[data-section="blog"]{--accent:#3D4A52;}
.blog-head{padding:54px 0 8px;}
.blog-head .mark{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.blog-head .sq{width:22px;height:22px;background:var(--slate);transform:rotate(-12deg);}
.blog-head h1{font-size:clamp(30px,5vw,42px);font-weight:500;letter-spacing:.5px;line-height:1.05;}
.blog-head .accent{height:4px;width:64px;background:var(--slate);margin-top:18px;}
.blog-head .blurb{font-family:var(--serif);font-size:17px;line-height:1.6;color:#33322D;margin-top:20px;max-width:60ch;}

.posts{margin:40px 0 60px;}
.post-link{display:block;padding:28px 0;border-bottom:1px solid var(--rule);transition:padding-left .2s;}
.post-link:hover,.post-link:focus-visible{padding-left:10px;outline:none;}
.post-link .meta{display:flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;flex-wrap:wrap;}
.post-link .tag{border:1px solid var(--rule);border-radius:2px;padding:2px 9px;letter-spacing:1px;}
.post-link h2{font-size:24px;font-weight:500;letter-spacing:.3px;line-height:1.2;}
.post-link .excerpt{font-family:var(--serif);font-size:16px;line-height:1.65;color:#3A3A34;margin-top:10px;max-width:62ch;}
.post-link .more{display:inline-block;margin-top:12px;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--slate);font-weight:500;}

.blog-foot{padding:30px 0 60px;border-top:1px solid var(--rule);font-size:13px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.blog-foot a{color:var(--slate);font-weight:500;}

/* ---------- single post reading view ---------- */
body[data-section="post"]{font-family:var(--serif);--accent:#3D4A52;}
body[data-section="post"] a{color:var(--slate);border-bottom:1px solid rgba(61,74,82,.35);}
body[data-section="post"] a:hover{border-bottom-color:var(--slate);}
body[data-section="post"] .bar,
body[data-section="post"] .bar a{font-family:var(--sans);}
body[data-section="post"] .bar a.home{border-bottom:none;}

.phead{padding:52px 0 0;}
.phead .meta{font-family:var(--sans);display:flex;align-items:center;gap:12px;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:18px;flex-wrap:wrap;}
.phead .tag{border:1px solid var(--rule);border-radius:2px;padding:2px 9px;}
.phead h1{font-family:var(--sans);font-size:clamp(28px,5vw,36px);font-weight:500;line-height:1.12;letter-spacing:.3px;}
.phead .accent{height:4px;width:56px;background:var(--slate);margin:22px 0 6px;}

.post-body{font-size:19px;line-height:1.75;color:#23231F;padding:14px 0 10px;}
.post-body p{margin:0 0 1.25em;}
.post-body > p:first-of-type::first-letter{font-family:var(--sans);font-weight:500;font-size:3.1em;line-height:.82;float:left;padding:6px 10px 0 0;color:var(--slate);}
.post-body h2{font-family:var(--sans);font-size:22px;font-weight:500;margin:1.8em 0 .5em;letter-spacing:.3px;}
.post-body h3{font-family:var(--sans);font-size:17px;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin:1.6em 0 .4em;}
.post-body blockquote{margin:1.5em 0;padding:6px 0 6px 24px;border-left:4px solid var(--slate);font-style:italic;color:#34342E;}
.post-body code{font-family:var(--mono);font-size:.82em;background:rgba(26,26,26,.06);padding:2px 6px;border-radius:3px;}
.post-body strong{font-weight:600;}
.post-body hr{border:none;height:1px;background:var(--rule);margin:2.2em 0;}

.pfoot{font-family:var(--sans);margin:36px 0 64px;padding-top:24px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;}
.pfoot a{border-bottom:none;color:var(--slate);font-weight:500;letter-spacing:.5px;text-transform:uppercase;}

/* ===========================================================
   Shared responsive collapses for interior grids
   =========================================================== */
@media (max-width:860px){
  .hero-bau{grid-auto-rows:auto;}
  .hero-bau .b-title,.hero-bau .b-circle,.hero-bau .b-strip{grid-column:1/13;grid-row:auto;}
  .hero-bau .b-title{min-height:160px;} .hero-bau .b-circle{min-height:170px;}
  .areas,.themes,.projects{grid-template-columns:1fr;}
  .affil div{grid-column:1/13 !important;}
  .pub{grid-template-columns:44px 1fr;}
  .pub .go{grid-column:2;justify-self:start;margin-top:8px;}
  .hero-mond{grid-template-columns:repeat(4,1fr);}
  .hero-mond .m-name{grid-column:1/5;}
  .hero-mond .m-red,.hero-mond .m-white,.hero-mond .m-yellow,.hero-mond .m-blue{grid-column:1/5;}
  .project{border-right:none;}
  .funders{grid-template-columns:1fr 1fr;}
  .course{grid-template-columns:70px 1fr;}
  .course .term{grid-column:2;}
}
@media (max-width:620px){
  .blog-head h1{font-size:32px;}
  .post-link h2{font-size:21px;}
  .post-body{font-size:18px;}
}
