/* =================== THEME TOKENS =================== */
:root{
  --bg:#f5f3ea;--bg2:#efece0;--panel:#fffdf6;--ink:#191a10;--soft:#55564a;
  --line:rgba(25,26,16,.12);--line2:rgba(25,26,16,.24);
  --brand:#85BB65;--brand-ink:#3c7a2c;--gold:#b08a26;--gold-ink:#8a6c18;
  --radius:14px;--bw:1px;--bc:var(--line);--shadow:0 1px 0 rgba(25,26,16,.04),0 22px 46px -28px rgba(25,26,16,.32);
  --hard:none;--rot:0deg;--rot2:0deg;--skew:0deg;--glow:0 0;--grain:.045;
  --fdisp:"Anton",sans-serif;--fbody:"Hanken Grotesk",system-ui,sans-serif;--flabel:"JetBrains Mono",monospace;
  --ucase:none;--track:0;--labsz:15px;--scan:0;
  --fscale:1;
}
@media(prefers-color-scheme:dark){:root:not([data-theme-set]){
  --bg:#111208;--bg2:#16170d;--panel:#1b1c11;--ink:#f1eee1;--soft:#a8a695;
  --line:rgba(241,238,225,.12);--line2:rgba(241,238,225,.22);
  --brand:#85BB65;--brand-ink:#9ed079;--gold:#d3ab3d;--gold-ink:#e0bb52;
  --shadow:0 1px 0 rgba(0,0,0,.4),0 26px 52px -30px rgba(0,0,0,.75);--grain:.06;
}}
[data-theme="dark"]{
  --bg:#111208;--bg2:#16170d;--panel:#1b1c11;--ink:#f1eee1;--soft:#a8a695;
  --line:rgba(241,238,225,.12);--line2:rgba(241,238,225,.22);
  --brand:#85BB65;--brand-ink:#9ed079;--gold:#d3ab3d;--gold-ink:#e0bb52;
  --shadow:0 1px 0 rgba(0,0,0,.4),0 26px 52px -30px rgba(0,0,0,.75);--grain:.06;
}
/* BOLD — big modern */
[data-skin="bold"]{
  --radius:18px;--fdisp:"Hanken Grotesk",sans-serif;--track:-.015em;--labsz:15px;
}
[data-skin="bold"] h1,[data-skin="bold"] h2,[data-skin="bold"] h3{font-weight:800}
/* PUNK */
[data-skin="punk"]{
  --bg:#efe9dc;--bg2:#e6dec9;--panel:#fffdf4;--ink:#13120d;--soft:#403d34;
  --line:#13120d;--line2:#13120d;--brand:#85BB65;--brand-ink:#2c6a1c;--gold:#b9882a;--gold-ink:#7e5d14;
  --radius:0;--bw:3px;--bc:var(--ink);--hard:7px 7px 0 var(--ink);--shadow:none;
  --rot:-1.3deg;--rot2:1.1deg;--skew:-4deg;--grain:.09;--ucase:uppercase;--track:.01em;
  --fdisp:"Archivo Black",sans-serif;--flabel:"Caveat",cursive;--labsz:21px;
}
[data-skin="punk"][data-theme="dark"]{
  --bg:#0b0b07;--bg2:#121009;--panel:#15140d;--ink:#f4f1e3;--soft:#b2af9d;
  --line:#f4f1e3;--line2:#f4f1e3;--brand:#9ace77;--brand-ink:#9ace77;--gold:#e3b63f;--gold-ink:#e3b63f;--hard:7px 7px 0 var(--brand);
}
/* CYBER — cyberpunk */
[data-skin="cyber"]{
  --bg:#e9ede6;--bg2:#dfe5da;--panel:#ffffff;--ink:#0c0e0b;--soft:#384038;
  --line:#0c0e0b;--line2:#0c0e0b;--brand:#85BB65;--brand-ink:#1f7a3f;--gold:#b8901f;--gold-ink:#8a6c14;
  --radius:0;--bw:2px;--bc:var(--ink);--hard:6px 6px 0 var(--gold);--shadow:none;
  --grain:0;--ucase:uppercase;--track:.06em;--scan:1;
  --fdisp:"JetBrains Mono",monospace;--fbody:"JetBrains Mono",monospace;--flabel:"JetBrains Mono",monospace;--labsz:13px;
}
[data-skin="cyber"][data-theme="dark"]{
  --bg:#06080a;--bg2:#0a0d0f;--panel:#0d1113;--ink:#e7f3ea;--soft:#82a191;
  --line:#1f8a4d;--line2:#2cae62;--brand:#4dffa0;--brand-ink:#4dffa0;--gold:#ffd34d;--gold-ink:#ffd34d;
  --bc:var(--brand);--hard:6px 6px 0 var(--gold);--glow:0 0 16px;
}
/* BRUTAL — neo-brutalist (no neon, stark blocks) */
[data-skin="brutal"]{
  --bg:#eeeae0;--bg2:#fff;--panel:#fff;--ink:#111;--soft:#3a382f;
  --line:#111;--line2:#111;--brand:#85BB65;--brand-ink:#1f6b15;--gold:#caa12f;--gold-ink:#7c5e10;
  --radius:0;--bw:3px;--bc:var(--ink);--hard:8px 8px 0 var(--ink);--shadow:none;
  --grain:0;--ucase:uppercase;--track:0;
  --fdisp:"Archivo Black",sans-serif;--flabel:"JetBrains Mono",monospace;--labsz:13px;
}
[data-skin="brutal"][data-theme="dark"]{
  --bg:#15140f;--bg2:#1c1b14;--panel:#1c1b14;--ink:#f4f1e4;--soft:#aeac9b;
  --line:#f4f1e4;--line2:#f4f1e4;--brand:#9ace77;--brand-ink:#9ace77;--gold:#e3b63f;--gold-ink:#e3b63f;--hard:8px 8px 0 var(--brand);
}

