/* ============================================================
   FUNHOUSE — maceojourdan.com design system
   Playground brutalism ▸ Riso print (grain · misregistration · stamp)
   Fonts loaded per-page: Darker Grotesque, DM Sans, DM Mono
   ============================================================ */
:root{
  --paper:#faf3e2; --paper2:#f3ead4; --ink:#100f12; --ink2:#322d22; --mut:#6c6456;
  --blue:#2f49ff; --pink:#ff3d9a; --lime:#c2ee00; --orange:#ff6a2c; --cyan:#27d3e0; --teal:#0bbf9a;
  --line:#cfc4a8;
  --disp:"Darker Grotesque",system-ui,sans-serif;
  --sans:"DM Sans",system-ui,sans-serif;
  --mono:"DM Mono",ui-monospace,Menlo,monospace;
  --bd:3px solid var(--ink); --bd2:2px solid var(--ink);
  --sh:6px 6px 0 var(--ink); --shsm:4px 4px 0 var(--ink); --shlg:9px 9px 0 var(--ink);
  --maxw:1180px;
}
*{box-sizing:border-box}
html,body{margin:0;max-width:100%;overflow-x:hidden}
body{
  background:var(--paper); color:var(--ink); font-family:var(--sans);
  -webkit-font-smoothing:antialiased; position:relative; line-height:1.55;
}
/* print grain + duotone overprint atmosphere */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;mix-blend-mode:multiply;opacity:.4;
  background-image:radial-gradient(var(--ink) .6px,transparent .7px);background-size:3px 3px}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.30;mix-blend-mode:multiply;
  background:radial-gradient(75% 55% at 92% 0,rgba(255,61,154,.40),transparent 45%),
             radial-gradient(65% 50% at 4% 100%,rgba(47,73,255,.30),transparent 50%)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;position:relative;z-index:1}
.narrow{max-width:760px}
a{color:inherit}
img{max-width:100%}

/* ---- nav ---- */
.site-nav{position:sticky;top:0;z-index:50;background:rgba(250,243,226,.85);backdrop-filter:blur(7px);border-bottom:var(--bd)}
.site-nav .in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--disp);font-weight:900;font-size:27px;letter-spacing:-.02em;line-height:1;text-decoration:none;color:var(--ink)}
.brand b{color:var(--pink)}
.links{display:flex;gap:6px;align-items:center}
.links a{font-weight:600;font-size:14px;text-decoration:none;color:var(--ink2);padding:8px 11px;border-radius:9px;border:2px solid transparent}
.links a:hover{color:var(--ink);background:var(--lime);border-color:var(--ink)}
.links a.cur{background:var(--paper2);border-color:var(--ink)}
.links a.cta{background:var(--blue);color:#fff;border:var(--bd);font-weight:700;box-shadow:var(--shsm)}
.links a.cta:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);background:var(--blue)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:800;font-size:21px;text-transform:uppercase;
  letter-spacing:.005em;text-decoration:none;color:var(--ink);border:var(--bd);border-radius:13px;padding:12px 26px;box-shadow:var(--sh);
  background:var(--paper);transition:transform .12s,box-shadow .12s}