/* =================== BASE =================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
.prose [id]{scroll-margin-top:100px}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--fbody);font-size:19px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .35s,color .35s}
body::before{content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:var(--grain);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
body::after{content:"";position:fixed;inset:0;z-index:9997;pointer-events:none;opacity:calc(var(--scan)*.5);
  background:repeating-linear-gradient(0deg,transparent 0 2px,color-mix(in srgb,var(--ink) 6%,transparent) 2px 3px)}
.wrap{max-width:1180px;margin:0 auto;padding:0 30px}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--flabel)}
h1,h2,h3{font-family:var(--fdisp);font-weight:400;line-height:.98;margin:0;text-transform:var(--ucase);letter-spacing:var(--track)}
[data-skin="punk"] h1,[data-skin="punk"] h2{transform:skewX(var(--skew))}
.brand-c{color:var(--brand-ink)}.gold-c{color:var(--gold-ink)}
.eyebrow{font-family:var(--flabel);font-size:var(--labsz);letter-spacing:.02em;color:var(--brand-ink);text-transform:var(--ucase)}
.glow{text-shadow:var(--glow) var(--brand)}

/* header */
header{position:sticky;top:0;z-index:60;backdrop-filter:blur(11px);background:color-mix(in srgb,var(--bg) 84%,transparent);border-bottom:var(--bw) solid var(--bc)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:18px;height:82px}
.bar-left{display:flex;align-items:center;gap:20px}
.logo img{height:40px;width:auto;display:block}
.nav-articles{font-family:var(--fbody);font-weight:700;font-size:16px;color:var(--soft);padding:6px 2px;border-bottom:2px solid transparent;transition:.18s}
.nav-articles:hover{color:var(--ink);border-bottom-color:var(--brand)}
nav.main{display:flex;gap:4px;align-items:center}
.navitem{position:relative}
.navitem>a,.navitem>button{font-family:var(--fbody);font-weight:700;font-size:16px;color:var(--soft);background:none;border:0;cursor:pointer;padding:9px 13px;border-radius:var(--radius);display:inline-flex;align-items:center;gap:6px;transition:.18s;text-transform:var(--ucase)}
.navitem:hover>a,.navitem:hover>button,.navitem>a:focus{color:var(--ink)}
.caret{width:11px;height:11px;opacity:.7}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:260px;background:var(--panel);border:var(--bw) solid var(--bc);border-radius:var(--radius);box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(7px);transition:.18s;z-index:70}
.navitem:hover .dropdown,.navitem:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:10px 13px;border-radius:calc(var(--radius) - 4px);font-size:15.5px;font-weight:600;color:var(--soft)}
.dropdown a:hover{background:var(--brand);color:#10130a}
.tools{display:flex;align-items:center;gap:10px}
.chip{height:44px;padding:0 14px;border:var(--bw) solid var(--line2);border-radius:var(--radius);background:transparent;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-family:var(--flabel);font-size:13px;font-weight:700;transition:.18s;text-transform:uppercase}
.chip:hover{border-color:var(--brand);color:var(--brand-ink)}
.chip svg{width:17px;height:17px}
[data-theme="light"] .moon{display:none}[data-theme="dark"] .sun{display:none}
/* font size btns */
.fsize-btn{padding:0 10px;font-size:14px}
/* tooltip wrappers */
.tip-wrap{position:relative;display:flex;align-items:center;gap:4px}
.tip-wrap::after{content:attr(data-tip);position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--ink);color:var(--bg);font-family:var(--flabel);font-size:12px;font-weight:600;letter-spacing:.02em;padding:7px 12px;border-radius:8px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;z-index:100;text-transform:none;transform:translateX(-50%) translateY(4px)}
.tip-wrap::before{content:"";position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-bottom-color:var(--ink);opacity:0;pointer-events:none;transition:opacity .18s;z-index:101}
.tip-wrap:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.tip-wrap:hover::before{opacity:1}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--fbody);font-weight:800;font-size:16px;border-radius:var(--radius);padding:13px 22px;cursor:pointer;border:var(--bw) solid transparent;transition:.18s;text-transform:var(--ucase);letter-spacing:var(--track)}
.btn-primary{background:var(--brand);color:#0f130a;border-color:var(--bc);box-shadow:var(--hard)}
.btn-primary:hover{transform:translate(-2px,-2px)}
[data-skin="clean"] .btn-primary:hover,[data-skin="bold"] .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--hard),0 14px 26px -12px var(--brand)}
.btn-ghost{border-color:var(--line2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand-ink)}
.menubtn{display:none}