.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shlg)}
.btn.blue{background:var(--blue);color:#fff}
.btn.pink{background:var(--pink);color:#fff}
.btn.lime{background:var(--lime)}
.btn.sm{font-size:16px;padding:10px 18px;box-shadow:var(--shsm)}

/* ---- shared bits ---- */
.kick{display:inline-block;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;
  background:var(--cyan);border:var(--bd);padding:7px 12px;border-radius:9px;box-shadow:var(--shsm)}
.eyebrow{font-family:var(--disp);font-weight:900;font-size:30px;text-transform:uppercase;letter-spacing:-.01em;margin:0 0 22px}
.eyebrow.sm{font-family:var(--mono);font-weight:400;font-size:12px;letter-spacing:.16em;color:var(--mut)}
.stamp{width:120px;height:120px;border-radius:50%;border:var(--bd);color:var(--pink);background:rgba(250,243,226,.5);
  display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--mono);font-weight:500;
  font-size:11px;text-transform:uppercase;line-height:1.4;transform:rotate(8deg);box-shadow:var(--sh)}

/* ---- headings ---- */
h1.hero{font-family:var(--disp);font-weight:900;font-size:clamp(56px,11vw,142px);line-height:.84;letter-spacing:-.03em;
  margin:24px 0 0;text-transform:uppercase}
/* marker-style highlight: sits BEHIND the text, hugs the glyphs, never bleeds onto the line above */
h1.hero mark,.pagehead h1 mark,.band h2 mark,.empty h2 mark{
  position:relative;display:inline-block;background:transparent;color:var(--ink);padding:0 .08em;z-index:0}
h1.hero mark::before,.pagehead h1 mark::before,.band h2 mark::before,.empty h2 mark::before{
  content:"";position:absolute;left:0;right:0;top:.16em;bottom:.06em;background:var(--lime);z-index:-1;border-radius:2px}
h1.hero .blue{color:var(--blue)}
.reg{position:relative;display:inline-block}
.reg::before,.reg::after{content:attr(data-t);position:absolute;left:0;top:0;z-index:-1}
.reg::before{color:var(--pink);transform:translate(4px,4px);mix-blend-mode:multiply}
.reg::after{color:var(--blue);transform:translate(-3px,-3px);mix-blend-mode:multiply}

/* page header (inner pages) */
.pagehead{padding:48px 0 36px}
.pagehead .k{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--mut);margin:0 0 16px}
.pagehead h1{font-family:var(--disp);font-weight:900;font-size:clamp(46px,8vw,104px);line-height:.86;letter-spacing:-.03em;margin:0;text-transform:uppercase}
.pagehead h1 mark{color:var(--ink)}
.pagehead .lede{font-size:18px;line-height:1.55;max-width:60ch;margin:22px 0 0;font-weight:500;color:var(--ink2)}
.pagehead .lede b{color:var(--ink)}

.lede-lg{font-size:17px;line-height:1.6;max-width:52ch;margin:24px 0 0;font-weight:500}
.lede-lg b{background:var(--orange);color:#fff;padding:1px 5px}

/* ---- proof color blocks ---- */
.proof{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pb{border:var(--bd);border-radius:16px;padding:20px;box-shadow:var(--sh)}
.pb:nth-child(4n+1){background:var(--lime)}
.pb:nth-child(4n+2){background:var(--pink);color:#fff}
.pb:nth-child(4n+3){background:var(--cyan)}
.pb:nth-child(4n+4){background:var(--orange);color:#fff}
.pb .v{font-family:var(--disp);font-weight:900;font-size:clamp(30px,4.2vw,52px);line-height:.9}
.pb .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.03em;margin-top:8px;opacity:.85}

/* ---- generic cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--paper);border:var(--bd);border-radius:18px;padding:26px;box-shadow:var(--sh);transition:transform .12s,box-shadow .12s}
.card:hover{transform:translate(-3px,-3px);box-shadow:var(--shlg)}
.card .num{display:inline-block;font-family:var(--disp);font-weight:900;font-size:24px;width:46px;height:46px;border:var(--bd);
  border-radius:50%;text-align:center;line-height:42px}
.card:nth-child(3n+1) .num{background:var(--lime)}
.card:nth-child(3n+2) .num{background:var(--cyan)}
.card:nth-child(3n+3) .num{background:var(--pink);color:#fff}
.card h3{font-family:var(--disp);font-weight:800;font-size:25px;text-transform:uppercase;margin:15px 0 8px;line-height:1}
.card p{font-size:14.5px;line-height:1.55;margin:0;font-weight:500;color:var(--ink2)}

/* ---- sections ---- */
.section{padding:60px 0}
.divider{border:none;border-top:var(--bd);margin:0}

/* ---- CTA band ---- */
.band{background:var(--ink);color:var(--paper);border-radius:22px;padding:54px 30px;text-align:center;margin:20px 0}
.band h2{font-family:var(--disp);font-weight:900;font-size:clamp(30px,5vw,52px);text-transform:uppercase;margin:0 0 14px;line-height:.9}
.band h2 mark{color:var(--ink)}
.band p{color:#d9d3c4;margin:0 0 26px;font-weight:500}
.band .btn{background:var(--lime)}

/* ---- marquee ---- */
.marq{background:var(--ink);color:var(--paper);border:var(--bd);border-radius:14px;overflow:hidden;white-space:nowrap}
.marq div{display:inline-block;animation:fh-roll 24s linear infinite;font-family:var(--disp);font-weight:800;font-size:22px;
  text-transform:uppercase;padding:11px 0}
.marq span{margin:0 22px}.marq .a{color:var(--lime)}.marq .p{color:var(--pink)}
@keyframes fh-roll{to{transform:translateX(-50%)}}

/* ---- footer ---- */
.site-foot{border-top:var(--bd);margin-top:30px;padding:40px 0;font-family:var(--mono);font-size:13px;color:var(--mut)}
.site-foot .in{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center}
.site-foot a{color:var(--ink2);text-decoration:none;margin-right:16px}
.site-foot a:hover{color:var(--pink)}

/* ---- prose / article (about) ---- */
.prose h2{font-family:var(--disp);font-weight:900;font-size:clamp(26px,4vw,40px);text-transform:uppercase;letter-spacing:-.02em;margin:48px 0 14px;line-height:.95}
.prose h2:first-child{margin-top:0}
.prose p{font-size:17px;line-height:1.7;color:var(--ink2);margin:0 0 18px}
.prose p b,.prose p strong{color:var(--ink)}
.prose a[href^="http"],.prose a[href^="mailto"]{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose .drop::first-letter{font-family:var(--disp);font-weight:900;font-size:62px;float:left;line-height:.72;padding:8px 12px 0 0;color:var(--pink)}
.pull{font-family:var(--disp);font-weight:800;font-size:clamp(24px,3.4vw,38px);line-height:1.02;text-transform:uppercase;
  letter-spacing:-.01em;background:var(--lime);border:var(--bd);border-radius:16px;box-shadow:var(--sh);padding:22px 26px;margin:36px 0}
blockquote.q{margin:26px 0;padding:22px 24px;background:var(--paper2);border:var(--bd);border-radius:16px;box-shadow:var(--sh);color:var(--ink2);font-size:16px}
blockquote.q p{margin:0 0 10px}blockquote.q p:last-child{margin:0}
ul.kick-list{list-style:none;padding:0;margin:22px 0;display:grid;grid-template-columns:1fr 1fr;gap:10px 28px;font-size:17px;color:var(--ink2)}
ul.kick-list b{color:var(--pink);font-family:var(--disp);font-weight:900;font-size:20px}
.prose ul,.prose ol{color:var(--ink2);font-size:17px;line-height:1.7;padding-left:22px}
.prose ul li,.prose ol li{margin-bottom:8px}
.signoff{font-family:var(--mono);color:var(--ink);font-weight:500;margin-top:8px}

/* ---- project rows (projects) ---- */
.proj{display:grid;grid-template-columns:220px 1fr;gap:28px;border:var(--bd);border-radius:18px;box-shadow:var(--sh);padding:26px;margin-bottom:20px;background:var(--paper)}
.proj .meta .role{font-family:var(--disp);font-weight:800;font-size:22px;text-transform:uppercase;line-height:1}
.proj .meta .org{font-family:var(--mono);font-size:12px;color:var(--mut);margin-top:8px}
.proj .meta .yr{font-family:var(--mono);font-size:11px;color:var(--mut);margin-top:8px;text-transform:uppercase;letter-spacing:.08em}
.proj .meta .kpi{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.proj .meta .kpi b{font-family:var(--disp);font-weight:900;font-size:24px;line-height:.9;color:var(--blue)}
.proj .meta .kpi span{font-family:var(--mono);font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.06em;display:block}
.proj h3{font-family:var(--disp);font-weight:800;font-size:24px;text-transform:uppercase;margin:0 0 10px}
.proj .lbl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--pink);font-weight:500;margin:16px 0 8px}
.proj ul{margin:0;padding-left:18px;color:var(--ink2);font-size:15px;line-height:1.5}
.proj ul li{margin-bottom:8px}.proj ul li b{color:var(--ink)}
.stack{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.stack span{font-family:var(--mono);font-size:12px;color:var(--ink);background:var(--paper2);border:var(--bd2);border-radius:7px;padding:4px 9px}

/* capability matrix */
.capgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.capcard{border:var(--bd);border-radius:16px;padding:22px;box-shadow:var(--sh);background:var(--paper)}
.capcard h4{font-family:var(--disp);font-weight:800;font-size:17px;text-transform:uppercase;margin:0 0 10px}
.capcard p{margin:0;font-family:var(--mono);font-size:13px;color:var(--ink2);line-height:1.7}

/* ---- portfolio cards ---- */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.pcard{border:var(--bd);border-radius:18px;padding:26px;background:var(--paper);box-shadow:var(--sh);display:flex;flex-direction:column;transition:transform .12s,box-shadow .12s}
.pcard:hover{transform:translate(-3px,-3px);box-shadow:var(--shlg)}
.pcard.feat{grid-column:1 / -1}
.pcard .top{display:flex;justify-content:space-between;gap:12px;align-items:baseline;margin-bottom:10px}
.pcard h3{font-family:var(--disp);font-weight:800;font-size:24px;text-transform:uppercase;margin:0;line-height:1}
.pcard .lang{font-family:var(--mono);font-size:12px;color:var(--mut);white-space:nowrap}
.pcard p{margin:0 0 16px;color:var(--ink2);font-size:15px;font-weight:500}
.pcard p b{color:var(--ink)}
.pcard .glinks{margin-top:auto;display:flex;gap:14px}
.pcard .glinks a{font-family:var(--disp);font-weight:800;font-size:16px;text-transform:uppercase;text-decoration:none;color:var(--ink)}
.pcard .glinks a:hover{color:var(--pink)}
.tagcloud{display:flex;gap:9px;flex-wrap:wrap}
.tagcloud a{font-family:var(--mono);font-size:13px;color:var(--ink);background:var(--paper);border:var(--bd2);border-radius:999px;padding:7px 14px;text-decoration:none}
.tagcloud a:hover{background:var(--lime)}

/* ---- media: as-seen-on ---- */
.asseenon{padding:44px 0 6px;text-align:center}
.asseenon .lbl{font-family:var(--disp);font-weight:900;font-size:26px;text-transform:uppercase;letter-spacing:.02em;margin:0 0 18px}
.asseenon .ribbon{border:var(--bd);border-radius:16px;box-shadow:var(--sh);background:#fff;padding:22px 26px;display:inline-block;max-width:760px;width:100%}
.asseenon img{width:100%;height:auto;display:block}
.asseenon .more{font-family:var(--mono);font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.08em;margin:14px 0 0}

/* featured interview cards */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fcard{border:var(--bd);border-radius:18px;overflow:hidden;background:var(--paper);box-shadow:var(--sh);display:flex;flex-direction:column;text-decoration:none;transition:transform .12s,box-shadow .12s}
.fcard:hover{transform:translate(-3px,-3px);box-shadow:var(--shlg)}
.fcard .thumb{aspect-ratio:16/9;background:var(--paper2);overflow:hidden;position:relative;border-bottom:var(--bd)}
.fcard .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.fcard .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.fcard .play span{width:50px;height:50px;border-radius:50%;background:var(--pink);border:var(--bd);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;padding-left:3px}
.fcard .body{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.fcard .show{font-family:var(--mono);font-size:11px;color:var(--pink);text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}
.fcard h3{font-family:var(--disp);font-weight:800;font-size:20px;text-transform:uppercase;margin:0 0 12px;line-height:1.02}
.fcard .go{margin-top:auto;font-family:var(--mono);font-size:12px;font-weight:500;color:var(--mut)}

/* cover-art grid */
.mgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mcard{border:var(--bd);border-radius:14px;overflow:hidden;background:var(--paper);box-shadow:var(--shsm);text-decoration:none;display:flex;flex-direction:column;transition:transform .12s,box-shadow .12s}
.mcard:hover{transform:translate(-3px,-3px);box-shadow:var(--sh)}
.mthumb{aspect-ratio:1/1;background:var(--paper2);overflow:hidden;border-bottom:var(--bd)}
.mthumb img{width:100%;height:100%;object-fit:cover;display:block}
.mthumb.tile{display:flex;align-items:center;justify-content:center;text-align:center;padding:14px;background:var(--ink);color:var(--paper)}
.mthumb.tile span{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:#c9c3b4;display:block}
.mthumb.tile b{font-family:var(--disp);font-weight:900;font-size:30px;display:block;margin-top:6px;color:var(--lime)}
.mbody{padding:13px 14px 15px;display:flex;flex-direction:column;flex:1}
.mbody .show{font-family:var(--mono);font-size:10.5px;color:var(--pink);text-transform:uppercase;letter-spacing:.04em;margin:0 0 6px;line-height:1.3}
.mbody h4{font-family:var(--disp);font-weight:800;font-size:16px;text-transform:uppercase;margin:0 0 10px;line-height:1.05}
.mbody .go{margin-top:auto;font-family:var(--mono);font-size:11px;color:var(--mut)}

/* rundown / archived */
.ilist{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.irow{display:flex;gap:14px;align-items:flex-start;border:var(--bd2);border-radius:12px;padding:16px 18px;background:var(--paper)}
.irow .pl{font-family:var(--mono);font-size:11px;color:var(--ink);background:var(--cyan);border:var(--bd2);border-radius:6px;padding:5px 8px;white-space:nowrap}
.irow h4{font-family:var(--disp);font-weight:800;font-size:17px;text-transform:uppercase;margin:0 0 3px;line-height:1.05}
.irow .meta{font-family:var(--mono);font-size:12px;color:var(--mut)}

/* ---- empty state (writing) ---- */
.empty{border:var(--bd);border-radius:18px;box-shadow:var(--sh);background:var(--paper2);padding:48px;text-align:center}
.empty h2{font-family:var(--disp);font-weight:900;font-size:clamp(26px,4vw,38px);text-transform:uppercase;margin:0 0 12px}
.empty p{color:var(--ink2);max-width:48ch;margin:0 auto 24px;font-weight:500}
.chips{display:flex;gap:9px;flex-wrap:wrap;justify-content:center;margin-top:24px}
.chips span{font-family:var(--mono);font-size:12px;color:var(--ink);border:var(--bd2);background:var(--paper);border-radius:999px;padding:7px 14px}

/* ---- contact ---- */
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:8px 0 36px}
.cc{border:var(--bd);border-radius:16px;padding:22px;box-shadow:var(--sh);background:var(--paper)}
.cc .l{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--mut);margin:0 0 8px}
.cc a,.cc .v{font-family:var(--disp);font-weight:800;font-size:20px;text-decoration:none;text-transform:uppercase}
.cc a:hover{color:var(--pink)}

/* ---- responsive ---- */
@media(max-width:860px){
  .links a:not(.cta){display:none}
  .proof{grid-template-columns:1fr 1fr}
  .cards,.capgrid,.fgrid{grid-template-columns:1fr}
  .pgrid{grid-template-columns:1fr}.pcard.feat{grid-column:auto}
  .mgrid{grid-template-columns:1fr 1fr}
  .ilist,.cgrid,ul.kick-list{grid-template-columns:1fr}
  .proj{grid-template-columns:1fr;gap:14px}
}