/* hero */
.hero{position:relative;padding:96px 0 78px;overflow:hidden}
.hero .gb{position:absolute;font-family:var(--fdisp);font-size:min(48vw,680px);line-height:.66;color:var(--brand);opacity:.08;z-index:0;user-select:none}
.hero .gb.l{left:-4vw;top:-8vh}.hero .gb.r{right:-4vw;bottom:-22vh}
.hero .inner{position:relative;z-index:2;display:grid;grid-template-columns:1.25fr .85fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(46px,7.4vw,108px);margin:14px 0 0}
.hero h1 .arw{color:var(--gold-ink);display:inline-block}
.lede{font-size:clamp(19px,2.1vw,23px);color:var(--soft);max-width:54ch;margin:24px 0 0;line-height:1.55}
.hbul{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:12px}
.hbul li{display:flex;gap:12px;align-items:flex-start;font-size:18px;font-weight:600}
.hbul li::before{content:"+";color:var(--brand-ink);font-family:var(--flabel);font-weight:800;font-size:20px;line-height:1.2}
.cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.herofig{position:relative;border:var(--bw) solid var(--line2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--hard),var(--shadow);transform:rotate(var(--rot))}
.herofig img.ph{display:block;width:100%;height:auto}
[data-theme="light"] .herofig img.ph{filter:url(#duoLight)}
[data-theme="dark"] .herofig img.ph{filter:url(#duoDark)}
.herofig .badge{position:absolute;left:0;bottom:0;background:var(--gold);color:#1a1305;font-family:var(--flabel);font-weight:700;font-size:13px;padding:8px 13px;text-transform:uppercase;letter-spacing:.03em}
.heromark{display:none}
/* BOLD hero: huge photo, wordmark over it, blends into bg */
[data-skin="bold"] .hero{padding:70px 0 60px}
[data-skin="bold"] .hero .inner{grid-template-columns:1fr;gap:30px}
[data-skin="bold"] .hero .copy{max-width:none}
[data-skin="bold"] .hero h1{font-size:clamp(52px,9vw,128px)}
[data-skin="bold"] .herofig{transform:none;border:0;border-radius:24px;box-shadow:none;background:transparent;margin-top:10px}
[data-skin="bold"] .herofig img.ph{border-radius:24px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 22%,#000 78%,transparent),linear-gradient(180deg,#000 60%,transparent);
  -webkit-mask-composite:source-in;mask-image:linear-gradient(90deg,transparent,#000 22%,#000 78%,transparent),linear-gradient(180deg,#000 60%,transparent);mask-composite:intersect;
  filter:saturate(.5) contrast(1.02)}
[data-theme="dark"][data-skin="bold"] .herofig img.ph{filter:saturate(.45) brightness(.8)}
[data-skin="bold"] .heromark{display:block;position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:min(86%,920px);opacity:.96;z-index:3;mix-blend-mode:normal;pointer-events:none}
[data-skin="bold"] .badge{display:none}

/* creds */
.creds{border-top:var(--bw) solid var(--bc);border-bottom:var(--bw) solid var(--bc);background:var(--bg2);padding:30px 0}
.creds .wrap{display:flex;gap:18px 40px;flex-wrap:wrap;align-items:center}
.creds .lbl{font-family:var(--flabel);font-size:13px;color:var(--soft);text-transform:uppercase;letter-spacing:.04em}
.creds b{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:26px;color:var(--ink);opacity:.74;letter-spacing:.01em;text-transform:var(--ucase)}
[data-skin="bold"] .creds b{font-weight:800}

/* sections */
section.block{padding:90px 0}
.kicker{font-family:var(--flabel);font-size:var(--labsz);color:var(--brand-ink);margin-bottom:16px;text-transform:var(--ucase)}
.kicker::before{content:"{ "}.kicker::after{content:" }"}
.sechead{font-size:clamp(34px,5vw,62px);max-width:20ch;text-transform:var(--ucase)}
.seclead{color:var(--soft);max-width:64ch;margin-top:18px;font-size:20px}

/* numbers */
.nums{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
.num{border:var(--bw) solid var(--bc);border-radius:var(--radius);padding:26px;background:var(--panel);box-shadow:var(--hard)}
.num .n{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:clamp(38px,5vw,60px);line-height:.9;color:var(--brand-ink);text-shadow:var(--glow) var(--brand)}
[data-skin="bold"] .num .n{font-weight:800}
.num .t{font-size:15px;color:var(--soft);margin-top:8px}

/* cards */
.grid{display:grid;gap:22px;margin-top:42px}
.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--panel);border:var(--bw) solid var(--bc);border-radius:var(--radius);padding:26px;transition:transform .2s,box-shadow .2s;box-shadow:var(--hard);position:relative;display:block;color:inherit}
[data-skin="punk"] .grid .card:nth-child(odd){transform:rotate(var(--rot))}
[data-skin="punk"] .grid .card:nth-child(even){transform:rotate(var(--rot2))}
.card:hover{transform:translate(-3px,-3px);box-shadow:var(--hard),var(--shadow)}
[data-skin="clean"] .card:hover,[data-skin="bold"] .card:hover{transform:translateY(-4px)}
.card .k{font-family:var(--flabel);font-size:13px;color:var(--gold-ink);margin-bottom:12px;text-transform:uppercase;letter-spacing:.03em}
.card h3{font-size:clamp(21px,2.3vw,27px);margin-bottom:10px;font-weight:var(--boldw,400)}
[data-skin="bold"] .card h3{font-weight:800}
.card p{font-size:16px;color:var(--soft);margin:0}
.card .go{margin-top:16px;font-family:var(--flabel);font-size:14px;color:var(--brand-ink)}
.card.feat{background:var(--ink);color:var(--bg)}
.card.feat h3,.card.feat .price{color:var(--bg)} .card.feat p{color:color-mix(in srgb,var(--bg) 72%,transparent)}
.card.feat .k{color:var(--brand)}
.price{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:54px;line-height:.9;color:var(--brand)}

/* gigs */
.gigs{margin-top:38px;border-top:var(--bw) solid var(--bc)}
.gig{display:grid;grid-template-columns:120px 1fr auto;gap:22px;align-items:baseline;padding:20px 6px;border-bottom:var(--bw) solid var(--bc)}
.gig .yr{font-family:var(--flabel);color:var(--gold-ink);font-size:15px}
.gig .ev{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:clamp(20px,2.4vw,30px);text-transform:var(--ucase)}
[data-skin="bold"] .gig .ev{font-weight:800}
.gig .loc{font-size:15px;color:var(--soft);font-family:var(--flabel)}

/* about */
.about{display:grid;grid-template-columns:1.35fr .9fr;gap:50px;align-items:center}
.about .bio p{color:var(--soft);font-size:18px;margin:0 0 16px}
.about .bio p strong{color:var(--ink);font-weight:700}
.aboutfig{border:var(--bw) solid var(--line2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--hard),var(--shadow)}
.aboutfig img{display:block;width:100%}
[data-theme="light"] .aboutfig img{filter:url(#duoLight)}[data-theme="dark"] .aboutfig img{filter:url(#duoDark)}

/* contact */
.contact{background:var(--ink);color:var(--bg);border-radius:calc(var(--radius) + 6px);padding:54px;position:relative;overflow:hidden;box-shadow:var(--hard)}
.contact h2{color:var(--bg)}.contact .kicker{color:var(--brand)}
.contact .seclead{color:color-mix(in srgb,var(--bg) 72%,transparent)}
.cform{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px}
.cform .full{grid-column:1/-1}
.cform label{display:block;font-family:var(--flabel);font-size:13px;color:color-mix(in srgb,var(--bg) 66%,transparent);margin-bottom:7px;text-transform:uppercase;letter-spacing:.04em}
.cform input,.cform select,.cform textarea{width:100%;background:color-mix(in srgb,var(--bg) 9%,transparent);border:var(--bw) solid color-mix(in srgb,var(--bg) 26%,transparent);border-radius:var(--radius);color:var(--bg);padding:13px 15px;font-family:var(--fbody);font-size:16px}
.cform textarea{min-height:124px;resize:vertical}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--brand)}
.cform option{color:#111}
.csent{display:none;margin-top:16px;font-family:var(--flabel);color:var(--brand)}

/* footer */
footer{border-top:var(--bw) solid var(--bc);background:var(--bg2);padding:54px 0 44px}
.foot{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.back-top{font-family:var(--flabel);font-size:14px;color:var(--soft);text-decoration:none;letter-spacing:.03em}.back-top:hover{color:var(--brand-ink)}
.foot-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.foot-socials{display:flex;gap:14px;align-items:center}
.social-icon{color:var(--soft);display:inline-flex;transition:color .15s}.social-icon:hover{color:var(--brand-ink)}
.author-name-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.foot nav{display:flex;gap:22px;flex-wrap:wrap}
.foot nav a{font-size:16px;color:var(--soft)}.foot nav a:hover{color:var(--brand-ink)}
.copy{font-family:var(--flabel);font-size:13px;color:var(--soft);margin-top:26px}

/* =============== ARTICLE (multi-lens) =============== */
.page-head{padding:64px 0 10px}
.crumbs{font-family:var(--flabel);font-size:13px;color:var(--soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}
.crumbs a{color:var(--brand-ink)}
.arttitle{font-size:clamp(28px,4vw,52px);max-width:18ch;text-transform:var(--ucase);font-weight:var(--boldw,400)}
[data-skin="bold"] .arttitle{font-weight:800}
.artmeta{font-family:var(--flabel);font-size:14px;color:var(--soft);margin-top:18px}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:30px 0 0;border-bottom:var(--bw) solid var(--bc);padding-bottom:0}
.tab{font-family:var(--flabel);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--soft);background:transparent;border:var(--bw) solid transparent;border-bottom:none;padding:11px 16px;border-radius:var(--radius) var(--radius) 0 0;cursor:pointer;transition:.16s;margin-bottom:-1px}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--ink);background:var(--panel);border-color:var(--bc)}
.tab .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--brand);margin-right:7px;vertical-align:middle}
.tabwrap{background:var(--panel);border:var(--bw) solid var(--bc);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:38px 42px;box-shadow:var(--hard)}
.tabpane{display:none}.tabpane.on{display:block}
.prose{font-size:calc(18.5px * var(--fscale));line-height:1.78;max-width:72ch}
.prose h2{font-size:clamp(26px,3vw,38px);margin:34px 0 14px;font-family:var(--fdisp);font-weight:var(--boldw,400)}
.prose h3{font-size:22px;margin:26px 0 10px}
.prose p{margin:0 0 18px;color:var(--ink)}
.prose ul{margin:0 0 18px;padding-left:0;list-style:none;display:grid;gap:10px}
.prose ul li{display:flex;gap:12px}.prose ul li::before{content:"+";color:var(--brand-ink);font-family:var(--flabel);font-weight:800}
.prose code{font-family:var(--flabel);font-size:.88em;background:var(--bg2);padding:2px 7px;border-radius:6px}
.callout{border-left:4px solid var(--brand);background:var(--bg2);padding:16px 20px;border-radius:0 var(--radius) var(--radius) 0;margin:0 0 18px;font-size:17px}
.ai-note{font-family:var(--flabel);font-size:13px;color:var(--gold-ink);text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px}
.raw{font-family:var(--flabel);font-size:15px;line-height:1.7;white-space:pre-wrap;color:var(--soft)}

/* glossary term tooltip */
.term{border-bottom:2px dotted var(--brand-ink);cursor:help;position:relative;font-weight:600;color:var(--ink);outline:none}
.term:hover::after,.term:focus::after{content:attr(data-def);position:absolute;left:0;top:calc(100% + 8px);width:280px;background:var(--ink);color:var(--bg);font-family:var(--fbody);font-weight:500;font-size:14px;line-height:1.5;padding:12px 14px;border-radius:var(--radius);box-shadow:var(--shadow);z-index:40;text-transform:none;letter-spacing:0}
.term:hover::before,.term:focus::before{content:"";position:absolute;left:18px;top:calc(100% + 2px);border:6px solid transparent;border-bottom-color:var(--ink);z-index:41}

/* glossary index */
.gloss-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:40px}
.gterm{border:var(--bw) solid var(--bc);border-radius:var(--radius);padding:24px;background:var(--panel);box-shadow:var(--hard)}
.gterm h3{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:26px;margin-bottom:8px}
.gterm p{color:var(--soft);font-size:16px;margin:0 0 14px}
.gterm .links{display:flex;gap:16px;font-family:var(--flabel);font-size:13px}
.gterm .links a{color:var(--brand-ink)}

/* filter bar (thought leadership) */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:36px}
.filt{font-family:var(--flabel);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--soft);background:transparent;border:var(--bw) solid var(--line2);border-radius:999px;padding:9px 17px;cursor:pointer;transition:.16s}
[data-skin="cyber"] .filt,[data-skin="punk"] .filt,[data-skin="brutal"] .filt{border-radius:0}
.filt:hover{color:var(--ink)}.filt.on{background:var(--brand);color:#10130a;border-color:var(--bc)}
.tl-list{margin-top:34px;display:grid;gap:16px}
.tl-row{display:grid;grid-template-columns:120px 1fr auto;gap:22px;align-items:center;border:var(--bw) solid var(--bc);border-radius:var(--radius);padding:20px 24px;background:var(--panel);box-shadow:var(--hard);transition:.18s}
.tl-row:hover{transform:translate(-2px,-2px);box-shadow:var(--hard),var(--shadow)}
.tl-row .ty{font-family:var(--flabel);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--gold-ink)}
.tl-row .ti{font-weight:700;font-size:18px}
.tl-row .mt{font-family:var(--flabel);font-size:13px;color:var(--soft)}
.hide{display:none}

@media(max-width:920px){
  .hero .inner,.about{grid-template-columns:1fr;gap:34px}.herofig{order:-1;max-width:460px}
  [data-skin="bold"] .herofig{max-width:none}
  .nums{grid-template-columns:repeat(2,1fr)}.g3,.g2,.gloss-grid{grid-template-columns:1fr}.cform{grid-template-columns:1fr}
  nav.main{display:none}.menubtn{display:inline-flex}
  .gig,.tl-row{grid-template-columns:64px 1fr;row-gap:4px}.gig .loc{grid-column:2}.tl-row .mt{grid-column:2}
  .contact{padding:32px}.tabwrap{padding:26px 22px}.creds b{font-size:20px}
}

.view{display:none}.view.on{display:block}

/* article screenshots */
.prose .shot{margin:26px 0;border:var(--bw) solid var(--bc);border-radius:var(--radius);overflow:hidden;background:var(--panel);box-shadow:var(--hard)}
.prose .shot img{display:block;width:100%;height:auto}
.prose .shot figcaption{font-family:var(--flabel);font-size:13px;color:var(--soft);padding:11px 15px;border-top:var(--bw) solid var(--bc);text-transform:var(--ucase);letter-spacing:.02em}

/* =============== ART LAYOUT (TOC + content) =============== */
.art-layout{display:grid;grid-template-columns:210px 1fr;gap:44px;align-items:start;margin-top:30px}

/* TOC sidebar */
.toc-sidebar{position:sticky;top:102px;max-height:calc(100vh - 120px);overflow-y:auto}
.toc-inner{background:var(--panel);border:var(--bw) solid var(--bc);border-radius:var(--radius);padding:18px 16px;box-shadow:var(--hard)}
.toc-label{font-family:var(--flabel);font-size:11px;color:var(--soft);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;padding:0 6px}
.toc{display:flex;flex-direction:column;gap:1px}
.toc-link{display:block;font-family:var(--fbody);font-size:14px;font-weight:500;color:var(--soft);padding:7px 10px;border-radius:calc(var(--radius) - 4px);transition:.15s;line-height:1.3;text-decoration:none}
.toc-link:hover{color:var(--ink);background:var(--bg2)}
.toc-link.active{color:var(--brand-ink);background:var(--bg2);font-weight:700}
.toc-divider{border:none;border-top:var(--bw) solid var(--bc);margin:8px 4px}

/* Tabs inside art-main */
.art-main .tabs{margin-top:0}

/* =============== SUPERSCRIPT TERM REFS =============== */
.sref{font-family:var(--flabel);font-size:9px;font-weight:800;color:var(--brand-ink);border:1px solid currentColor;border-radius:3px;padding:0 3px;cursor:pointer;vertical-align:super;line-height:0;margin-left:1px;transition:.15s;white-space:nowrap;user-select:none;position:relative;display:inline-block}
.sref:hover{background:var(--brand);color:#0f130a;border-color:var(--brand)}
.sref::after{content:attr(data-def);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);width:260px;background:var(--ink);color:var(--bg);font-family:var(--fbody);font-weight:500;font-size:13px;line-height:1.5;padding:11px 13px;border-radius:var(--radius);box-shadow:var(--shadow);z-index:50;pointer-events:none;opacity:0;transition:opacity .15s;text-transform:none;letter-spacing:0;white-space:normal}
.sref::before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink);z-index:51;pointer-events:none;opacity:0;transition:opacity .15s}
.sref:hover::after,.sref:hover::before{opacity:1}

/* artmeta second line */
.artmeta-actions{margin-top:6px}

/* =============== LISTEN BUTTON =============== */
.listen-btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--flabel);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--brand-ink);background:transparent;border:1px solid var(--brand-ink);border-radius:999px;padding:3px 10px 3px 8px;cursor:pointer;transition:.15s;vertical-align:middle;line-height:1}
.listen-btn:hover,.listen-btn.playing{background:var(--brand);color:#0f130a;border-color:var(--brand)}

/* artmeta sep spacing */
.sep{padding:0 1px}

/* =============== TL;DR + AI SUMMARY =============== */
.tldr-box{background:var(--bg2);border:var(--bw) solid var(--bc);border-left:4px solid var(--brand);border-radius:var(--radius);padding:24px 28px;margin-bottom:4px}
.tldr-text{font-size:18px;line-height:1.65;color:var(--ink);margin:8px 0 0}
.ai-summary-section{}

/* =============== DEFINITIONS =============== */
#pane-definitions{font-size:calc(16px * var(--fscale))}
.def-intro{font-family:var(--flabel);font-size:.8em;color:var(--soft);margin:0 0 24px;line-height:1.55}
.gloss-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:0}
.gterm{border:var(--bw) solid var(--bc);border-radius:var(--radius);padding:22px 24px;background:var(--panel);box-shadow:var(--hard);position:relative}
.gterm-num{font-family:var(--flabel);font-size:.625em;font-weight:800;color:var(--brand-ink);border:1px solid var(--brand-ink);border-radius:3px;display:inline-block;padding:1px 5px;margin-bottom:8px}
.gterm h3{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:1.375em;margin:0 0 8px;text-transform:var(--ucase)}
[data-skin="bold"] .gterm h3{font-weight:800}
.gterm p{color:var(--soft);font-size:.94em;margin:0;line-height:1.6}
.gterm code{font-family:var(--flabel);font-size:.85em;background:var(--bg2);padding:1px 5px;border-radius:4px}

/* =============== AUTHOR BOX =============== */
.author-box{display:flex;gap:28px;align-items:flex-start;margin-top:44px;padding:30px 34px;background:var(--panel);border:var(--bw) solid var(--bc);border-radius:var(--radius);box-shadow:var(--hard)}
.author-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--brand)}
.author-info{flex:1;min-width:0}
.author-name{font-family:var(--fdisp);font-size:26px;font-weight:var(--boldw,400);line-height:1;margin-bottom:0;text-transform:var(--ucase)}
[data-skin="bold"] .author-name{font-weight:800}
.author-role{font-family:var(--flabel);font-size:12px;color:var(--brand-ink);text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px}
.author-bio p{font-size:14.5px;color:var(--soft);margin:0 0 10px;line-height:1.65}
.author-bio p:last-child{margin-bottom:0}
.author-tags{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.author-tags li{font-family:var(--flabel);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-ink);background:var(--bg2);border:1px solid var(--brand-ink);border-radius:999px;padding:4px 12px}

/* =============== RESPONSIVE =============== */
@media(max-width:960px){
  .art-layout{grid-template-columns:1fr}
  .toc-sidebar{display:none}
}
@media(max-width:680px){
  .gloss-grid{grid-template-columns:1fr}
  .author-box{flex-direction:column;align-items:center;text-align:center;padding:24px 20px}
  .author-name,.author-role{text-align:center}
  .tabwrap{padding:22px 18px}
}

/* ===================== AI + SEO DATA PANE ===================== */
#pane-seodata{font-size:calc(16px * var(--fscale))}
.sd-eyebrow{font-family:var(--flabel);font-size:.69em;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-ink);display:block;margin-bottom:5px}
.sd-intro{color:var(--soft);font-size:1em;margin:0 0 20px;max-width:70ch}
.sd-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.sd-input{flex:1;min-width:240px;height:44px;border:var(--bw) solid var(--line2);border-radius:var(--radius);background:var(--bg2);color:var(--ink);padding:0 14px;font-family:var(--flabel);font-size:13px}
.sd-input:focus{outline:none;border-color:var(--brand)}
.sd-btn{height:44px;padding:0 18px;border:var(--bw) solid var(--bc);border-radius:var(--radius);background:var(--brand);color:#0f130a;font-family:var(--flabel);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;box-shadow:var(--hard);transition:.16s}
.sd-btn:hover{transform:translate(-2px,-2px)}
.sd-legend{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--flabel);font-size:12px;color:var(--soft);margin-bottom:24px}
.sd-legend .live{color:var(--brand-ink)}
.sd-card{border:var(--bw) solid var(--bc);border-radius:var(--radius);background:var(--panel);box-shadow:var(--hard);padding:22px 24px;margin-bottom:20px}
.sd-card>h3{font-family:var(--fdisp);font-weight:var(--boldw,400);font-size:1.5em;margin:0 0 4px;text-transform:var(--ucase);line-height:1.05}
[data-skin="bold"] .sd-card>h3{font-weight:800}
.sd-card .sd-sub{color:var(--soft);font-size:.875em;margin:0 0 16px;line-height:1.5}
.sd-embed{width:100%;border:var(--bw) solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg2);min-height:420px}
.sd-embed iframe{width:100%;border:0;display:block}
.sd-note{font-size:13px;color:var(--soft);margin-top:10px;font-family:var(--flabel)}
.sd-chunk{border:var(--bw) solid var(--line);border-radius:var(--radius);background:var(--bg2);padding:14px 16px;margin-bottom:12px}
.sd-chunk-h{display:flex;gap:10px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.sd-score{font-family:var(--flabel);font-weight:800;font-size:12px;padding:4px 10px;border-radius:999px;color:#10130a}
.sd-tags{display:flex;gap:6px;flex-wrap:wrap}
.sd-tag{font-family:var(--flabel);font-size:11px;padding:2px 8px;border-radius:999px;background:color-mix(in srgb,var(--brand) 22%,transparent);color:var(--brand-ink);border:1px solid color-mix(in srgb,var(--brand) 40%,transparent)}
.sd-chunk p{margin:0;font-size:14.5px;color:var(--ink);line-height:1.55}
.sd-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sd-soon{opacity:.82}
.sd-badge{display:inline-block;font-family:var(--flabel);font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-ink);border:1px solid var(--gold-ink);border-radius:999px;padding:2px 9px;vertical-align:middle}
.sd-skeleton{margin-top:4px;min-height:110px;border-radius:var(--radius);border:1px dashed var(--line2);background:repeating-linear-gradient(110deg,var(--bg2) 0 16px,transparent 16px 32px);display:flex;align-items:center;justify-content:center;text-align:center;padding:18px;color:var(--soft);font-family:var(--flabel);font-size:13px}
.sd-embed{overflow:visible}
.sd-methods{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.sd-mini{font-family:var(--flabel);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--soft);background:var(--bg2);border:var(--bw) solid var(--line2);border-radius:999px;padding:7px 14px;cursor:pointer;transition:.16s}
.sd-mini:hover{border-color:var(--brand);color:var(--brand-ink)}
.sd-mini.on{background:var(--brand);color:#0f130a;border-color:var(--bc)}
.sd-method-note{font-family:var(--flabel);font-size:12px;color:var(--soft);margin:0 0 16px;line-height:1.5;min-height:1.2em}
.sd-method-tag{font-family:var(--flabel);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--gold-ink);border:1px solid var(--gold-ink);border-radius:999px;padding:2px 8px}
@media(max-width:720px){.sd-grid2{grid-template-columns:1fr}}
