:root{--bg-0:#0F1115;--bg-1:#15171C;--bg-2:#1C1F26;--bg-3:#222830;--bg-header:#101216;--bg-glass:rgba(15,17,21,0.88);--ink:#FFFC9E;--ink-soft:#FFFFFF;--ink-mute:#D6D18A;--ink-dim:#8A8650;--accent:#FBFE39;--accent-btn:#FBFE39;--accent-hot:#FFFBD1;--accent-deep:#C8CB00;--accent-soft:rgba(251,254,57,0.12);--accent-line:rgba(251,254,57,0.45);--glow-right:rgba(255,252,158,0.12);--line:rgba(255,252,158,0.13);--line-strong:rgba(255,252,158,0.17);--hero-glow-opacity:0.12;--line-opacity:0.13;--line-strong-opacity:0.17;--deco-line:rgba(255,252,158,0.28);--deco-accent-line:rgba(236,231,75,0.45);--deco-accent:rgba(236,231,75,0.92);--font-display:"Anton","Bebas Neue","Oswald","Impact",sans-serif;--font-ui:"Rajdhani","Barlow Condensed","Oswald",sans-serif;--font-body:"Manrope","Inter",-apple-system,system-ui,sans-serif;--max-width:1440px;--gutter:clamp(1.25rem,4vw,3.5rem);--header-h:72px;--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-in-out:cubic-bezier(0.65,0,0.35,1);--t-fast:180ms;--t-med:420ms;--t-slow:900ms;--shadow-card:0 30px 80px -30px rgba(8,7,5,0.82),0 8px 24px -8px rgba(8,7,5,0.58);--shadow-glow:0 0 0 1px var(--accent-line),0 0 32px -4px rgba(251,254,57,0.28)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scrollbar-color:var(--accent) var(--bg-1);scrollbar-width:thin}
body{scrollbar-gutter:stable}
body{background:var(--bg-1);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.6;font-weight:400;overflow-x:clip;min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-0)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--accent-deep),var(--accent));border-radius:1px}
img,video,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:color var(--t-fast) var(--ease-out)}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--accent);color:#0F1115}
.title-xxl,.title-xl,.title-l{font-family:var(--font-display);font-weight:400;letter-spacing:-0.005em;line-height:0.86;color:var(--ink);text-transform:uppercase;text-shadow:0 2px 0 rgba(8,6,4,0.50);overflow:visible;display:block;word-break:break-word}
.title-xxl{font-size:clamp(3rem,11vw,11rem)}
.title-xl{font-size:clamp(2.6rem,7vw,6.5rem)}
.title-l{font-size:clamp(2rem,4vw,3.4rem);line-height:0.95}
.title-xxl .dot,.title-xl .dot,.title-l .dot{color:var(--accent)}
.eyebrow{font-family:var(--font-ui);font-size:0.75rem;font-weight:500;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent)}
.eyebrow--ink{color:var(--ink-soft)}
.lead{font-size:clamp(0.95rem,1.05vw,1.05rem);color:var(--ink-soft);max-width:52ch;line-height:1.65;overflow:visible;word-wrap:break-word}
.meta{font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}
.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--gutter)}
.section{position:relative;padding-block:clamp(4rem,9vw,8rem)}
.section--full{min-height:100svh;display:flex;align-items:center}
.grid{display:grid;gap:clamp(1rem,2.4vw,2.4rem)}
.flex{display:flex;gap:1rem}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.center{align-items:center;justify-content:center}
.divider{height:1px;background:var(--line);width:100%}
.divider--accent{height:1px;width:80px;background:var(--accent);margin-block:1rem}
.tags{display:flex;flex-wrap:wrap;gap:0.4rem}
.tag{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line-strong);padding:0.32rem 0.7rem;border-radius:1px;background:rgba(234,228,218,0.02)}
.grain::before{content:"";position:fixed;inset:0;z-index:999;pointer-events:none;opacity:0.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.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 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 38%,rgba(8,7,5,0.52) 78%,rgba(6,5,4,0.88) 100%)}
.fog{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(15,17,21,0) 30%,rgba(15,17,21,0.55) 75%,rgba(15,17,21,0.95) 100%),linear-gradient(90deg,rgba(15,17,21,0.85) 0%,rgba(15,17,21,0) 35%,rgba(15,17,21,0) 65%,rgba(15,17,21,0.6) 100%)}
.no-image{background:radial-gradient(ellipse at 30% 20%,hsl(var(--hue,24deg) 40% 22% / 0.85),transparent 55%),radial-gradient(ellipse at 75% 80%,hsl(calc(var(--hue,24deg)+30deg) 50% 14% / 0.95),transparent 50%),linear-gradient(135deg,#15151b 0%,#0F1115 100%) !important;position:relative}
.no-image::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(8,7,5,0.65) 100%);pointer-events:none}
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;background:linear-gradient(180deg,rgba(16,18,22,0.95) 0%,rgba(16,18,22,0.60) 80%,transparent 100%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--line);transition:background var(--t-med) var(--ease-out)}
.site-header__inner{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:0.85rem}
.brand__logo{width:40px;height:40px;border:1.5px solid var(--accent);display:grid;place-items:center;font-family:var(--font-display);font-size:1.05rem;letter-spacing:0.05em;color:var(--accent);background:rgba(236,231,75,0.06);position:relative}
.brand__logo::before,.brand__logo::after{content:"";position:absolute;width:5px;height:5px;border:1px solid var(--accent)}
.brand__logo::before{top:-2px;left:-2px;border-right:0;border-bottom:0}
.brand__logo::after{bottom:-2px;right:-2px;border-left:0;border-top:0}
.brand__name{font-family:var(--font-ui);font-weight:600;font-size:0.95rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);line-height:1;display:block}
.brand__role{font-family:var(--font-ui);font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-mute);margin-top:0.25rem;display:block}
.nav{display:flex;align-items:center;gap:0}
.nav a{touch-action:manipulation;position:relative;font-family:var(--font-ui);font-weight:500;font-size:0.85rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-soft);padding:0.6rem 1.1rem;transition:color var(--t-fast) var(--ease-out)}
.nav a+a{border-left:1px solid var(--line)}
.nav a::after{content:"";position:absolute;left:50%;bottom:0.2rem;transform:translateX(-50%);width:0;height:1.5px;background:var(--accent);transition:width var(--t-med) var(--ease-out)}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:32px}
.nav a.active{color:var(--accent)}
.nav a.active::after{width:18px}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line-strong);position:relative}
.nav-toggle span{position:absolute;left:10px;right:10px;height:1.5px;background:var(--ink);transition:transform var(--t-fast) var(--ease-out),opacity var(--t-fast)}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:28px}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.btn{touch-action:manipulation;--btn-bg:transparent;--btn-color:var(--ink);--btn-border:var(--line-strong);position:relative;display:inline-flex;align-items:center;gap:0.85rem;padding:0.95rem 1.4rem;font-family:var(--font-ui);font-size:0.78rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;background:var(--btn-bg);color:var(--btn-color);border:1px solid var(--btn-border);cursor:pointer;transition:background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out),border var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-out);overflow:hidden;isolation:isolate}
.btn .arrow{display:inline-block;transition:transform var(--t-med) var(--ease-out)}
.btn:hover .arrow{transform:translateX(4px)}
.btn--primary{--btn-bg:var(--accent);--btn-color:#0F1115;--btn-border:var(--accent)}
.btn--primary::before{content:"";position:absolute;inset:0;background:var(--accent-hot);transform:translateX(-101%);transition:transform var(--t-med) var(--ease-out);z-index:-1}
.btn--primary:hover::before{transform:translateX(0)}
.btn--ghost{--btn-bg:transparent;--btn-color:var(--ink);--btn-border:var(--accent)}
.btn--ghost:hover{color:var(--accent)}
.hud-frame{position:relative}
.hud-frame::before,.hud-frame::after,.hud-frame>.hud-corner-bl,.hud-frame>.hud-corner-br{content:"";position:absolute;width:18px;height:18px;border:1.5px solid var(--accent);pointer-events:none;transition:width var(--t-med) var(--ease-out),height var(--t-med) var(--ease-out);z-index:3}
.hud-frame::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hud-frame::after{top:-1px;right:-1px;border-left:0;border-bottom:0}
.hud-frame .hud-corner-bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
.hud-frame .hud-corner-br{bottom:-1px;right:-1px;border-left:0;border-top:0}
.hud-frame:hover::before,.hud-frame:hover::after,.hud-frame:hover .hud-corner-bl,.hud-frame:hover .hud-corner-br{width:28px;height:28px}
.page-home .site-header{background:linear-gradient(180deg,rgba(16,18,22,0.96) 0%,rgba(16,18,22,0.70) 70%,rgba(16,18,22,0.18) 100%);border-bottom-color:rgba(236,231,75,0.20)}
.page-home .nav a{font-size:0.82rem;letter-spacing:0.34em}
.hero{position:relative;min-height:100svh;width:100%;display:flex;align-items:center;overflow:hidden;isolation:isolate;background:var(--bg-0)}
.hero::before,.hero::after{content:"";position:absolute;z-index:3;pointer-events:none;opacity:0.6}
.hero::before{left:calc(var(--gutter) * 0.58);top:17vh;width:30px;height:74px;border-left:1px solid var(--deco-accent-line);border-top:1px solid var(--deco-line);background:linear-gradient(180deg,transparent 30%,var(--deco-accent) 30% 72%,transparent 72%);background-size:1px 100%;background-repeat:no-repeat;background-position:0 0}
.hero::after{left:calc(var(--gutter) * 0.58);bottom:19vh;width:28px;height:28px;border-left:1px solid var(--deco-line);border-top:1px solid var(--deco-line)}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:62% center;background-repeat:no-repeat;z-index:-3;animation:heroZoom 32s var(--ease-out) infinite alternate;will-change:transform;filter:saturate(0.92) contrast(1.08) brightness(0.84);overflow:hidden;pointer-events:none}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:62% center;z-index:1;pointer-events:none;opacity:0;transition:opacity 700ms var(--ease-out),filter 700ms var(--ease-out);background:transparent}
.hero__video.is-ready{opacity:1}
.hero__video--backdrop{z-index:0;object-fit:cover;filter:blur(28px) saturate(1.08) contrast(1.08) brightness(0.68);transform:scale(1.1);opacity:0}
.hero__video--backdrop.is-ready{opacity:0.72}
.hero__video--contain{object-fit:contain;object-position:center center}
.hero__video--contain.is-ready{opacity:0.98}
.hero__bg.has-hero-video{background-color:var(--bg-0)}
@keyframes heroZoom{0%{transform:scale(1.035) translate3d(0,0,0)}100%{transform:scale(1.14) translate3d(-1.4%,-0.8%,0)}}
.hero__bg.no-image{background:radial-gradient(circle at 70% 48%,rgba(240,235,80,0.42) 0%,rgba(236,231,75,0.19) 14%,transparent 32%),radial-gradient(ellipse at 70% 55%,rgba(236,231,75,0.16) 24%,transparent 62%),radial-gradient(ellipse at 30% 80%,rgba(15,17,21,0.96) 30%,transparent 70%),linear-gradient(135deg,#0F1115 0%,#1A1A08 50%,#15171C 100%) !important}
.hero__bg.no-image::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 10% 22% at 58% 70%,rgba(0,0,0,0.92),transparent 70%),radial-gradient(ellipse 14% 32% at 65% 65%,rgba(0,0,0,0.88),transparent 72%),radial-gradient(ellipse 18% 40% at 78% 60%,rgba(0,0,0,0.78),transparent 75%),linear-gradient(180deg,transparent 40%,rgba(15,12,8,0.42) 70%,rgba(10,10,13,0.92) 100%)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,17,21,0.98) 0%,rgba(15,17,21,0.86) 25%,rgba(15,17,21,0.38) 52%,rgba(15,17,21,0.08) 72%,rgba(15,17,21,0.72) 100%),linear-gradient(180deg,rgba(15,17,21,0.42) 0%,rgba(15,17,21,0.1) 46%,rgba(15,17,21,0.92) 100%);z-index:-2}
.hero .vignette{z-index:-1;opacity:0.9;background:radial-gradient(ellipse at 62% 48%,transparent 20%,rgba(8,7,5,0.30) 58%,rgba(6,5,4,0.85) 100%),linear-gradient(180deg,rgba(8,7,5,0.24),rgba(6,5,4,0.68))}
.hero__content{position:relative;width:100%;max-width:var(--max-width);margin-inline:auto;padding:calc(var(--header-h)+3.8rem) var(--gutter) 6rem;display:grid;grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);gap:clamp(2rem,5vw,6rem);align-items:center;z-index:2}
.hero__copy{position:relative;max-width:48rem;padding-left:clamp(0rem,2.5vw,3.3rem)}
.hero__copy::before{content:"";position:absolute;left:clamp(-0.3rem,1.8vw,1.7rem);top:0.25rem;width:1px;height:clamp(74px,9vw,132px);background:linear-gradient(180deg,rgba(236,231,75,0.92),rgba(236,231,75,0))}
.hero__title{font-family:var(--font-display);font-size:clamp(5rem,10.4vw,10.6rem);line-height:0.78;letter-spacing:-0.018em;text-transform:uppercase;margin-bottom:clamp(0.9rem,1.7vw,1.4rem);color:transparent;background:linear-gradient(180deg,#f7f4ec 0%,#d7d3c8 48%,#8b867b 100%),repeating-linear-gradient(90deg,rgba(234,228,218,0.2) 0 1px,rgba(0,0,0,0.16) 1px 3px);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 6px 0 rgba(8,6,4,0.50)) drop-shadow(0 22px 42px rgba(8,6,4,0.48))}
.hero__title .line{display:block}
.hero__title .dot{color:var(--accent);background:none;-webkit-background-clip:initial;background-clip:initial}
.hero__identity{position:relative}
.hero__role{display:block;font-family:var(--font-display);font-size:clamp(1.45rem,2.45vw,2.45rem);letter-spacing:0.095em;text-transform:uppercase;color:var(--accent);line-height:1;text-shadow:0 2px 0 rgba(8,6,4,0.52)}
.hero__sub{font-family:var(--font-ui);font-size:clamp(0.82rem,1vw,1.02rem);font-weight:600;letter-spacing:0.46em;text-transform:uppercase;color:rgba(234,228,218,0.76);margin-top:0.7rem;margin-bottom:1.25rem}
.hero__desc{color:rgba(234,228,218,0.72);max-width:29rem;margin-bottom:clamp(1.7rem,2.8vw,2.5rem);font-size:clamp(0.92rem,1vw,1rem);line-height:1.65}
.hero__buttons{display:flex;gap:1rem;flex-wrap:wrap}
.page-home .hero__buttons .btn{min-width:176px;justify-content:center;padding:0.96rem 1.55rem;letter-spacing:0.26em}
.page-home .hero__buttons .btn--primary{clip-path:polygon(0 0,100% 0,96% 100%,2% 100%);box-shadow:0 0 0 1px rgba(236,231,75,0.8),0 18px 40px -24px rgba(236,231,75,0.9)}
.page-home .hero__buttons .btn--ghost{background:rgba(4,4,6,0.38);border-color:rgba(236,231,75,0.55)}
.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);font-family:var(--font-ui);font-size:0.68rem;letter-spacing:0.42em;text-transform:uppercase;color:var(--ink-mute);display:flex;flex-direction:column;align-items:center;gap:0.5rem;pointer-events:none;z-index:5}
.hero__scroll::after{content:"";width:1px;height:34px;background:linear-gradient(180deg,var(--accent),transparent);animation:scrollHint 2s var(--ease-in-out) infinite}
@keyframes scrollHint{0%,100%{transform:scaleY(0.4);transform-origin:top}50%{transform:scaleY(1)}}
.hero__rail{position:absolute;right:var(--gutter);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:1.25rem;z-index:4;padding:2.15rem 0}
.hero__rail::before,.hero__rail::after{content:"";position:absolute;right:-10px;width:18px;height:18px;border-color:var(--deco-line);border-style:solid}
.hero__rail::before{top:0;border-width:1px 1px 0 0}
.hero__rail::after{bottom:0;border-width:0 1px 1px 0}
.hero__rail a{width:32px;height:32px;display:grid;place-items:center;color:var(--accent);opacity:0.86;transition:opacity var(--t-fast),transform var(--t-fast),color var(--t-fast),text-shadow var(--t-fast)}
.hero__rail a:hover{opacity:1;color:var(--accent-hot);transform:translateX(-5px) scale(1.06);text-shadow:0 0 18px rgba(236,231,75,0.65)}
.hero__rail a svg{width:24px;height:24px}
.hero__rail-text{font-family:var(--font-ui);font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;line-height:1}
.choice-section{position:relative;min-height:100svh;padding:calc(var(--header-h)+4rem) 0 clamp(4rem,8vw,7rem);display:flex;align-items:center;overflow:hidden;background:radial-gradient(ellipse at 50% 0%,rgba(236,231,75,0.12),transparent 44%),linear-gradient(180deg,#0F1115 0%,#15171C 45%,#0F1115 100%);isolation:isolate}
.choice-section::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(236,231,75,0.06) 1px,transparent 1px),linear-gradient(180deg,rgba(236,231,75,0.04) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(ellipse at center,black 0%,transparent 72%);opacity:0.32;pointer-events:none;z-index:-1}
.choice-section .container{padding-inline:var(--gutter);width:100%}
.choice-section__head{display:grid;grid-template-columns:1fr minmax(260px,34rem);gap:clamp(1rem,3vw,3rem);align-items:end;margin-bottom:clamp(1.6rem,3vw,2.6rem);will-change:transform,opacity}
.choice-section__title{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,6rem);line-height:0.9;text-transform:uppercase;color:var(--ink)}
.choice-section__title .dot{color:var(--accent)}
.choice-section__head p{color:var(--ink-soft);max-width:42rem;justify-self:end}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2vw,1.6rem);perspective:1100px}
.choice{position:relative;min-height:clamp(420px,42vw,560px);overflow:hidden;background:var(--bg-2);isolation:isolate;border:1px solid rgba(236,231,75,0.24);cursor:pointer;transition:border-color var(--t-med) var(--ease-out),box-shadow var(--t-med) var(--ease-out),filter var(--t-med) var(--ease-out);display:block;box-shadow:var(--shadow-card);will-change:transform,opacity}
.choice::after{content:"";position:absolute;inset:0;border:1px solid transparent;background:linear-gradient(135deg,rgba(236,231,75,0.34),transparent 22%,transparent 72%,rgba(236,231,75,0.2)) border-box;mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);mask-composite:exclude;pointer-events:none;opacity:0;transition:opacity var(--t-med) var(--ease-out)}
.choice__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);transition:transform 1.4s var(--ease-out),filter var(--t-med);z-index:-2;filter:saturate(0.88) contrast(1.05) brightness(0.72)}
.choice__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,17,21,0.32) 0%,rgba(15,17,21,0.10) 40%,rgba(15,17,21,0.72) 100%),linear-gradient(90deg,rgba(15,17,21,0.55) 0%,rgba(15,17,21,0.08) 58%,rgba(15,17,21,0.45) 100%);z-index:-1;transition:opacity var(--t-med)}
.choice:hover{border-color:rgba(236,231,75,0.58);box-shadow:var(--shadow-card),var(--shadow-glow);filter:brightness(1.05)}
.choice:hover::after{opacity:1}
.choice:hover .choice__bg{transform:scale(1.13);filter:saturate(1.02) contrast(1.12) brightness(0.88)}
.choice:hover .choice__overlay{opacity:0.88}
.choice__content{position:relative;height:100%;min-height:inherit;padding:clamp(1.5rem,3vw,3rem);display:flex;flex-direction:column;justify-content:space-between}
.choice__num{font-family:var(--font-ui);font-weight:700;font-size:0.88rem;letter-spacing:0.34em;color:var(--accent)}
.choice__title{font-family:var(--font-display);font-size:clamp(3.2rem,6vw,6.6rem);line-height:0.84;letter-spacing:-0.01em;text-transform:uppercase;color:var(--ink);margin-bottom:0.7rem;text-shadow:0 4px 0 rgba(8,6,4,0.52)}
.choice__title .dot{color:var(--accent)}
.choice__desc{color:var(--ink-soft);max-width:34rem;margin-bottom:1.4rem;font-size:0.95rem}
.selector{position:relative;min-height:100vh;display:flex;align-items:center;padding:calc(var(--header-h)+4rem) var(--gutter) 4rem;overflow:hidden;isolation:isolate}
.selector__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:-3;transform:scale(1.06);transition:opacity 800ms var(--ease-out);filter:brightness(0.55) saturate(0.95);animation:heroZoom 26s var(--ease-out) infinite alternate}
.selector__bg+.selector__bg{opacity:0}
.selector__overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 60% 50%,rgba(15,17,21,0.3) 0%,rgba(15,17,21,0.85) 80%),linear-gradient(180deg,rgba(15,17,21,0.4) 0%,rgba(15,17,21,1) 100%);z-index:-1}
.selector__inner{width:100%;max-width:var(--max-width);margin-inline:auto}
.selector__head{display:flex;align-items:baseline;justify-content:space-between;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.selector__list{list-style:none}
.selector__item{display:grid;grid-template-columns:64px minmax(0,1fr) auto;gap:2rem;align-items:center;padding:1.4rem 0;border-bottom:1px solid var(--line);cursor:pointer;transition:padding var(--t-med) var(--ease-out);position:relative}
.selector__item:first-child{border-top:1px solid var(--line)}
.selector__num{font-family:var(--font-ui);font-size:0.85rem;letter-spacing:0.32em;color:var(--accent);opacity:0.7;transition:opacity var(--t-fast)}
.selector__title{font-family:var(--font-display);font-size:clamp(2rem,5.5vw,4.6rem);line-height:0.95;letter-spacing:-0.01em;text-transform:uppercase;color:var(--ink-soft);transition:color var(--t-med),transform var(--t-med)}
.selector__title .dot{color:var(--accent)}
.selector__caret{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.32em;color:var(--accent);opacity:0;transform:translateX(-10px);transition:opacity var(--t-med),transform var(--t-med)}
.selector__item::before{content:"";position:absolute;left:0;top:50%;width:0;height:2px;background:var(--accent);transform:translateY(-50%);transition:width var(--t-med) var(--ease-out)}
.selector__item:hover{padding-left:1.5rem}
.selector__item:hover::before{width:28px}
.selector__item:hover .selector__title{color:var(--ink)}
.selector__item:hover .selector__caret{opacity:1;transform:translateX(0)}
.selector__list:hover .selector__item:not(:hover) .selector__title{color:var(--ink-mute)}
.category-view{padding:calc(var(--header-h)+3rem) var(--gutter) 6rem;max-width:var(--max-width);margin-inline:auto}
.category-view__back{display:inline-flex;align-items:center;gap:0.6rem;font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:2rem;transition:color var(--t-fast),transform var(--t-fast);background:none;border:none;cursor:pointer;padding:0;text-decoration:none}
.category-view__back:hover{color:var(--accent);transform:translateX(-4px)}
.category-view__back .arrow{transform:scaleX(-1)}
.category-view__head{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;padding-bottom:2rem;border-bottom:1px solid var(--line);margin-bottom:3rem}
.category-view__meta{font-family:var(--font-ui);font-size:0.75rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--ink-mute);text-align:right;line-height:1.8}
.category-view__meta strong{color:var(--accent);font-weight:500}
.works{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(1rem,2vw,1.6rem)}
.work{position:relative;grid-column:span 3;aspect-ratio:16 / 11;overflow:hidden;background:var(--bg-2);isolation:isolate;cursor:pointer;border:1px solid var(--line)}
.work:nth-child(5n+1){grid-column:span 4}
.work:nth-child(5n+2){grid-column:span 2;aspect-ratio:1 / 1.05}
.work__img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);transition:transform 1.6s var(--ease-out),filter var(--t-med);z-index:-2}
.work__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,17,21,0.2) 0%,rgba(15,17,21,0.5) 60%,rgba(15,17,21,0.95) 100%);z-index:-1;transition:opacity var(--t-med)}
.work:hover .work__img{transform:scale(1.12);filter:brightness(1.1) saturate(1.05)}
.work__content{position:relative;height:100%;padding:clamp(1.2rem,2vw,1.8rem);display:flex;flex-direction:column;justify-content:flex-end;gap:0.4rem}
.work__type{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent);opacity:0.85}
.work__title{font-family:var(--font-display);font-size:clamp(1.4rem,2.4vw,2.2rem);line-height:0.95;text-transform:uppercase;color:var(--ink);letter-spacing:-0.005em}
.work__metaLine{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute);margin-top:0.4rem;opacity:0;max-height:0;transition:opacity var(--t-med),max-height var(--t-med)}
.work:hover .work__metaLine{opacity:1;max-height:2rem}
.work__line{position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent);transition:width var(--t-med) var(--ease-out);z-index:4}
.work:hover .work__line{width:100%}
.archive-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(0.8rem,1.5vw,1.2rem);padding:0 var(--gutter) 6rem;max-width:var(--max-width);margin-inline:auto}
.arc-item{position:relative;overflow:hidden;background:var(--bg-2);cursor:pointer;isolation:isolate;border:1px solid var(--line);aspect-ratio:4 / 3}
.arc-item:nth-child(12n+1){grid-column:span 5;aspect-ratio:4 / 3}
.arc-item:nth-child(12n+2){grid-column:span 4;aspect-ratio:1 / 1}
.arc-item:nth-child(12n+3){grid-column:span 3;aspect-ratio:3 / 4}
.arc-item:nth-child(12n+4){grid-column:span 4;aspect-ratio:4 / 3}
.arc-item:nth-child(12n+5){grid-column:span 4;aspect-ratio:4 / 5}
.arc-item:nth-child(12n+6){grid-column:span 4;aspect-ratio:4 / 3}
.arc-item:nth-child(12n+7){grid-column:span 3;aspect-ratio:3 / 4}
.arc-item:nth-child(12n+8){grid-column:span 5;aspect-ratio:16 / 10}
.arc-item:nth-child(12n+9){grid-column:span 4;aspect-ratio:1 / 1}
.arc-item:nth-child(12n+10){grid-column:span 4;aspect-ratio:4 / 3}
.arc-item:nth-child(12n+11){grid-column:span 4;aspect-ratio:1 / 1}
.arc-item:nth-child(12n+0){grid-column:span 12;aspect-ratio:21 / 9}
.arc-item__img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);transition:transform 1.4s var(--ease-out),filter var(--t-med);z-index:-2}
.arc-item:hover .arc-item__img{transform:scale(1.16);filter:brightness(0.7)}
.arc-item__overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,17,21,0.95) 100%);z-index:-1}
.arc-item__content{position:absolute;left:0;right:0;bottom:0;padding:1.2rem 1.4rem;transform:translateY(8px);opacity:0;transition:transform var(--t-med),opacity var(--t-med)}
.arc-item:hover .arc-item__content{transform:translateY(0);opacity:1}
.arc-item__type{font-family:var(--font-ui);font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent)}
.arc-item__title{font-family:var(--font-display);font-size:clamp(1.1rem,1.6vw,1.5rem);text-transform:uppercase;color:var(--ink);letter-spacing:0.005em;margin-top:0.2rem;line-height:1}
.about-section{padding:calc(var(--header-h) + 5rem) var(--gutter) 6rem;max-width:var(--max-width);margin-inline:auto}
.about-header{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:flex-start;overflow:visible;min-width:0}
.about-header__left{min-width:0;overflow:visible;word-wrap:break-word}
.about-header__meta{white-space:nowrap;align-self:flex-start;padding-top:clamp(0.8rem,2vw,1.2rem);font-size:clamp(0.75rem,0.9vw,0.85rem)}
.about-identity-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1rem}
.about-identity-tag{font-family:var(--font-ui);font-size:0.68rem;letter-spacing:0.26em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-line);padding:0.3rem 0.7rem;background:var(--accent-soft)}
.about-grid{display:grid;grid-template-columns:0.85fr 1.6fr;gap:clamp(2rem,4vw,5rem);align-items:start;margin-top:3rem}
.about-portrait{position:relative;aspect-ratio:1/1;background:var(--bg-2);overflow:hidden;border:1px solid var(--line)}
.about-portrait__img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03);animation:heroZoom 30s var(--ease-out) infinite alternate}
.about-portrait__img--photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;transform:scale(1.03);animation:heroZoom 30s var(--ease-out) infinite alternate;display:block}
.about-portrait picture{position:absolute;inset:0;display:block}
.about-bio{display:flex;flex-direction:column;gap:2rem}
.about-bio p{color:var(--ink-soft);font-size:1.02rem;line-height:1.75}
.skill-list{list-style:none;display:grid;gap:0.7rem;margin-top:0.8rem}
.skill-list li{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;padding-block:0.6rem;border-bottom:1px solid var(--line)}
.skill-list .skill-num{font-family:var(--font-ui);font-size:0.75rem;letter-spacing:0.32em;color:var(--accent)}
.skill-list .skill-name{font-family:var(--font-display);font-size:1.6rem;text-transform:uppercase;color:var(--ink);letter-spacing:0.005em}
.skill-list .skill-tag{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--ink-mute)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:2rem;background:var(--line);border:1px solid var(--line)}
.stat{background:var(--bg-1);padding:1.6rem 1.2rem}
.stat__num{font-family:var(--font-display);font-size:clamp(2rem,3vw,2.8rem);color:var(--accent);line-height:1}
.stat__label{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-mute);margin-top:0.5rem}
.blog-head{position:relative;padding:calc(var(--header-h)+4rem) var(--gutter) 3rem;max-width:var(--max-width);margin-inline:auto;display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:end;border-bottom:1px solid var(--line)}
.blog-head__decor{position:absolute;left:var(--gutter);top:calc(var(--header-h)+4rem);width:24px;display:flex;flex-direction:column;align-items:center;gap:0.5rem;pointer-events:none}
.blog-head__decor i{display:block;width:8px;height:8px;background:var(--accent)}
.blog-head__decor span{width:1px;height:80px;background:linear-gradient(180deg,var(--accent),transparent);display:block}
.blog-head__decor i.hollow{background:transparent;border:1px solid var(--accent);width:14px;height:14px}
.blog-head__title{padding-left:4rem}
.blog-head__title p{margin-top:1rem;color:var(--ink-soft);font-size:0.95rem;line-height:1.7;max-width:36rem}
.blog-head__updated{text-align:right}
.blog-head__updated .label{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.32em;color:var(--accent);text-transform:uppercase}
.blog-head__updated .date{font-family:var(--font-display);font-size:clamp(1.6rem,2.4vw,2.2rem);color:var(--ink);text-transform:uppercase;letter-spacing:0.02em;line-height:1;margin-top:0.4rem}
.blog-head__updated p{margin-top:1rem;font-size:0.9rem;color:var(--ink-soft);line-height:1.6;max-width:26rem;margin-left:auto}
.blog-list{max-width:var(--max-width);margin-inline:auto;padding:0 var(--gutter) 6rem}
.blog-row{display:grid;grid-template-columns:280px 1fr;gap:clamp(1.5rem,3vw,3rem);align-items:start;padding:2rem 0;border-bottom:1px solid var(--line);position:relative;cursor:pointer;transition:padding var(--t-med) var(--ease-out)}
.blog-row::before{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--accent);transition:width var(--t-med) var(--ease-out)}
.blog-row:hover::before{width:100%}
.blog-row:hover{padding-left:1rem}
.blog-row__thumb{position:relative;aspect-ratio:16 / 10;overflow:hidden;background:var(--bg-2);border:1px solid var(--line)}
.blog-row__thumb-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03);transition:transform 1.4s var(--ease-out)}
.blog-row:hover .blog-row__thumb-img{transform:scale(1.12)}
.blog-row__meta{display:flex;align-items:center;gap:1rem;font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.28em;text-transform:uppercase;margin-bottom:0.55rem}
.blog-row__cat{color:var(--accent);font-weight:600}
.blog-row__sep{color:var(--ink-mute)}
.blog-row__date{color:var(--ink-soft)}
.blog-row__title{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,2.2rem);text-transform:uppercase;color:var(--ink);line-height:1;letter-spacing:0.005em;margin-bottom:0.7rem;transition:color var(--t-fast)}
.blog-row:hover .blog-row__title{color:var(--accent-hot)}
.blog-row__excerpt{color:var(--ink-soft);font-size:0.96rem;line-height:1.65;max-width:60ch;margin-bottom:1rem}
.blog-row__more{display:inline-flex;align-items:center;gap:0.7rem;font-family:var(--font-ui);font-size:0.75rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent);font-weight:600}
.blog-row__more .arrow{transition:transform var(--t-med)}
.blog-row:hover .blog-row__more .arrow{transform:translateX(6px)}
.contact-section{position:relative;padding:calc(var(--header-h)+4rem) var(--gutter) 6rem;max-width:var(--max-width);margin-inline:auto;isolation:isolate}
.contact-section__bg{position:fixed;inset:0;background-size:cover;background-position:center;filter:brightness(0.32) blur(4px);z-index:-3}
.contact-section__overlay{position:fixed;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(236,231,75,0.08),transparent 50%),linear-gradient(180deg,rgba(15,17,21,0.6),rgba(15,17,21,0.95));z-index:-2}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(2rem,4vw,5rem);margin-top:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.8rem}
.contact-info__block .label{font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent);margin-bottom:0.4rem;display:block}
.contact-info__block .value{font-family:var(--font-display);font-size:1.4rem;text-transform:uppercase;color:var(--ink);letter-spacing:0.02em}
.contact-info__block p{color:var(--ink-soft);font-size:0.95rem;line-height:1.7}
.contact-form{background:var(--bg-glass);border:1px solid var(--line-strong);padding:clamp(1.5rem,3vw,2.5rem);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:relative}
.field{margin-bottom:1.4rem}
.field label{display:block;font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:0.5rem}
.field input,.field textarea{width:100%;background:rgba(10,9,8,0.55);border:1px solid var(--line-strong);padding:0.9rem 1rem;color:var(--ink);font-family:var(--font-body);font-size:0.95rem;transition:border var(--t-fast),background var(--t-fast)}
.field input:focus,.field textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent);background:rgba(10,9,8,0.72)}
.field textarea{min-height:140px;resize:vertical}
.form-msg{margin-top:1rem;font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);min-height:1.4rem}
.modal{position:fixed;inset:0;z-index:200;display:none;background:radial-gradient(ellipse at 50% 50%,#1c1f23 0%,#0e1014 60%,#07080b 100%);opacity:0;transition:opacity 320ms var(--ease-out);overflow:hidden;font-family:var(--font-body)}
.modal.is-open{display:block;opacity:1}
.modal.is-fullscreen{background:#07080b}
.modal::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:0.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.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 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");z-index:1}
.modal__topbar{position:absolute;top:0;left:0;right:0;z-index:6;display:grid;grid-template-columns:1fr auto 1fr auto;align-items:start;gap:clamp(1rem,3vw,2.5rem);padding:clamp(1rem,2.4vw,1.6rem) clamp(1.2rem,3vw,2.4rem);pointer-events:none}
.modal__topbar>*{pointer-events:auto}
.modal__credits{display:flex;flex-direction:column;gap:0.18rem;font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;line-height:1.5}
.modal__credit .lbl{color:var(--accent)}
.modal__credit .val{color:var(--ink);margin-left:0.4rem}
.modal__counter{font-family:var(--font-ui);font-size:0.78rem;font-weight:600;letter-spacing:0.32em;color:var(--ink-mute);align-self:center;white-space:nowrap}
.modal__counter .num{color:var(--accent)}
.modal__counter .tot{color:var(--ink-soft)}
.modal__actions{display:flex;align-items:center;gap:0.6rem;align-self:center;font-family:var(--font-ui);font-size:0.74rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase}
.modal__action{background:none;border:0;padding:0.3rem 0.2rem;color:var(--ink);cursor:pointer;letter-spacing:inherit;text-transform:inherit;font:inherit;transition:color 200ms var(--ease-out),text-shadow 200ms var(--ease-out)}
.modal__action:hover,.modal__action:focus-visible,.modal__action.is-active{color:var(--accent-hot);text-shadow:0 0 12px rgba(236,231,75,0.5);outline:2px solid var(--accent);outline-offset:3px}
.modal__sep{color:var(--ink-mute);user-select:none}
.modal__close{align-self:center;width:36px;height:36px;display:grid;place-items:center;background:none;border:0;color:var(--accent);font-size:1.3rem;font-weight:400;cursor:pointer;transition:transform 220ms var(--ease-out),color 220ms var(--ease-out),text-shadow 220ms var(--ease-out)}
.modal__close:hover,.modal__close:focus-visible{transform:rotate(90deg) scale(1.05);color:var(--accent-hot);text-shadow:0 0 18px rgba(236,231,75,0.55);outline:2px solid var(--accent);outline-offset:3px}
.modal__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:44px;height:80px;display:grid;place-items:center;background:rgba(8,9,12,0.68);border:1px solid var(--accent-line);color:var(--ink);cursor:pointer;transition:background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out),box-shadow var(--t-fast) var(--ease-out);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.modal__nav svg{width:18px;height:18px;transition:transform var(--t-med) var(--ease-out)}
.modal__nav--prev{left:0;border-radius:0 4px 4px 0;border-left:0}
.modal__nav--next{right:0;border-radius:4px 0 0 4px;border-right:0;color:var(--accent)}
.modal__nav:hover,.modal__nav:focus-visible{background:rgba(236,231,75,0.28);border-color:var(--accent);color:var(--accent-hot);box-shadow:0 0 24px -4px rgba(236,231,75,0.55);outline:none}
.modal__nav--prev:hover svg,.modal__nav--prev:focus-visible svg{transform:translateX(-3px)}
.modal__nav--next:hover svg,.modal__nav--next:focus-visible svg{transform:translateX(3px)}
.modal__nav.is-disabled{opacity:0;pointer-events:none}
.modal__nav[hidden]{display:none!important}
.modal__stage{position:absolute;inset:0;display:grid;place-items:center;padding:clamp(4rem,6vw,5.5rem) clamp(2rem,4vw,4rem) clamp(6rem,10vw,10rem);z-index:2}
.modal__watermark{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--font-display);font-size:clamp(20rem,38vw,44rem);line-height:1;letter-spacing:-0.04em;color:rgba(234,228,218,0.018);pointer-events:none;user-select:none;z-index:0;filter:blur(1px)}
.modal__img-wrap{position:relative;overflow:hidden;z-index:1;width:min(100%,1600px);height:min(80vh,960px);max-height:min(80vh,960px);aspect-ratio:auto;background:#0F1115;box-shadow:0 40px 90px -30px rgba(8,7,5,0.82),0 12px 32px -12px rgba(0,0,0,0.7),0 0 0 1px rgba(234,228,218,0.04);cursor:zoom-in;transition:transform 480ms var(--ease-out),box-shadow 480ms var(--ease-out);display:flex;align-items:center;justify-content:center}
.modal__img-wrap.is-zoomed{cursor:zoom-out;transform:scale(1.35);box-shadow:0 60px 120px -30px rgba(0,0,0,0.92),0 0 0 1px rgba(236,231,75,0.22)}
.modal__img{position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat;transition:opacity 220ms var(--ease-out),transform 480ms var(--ease-out);min-height:320px}
.modal__caption{position:absolute;left:clamp(1.2rem,3vw,2.4rem);right:clamp(1.2rem,3vw,2.4rem);bottom:clamp(1.2rem,2.5vw,2rem);z-index:4;display:flex;flex-direction:column;gap:0.45rem;align-items:flex-start;pointer-events:none;text-align:left;transition:opacity 280ms var(--ease-out),transform 320ms var(--ease-out)}
.modal__caption .modal__category{font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent)}
.modal__caption .modal__title{font-family:var(--font-display);font-size:clamp(1.6rem,2.6vw,2.4rem);line-height:0.95;letter-spacing:0.005em;text-transform:uppercase;color:var(--ink);text-shadow:0 2px 8px rgba(0,0,0,0.6);max-width:42ch}
.modal__caption .modal__title .dot{color:var(--accent)}
.modal__caption .modal__desc{font-size:0.92rem;color:var(--ink-soft);max-width:64ch;line-height:1.55}
.modal__caption .tags{margin-top:0.3rem;display:flex;flex-wrap:wrap;gap:0.35rem}
.modal.is-swapping .modal__img,.modal.is-swapping .modal__caption{opacity:0;transform:translateY(6px)}
.modal__toast{position:absolute;left:50%;bottom:clamp(1.5rem,3vw,2.5rem);transform:translate(-50%,12px);z-index:8;padding:0.55rem 1rem;background:rgba(8,8,12,0.92);border:1px solid var(--accent-line);font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);opacity:0;pointer-events:none;transition:opacity 220ms var(--ease-out),transform 220ms var(--ease-out)}
.modal__toast.is-visible{opacity:1;transform:translate(-50%,0)}
body.modal-open{overflow:hidden}
@media (max-width:760px){.modal__topbar{grid-template-columns:1fr auto auto;grid-template-rows:auto auto;gap:0.5rem 0.8rem}.modal__credits{grid-column:1 / -1;order:2;font-size:0.65rem}.modal__counter{order:1}.modal__actions{order:1;font-size:0.66rem;gap:0.4rem}.modal__close{order:1}.modal__stage{padding:clamp(7rem,18vw,8.5rem) clamp(3rem,9vw,4.5rem) clamp(8rem,22vw,11rem)}.modal__nav{width:44px;height:44px}.modal__caption .modal__title{font-size:clamp(1.4rem,5.4vw,2rem)}.modal__caption .modal__desc{font-size:0.85rem}.modal__watermark{font-size:14rem}}
.modal__more{display:inline-flex;align-items:center;gap:0.5rem;margin-top:0.6rem;padding:0.55rem 1rem;background:rgba(236,231,75,0.12);border:1px solid var(--accent);color:var(--accent);font-family:var(--font-ui);font-size:0.74rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;cursor:pointer;pointer-events:auto;transition:background 220ms var(--ease-out),color 220ms var(--ease-out),transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out)}
.modal__more:hover,.modal__more:focus-visible{background:var(--accent);color:#EAE4DA;transform:translateY(-2px);box-shadow:0 0 24px -4px rgba(236,231,75,0.6);outline:2px solid var(--accent-hot);outline-offset:2px}
.modal__more .arrow{font-size:0.9rem;line-height:1}
.modal__details{position:absolute;left:0;right:0;bottom:0;z-index:7;height:78vh;max-height:78vh;background:linear-gradient(180deg,rgba(14,13,12,0.96) 0%,rgba(10,10,13,0.99) 60%,rgba(8,8,10,1) 100%);border-top:1px solid var(--accent-line);box-shadow:0 -40px 80px -30px rgba(0,0,0,0.85);transform:translateY(102%);opacity:0;pointer-events:none;overflow-y:auto;overflow-x:hidden;padding:clamp(2rem,4vw,3.2rem) clamp(1.5rem,4vw,3rem) clamp(2rem,4vw,3rem);transition:transform 540ms cubic-bezier(0.22,1,0.36,1),opacity 360ms var(--ease-out);scrollbar-width:thin;scrollbar-color:var(--accent) transparent}
.modal__details::-webkit-scrollbar{width:6px}
.modal__details::-webkit-scrollbar-thumb{background:var(--accent)}
.modal.details-open .modal__details{transform:translateY(0);opacity:1;pointer-events:auto}
.modal.details-open .modal__nav,.modal.details-open .modal__caption,.modal.details-open .modal__topbar{opacity:0.0;pointer-events:none}
.modal.details-open .modal__topbar{opacity:0.35}
.modal.details-open .modal__img-wrap{transform:scale(0.92) translateY(-4vh);opacity:0.55}
.modal-details__close{position:sticky;top:0;margin-left:auto;display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 0.9rem;background:rgba(8,8,12,0.85);border:1px solid var(--line-strong);color:var(--ink);font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;cursor:pointer;z-index:2;transition:background 200ms var(--ease-out),color 200ms var(--ease-out),border-color 200ms var(--ease-out)}
.modal-details__close:hover{background:var(--accent);color:#EAE4DA;border-color:var(--accent)}
.modal-details__close .arrow{font-size:0.95rem;line-height:1}
.modal-details__head{margin-bottom:1.4rem}
.modal-details__grid{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(1.5rem,3.5vw,3rem);max-width:1280px;margin-inline:auto}
.modal-details__col{min-width:0}
.modal-details__col--meta{padding-left:clamp(0rem,2vw,1.2rem);border-left:1px solid var(--line)}
.modal-details__section{margin-bottom:1.6rem}
.modal-details__section .eyebrow{display:block;margin-bottom:0.6rem;color:var(--accent);font-family:var(--font-ui);font-size:0.7rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase}
.modal-details__text{font-size:0.98rem;line-height:1.75;color:var(--ink-soft);max-width:70ch}
.modal-details__steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0.6rem}
.modal-details__step{position:relative;padding:1rem 1.1rem;background:rgba(234,228,218,0.018);border:1px solid var(--line);transition:border-color 220ms var(--ease-out),background 220ms var(--ease-out)}
.modal-details__step:hover{border-color:var(--accent-line);background:rgba(236,231,75,0.04)}
.modal-details__step-label{font-family:var(--font-ui);font-size:0.65rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent)}
.modal-details__step-title{margin:0.35rem 0 0.4rem;font-family:var(--font-display);font-weight:400;font-size:1.05rem;letter-spacing:0.02em;text-transform:uppercase;color:var(--ink)}
.modal-details__step-text{font-size:0.85rem;line-height:1.6;color:var(--ink-soft)}
.modal-details__dl{display:flex;flex-direction:column;gap:0.55rem;margin:0}
.modal-details__dl>div{display:grid;grid-template-columns:90px 1fr;gap:0.6rem;padding:0.4rem 0;border-bottom:1px solid var(--line)}
.modal-details__dl dt{font-family:var(--font-ui);font-size:0.65rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-mute)}
.modal-details__dl dd{margin:0;font-family:var(--font-ui);font-size:0.85rem;color:var(--ink);letter-spacing:0.04em}
@media (max-width:880px){.modal__details{height:88vh;max-height:88vh}.modal-details__grid{grid-template-columns:1fr}.modal-details__col--meta{padding-left:0;border-left:0;border-top:1px solid var(--line);padding-top:1.2rem}}
@media (prefers-reduced-motion:reduce){.modal,.modal__img,.modal__caption,.modal__img-wrap,.modal__nav svg,.modal__close,.modal__details{transition-duration:0.001ms !important}}
.page-post{background:var(--bg-0)}
.post{max-width:1400px;margin:0 auto;padding:calc(var(--header-h)+3rem) var(--gutter) 5rem;opacity:0;transform:translateY(48px);transition:transform 720ms cubic-bezier(0.22,1,0.36,1),opacity 600ms var(--ease-out);will-change:transform,opacity}
.post.is-in{opacity:1;transform:translateY(0)}
.post__back{display:inline-flex;align-items:center;gap:0.5rem;margin-bottom:2rem;font-family:var(--font-ui);font-size:0.74rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color 220ms var(--ease-out),gap 220ms var(--ease-out)}
.post__back:hover{color:var(--accent);gap:0.75rem}
.post__back .arrow{font-size:1rem}
.post__head{display:flex;flex-direction:column;gap:0.8rem;margin-bottom:2rem;max-width:78ch}
.post__meta{display:flex;flex-wrap:wrap;align-items:center;gap:0.6rem;font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase}
.post__cat{color:var(--accent)}
.post__date{color:var(--ink-soft)}
.post__read{color:var(--ink-mute)}

/* Big read-time badge below the excerpt */
.post__read-time {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0.5rem;
  padding: 0.45rem 0.9rem;
  background: rgba(236,231,75,0.10);
  border: 1px solid var(--accent-line);
  color: var(--accent);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.30em;
  text-transform: uppercase;
}
.post__read-time svg { opacity: 0.8; flex-shrink: 0; }

/* Company / Studio badge in sidebar */
.post__context-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 0.9rem;
  background: rgba(236,231,75,0.08);
  border: 1px solid var(--accent-line);
  color: var(--ink);
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  width: 100%;
}
[data-theme="light"] .post__read-time { background: rgba(168,86,0,0.08); }
[data-theme="light"] .post__context-badge { background: rgba(168,86,0,0.07); }
.post__sep{color:var(--ink-mute)}
.post__title{font-family:var(--font-display);font-weight:400;font-size:clamp(2.4rem,5.5vw,4.4rem);line-height:0.96;letter-spacing:0.005em;text-transform:uppercase;color:var(--ink);margin:0;max-width:22ch}
.post__title .dot{color:var(--accent)}
.post__excerpt{margin:0;font-size:1.05rem;line-height:1.65;color:var(--ink-soft);max-width:70ch}
.post__hero{position:relative;margin-bottom:3rem;aspect-ratio:21 / 9;width:100%;background:var(--bg-2);overflow:hidden}
.post__hero-img{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(1.0) contrast(1.05)}
.post__layout{display:grid;grid-template-columns:1fr 220px;gap:clamp(2rem,4vw,3.5rem);align-items:start;margin-bottom:4rem}
.post__body{min-width:0;max-width:none}
.post-body__h{font-family:var(--font-display);font-weight:400;font-size:clamp(1.4rem,2.4vw,1.9rem);line-height:1.1;letter-spacing:0.01em;text-transform:uppercase;color:var(--ink);margin:2.4rem 0 1rem}
.post-body__p{font-size:1rem;line-height:1.75;color:var(--ink-soft);margin:0 0 1.2rem}
.post-body__fig{margin:2rem 0}
.post-body__img{aspect-ratio:16 / 9;background:var(--bg-2);background-size:cover;background-position:center}
.post-body__fig figcaption{margin-top:0.6rem;font-family:var(--font-ui);font-size:0.72rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}
.post-body__quote{margin:2rem 0;padding:1rem 1.4rem;border-left:3px solid var(--accent);background:rgba(236,231,75,0.04)}
.post-body__quote p{font-family:var(--font-display);font-weight:400;font-size:1.3rem;line-height:1.4;letter-spacing:0.005em;color:var(--ink);margin:0}
.post-body__quote cite{display:block;margin-top:0.6rem;font-family:var(--font-ui);font-size:0.72rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-mute);font-style:normal}
.post__aside{position:sticky;top:calc(var(--header-h)+2rem);display:flex;flex-direction:column;gap:1.6rem;padding-left:clamp(1rem,2.5vw,2rem);border-left:1px solid var(--line)}
.post__aside-block .label{display:block;margin-bottom:0.6rem;font-family:var(--font-ui);font-size:0.7rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent)}
.post__tools{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0.3rem}
.post__tools li{font-family:var(--font-ui);font-size:0.85rem;letter-spacing:0.04em;color:var(--ink);padding:0.35rem 0;border-bottom:1px solid var(--line)}
.post__share{display:flex;flex-direction:column;gap:0.4rem}
.post__share button{width:100%;padding:0.55rem 0.8rem;background:transparent;border:1px solid var(--line-strong);color:var(--ink);font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;text-align:left;cursor:pointer;transition:border-color 200ms,color 200ms,background 200ms}
.post__share button:hover{border-color:var(--accent);color:var(--accent);background:rgba(236,231,75,0.06)}
.post-breakdown{margin-bottom:4rem;padding-top:2rem;border-top:1px solid var(--line)}
.post-breakdown__head{margin-bottom:1.6rem}
.post-breakdown__head .eyebrow{color:var(--accent)}
.post-breakdown__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0.8rem}
.post-breakdown__item{padding:1.4rem 1.4rem 1.6rem;background:rgba(234,228,218,0.018);border:1px solid var(--line);transition:border-color 220ms var(--ease-out),background 220ms var(--ease-out),transform 320ms var(--ease-out)}
.post-breakdown__item:hover{border-color:var(--accent-line);background:rgba(236,231,75,0.04);transform:translateY(-3px)}
.post-breakdown__label{font-family:var(--font-ui);font-size:0.68rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent)}
.post-breakdown__title{margin:0.4rem 0 0.5rem;font-family:var(--font-display);font-weight:400;font-size:1.2rem;letter-spacing:0.01em;text-transform:uppercase;color:var(--ink)}
.post-breakdown__text{margin:0;font-size:0.92rem;line-height:1.6;color:var(--ink-soft)}
.post__nav{display:grid;grid-template-columns:1fr 1fr;gap:0.8rem;margin-bottom:4rem;padding-top:2rem;border-top:1px solid var(--line)}
.post__nav-link{display:flex;flex-direction:column;gap:0.45rem;padding:1.4rem 1.5rem;background:rgba(234,228,218,0.015);border:1px solid var(--line);text-decoration:none;transition:border-color 220ms,background 220ms,transform 220ms}
.post__nav-link:hover{border-color:var(--accent);background:rgba(236,231,75,0.04);transform:translateY(-2px)}
.post__nav-link--next{text-align:right}
.post__nav-link .label{font-family:var(--font-ui);font-size:0.7rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;color:var(--accent)}
.post__nav-link .title{font-family:var(--font-display);font-weight:400;font-size:1.1rem;letter-spacing:0.01em;text-transform:uppercase;color:var(--ink)}
.post-comments{padding-top:2rem;border-top:1px solid var(--line)}
.post-comments__head{margin-bottom:1.6rem}
.post-comments__head .eyebrow{color:var(--accent)}
.post-comments__note{margin-top:0.5rem;font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute)}
.post-comments__form{display:flex;flex-direction:column;gap:1rem;padding:1.4rem;margin-bottom:2rem;background:rgba(234,228,218,0.015);border:1px solid var(--line)}
.post-comments__form .field{display:flex;flex-direction:column;gap:0.4rem}
.post-comments__form label{font-family:var(--font-ui);font-size:0.7rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-mute)}
.post-comments__form input,.post-comments__form textarea{padding:0.7rem 0.9rem;background:rgba(10,9,8,0.55);border:1px solid var(--line-strong);color:var(--ink-mute);font-family:var(--font-body);font-size:0.92rem;resize:vertical}
.post-comments__form input:disabled,.post-comments__form textarea:disabled,.post-comments__form button:disabled{cursor:not-allowed;opacity:0.55}
.post-comments__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}
.post-comment{display:grid;grid-template-columns:44px 1fr;gap:1rem;padding:1.2rem 1.3rem;background:rgba(234,228,218,0.015);border:1px solid var(--line);transition:border-color 220ms}
.post-comment:hover{border-color:var(--accent-line)}
.post-comment__avatar{width:44px;height:44px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(236,231,75,0.25),rgba(236,231,75,0.08));border:1px solid var(--accent-line);font-family:var(--font-display);font-size:1.2rem;color:var(--accent)}
.post-comment__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:0.5rem;margin-bottom:0.4rem}
.post-comment__author{font-family:var(--font-ui);font-weight:700;font-size:0.85rem;letter-spacing:0.04em;color:var(--ink)}
.post-comment__handle{font-family:var(--font-ui);font-size:0.75rem;letter-spacing:0.06em;color:var(--accent)}
.post-comment__time{font-family:var(--font-ui);font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute)}
.post-comment__text{margin:0;font-size:0.92rem;line-height:1.6;color:var(--ink-soft)}
.post-comment__actions{display:flex;gap:0.8rem;margin-top:0.5rem}
.post-comment__actions button{padding:0.3rem 0.7rem;background:transparent;border:1px solid var(--line);color:var(--ink-mute);font-family:var(--font-ui);font-size:0.65rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;cursor:not-allowed;opacity:0.55}
.post-toast{position:fixed;left:50%;bottom:2rem;transform:translate(-50%,12px);z-index:300;padding:0.55rem 1rem;background:rgba(8,8,12,0.95);border:1px solid var(--accent-line);font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);opacity:0;pointer-events:none;transition:opacity 220ms var(--ease-out),transform 220ms var(--ease-out)}
.post-toast.is-visible{opacity:1;transform:translate(-50%,0)}
@media (max-width:880px){.post__layout{grid-template-columns:1fr}.post__aside{position:static;padding-left:0;border-left:0;border-top:1px solid var(--line);padding-top:1.6rem}.post__nav{grid-template-columns:1fr}.post__nav-link--next{text-align:left}.post__hero{aspect-ratio:16 / 9}}
@media (prefers-reduced-motion:reduce){.post,.post-breakdown__item,.post__nav-link{transition-duration:0.001ms !important}}
.site-footer{border-top:1px solid var(--line);padding:3rem var(--gutter) 2rem;margin-top:4rem;background:var(--bg-0);position:relative;z-index:1}
.site-footer__inner{max-width:var(--max-width);margin-inline:auto;display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center}
.site-footer .meta{font-size:0.7rem}
.site-footer .center-mark{font-family:var(--font-display);color:var(--accent);letter-spacing:0.05em;text-transform:uppercase}
.site-footer .right{text-align:right}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 800ms var(--ease-out),transform 800ms var(--ease-out);transition-delay:var(--delay,0ms);will-change:transform,opacity}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.fade-up{opacity:0;transform:translateY(40px);animation:fadeUp 1s var(--ease-out) forwards;animation-delay:var(--delay,0ms)}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
body.modal-open{overflow:hidden}
@media (max-width:1024px){.hero__content{grid-template-columns:1fr}.hero__rail{display:none}.hero__copy{padding-left:0}.hero__copy::before{display:none}.nav a{padding:0.5rem 0.7rem;font-size:0.78rem;letter-spacing:0.22em}.choice-section__head{grid-template-columns:1fr}.choice-section__head p{justify-self:start}.choice-grid{grid-template-columns:1fr}.choice{min-height:340px;height:auto}.works{grid-template-columns:repeat(4,1fr)}.work{grid-column:span 2 !important;aspect-ratio:16/11 !important}.archive-grid{grid-template-columns:repeat(6,1fr)}.arc-item{grid-column:span 3 !important;aspect-ratio:4/3 !important}.arc-item:nth-child(odd){aspect-ratio:1/1 !important}.about-grid{grid-template-columns:1fr}.about-portrait{max-width:380px}.blog-head{grid-template-columns:1fr;gap:1.5rem}.blog-head__title{padding-left:3rem}.blog-head__updated{text-align:left}.blog-head__updated p{margin-left:0}.blog-row{grid-template-columns:220px 1fr}.contact-grid{grid-template-columns:1fr}.modal__panel{grid-template-columns:1fr;max-height:88vh}.modal__media{min-height:280px;aspect-ratio:16/9}}
@media (max-width:720px){:root{--header-h:60px}.brand__name{font-size:0.78rem;letter-spacing:0.12em}.brand__role{display:none}.nav{display:none}.nav.is-open{display:flex;position:fixed;inset:var(--header-h) 0 0 0;background:var(--bg-0);flex-direction:column;padding:2rem var(--gutter);align-items:stretch;border-top:1px solid var(--line);overflow-y:auto}.nav.is-open a{padding:1rem 0;border-left:0;border-bottom:1px solid var(--line);font-size:1rem}.nav-toggle{display:block}.hero{align-items:center}.hero::before,.hero::after{display:none}.hero__content{padding:calc(var(--header-h)+2.6rem) var(--gutter) 4.5rem}.hero__title{font-size:clamp(3.7rem,18vw,5.8rem);line-height:0.82}.hero__sub{letter-spacing:0.25em}.hero__buttons{flex-direction:column;align-items:stretch}.choice-section{padding-top:calc(var(--header-h)+2.6rem)}.choice-section__title{font-size:clamp(2.7rem,14vw,4.8rem)}.choice{min-height:320px}.choice__title{font-size:clamp(3rem,16vw,5rem)}.selector__item{grid-template-columns:36px 1fr auto;padding:1rem 0;gap:1rem}.selector__title{font-size:1.6rem}.works{grid-template-columns:1fr;gap:0.8rem}.work{grid-column:span 1 !important;aspect-ratio:16/10 !important}.archive-grid{grid-template-columns:1fr}.arc-item{grid-column:span 1 !important;aspect-ratio:4/3 !important}.blog-row{grid-template-columns:1fr}.blog-head__title{padding-left:2.5rem}.blog-head__decor{transform:scale(0.8);transform-origin:top left}.stats{grid-template-columns:1fr}.skill-list .skill-name{font-size:1.2rem}.modal__details{grid-template-columns:1fr}.modal__related-grid{grid-template-columns:repeat(2,1fr)}.site-footer__inner{grid-template-columns:1fr;text-align:center}.site-footer .right{text-align:center}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;scroll-behavior:auto !important}.hero__bg,.selector__bg,.about-portrait__img{animation:none !important}.reveal{opacity:1;transform:none}}
.page-home .hero{min-height:100svh;align-items:center}
.page-home .hero__content{padding-top:calc(var(--header-h)+clamp(2.2rem,4.5vw,4.6rem));padding-bottom:clamp(4.2rem,7vw,6.8rem);grid-template-columns:minmax(0,1fr);gap:0}
.page-home .hero__spacer{display:none}
.page-home .hero__copy{max-width:min(72rem,78vw);padding-left:clamp(0.6rem,3.2vw,4.4rem);transform:translateY(clamp(0rem,1.5vh,1.1rem))}
.page-home .hero__copy::before{left:clamp(-0.15rem,1.9vw,2.25rem);top:0.18rem;height:clamp(78px,11vw,144px);opacity:0.82}
.page-home .hero__title{font-family:var(--font-display);font-size:clamp(5rem,11vw,11rem);line-height:0.92;letter-spacing:0.005em;text-transform:uppercase;max-width:14ch;margin-bottom:clamp(0.7rem,1.2vw,1.1rem);color:transparent;background:linear-gradient(180deg,#EAE4DA 0%,#d4cfc5 44%,#8b867b 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 3px 0 rgba(8,6,4,0.52)) drop-shadow(0 16px 32px rgba(8,6,4,0.50))}
.page-home .hero__title .line{display:block;white-space:nowrap;padding-top:0.06em;padding-bottom:0.04em}
.page-home .hero__title .dot{color:var(--accent);-webkit-text-fill-color:var(--accent);background:none;-webkit-background-clip:initial;background-clip:initial;filter:drop-shadow(0 0 14px rgba(236,231,75,0.5))}
.page-home .hero__role{font-size:clamp(1.55rem,2.15vw,2.18rem);letter-spacing:0.13em}
.page-home .hero__sub{font-size:clamp(0.78rem,0.95vw,0.95rem);letter-spacing:clamp(0.28em,0.42vw,0.46em);margin-top:0.55rem;margin-bottom:1rem}
.page-home .hero__desc{max-width:28.5rem;font-size:0.96rem}
.page-home .hero__buttons{gap:1.05rem}
.page-home .hero__rail{right:clamp(1.25rem,2.4vw,2.6rem)}
.page-home .hero__rail a{width:34px;height:34px}
.page-home .choice-section{height:290svh;min-height:290svh;padding:0;display:block;position:relative;overflow:visible;background:#0F1115;border-top:1px solid rgba(236,231,75,0.16)}
.page-home .choice-stage{position:sticky;top:0;height:100svh;width:100%;overflow:hidden;background:#0F1115;isolation:isolate}
.page-home .choice-stage::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(236,231,75,0.08),transparent 42%),linear-gradient(180deg,rgba(8,7,5,0.06),rgba(8,7,5,0.24));opacity:0.75;z-index:0;pointer-events:none}
.page-home .choice-stage__hud{position:absolute;top:calc(var(--header-h)+1.1rem);left:clamp(1rem,2vw,2rem);z-index:7;display:flex;gap:0.18rem;opacity:0.8;pointer-events:none}
.page-home .choice-stage__hud span{width:3px;height:28px;border:1px solid rgba(234,228,218,0.82);border-radius:10px}
.page-home .choice-stage__intro{position:absolute;top:calc(var(--header-h)+1.35rem);left:50%;transform:translateX(-50%);z-index:7;text-align:center;pointer-events:none}
.page-home .choice-stage__intro p{margin-top:0.35rem;font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.22em;text-transform:uppercase;color:rgba(234,228,218,0.68)}
.page-home .choice-grid{position:relative;z-index:3;display:grid;grid-template-columns:1fr 1fr;gap:0;width:100%;height:100%}
.page-home .choice{position:relative;min-height:100%;height:100%;width:100%;border:0;border-radius:0;box-shadow:none;overflow:hidden;background:#0F1115;isolation:isolate;transform-origin:center center;will-change:transform,opacity;pointer-events:auto;cursor:pointer;text-decoration:none;transition:filter 360ms var(--ease-out),box-shadow 360ms var(--ease-out)}
.page-home .choice>*{pointer-events:none}
.page-home .choice+.choice{border-left:1px solid rgba(234,228,218,0.13)}
.page-home .choice::before,.page-home .choice::after{display:none}
.page-home .choice__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transform:scale(1.06);opacity:1;filter:saturate(1.0) contrast(1.05) brightness(0.92);transition:transform 900ms var(--ease-out),filter 520ms var(--ease-out),opacity 520ms var(--ease-out);pointer-events:none;will-change:transform,filter,opacity}
.page-home .choice--gallery .choice__bg{filter:saturate(0.92) contrast(1.05) brightness(0.88)}
.page-home .choice--portfolio .choice__bg.no-image{background:radial-gradient(ellipse at 28% 22%,rgba(236,231,75,0.32),transparent 58%),radial-gradient(ellipse at 72% 78%,rgba(150,42,0,0.42),transparent 55%),linear-gradient(135deg,#2a160d 0%,#14080a 55%,#06070a 100%) !important}
.page-home .choice--portfolio .choice__bg.no-image::after{display:none}
.page-home .choice--gallery .choice__bg.no-image{background:radial-gradient(ellipse at 70% 28%,rgba(72,98,138,0.38),transparent 58%),radial-gradient(ellipse at 28% 78%,rgba(140,90,46,0.30),transparent 55%),linear-gradient(135deg,#1c1a26 0%,#0c0d14 55%,#06070a 100%) !important}
.page-home .choice--gallery .choice__bg.no-image::after{display:none}
.page-home .choice__overlay{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 50% 55%,transparent 0%,rgba(8,7,5,0.12) 55%,rgba(8,7,5,0.36) 100%),linear-gradient(180deg,rgba(8,7,5,0.02) 0%,rgba(8,7,5,0.05) 45%,rgba(8,7,5,0.34) 100%);opacity:1;transition:background 520ms var(--ease-out),opacity 520ms var(--ease-out);pointer-events:none}
.page-home .choice__content{position:relative;z-index:2;min-height:100%;height:100%;padding:calc(var(--header-h)+clamp(4.5rem,8vw,7rem)) clamp(1.8rem,5vw,6rem) clamp(4rem,8vw,6.5rem);display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;pointer-events:none}.page-home .choice__cta{pointer-events:auto}
.page-home .choice__num{position:absolute;top:calc(var(--header-h)+clamp(2rem,4vw,4rem));left:clamp(1.5rem,4vw,4.8rem);font-family:var(--font-ui);font-weight:700;font-size:0.78rem;letter-spacing:0.34em;color:var(--accent);opacity:0.9;transition:color 240ms var(--ease-out),opacity 240ms var(--ease-out)}
.page-home .choice__copy{transform:translateY(0);transition:transform 600ms var(--ease-out)}
.page-home .choice__title{font-family:var(--font-display);font-weight:400;font-size:clamp(3.6rem,8.5vw,8rem);line-height:0.92;letter-spacing:0.005em;text-transform:uppercase;max-width:12ch;padding-top:0.08em;padding-bottom:0.04em;margin-inline:auto;margin-bottom:1.1rem;color:#EAE4DA}
.page-home .choice__title .dot{color:var(--accent)}
.page-home .choice__desc{max-width:31rem;margin-inline:auto;margin-bottom:1.5rem;color:rgba(234,228,218,0.92);text-shadow:0 1px 8px rgba(8,6,4,0.75),0 2px 24px rgba(8,6,4,0.55)}
.page-home .choice__cta{display:inline-flex;align-items:center;gap:0.9rem;min-width:190px;justify-content:center;padding:0.78rem 1.45rem;border:1px solid currentColor;border-radius:999px;font-family:var(--font-ui);font-size:0.74rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);background:rgba(8,7,5,0.28);transition:color 240ms var(--ease-out),border-color 240ms var(--ease-out),background 240ms var(--ease-out),transform 240ms var(--ease-out),box-shadow 240ms var(--ease-out)}
.page-home .choice--gallery .choice__cta{color:var(--accent)}
.page-home .choice:hover,.page-home .choice:focus-visible,.page-home .choice.is-active{filter:brightness(1.06);box-shadow:inset 0 0 0 1px rgba(236,231,75,0.55),inset 0 0 180px -40px rgba(236,231,75,0.30)}
.page-home .choice:hover .choice__bg,.page-home .choice:focus-visible .choice__bg,.page-home .choice.is-active .choice__bg{transform:scale(1.16);opacity:1;filter:saturate(1.20) contrast(1.10) brightness(1.10)}
.page-home .choice:hover .choice__overlay,.page-home .choice:focus-visible .choice__overlay,.page-home .choice.is-active .choice__overlay{background:radial-gradient(ellipse at 50% 52%,rgba(236,231,75,0.16),rgba(8,7,5,0.10) 55%,rgba(8,7,5,0.38) 100%),linear-gradient(180deg,rgba(30,18,10,0.0) 0%,rgba(18,12,6,0.04) 50%,rgba(8,7,5,0.34) 100%)}
.page-home .choice:hover .choice__copy,.page-home .choice:focus-visible .choice__copy,.page-home .choice.is-active .choice__copy{transform:translateY(-12px)}
.page-home .choice:hover .choice__num,.page-home .choice:focus-visible .choice__num,.page-home .choice.is-active .choice__num{color:var(--accent-hot);opacity:1}
.page-home .choice:hover .choice__cta,.page-home .choice:focus-visible .choice__cta,.page-home .choice.is-active .choice__cta{color:var(--accent-hot);border-color:var(--accent-hot);background:rgba(236,231,75,0.20);transform:translateY(-2px);box-shadow:0 0 30px -4px rgba(236,231,75,0.55),inset 0 0 0 1px rgba(210,130,60,0.45)}
.page-home .choice-grid:hover .choice:not(:hover):not(:focus-visible) .choice__bg{filter:saturate(0.80) contrast(1.05) brightness(0.70)}
.page-home .choice-grid:hover .choice:not(:hover):not(:focus-visible) .choice__overlay{background:radial-gradient(ellipse at 50% 55%,transparent 0%,rgba(8,7,5,0.24) 55%,rgba(8,7,5,0.50) 100%),linear-gradient(180deg,rgba(8,7,5,0.08) 0%,rgba(8,7,5,0.15) 45%,rgba(8,7,5,0.45) 100%)}
@media (max-width:1040px){.page-home .hero__content{grid-template-columns:1fr}.page-home .hero__copy{max-width:44rem}.page-home .hero__title{font-size:clamp(4.4rem,14vw,7.6rem)}.page-home .choice-section{height:auto;min-height:100svh}.page-home .choice-stage{position:relative;height:auto;min-height:100svh}.page-home .choice-grid{min-height:100svh;grid-template-columns:1fr}.page-home .choice{min-height:50svh}.page-home .choice__title{font-size:clamp(3.6rem,13vw,6rem)}.page-home .choice-stage__intro{display:none}}
@media (max-width:620px){.page-home .hero__copy{max-width:100%;padding-left:0}.page-home .hero__title{font-size:clamp(2.8rem,13.5vw,4.6rem);line-height:0.92;max-width:100%}.page-home .hero__sub{letter-spacing:0.22em}.page-home .choice__content{padding:calc(var(--header-h)+2.5rem) var(--gutter) 3rem}.page-home .choice__num{top:calc(var(--header-h)+1.7rem);left:var(--gutter)}.page-home .choice__title{font-size:clamp(3.2rem,15vw,5rem)}.page-home .choice__desc{font-size:0.9rem}}
@media (prefers-reduced-motion:reduce){.page-home .choice-section{height:auto;min-height:100svh}.page-home .choice-stage{position:relative;height:100svh}.page-home .choice,.page-home .choice__copy,.page-home .choice__bg{transform:none !important;transition:none !important}}
.page-portfolio .selector{min-height:100svh;display:grid;place-items:center;padding:calc(var(--header-h)+3rem) var(--gutter) clamp(3rem,6vw,5rem)}
.page-portfolio .selector__bg{filter:brightness(0.55) saturate(0.92) contrast(1.04);transition:opacity 700ms var(--ease-out),filter 700ms var(--ease-out)}
.page-portfolio .selector__overlay{background:radial-gradient(ellipse at 50% 50%,rgba(15,17,21,0.18) 0%,rgba(15,17,21,0.78) 78%),linear-gradient(180deg,rgba(15,17,21,0.30) 0%,rgba(15,17,21,0.60) 60%,rgba(15,17,21,0.92) 100%)}
.page-portfolio .selector__inner{display:grid;gap:clamp(2rem,4vw,3.4rem);text-align:center;justify-items:center}
.page-portfolio .selector__head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:0.6rem;margin:0;max-width:56rem}
.page-portfolio .selector__head>div{display:flex;flex-direction:column;align-items:center;gap:0.5rem}
.page-portfolio .selector__head .meta{display:none}
.page-portfolio .selector__head .lead{max-width:44ch;font-size:0.92rem}
.page-portfolio .selector__head .title-xxl{font-size:clamp(2.4rem,5.4vw,5rem);line-height:0.95}
.page-portfolio .selector__list{list-style:none;display:flex;flex-direction:column;align-items:center;gap:clamp(0.1rem,0.4vw,0.4rem);width:100%}
.page-portfolio .selector__item{display:block;grid-template-columns:none;gap:0;padding:0.32rem 0.4rem;border:0;text-align:center;width:auto;cursor:pointer;position:relative;transition:padding 0ms}
.page-portfolio .selector__item:first-child{border-top:0}
.page-portfolio .selector__item:hover{padding-left:0.4rem}
.page-portfolio .selector__item::before{display:none}
.page-portfolio .selector__num,.page-portfolio .selector__caret{display:none}
.page-portfolio .selector__title{display:inline-block;font-family:var(--font-display);font-size:clamp(2rem,5.2vw,4.6rem);line-height:1.0;letter-spacing:0.005em;text-transform:uppercase;color:var(--ink);text-shadow:0 2px 0 rgba(10,8,6,0.6),0 8px 20px rgba(10,8,6,0.5);transition:color 280ms var(--ease-out),transform 380ms var(--ease-out),text-shadow 280ms var(--ease-out);will-change:transform,color}
.page-portfolio .selector__title .dot{color:var(--accent);transition:opacity 240ms var(--ease-out)}
.page-portfolio .selector__item:hover .selector__title,.page-portfolio .selector__item:focus-visible .selector__title{color:var(--accent);transform:translateX(10px);text-shadow:0 2px 0 rgba(0,0,0,0.55),0 10px 28px rgba(236,231,75,0.35),0 0 36px rgba(236,231,75,0.20)}
.page-portfolio .selector__list:hover .selector__item:not(:hover) .selector__title{color:rgba(234,228,218,0.78);text-shadow:0 2px 0 rgba(0,0,0,0.5)}
.page-portfolio .selector__inner:hover~.selector__bg,.page-portfolio .selector:hover .selector__bg{filter:brightness(0.68) saturate(1.0) contrast(1.06)}
@media (max-width:720px){.page-portfolio .selector__title{font-size:clamp(2.2rem,12vw,3.8rem)}.page-portfolio .selector__item:hover .selector__title{transform:translateX(0)}}
@media (prefers-reduced-motion:reduce){.page-portfolio .selector__title{transition:color 240ms !important;transform:none !important}.page-portfolio .selector__item:hover .selector__title{transform:none !important}}
.game-list{display:flex;flex-direction:column;gap:2.5rem;padding:2rem var(--gutter) 4rem;max-width:var(--max-width);margin-inline:auto}
.game-card{position:relative;background:var(--bg-2);border:1px solid var(--line-strong);transition:border-color 280ms ease,transform 280ms ease}
.game-card:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.game-card__inner{display:grid;grid-template-columns:340px 1fr;min-height:380px}
.game-card__img-col{display:flex;flex-direction:column;flex-shrink:0}
.game-card__img{flex:1;min-height:240px;background-size:cover;background-position:center;background-color:var(--bg-3)}
.game-card__img.no-image{background-image:linear-gradient( 135deg,hsl(calc(var(--hue,25deg)),40%,14%) 0%,hsl(calc(var(--hue,25deg)+20deg),30%,10%) 100% )}
.game-card__specs{background:var(--bg-0);padding:0.9rem 1.1rem;display:grid;grid-template-columns:1fr 1fr;gap:0.5rem 1rem;border-top:1px solid var(--line)}
.game-card__spec{display:flex;flex-direction:column;gap:0.15rem}
.game-card__spec .lbl{font-family:var(--font-ui);font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-mute)}
.game-card__spec .val{font-family:var(--font-ui);font-size:0.78rem;font-weight:600;color:var(--ink-soft)}
.game-card__body{padding:2rem 2rem 1.6rem;display:flex;flex-direction:column;gap:1.4rem;border-left:1px solid var(--line)}
.game-card__genre{font-family:var(--font-ui);font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:0.4rem}
.game-card__title{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.8rem);line-height:1;color:var(--ink);margin:0}
.game-card__desc{color:var(--ink-soft);font-size:0.95rem;line-height:1.7;margin-top:0.5rem}
.game-card__role-block{padding:1rem 1.2rem;background:var(--bg-3);border-left:2px solid var(--accent-line)}
.game-card__role{color:var(--ink-soft);font-size:0.88rem;line-height:1.7;margin-top:0.5rem}
.game-card__systems{display:flex;flex-direction:column;gap:0.7rem}
.game-card__sys-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:0.7rem;margin-top:0.6rem}
.game-card__sys-item{background:var(--bg-3);border:1px solid var(--line);padding:0.8rem 1rem;transition:border-color 200ms}
.game-card__sys-item:hover{border-color:var(--accent-line)}
.game-card__sys-label{font-family:var(--font-ui);font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:0.3rem}
.game-card__sys-text{font-size:0.82rem;color:var(--ink-soft);line-height:1.6;margin:0}
.game-card__footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:auto;padding-top:0.5rem;border-top:1px solid var(--line)}
.game-card__more{white-space:nowrap;flex-shrink:0}
@media (max-width:900px){.game-card__inner{grid-template-columns:1fr}.game-card__img{min-height:200px;max-height:280px}.game-card__body{border-left:none;border-top:1px solid var(--line)}.game-card__specs{grid-template-columns:repeat(4,1fr)}}
@media (max-width:600px){.game-card__specs{grid-template-columns:1fr 1fr}.game-card__body{padding:1.4rem 1.2rem;gap:1rem}.game-card__footer{flex-direction:column;align-items:flex-start}}
.game-list--wide{max-width:min(1680px,calc(100vw - 2rem));padding-top:2.8rem}
.game-card--steam{overflow:hidden;background:linear-gradient(135deg,rgba(236,231,75,0.055),transparent 42%),linear-gradient(180deg,var(--bg-2),var(--bg-0));box-shadow:0 28px 90px -58px rgba(0,0,0,0.92)}
.game-card--steam::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(236,231,75,0.08),transparent 26%,transparent 74%,rgba(236,231,75,0.035)),radial-gradient(ellipse at 28% 10%,rgba(236,231,75,0.10),transparent 42%);opacity:0.72;transition:opacity 320ms var(--ease-out)}
.game-card--steam:hover::before{opacity:1}
.game-card--steam .game-card__inner{position:relative;z-index:1;grid-template-columns:minmax(480px,58%) minmax(360px,42%);min-height:430px}
.game-card__img-col--large{position:relative;min-height:430px;overflow:hidden;border-right:1px solid var(--line-strong);color:inherit}
.game-card__img-col--large .game-card__img{position:absolute;inset:0;min-height:100%;transform:scale(1.02);filter:saturate(1.02) contrast(1.05) brightness(0.86);transition:transform 900ms var(--ease-out),filter 480ms var(--ease-out)}
.game-card--steam:hover .game-card__img{transform:scale(1.07);filter:saturate(1.08) contrast(1.08) brightness(0.95)}
.game-card__img-col--large::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 45%,rgba(15,17,21,0.70) 100%),linear-gradient(180deg,transparent 45%,rgba(15,17,21,0.65) 100%);pointer-events:none}
.game-card__media-strip{position:absolute;left:1rem;right:1rem;bottom:1rem;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:0.5rem}
.game-card__media-strip span{height:42px;border:1px solid rgba(234,228,218,0.18);background:linear-gradient(135deg,rgba(234,228,218,0.08),rgba(234,228,218,0.02)),rgba(12,11,10,0.38);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.game-card--steam .game-card__body{background:linear-gradient(180deg,rgba(28,28,37,0.95),rgba(12,12,17,0.98));border-left:0;padding:clamp(1.6rem,2.6vw,2.5rem)}
.game-card__quick{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.6rem}
.game-card__quick .game-card__spec{min-width:0;padding:0.7rem 0.8rem;background:rgba(12,11,10,0.30);border:1px solid var(--line)}
.game-card__quick .game-card__spec .val{overflow-wrap:anywhere;color:var(--ink)}
.game-card--steam .tag,.game-detail .tag,.blog-row .tag,.post__aside .tag{color:var(--ink);background:rgba(236,231,75,0.07);border-color:var(--accent-line)}
.page-game-project{background:radial-gradient(ellipse at 50% 0%,rgba(236,231,75,0.10),transparent 45%),var(--bg-0)}
.game-detail{position:relative;min-height:100vh;overflow:hidden;isolation:isolate;opacity:0;transform:translateY(44px);transition:opacity 640ms var(--ease-out),transform 760ms cubic-bezier(0.22,1,0.36,1)}
.game-detail.is-in{opacity:1;transform:translateY(0)}
.game-detail--missing{padding:calc(var(--header-h)+3rem) var(--gutter) 6rem;opacity:1;transform:none}
.game-detail__bg{position:fixed;inset:0;z-index:-4;background-size:cover;background-position:center;filter:blur(6px) brightness(0.26) saturate(0.95);transform:scale(1.04)}
.game-detail__overlay{position:fixed;inset:0;z-index:-3;background:radial-gradient(ellipse at 26% 18%,rgba(236,231,75,0.12),transparent 34%),linear-gradient(180deg,rgba(15,17,21,0.66) 0%,rgba(15,17,21,0.94) 38%,rgba(15,17,21,1) 100%),linear-gradient(90deg,rgba(15,17,21,0.96) 0%,rgba(15,17,21,0.38) 46%,rgba(15,17,21,0.96) 100%)}
.game-detail__inner{width:100%;max-width:1580px;margin-inline:auto;padding:calc(var(--header-h)+2.8rem) var(--gutter) 6rem}
.game-detail__back{margin-bottom:1.7rem}
.game-detail__hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:2rem;align-items:end;margin-bottom:1.5rem}
.game-detail__title{font-family:var(--font-display);font-size:clamp(3.2rem,8vw,8.6rem);line-height:0.86;text-transform:uppercase;color:var(--ink);letter-spacing:0.005em;margin:0.55rem 0 0;text-shadow:0 8px 40px rgba(8,6,4,0.70)}
.game-detail__title .dot{color:var(--accent)}
.game-detail__tagline{margin-top:1rem;color:var(--ink-soft);font-size:clamp(1rem,1.2vw,1.15rem);line-height:1.65;max-width:62ch}
.game-detail__hero-meta{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:0.5rem;max-width:420px}
.game-detail__hero-meta span{font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);background:rgba(20,20,27,0.86);border:1px solid var(--line-strong);padding:0.55rem 0.75rem}
.game-detail__storefront{display:grid;grid-template-columns:minmax(0,1.72fr) minmax(320px,0.72fr);gap:clamp(1rem,2vw,1.4rem);align-items:start;background:linear-gradient(135deg,rgba(236,231,75,0.06),transparent 38%),rgba(15,17,21,0.80);border:1px solid var(--line-strong);box-shadow:0 30px 110px -65px rgba(0,0,0,0.95),inset 0 1px 0 rgba(234,228,218,0.035);padding:clamp(0.9rem,1.4vw,1.25rem)}
.game-detail__media-panel,.game-detail__side-panel,.game-detail-section,.game-detail__toc,.game-detail__nav a{background:linear-gradient(180deg,rgba(28,28,37,0.86),rgba(12,12,17,0.95));border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(234,228,218,0.035)}
.game-detail__media-panel{min-width:0;padding:0.75rem;display:flex;flex-direction:column;gap:0.7rem;align-self:start}
.game-detail__main-media{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg-3);background-size:cover;background-position:center;border:1px solid var(--line-strong)}
.game-detail__main-media::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 55%,rgba(8,7,5,0.46) 100%),radial-gradient(ellipse at center,transparent 46%,rgba(8,7,5,0.26) 100%)}
.game-detail__main-media.is-video::after{display:none}
.game-detail__media-kind{position:absolute;left:0.8rem;bottom:0.8rem;z-index:2;font-family:var(--font-ui);font-size:0.66rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);background:rgba(12,11,10,0.64);border:1px solid var(--line-strong);padding:0.4rem 0.6rem}
.game-detail__thumbs{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:0.55rem;margin-top:0;overflow-x:auto;padding-bottom:0.1rem}
.game-detail__thumb{position:relative;min-width:120px;height:86px;overflow:hidden;border:1px solid var(--line);background:rgba(12,11,10,0.35);color:var(--ink);text-align:left;transition:border-color 220ms var(--ease-out),transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out)}
.game-detail__thumb:hover,.game-detail__thumb.is-active{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 0 0 1px var(--accent-line)}
.game-detail__thumb-img{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(0.78) saturate(0.94)}
.game-detail__thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(8,7,5,0.68) 100%)}
.game-detail__thumb-label{position:absolute;left:0.45rem;right:0.45rem;bottom:0.38rem;z-index:2;font-family:var(--font-ui);font-size:0.62rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);line-height:1.15}
.game-detail__thumb-play{position:absolute;right:0.45rem;top:0.38rem;z-index:3;color:var(--accent);font-size:0.72rem}
.game-detail__side-panel{padding:clamp(1rem,1.8vw,1.5rem);display:flex;flex-direction:column;gap:1rem;min-width:0}
.game-detail__cover{aspect-ratio:16 / 9;background-size:cover;background-position:center;background-color:var(--bg-3);border:1px solid var(--line-strong)}
.game-detail__summary{color:var(--ink-soft);font-size:0.96rem;line-height:1.68;margin:0}
.game-detail__tags{padding-bottom:0.9rem;border-bottom:1px solid var(--line)}
.game-detail__facts{display:flex;flex-direction:column;gap:0.1rem;margin:0}
.game-detail__facts div{display:grid;grid-template-columns:118px 1fr;gap:0.7rem;padding:0.55rem 0;border-bottom:1px solid var(--line)}
.game-detail__facts dt{font-family:var(--font-ui);font-size:0.66rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}
.game-detail__facts dd{margin:0;color:var(--ink);font-family:var(--font-ui);font-size:0.86rem;line-height:1.35}
.game-detail__content{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:clamp(1rem,2.2vw,1.6rem);margin-top:clamp(1rem,2vw,1.4rem)}
.game-detail__longform{display:flex;flex-direction:column;gap:1rem;min-width:0}
.game-detail-section{padding:clamp(1.25rem,2.5vw,2rem)}
.game-detail-section h2{font-family:var(--font-display);font-size:clamp(1.55rem,2.8vw,2.4rem);line-height:0.98;text-transform:uppercase;color:var(--ink);margin:0.45rem 0 0.9rem}
.game-detail-section p{color:var(--ink-soft);font-size:1rem;line-height:1.82;max-width:84ch;margin:0}
.game-detail-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0.75rem;margin-top:1rem}
.game-detail-feature{padding:1rem 1rem 1.1rem;background:rgba(12,11,10,0.28);border:1px solid var(--line);transition:border-color 220ms var(--ease-out),transform 220ms var(--ease-out)}
.game-detail-feature:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.game-detail-feature__num{font-family:var(--font-ui);font-size:0.65rem;font-weight:700;letter-spacing:0.28em;color:var(--accent)}
.game-detail-feature h3{margin:0.45rem 0 0.4rem;font-family:var(--font-display);font-size:1.2rem;font-weight:400;line-height:1;text-transform:uppercase;color:var(--ink)}
.game-detail-feature p{font-size:0.9rem;line-height:1.62}
.game-detail-reqs{display:grid;grid-template-columns:1fr 1fr;gap:0.8rem;margin-top:1rem}
.game-detail-reqs>div{padding:1rem;background:rgba(12,11,10,0.28);border:1px solid var(--line)}
.game-detail-reqs__label{display:block;margin-bottom:0.45rem;font-family:var(--font-ui);font-size:0.7rem;font-weight:700;letter-spacing:0.28em;text-transform:uppercase;color:var(--accent)}
.game-detail__toc{position:sticky;top:calc(var(--header-h)+1.2rem);align-self:start;padding:1rem;display:flex;flex-direction:column;gap:0.45rem}
.game-detail__toc a{padding:0.55rem 0.65rem;border:1px solid transparent;font-family:var(--font-ui);font-size:0.72rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-soft)}
.game-detail__toc a:hover{color:var(--accent);border-color:var(--accent-line);background:rgba(236,231,75,0.05)}
.game-detail__nav{display:grid;grid-template-columns:1fr 1fr;gap:0.9rem;margin-top:1.2rem}
.game-detail__nav a{padding:1.25rem 1.4rem;transition:border-color 220ms var(--ease-out),background 220ms var(--ease-out),transform 220ms var(--ease-out)}
.game-detail__nav a:hover{border-color:var(--accent);background:rgba(236,231,75,0.05);transform:translateY(-2px)}
.game-detail__nav .label{display:block;margin-bottom:0.35rem;font-family:var(--font-ui);font-size:0.68rem;font-weight:700;letter-spacing:0.26em;text-transform:uppercase;color:var(--accent)}
.game-detail__nav .title{font-family:var(--font-display);font-size:1.2rem;line-height:1;text-transform:uppercase;color:var(--ink)}
.blog-row{padding:1.35rem;margin-bottom:1rem;background:linear-gradient(90deg,rgba(236,231,75,0.040),transparent 42%),rgba(21,23,28,0.72);border:1px solid var(--line);box-shadow:0 20px 70px -55px rgba(0,0,0,0.88)}
.blog-row:hover{padding-left:1.75rem;border-color:var(--accent-line);background:linear-gradient(90deg,rgba(236,231,75,0.075),transparent 48%),rgba(28,28,37,0.82)}
.blog-row__body{min-width:0;padding-top:0.15rem}
.blog-row__thumb{border-color:var(--line-strong);background:var(--bg-0)}
.page-post{background:radial-gradient(ellipse at 50% 0%,rgba(236,231,75,0.075),transparent 42%),var(--bg-0)}
.post__head,.post__body,.post__aside,.post-breakdown,.post-comments{background:rgba(21,23,28,0.58);border:1px solid var(--line);box-shadow:0 22px 80px -58px rgba(8,7,5,0.80)}
.post__head{padding:clamp(1.25rem,2.4vw,2rem)}
.post__body{padding:clamp(1.25rem,2.4vw,2rem);max-width:none}
.post__aside{padding:1.15rem;border-left:1px solid var(--line)}
.post-body__p{color:var(--ink-soft)}
.post-body__fig,.post-body__quote,.post-breakdown__item,.post__nav-link,.post-comments__form,.post-comment{background:rgba(28,28,37,0.70);border-color:var(--line-strong)}
.modal__caption{background:linear-gradient(180deg,rgba(15,17,21,0.12),rgba(15,17,21,0.80) 38%,rgba(15,17,21,0.96))}
.modal__details{background:linear-gradient(180deg,rgba(22,22,30,0.98) 0%,rgba(10,10,15,0.99) 72%,rgba(15,17,21,1) 100%)}
.modal-details__section,.modal-details__step,.modal-details__dl>div{background:rgba(234,228,218,0.022)}
@media (max-width:1120px){.game-card--steam .game-card__inner,.game-detail__storefront,.game-detail__content{grid-template-columns:1fr}.game-card__img-col--large{min-height:340px;border-right:0;border-bottom:1px solid var(--line-strong)}.game-detail__hero{grid-template-columns:1fr}.game-detail__hero-meta{justify-content:flex-start}.game-detail__toc{position:static}}
@media (max-width:720px){.game-list--wide{max-width:100%;padding-inline:var(--gutter)}.game-card__quick,.game-detail-reqs,.game-detail__nav{grid-template-columns:1fr}.game-detail__thumbs{grid-template-columns:repeat(5,minmax(64px,1fr))}.game-detail__inner{padding-top:calc(var(--header-h)+2rem)}.blog-row{padding:1rem}.blog-row:hover{padding-left:1rem}}
.game-list--wide{gap:1.65rem;padding-top:2.1rem;padding-bottom:3.6rem}
.game-card--steam .game-card__inner{grid-template-columns:minmax(500px,47%) minmax(0,53%);min-height:318px}
.game-card__img-col--large{min-height:318px}
.game-card__img-col--large .game-card__img{min-height:100%}
.game-card__media-strip{grid-template-columns:repeat(4,minmax(0,72px));justify-content:start}
.game-card__media-strip span{height:32px}
.game-card--steam .game-card__body{padding:clamp(1.15rem,1.7vw,1.65rem);gap:0.82rem}
.game-card__genre{font-size:0.62rem;margin-bottom:0.25rem}
.game-card__title{font-size:clamp(1.8rem,2.5vw,2.55rem)}
.game-card__desc{font-size:0.9rem;line-height:1.55;margin-top:0.35rem;max-width:72ch}
.game-card__quick{gap:0.45rem}
.game-card__quick .game-card__spec{padding:0.55rem 0.65rem}
.game-card__quick .game-card__spec .lbl{font-size:0.58rem}
.game-card__quick .game-card__spec .val{font-size:0.72rem;line-height:1.25}
.game-card__role-block{padding:0.7rem 0.85rem}
.game-card__role-block .eyebrow{font-size:0.58rem;letter-spacing:0.22em}
.game-card__role{font-size:0.82rem;line-height:1.52;margin-top:0.28rem}
.game-card__compact-systems{display:flex;align-items:center;gap:0.65rem;min-width:0}
.game-card__compact-label{flex:0 0 auto;font-family:var(--font-ui);font-size:0.62rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent)}
.game-card__system-pills{display:flex;flex-wrap:wrap;gap:0.38rem;min-width:0}
.game-card__system-pill{display:inline-flex;align-items:center;min-height:26px;padding:0.25rem 0.55rem;border:1px solid var(--line);background:rgba(234,228,218,0.025);color:var(--ink-soft);font-family:var(--font-ui);font-size:0.64rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap}
.game-card__footer{padding-top:0.42rem}
.game-card--steam .tags{gap:0.32rem}
.game-card--steam .tag{padding:0.26rem 0.55rem;font-size:0.62rem}
.game-card__more{padding-block:0.72rem}
.game-detail__main-media{isolation:isolate}
.game-detail__media-slide{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;background-color:var(--bg-3);transform:translate3d(0,0,0);will-change:transform,opacity}
.game-detail__media-slide.no-image{position:absolute}
.game-detail__main-media::before{z-index:1}
.game-detail__main-media.is-video::after{display:none}
.game-detail__media-kind{z-index:4}
.game-detail__media-arrow{position:absolute;top:50%;z-index:4;width:46px;height:64px;display:grid;place-items:center;transform:translateY(-50%);border:1px solid var(--line-strong);background:linear-gradient(180deg,rgba(26,24,22,0.80),rgba(15,17,21,0.85));color:var(--ink);font-family:var(--font-ui);font-size:1.2rem;font-weight:700;box-shadow:0 18px 38px -28px rgba(0,0,0,0.95);opacity:0.72;transition:opacity 220ms var(--ease-out),border-color 220ms var(--ease-out),background 220ms var(--ease-out),transform 220ms var(--ease-out)}
.game-detail__media-arrow:hover{opacity:1;border-color:var(--accent);color:var(--accent);transform:translateY(-50%) scale(1.04)}
.game-detail__media-arrow--prev{left:0.85rem}
.game-detail__media-arrow--next{right:0.85rem}
.game-detail__media-arrow[hidden]{display:none}
.game-detail__media-slide.is-slide-right{animation:gameMediaSlideRight 460ms var(--ease-out) both}
.game-detail__media-slide.is-slide-left{animation:gameMediaSlideLeft 460ms var(--ease-out) both}
@keyframes gameMediaSlideRight{from{transform:translate3d(7%,0,0);opacity:0.25;filter:blur(3px) brightness(0.82)}to{transform:translate3d(0,0,0);opacity:1;filter:blur(0) brightness(1)}}
@keyframes gameMediaSlideLeft{from{transform:translate3d(-7%,0,0);opacity:0.25;filter:blur(3px) brightness(0.82)}to{transform:translate3d(0,0,0);opacity:1;filter:blur(0) brightness(1)}}
@media (max-width:1120px){.game-card--steam .game-card__inner{grid-template-columns:1fr;min-height:auto}.game-card__img-col--large{min-height:300px;aspect-ratio:16 / 8}}
@media (max-width:720px){.game-list--wide{gap:1.2rem}.game-card__img-col--large{min-height:220px;aspect-ratio:16 / 9}.game-card--steam .game-card__body{padding:1.05rem}.game-card__quick{grid-template-columns:1fr 1fr}.game-card__compact-systems{align-items:flex-start;flex-direction:column;gap:0.45rem}.game-detail__media-arrow{width:38px;height:54px}.game-detail__media-arrow--prev{left:0.5rem}.game-detail__media-arrow--next{right:0.5rem}}
@media (prefers-reduced-motion:reduce){.game-detail__media-slide.is-slide-right,.game-detail__media-slide.is-slide-left{animation:none}}
.game-list--wide{max-width:min(1840px,calc(100vw - 1.25rem));padding-top:2rem}
.game-card--steam{margin-inline:auto}
.game-card--steam .game-card__inner{grid-template-columns:minmax(560px,54%) minmax(520px,46%);min-height:350px}
.game-card__img-col--large{min-height:350px}
.game-card__img-col--large .game-card__img{background-position:center center}
.game-card__img-col--large::after{background:linear-gradient(90deg,transparent 48%,rgba(15,17,21,0.56) 100%),linear-gradient(180deg,transparent 56%,rgba(15,17,21,0.36) 100%)}
.game-card__media-strip{display:none !important}
.game-card--steam .game-card__body{padding:clamp(1.35rem,1.8vw,1.9rem);gap:0.9rem}
.game-card__genre{font-size:0.68rem;letter-spacing:0.28em}
.game-card__title{font-size:clamp(2rem,3.6vw,3.35rem)}
.game-card__desc{font-size:0.92rem;line-height:1.55;margin-top:0.45rem;max-width:66ch}
.game-card__quick{gap:0.55rem}
.game-card__quick .game-card__spec{padding:0.62rem 0.78rem}
.game-card__quick .game-card__spec .lbl{font-size:0.62rem;letter-spacing:0.18em}
.game-card__quick .game-card__spec .val{font-size:0.9rem;line-height:1.4}
.game-card__role-block{padding:0.9rem 1rem}
.game-card__role{font-size:0.9rem;line-height:1.55;margin-top:0.4rem}
.game-card__compact-systems{display:flex;align-items:center;gap:0.8rem;flex-wrap:wrap}
.game-card__compact-label{flex:0 0 auto}
.game-card__system-pills{display:flex;flex-wrap:wrap;gap:0.45rem}
.game-card__system-pill{padding:0.45rem 0.7rem;font-size:0.66rem}
.game-card__footer{padding-top:0.65rem}
.game-card__footer .tags{gap:0.34rem}
.game-card__footer .tag{padding:0.34rem 0.62rem;font-size:0.64rem}
.game-card__more{padding:0.9rem 1.25rem}
@media (max-width:1360px){.game-list--wide{max-width:min(1680px,calc(100vw - 1.25rem))}.game-card--steam .game-card__inner{grid-template-columns:minmax(460px,52%) minmax(380px,48%);min-height:330px}.game-card__img-col--large{min-height:330px}}
@media (max-width:1100px){.game-card--steam .game-card__inner{grid-template-columns:minmax(0,1.05fr) minmax(0,0.95fr);min-height:320px}.game-card__img-col--large{min-height:320px}.game-card__title{font-size:clamp(1.9rem,4vw,2.8rem)}}
@media (max-width:900px){.game-card--steam .game-card__inner{grid-template-columns:1fr;min-height:0}.game-card__img-col--large{min-height:250px}.game-card--steam .game-card__body{padding:1.25rem 1.1rem}}
.category-view--games{max-width:none;width:100%;padding-left:clamp(1rem,2.6vw,3.25rem);padding-right:clamp(1rem,2.6vw,3.25rem)}
.category-view--games .category-view__back,.category-view--games .category-view__head{width:100%;max-width:min(1780px,calc(100vw - 3rem));margin-left:auto;margin-right:auto}
.category-view--games .game-list--wide{width:100%;max-width:min(1780px,calc(100vw - 3rem));margin-left:auto;margin-right:auto;display:grid;gap:clamp(1.35rem,2vw,2rem)}
.category-view--games .game-card--steam{width:100%}
.category-view--games .game-card--steam .game-card__inner{grid-template-columns:minmax(520px,42%) minmax(0,58%);min-height:360px}
.category-view--games .game-card__img-col--large{min-height:360px}
.category-view--games .game-card--steam .game-card__body{padding:clamp(1.3rem,1.75vw,2rem);gap:0.85rem}
.category-view--games .game-card__head{max-width:100%}
.category-view--games .game-card__desc{max-width:92ch;font-size:clamp(0.92rem,0.86vw,1rem);line-height:1.58}
.category-view--games .game-card__quick{grid-template-columns:repeat(4,minmax(0,1fr));gap:0.55rem}
.category-view--games .game-card__quick .game-card__spec{padding:0.62rem 0.76rem}
.category-view--games .game-card__role-block{padding:0.85rem 1rem}
.category-view--games .game-card__role{max-width:110ch;line-height:1.55}
.category-view--games .game-card__compact-systems{gap:0.75rem}
.category-view--games .game-card__footer{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:1rem;margin-top:0}
.category-view--games .game-card__footer--no-tags{display:flex;justify-content:flex-end}
.category-view--games .game-card__footer .tags{min-width:0}
.category-view--games .game-card__more{min-width:210px;justify-content:center}
@media (min-width:1700px){.category-view--games .game-list--wide,.category-view--games .category-view__back,.category-view--games .category-view__head{max-width:min(1880px,calc(100vw - 3rem))}.category-view--games .game-card--steam .game-card__inner{grid-template-columns:minmax(620px,43%) minmax(0,57%)}}
@media (max-width:1300px){.category-view--games .game-card--steam .game-card__inner{grid-template-columns:minmax(440px,44%) minmax(0,56%);min-height:350px}.category-view--games .game-card__img-col--large{min-height:350px}.category-view--games .game-card__quick{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:900px){.category-view--games{padding-left:var(--gutter);padding-right:var(--gutter)}.category-view--games .game-list--wide,.category-view--games .category-view__back,.category-view--games .category-view__head{max-width:var(--max-width)}.category-view--games .game-card--steam .game-card__inner{grid-template-columns:1fr;min-height:0}.category-view--games .game-card__img-col--large{min-height:250px}.category-view--games .game-card__quick{grid-template-columns:repeat(2,minmax(0,1fr))}.category-view--games .game-card__footer{grid-template-columns:1fr}.category-view--games .game-card__more{width:100%}}
.owner-only{display:none !important}
[data-owner-mode="true"] .owner-admin-bar.owner-only,[data-owner-mode="true"] .owner-page-actions.owner-only,[data-owner-mode="true"] .owner-card-actions.owner-only{display:flex !important}
.owner-corner-toggle{position:fixed;top:max(4px,env(safe-area-inset-top));right:max(4px,env(safe-area-inset-right));z-index:1400;min-width:46px;height:24px;padding:0 0.55rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--accent-line) 72%,transparent);background:color-mix(in srgb,var(--bg-2) 74%,transparent);color:var(--ink-soft);font-family:var(--font-ui);font-size:0.62rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;opacity:0.28;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:opacity var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out)}
.owner-corner-toggle:hover,.owner-corner-toggle:focus-visible,.owner-corner-toggle.is-active{opacity:1;transform:translateY(1px);border-color:var(--accent);background:var(--accent-soft);color:var(--accent);outline:none}
.owner-corner-toggle.is-active{box-shadow:var(--shadow-glow)}
.owner-admin-bar{position:fixed;right:clamp(0.8rem,2vw,1.5rem);bottom:clamp(0.8rem,2vw,1.5rem);z-index:1200;align-items:center;gap:0.45rem;max-width:min(92vw,760px);padding:0.55rem;border:1px solid var(--accent-line);background:color-mix(in srgb,var(--bg-2) 86%,transparent);box-shadow:var(--shadow-card),var(--shadow-glow);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.owner-admin-bar strong{padding:0 0.7rem;font-family:var(--font-ui);font-size:0.72rem;letter-spacing:0.24em;text-transform:uppercase;color:var(--accent);white-space:nowrap}
.owner-admin-bar button,.owner-inline-btn,.owner-cms-primary,.owner-cms-secondary,.owner-cms-modal__x{border:1px solid var(--line-strong);background:rgba(234,228,218,0.035);color:var(--ink);font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;padding:0.65rem 0.85rem;transition:transform var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out)}
.owner-admin-bar button:hover,.owner-inline-btn:hover,.owner-cms-primary:hover,.owner-cms-secondary:hover,.owner-cms-modal__x:hover{transform:translateY(-1px);border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.owner-page-actions{position:relative;z-index:20;width:min(100% - var(--gutter) * 2,var(--max-width));margin:calc(var(--header-h)+1rem) auto 0;justify-content:flex-end;flex-wrap:wrap;gap:0.7rem;padding:0.85rem;border:1px dashed var(--accent-line);background:color-mix(in srgb,var(--bg-2) 72%,transparent);box-shadow:0 18px 50px -36px rgba(8,7,5,0.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.page-game-project .owner-page-actions{margin-bottom:1rem}
.owner-inline-btn{border-color:var(--accent-line);color:var(--accent)}
.owner-cms-modal{position:fixed;inset:0;z-index:1300;display:none;align-items:center;justify-content:center;padding:clamp(1rem,3vw,2rem)}
.owner-cms-modal.is-open{display:flex}
.owner-cms-modal__backdrop{position:absolute;inset:0;background:rgba(8,7,5,0.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.owner-cms-modal__panel{position:relative;width:min(1040px,96vw);max-height:min(88vh,900px);overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--accent-line);background:linear-gradient(135deg,color-mix(in srgb,var(--bg-3) 92%,transparent),color-mix(in srgb,var(--bg-1) 96%,transparent)),var(--bg-2);box-shadow:var(--shadow-card),var(--shadow-glow)}
.owner-cms-modal__head{display:flex;align-items:start;justify-content:space-between;gap:1rem;padding:clamp(1rem,2.4vw,1.5rem);border-bottom:1px solid var(--line)}
.owner-cms-modal__head h2{margin-top:0.25rem;font-family:var(--font-display);font-size:clamp(2rem,4vw,3.8rem);line-height:0.9;text-transform:uppercase;color:var(--ink)}
.owner-cms-modal__x{width:42px;height:42px;display:grid;place-items:center;padding:0;font-size:1.35rem;line-height:1}
.owner-cms-form{overflow:auto;padding:clamp(1rem,2.4vw,1.5rem)}
.owner-cms-form__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.owner-field{display:grid;gap:0.4rem}
.owner-field--textarea{grid-column:span 2}
.owner-field span{font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft)}
.owner-field input,.owner-field textarea,.owner-field select{width:100%;border:1px solid var(--line-strong);background:color-mix(in srgb,var(--bg-1) 78%,transparent);color:var(--ink);padding:0.85rem 0.9rem;outline:none;resize:vertical}
.owner-field textarea{min-height:92px}
.owner-field input:focus,.owner-field textarea:focus,.owner-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.owner-image-preview{margin-top:1rem;min-height:160px;display:grid;place-items:center;border:1px dashed var(--line-strong);background:linear-gradient(135deg,rgba(234,228,218,0.03),transparent),var(--bg-2);background-size:cover;background-position:center;color:var(--ink-mute);font-family:var(--font-ui);letter-spacing:0.12em;text-transform:uppercase;text-align:center}
.owner-image-preview.is-loaded span{background:rgba(8,7,5,0.70);color:var(--ink);padding:0.45rem 0.7rem}
.owner-image-preview.is-error{border-color:rgba(255,80,80,0.55);color:#ff9b9b}
.owner-cms-form__footer{position:sticky;bottom:-1.5rem;display:flex;justify-content:flex-end;gap:0.7rem;margin:1.25rem -1.5rem -1.5rem;padding:1rem 1.5rem;border-top:1px solid var(--line);background:color-mix(in srgb,var(--bg-2) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.owner-cms-primary{background:var(--accent-btn);border-color:var(--accent-btn);color:#EAE4DA}
.owner-cms-primary:hover{color:#EAE4DA;background:var(--accent-hot)}
body.owner-modal-open{overflow:hidden}
@media (max-width:760px){.owner-admin-bar{left:0.75rem;right:0.75rem;bottom:0.75rem;flex-wrap:wrap}.owner-page-actions{justify-content:stretch}.owner-page-actions .owner-inline-btn{flex:1 1 100%}.owner-cms-form__grid{grid-template-columns:1fr}.owner-field--textarea{grid-column:span 1}.owner-cms-form__footer{margin-inline:-1rem;padding-inline:1rem}}
[data-owner-mode="true"] .owner-delete-btn.owner-only{display:inline-flex !important}
.owner-admin-bar{left:50%;right:auto;bottom:clamp(0.8rem,2vw,1.25rem);transform:translateX(-50%);border-radius:0;background:color-mix(in srgb,var(--bg-2) 94%,transparent);flex-wrap:wrap;max-width:min(96vw,900px);justify-content:center}
[data-bar-page-action]{border-color:var(--accent-line) !important;color:var(--accent) !important}
.owner-admin-bar button:hover{transform:translateY(-1px)}
.owner-cms-form__note{display:grid;gap:0.25rem;margin-bottom:1rem;padding:0.85rem 1rem;border:1px solid var(--line-strong);background:color-mix(in srgb,var(--bg-2) 76%,transparent);color:var(--ink-soft)}
.owner-cms-form__note strong{font-family:var(--font-ui);letter-spacing:0.16em;text-transform:uppercase;color:var(--accent)}
.owner-cms-form__note code{color:var(--ink);background:rgba(234,228,218,0.06);padding:0.05rem 0.3rem}
.owner-image-preview.is-dragging,.owner-drop-helper.is-dragging,.owner-block-image-drop.is-dragging{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft),var(--shadow-glow);color:var(--accent)}
.owner-drop-helper{display:grid;gap:0.3rem;margin-top:1rem;padding:1rem;min-height:92px;align-content:center;border:1px dashed var(--accent-line);background:color-mix(in srgb,var(--bg-2) 70%,transparent);color:var(--ink-soft);font-family:var(--font-ui);letter-spacing:0.12em;text-transform:uppercase;transition:border-color var(--t-fast) var(--ease-out),box-shadow var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out)}
.owner-drop-helper strong{color:var(--accent);font-size:0.86rem}
.owner-drop-helper span{font-size:0.72rem;letter-spacing:0.08em;text-transform:none;font-family:var(--font-body)}
.work,.game-card,.arc-item,.blog-row,.post__hero,.game-detail__cover{position:relative}
.owner-delete-btn{position:absolute;top:0.65rem;right:0.65rem;z-index:30;align-items:center;justify-content:center;min-height:34px;padding:0.45rem 0.75rem;border:1px solid rgba(255,90,90,0.55);background:rgba(20,5,5,0.82);color:#ffb3b3;font-family:var(--font-ui);font-size:0.68rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;opacity:0;transform:translateY(-4px);pointer-events:none;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:opacity var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out)}
.owner-delete-btn:hover{background:#ff4242;color:#140505;border-color:#ff6868}
[data-owner-mode="true"] .work:hover>.owner-delete-btn,[data-owner-mode="true"] .game-card:hover>.owner-delete-btn,[data-owner-mode="true"] .arc-item:hover>.owner-delete-btn,[data-owner-mode="true"] .blog-row:hover>.owner-delete-btn,[data-owner-mode="true"] .post__hero:hover>.owner-delete-btn,[data-owner-mode="true"] .game-detail__cover:hover>.owner-delete-btn,[data-owner-mode="true"] .owner-delete-btn:focus-visible{opacity:1;transform:translateY(0);pointer-events:auto}
.owner-builder{margin-top:1.2rem;border:1px solid var(--line-strong);background:color-mix(in srgb,var(--bg-2) 74%,transparent)}
.owner-builder__head{display:flex;justify-content:space-between;align-items:start;gap:1rem;padding:1rem;border-bottom:1px solid var(--line)}
.owner-builder__head h3{margin-top:0.25rem;font-family:var(--font-display);font-size:clamp(1.45rem,2.5vw,2.3rem);line-height:0.95;text-transform:uppercase;color:var(--ink)}
.owner-builder__head p{margin-top:0.4rem;color:var(--ink-soft);max-width:62ch}
.owner-builder__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:0.45rem}
.owner-builder__actions button,.owner-block__head button{border:1px solid var(--line-strong);background:rgba(234,228,218,0.035);color:var(--ink);font-family:var(--font-ui);font-size:0.68rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:0.55rem 0.7rem}
.owner-builder__actions button:hover,.owner-block__head button:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.owner-builder__list{display:grid;gap:0.75rem;padding:1rem}
.owner-block{border:1px solid var(--line);background:color-mix(in srgb,var(--bg-1) 82%,transparent)}
.owner-block__head{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;padding:0.75rem;border-bottom:1px solid var(--line)}
.owner-block__head strong{font-family:var(--font-ui);color:var(--accent);letter-spacing:0.16em;text-transform:uppercase}
.owner-block__head div{display:flex;flex-wrap:wrap;gap:0.35rem}
.owner-block__body{display:grid;gap:0.65rem;padding:0.75rem}
.owner-block-input{width:100%;border:1px solid var(--line-strong);background:color-mix(in srgb,var(--bg-1) 78%,transparent);color:var(--ink);padding:0.85rem 0.9rem;outline:none;resize:vertical}
.owner-block-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.owner-block-image-drop{min-height:110px;display:grid;place-items:center;border:1px dashed var(--accent-line);background:linear-gradient(135deg,rgba(234,228,218,0.03),transparent),var(--bg-2);color:var(--ink-mute);font-family:var(--font-ui);letter-spacing:0.12em;text-transform:uppercase;text-align:center}
.owner-block-image-preview{min-height:160px;background-size:cover;background-position:center;border:1px solid var(--line-strong)}
@media (max-width:760px){.owner-admin-bar{left:0.75rem;right:0.75rem;transform:none}.owner-builder__head{display:grid}.owner-builder__actions{justify-content:stretch}.owner-builder__actions button{flex:1 1 auto}.owner-delete-btn{opacity:1;transform:none;pointer-events:auto}}
[data-owner-mode="true"] .owner-delete-btn.owner-only{display:inline-flex !important;opacity:1;transform:translateY(0);pointer-events:auto}
.owner-delete-btn{box-shadow:0 16px 38px -20px rgba(0,0,0,0.8)}
.owner-builder__actions--templates{max-width:430px}
.owner-builder__tip{display:flex;flex-wrap:wrap;gap:0.4rem 0.65rem;align-items:center;padding:0.7rem 1rem;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg-1) 78%,transparent);color:var(--ink-soft);font-size:0.84rem}
.owner-builder__tip strong{font-family:var(--font-ui);letter-spacing:0.14em;text-transform:uppercase;color:var(--accent)}
.owner-builder__tip span{color:var(--ink-soft)}
.owner-two-image-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.85rem}
.owner-two-image-editor>div{display:grid;gap:0.55rem;min-width:0;padding:0.75rem;border:1px solid var(--line);background:color-mix(in srgb,var(--bg-2) 66%,transparent)}
.owner-block-divider-preview{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:0.8rem;color:var(--accent);font-family:var(--font-ui);letter-spacing:0.16em;text-transform:uppercase}
.owner-block-divider-preview span{height:1px;background:var(--accent-line)}
.post-body__fig--pair{margin-block:2rem}
.post-body__pair{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(0.8rem,2vw,1.2rem)}
.post-body__pair>div{min-width:0}
.post-body__fig--pair .post-body__img{min-height:clamp(220px,32vw,430px)}
.post-body__pair-caption{margin-top:0.7rem;text-align:center;color:var(--ink-mute)}
.post-body__callout{margin-block:1.6rem;padding:clamp(1rem,2vw,1.25rem);border-left:2px solid var(--accent);background:color-mix(in srgb,var(--accent-soft) 44%,transparent)}
.post-body__callout span{display:block;margin-bottom:0.35rem;font-family:var(--font-ui);font-size:0.72rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent)}
.post-body__callout h4,.post-body__list h4{margin-bottom:0.45rem;font-family:var(--font-ui);font-size:1.05rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink)}
.post-body__list{margin-block:1.5rem;padding:clamp(1rem,2vw,1.25rem);border:1px solid var(--line);background:color-mix(in srgb,var(--bg-2) 72%,transparent)}
.post-body__list ul{display:grid;gap:0.45rem;margin-left:1.2rem;color:var(--ink-soft)}
.post-body__note{margin-block:1.4rem;padding:clamp(0.85rem,1.6vw,1.1rem);border-left:2px solid #4a9e6a;background:rgba(42,90,58,0.18)}
.post-body__note span{display:block;margin-bottom:0.3rem;font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.22em;text-transform:uppercase;color:#6dbd8a}
.post-body__note p{color:var(--ink-soft);margin:0;font-size:0.96rem;line-height:1.7}
.post-body__stats{display:flex;flex-wrap:wrap;gap:0.1rem;margin-block:2rem;border:1px solid var(--line);background:color-mix(in srgb,var(--bg-2) 72%,transparent)}
.post-body__stat{flex:1 1 140px;padding:1.4rem 1.6rem;border-right:1px solid var(--line)}
.post-body__stat:last-child{border-right:0}
.post-body__stat strong{display:block;font-family:var(--font-display);font-size:clamp(2rem,3vw,2.8rem);color:var(--accent);line-height:1;margin-bottom:0.3rem}
.post-body__stat span{display:block;font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-mute)}
.post-body__embed{margin-block:2rem;position:relative;background:var(--bg-0);border:1px solid var(--line)}
.post-body__embed iframe{width:100%;height:var(--embed-h,480px);border:0;display:block}
.post-body__features{margin-block:2rem}
.post-body__features>h4{font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.post-body__feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0.75rem}
.post-body__feature{padding:1rem 1.1rem;border:1px solid var(--line);background:rgba(234,228,218,0.02);transition:border-color 220ms var(--ease-out)}
.post-body__feature:hover{border-color:var(--accent-line)}
.post-body__feature span{display:block;font-family:var(--font-ui);font-size:0.65rem;letter-spacing:0.32em;color:var(--accent)}
.post-body__feature strong{display:block;margin:0.35rem 0 0.3rem;font-family:var(--font-ui);font-size:0.9rem;letter-spacing:0.06em;text-transform:uppercase;color:var(--ink)}
.post-body__feature p{margin:0;font-size:0.86rem;line-height:1.6;color:var(--ink-soft)}
.post-body__columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(1.5rem,3vw,3rem);margin-block:2rem;padding:clamp(1rem,2vw,1.5rem);border:1px solid var(--line);background:rgba(234,228,218,0.02)}
.post-body__columns h4{font-family:var(--font-ui);font-size:0.78rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:0.6rem}
.post-body__columns p{color:var(--ink-soft);font-size:0.95rem;line-height:1.7;margin:0}
.post-body__download{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-block:2rem;padding:clamp(1rem,2vw,1.5rem);border:1px solid var(--accent-line);background:color-mix(in srgb,var(--accent-soft) 44%,transparent);flex-wrap:wrap}
.post-body__download strong{display:block;font-family:var(--font-ui);font-size:0.9rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink)}
.post-body__download span{display:block;margin-top:0.25rem;color:var(--ink-soft);font-size:0.88rem}
.post-body__image-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(0.5rem,1vw,0.75rem)}
.post-body__image-grid>div{aspect-ratio:4/3;overflow:hidden}
.post-body__image-grid .post-body__img{height:100%;min-height:0;background-size:cover}
@media (max-width:640px){.post-body__columns,.post-body__image-grid{grid-template-columns:1fr}.post-body__stats{flex-direction:column}.post-body__stat{border-right:0;border-bottom:1px solid var(--line)}.post-body__stat:last-child{border-bottom:0}}
.post-body__divider{height:1px;margin:2.2rem 0;background:linear-gradient(90deg,transparent,var(--accent-line),transparent)}
.game-detail-section--custom-blocks .post__body,.game-detail__custom-body{max-width:none}
.game-detail-section--custom-blocks .post-body__fig,.game-detail-section--custom-blocks .post-body__list,.game-detail-section--custom-blocks .post-body__callout{max-width:100%}
@media (max-width:760px){.owner-two-image-editor,.post-body__pair{grid-template-columns:1fr}.owner-builder__actions--templates{max-width:none}}
.owner-card-actions{position:absolute;top:0.75rem;right:0.75rem;z-index:40;display:flex;gap:0.45rem;flex-wrap:wrap;justify-content:flex-end;pointer-events:auto}
.owner-card-actions button,.copy-email-tag{border:1px solid var(--accent-line);background:var(--owner-btn-bg,rgba(15,17,21,0.88));color:var(--ink);padding:0.35rem 0.55rem;font-family:var(--font-ui);font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;box-shadow:var(--shadow-card)}
.owner-card-actions .owner-delete-btn{color:#ffd1c1;border-color:rgba(255,80,40,0.55)}
.owner-card-actions .owner-edit-btn{color:var(--accent-hot)}
.owner-block-checks{display:flex;flex-wrap:wrap;gap:0.6rem;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--ink-soft)}
.owner-three-image-editor{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.75rem}
.post-body__video-wrap,.post-body__video,.post-body__audio,.post-body__iframe{width:100%;border:1px solid var(--line-strong);background:var(--bg-0);box-shadow:var(--shadow-card)}
.post-body__video-wrap{aspect-ratio:16 / 9;overflow:hidden;position:relative}
.post-body__iframe{height:100%;border:0;display:block}
.post-body__video{display:block;max-height:72vh}
.post-body__audio{padding:0.5rem}
.post-body__triple,.post-body__pair{display:grid;gap:1rem}
.post-body__triple{grid-template-columns:repeat(3,minmax(0,1fr))}
.post-body__media-text{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr);gap:1.5rem;align-items:center;margin-block:2rem}
.post-body__media-text.is-reverse .post-body__media-text-media{order:2}
.post-body__media-text-copy h3,.post-body__table h4,.post-body__timeline h4,.post-body__audio-block h4,.post-body__cta h4{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:.65rem}
.post-body__table{overflow:auto;margin-block:2rem}
.post-body__table table{width:100%;border-collapse:collapse;min-width:520px;background:rgba(234,228,218,.02)}
.post-body__table th,.post-body__table td{border:1px solid var(--line);padding:.75rem;text-align:left;color:var(--ink-soft)}
.post-body__table th{color:var(--ink);font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase}
.post-body__timeline{margin-block:2rem}
.post-body__timeline ol{list-style:none;display:grid;gap:.75rem}
.post-body__timeline li{border-left:2px solid var(--accent);padding:.6rem 0 .6rem 1rem;background:rgba(234,228,218,.02)}
.post-body__timeline li strong{display:block;color:var(--ink);font-family:var(--font-ui);letter-spacing:.14em;text-transform:uppercase}
.post-body__timeline li span{color:var(--ink-soft)}
.post-body__cta{display:flex;justify-content:space-between;gap:1rem;align-items:center;border:1px solid var(--line-strong);padding:1rem;background:var(--bg-glass);margin-block:2rem}
.game-detail__links{display:flex;flex-wrap:wrap;gap:.6rem;margin:1rem 0}
.game-detail__main-media.is-video .game-detail__media-slide{display:flex;align-items:stretch;justify-content:stretch;background:var(--bg-0)}
.game-detail__main-media.is-video .post-body__video-wrap,.game-detail__main-media.is-video .post-body__video,.game-detail__main-media.is-video .post-body__audio{height:100%;max-height:none;box-shadow:none}
@media (max-width:760px){.owner-three-image-editor,.post-body__triple,.post-body__media-text{grid-template-columns:1fr}.post-body__media-text.is-reverse .post-body__media-text-media{order:0}.post-body__cta{flex-direction:column;align-items:flex-start}}
[data-owner-mode="true"] .owner-card-actions.owner-only{display:flex !important}
.owner-card-actions{pointer-events:auto;isolation:isolate}
.owner-card-actions::before{content:"OWNER";display:inline-flex;align-items:center;padding:0.35rem 0.5rem;border:1px solid rgba(236,231,75,0.5);background:rgba(15,17,21,0.92);color:var(--accent);font-family:var(--font-ui);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;box-shadow:var(--shadow-card)}
.owner-card-actions button{min-height:30px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.owner-card-actions button:hover{background:var(--accent);color:#0F1115;border-color:var(--accent)}
.owner-card-actions .owner-delete-btn:hover{background:#ff4c1a;border-color:#ff4c1a;color:#fff}
.owner-field--wide{grid-column:span 2}
.owner-field--option{min-height:112px;padding:0.85rem;border:1px solid var(--line-strong);background:linear-gradient(135deg,rgba(234,228,218,0.035),transparent),color-mix(in srgb,var(--bg-2) 86%,transparent)}
.owner-field--option>span{color:var(--accent)}
.owner-toggle{display:grid;grid-template-columns:auto 1fr;gap:0.75rem;align-items:center;cursor:pointer;user-select:none}
.owner-toggle input{position:absolute;opacity:0;pointer-events:none}
.owner-toggle__switch{width:52px;height:28px;border:1px solid var(--line-strong);background:rgba(234,228,218,0.06);position:relative;transition:background var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out),box-shadow var(--t-fast) var(--ease-out)}
.owner-toggle__switch::after{content:"";position:absolute;top:4px;left:4px;width:18px;height:18px;background:var(--ink-mute);transition:transform var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out)}
.owner-toggle input:checked+.owner-toggle__switch{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px rgba(236,231,75,0.08)}
.owner-toggle input:checked+.owner-toggle__switch::after{transform:translateX(24px);background:var(--accent)}
.owner-toggle__copy{display:grid;gap:0.15rem}
.owner-toggle__copy strong{font-family:var(--font-ui);font-size:0.76rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink)}
.owner-toggle__copy em{font-style:normal;font-size:0.78rem;line-height:1.35;color:var(--ink-mute)}
.owner-cms-form__note{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-bottom:1rem;padding:0.85rem 1rem;border:1px solid var(--accent-line);background:var(--accent-soft)}
.owner-cms-form__note strong{font-family:var(--font-ui);letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
.owner-cms-form__note span{color:var(--ink-soft);font-size:0.9rem}
.contact-email-row{display:flex;flex-wrap:wrap;gap:0.55rem;align-items:center}
.contact-email-row .value{margin-right:0.25rem}
@media (max-width:760px){.owner-field--wide,.owner-field--option{grid-column:span 1}.owner-cms-form__note{align-items:flex-start;flex-direction:column}}
.owner-card-actions::before{content:none !important;display:none !important}
[data-owner-mode="true"] .owner-card-actions.owner-only{display:inline-flex !important;align-items:center !important;gap:0.45rem !important;flex-wrap:nowrap !important;pointer-events:auto !important}
[data-owner-mode="true"] .owner-card-actions .owner-edit-btn,[data-owner-mode="true"] .owner-card-actions .owner-delete-btn{display:inline-flex !important;visibility:visible !important;opacity:1 !important;transform:none !important;pointer-events:auto !important;align-items:center;justify-content:center;min-width:58px;min-height:32px;white-space:nowrap}
.owner-card-actions .owner-edit-btn{background:rgba(15,17,21,0.90);color:var(--accent-hot);border-color:var(--accent-line)}
.owner-card-actions .owner-delete-btn{background:rgba(60,10,5,0.90);color:#ffe0d6;border-color:rgba(255,80,40,0.7)}
.owner-card-actions .owner-edit-btn:hover{background:var(--accent);color:#0F1115}
.owner-card-actions .owner-delete-btn:hover{background:#ff4c1a;color:#fff;border-color:#ff4c1a}
.contact-email-row{display:flex;flex-wrap:wrap;gap:0.55rem;align-items:center}
.contact-email-link{position:relative;display:inline-flex;align-items:center;color:var(--ink);border-bottom:1px solid var(--accent-line);padding:0.1rem 0;transition:color var(--t-fast) var(--ease-out),text-shadow var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out)}
.contact-email-link:hover,.contact-email-link:focus-visible{color:var(--accent-hot);border-color:var(--accent);text-shadow:0 0 18px rgba(236,231,75,0.45);outline:2px solid var(--accent);outline-offset:3px}
.copy-email-tag{display:inline-flex;align-items:center;justify-content:center;min-height:30px;border:1px solid var(--accent-line);background:rgba(15,17,21,0.88);color:var(--ink)}
.copy-email-tag:hover,.copy-email-tag:focus-visible{background:var(--accent);color:#0F1115;border-color:var(--accent);outline:2px solid var(--accent-hot);outline-offset:2px}
.copy-email-tag.is-copied{background:var(--accent-hot);color:#0F1115;border-color:var(--accent-hot)}
.owner-card-actions,[data-owner-mode="true"] .owner-card-actions.owner-only{position:absolute !important;top:0.75rem !important;right:0.75rem !important;left:auto !important;bottom:auto !important;display:flex !important;flex-direction:row !important;flex-wrap:nowrap !important;align-items:center !important;justify-content:flex-end !important;gap:0.5rem !important;width:max-content !important;max-width:none !important;min-width:0 !important;padding:0 !important;background:transparent !important;pointer-events:auto !important;z-index:80 !important}
.owner-card-actions>.owner-edit-btn,.owner-card-actions>.owner-delete-btn,[data-owner-mode="true"] .owner-card-actions>.owner-edit-btn,[data-owner-mode="true"] .owner-card-actions>.owner-delete-btn{position:static !important;inset:auto !important;top:auto !important;right:auto !important;left:auto !important;bottom:auto !important;display:inline-flex !important;flex:0 0 auto !important;align-items:center !important;justify-content:center !important;width:auto !important;min-width:64px !important;min-height:34px !important;margin:0 !important;opacity:1 !important;transform:none !important;pointer-events:auto !important;white-space:nowrap !important}
.owner-card-actions>.owner-edit-btn{order:1 !important}
.owner-card-actions>.owner-delete-btn{order:2 !important}
.motion-toggle{position:fixed;right:calc(clamp(0.85rem,2vw,1.5rem)+56px);bottom:clamp(1rem,3vw,2rem);z-index:120;width:46px;height:46px;display:grid;place-items:center;background:var(--bg-glass);border:1px solid var(--accent);color:var(--accent);cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);isolation:isolate;transition:background 220ms var(--ease-out),color 220ms var(--ease-out),border 220ms var(--ease-out),transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out);box-shadow:0 8px 28px -10px rgba(0,0,0,0.55)}
.motion-toggle:hover,.motion-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px;color:var(--accent-hot);border-color:var(--accent-hot);background:var(--accent-soft);transform:translateY(-2px);box-shadow:0 14px 36px -10px rgba(0,0,0,0.65),0 0 24px -4px rgba(236,231,75,0.45)}
.motion-toggle::before,.motion-toggle::after{content:"";position:absolute;width:6px;height:6px;border:1px solid var(--accent);pointer-events:none;transition:width 220ms var(--ease-out),height 220ms var(--ease-out),border-color 220ms var(--ease-out)}
.motion-toggle::before{top:-2px;left:-2px;border-right:0;border-bottom:0}
.motion-toggle::after{bottom:-2px;right:-2px;border-left:0;border-top:0}
.motion-toggle:hover::before,.motion-toggle:hover::after{width:10px;height:10px;border-color:var(--accent-hot)}
.motion-toggle__icons{position:relative;width:23px;height:23px;display:block}
.motion-toggle__icons svg{position:absolute;inset:0;width:100%;height:100%;transition:opacity 260ms var(--ease-out),transform 320ms var(--ease-out)}
.motion-toggle__icons .icon-motion-on{opacity:1;transform:scale(1)}
.motion-toggle__icons .icon-motion-off{opacity:0;transform:scale(0.65) rotate(-8deg)}
[data-motion="reduced"] .motion-toggle__icons .icon-motion-on{opacity:0;transform:scale(0.65) rotate(8deg)}
[data-motion="reduced"] .motion-toggle__icons .icon-motion-off{opacity:1;transform:scale(1)}
body.modal-open .motion-toggle,body.owner-modal-open .motion-toggle,body.owner-modal-open .theme-toggle{opacity:0;pointer-events:none}
[data-motion="reduced"]{scroll-behavior:auto !important}
[data-motion="reduced"] *,[data-motion="reduced"] *::before,[data-motion="reduced"] *::after{animation-duration:0.001ms !important;animation-delay:0ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;transition-delay:0ms !important}
[data-motion="reduced"] .fade-up,[data-motion="reduced"] .reveal,[data-motion="reduced"] .post,[data-motion="reduced"] .game-detail,[data-motion="reduced"] .choice,[data-motion="reduced"] .choice-section__head,[data-motion="reduced"] .arc-item__content,[data-motion="reduced"] .work__img,[data-motion="reduced"] .arc-item__img,[data-motion="reduced"] .blog-row__thumb-img,[data-motion="reduced"] .selector__item,[data-motion="reduced"] .selector__caret,[data-motion="reduced"] .modal__img-wrap,[data-motion="reduced"] .modal__details,[data-motion="reduced"] .hero__bg,[data-motion="reduced"] .selector__bg,[data-motion="reduced"] .post__hero-img,[data-motion="reduced"] .game-detail__bg{opacity:1 !important;transform:none !important;filter:none !important;will-change:auto !important}
[data-motion="reduced"] .choice-section{min-height:auto !important;height:auto !important;padding-block:calc(var(--header-h)+4rem) clamp(4rem,8vw,7rem) !important;overflow:visible !important}
[data-motion="reduced"] .choice-stage,[data-motion="reduced"] .choice-stage__sticky,[data-motion="reduced"] .choice-stage__intro{position:static !important;height:auto !important;transform:none !important;opacity:1 !important;filter:none !important}[data-motion="reduced"] .page-home .choice-grid{min-height:clamp(480px,60vw,720px) !important;height:auto !important;grid-template-columns:1fr 1fr !important}[data-motion="reduced"] .page-home .choice{min-height:clamp(400px,50vw,600px) !important;height:auto !important;opacity:1 !important;transform:none !important;scale:1 !important;width:100% !important}[data-motion="reduced"] .page-home .choice__content{pointer-events:auto !important}[data-motion="reduced"] .page-home .choice__cta{pointer-events:auto !important}
[data-motion="reduced"] .choice:hover .choice__bg,[data-motion="reduced"] .work:hover .work__img,[data-motion="reduced"] .arc-item:hover .arc-item__img,[data-motion="reduced"] .blog-row:hover .blog-row__thumb-img,[data-motion="reduced"] .hero__rail a:hover,[data-motion="reduced"] .btn:hover .arrow,[data-motion="reduced"] .post__back:hover,[data-motion="reduced"] .category-view__back:hover{transform:none !important}
[data-motion="reduced"] .scroll-hint,[data-motion="reduced"] .hero__bg{animation:none !important}
@media (max-width:720px){.motion-toggle{width:42px;height:42px;right:calc(0.75rem+50px);bottom:0.85rem}}
.modal__caption-content{display:flex;flex-direction:column;gap:0.45rem;align-items:flex-start}
.modal__caption-controls{display:flex;flex-wrap:wrap;gap:0.55rem;align-items:center;margin-top:0.15rem;pointer-events:auto}
.modal__caption-toggle{position:absolute;left:clamp(1.2rem,3vw,2.4rem);bottom:clamp(1.2rem,2.5vw,2rem);z-index:5;display:inline-flex;align-items:center;justify-content:center;min-width:92px;min-height:38px;padding:0.55rem 0.9rem;background:rgba(15,17,21,0.72);border:1px solid var(--accent);color:var(--accent);font-family:var(--font-ui);font-size:0.7rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;cursor:pointer;pointer-events:auto;transition:background 220ms var(--ease-out),color 220ms var(--ease-out),opacity 220ms var(--ease-out),transform 220ms var(--ease-out)}
.modal__caption-toggle:hover,.modal__caption-toggle:focus-visible{background:var(--accent);color:#EAE4DA;outline:2px solid var(--accent-hot);outline-offset:2px;transform:translateY(-2px)}
.modal:not(.caption-hidden) .modal__caption-toggle{opacity:0;pointer-events:none}
.modal.caption-hidden .modal__caption-content,.modal.caption-hidden .modal__caption-controls{opacity:0;transform:translateY(8px);pointer-events:none}
.modal.caption-hidden .modal__caption{pointer-events:none}
.modal.caption-hidden .modal__caption-toggle{opacity:1;pointer-events:auto}
.modal__img-wrap:fullscreen,.modal__img-wrap:-webkit-full-screen{width:100vw !important;height:100vh !important;max-height:none !important;aspect-ratio:auto !important;background:#0F1115 !important;box-shadow:none !important;transform:none !important;cursor:default}
.modal__img-wrap:fullscreen .modal__img,.modal__img-wrap:-webkit-full-screen .modal__img{background-size:contain !important;background-position:center !important;background-repeat:no-repeat !important}
.modal.is-fullscreen .modal__topbar,.modal.is-fullscreen .modal__caption,.modal.is-fullscreen .modal__caption-toggle,.modal.is-fullscreen .modal__nav,.modal.is-fullscreen .modal__details,.modal.is-fullscreen .modal__watermark{opacity:0;pointer-events:none}
[data-theme="light"] .modal__caption-toggle{background:rgba(243,246,249,0.82);color:var(--accent-deep);border-color:var(--accent)}
[data-theme="light"] .modal__caption-toggle:hover,[data-theme="light"] .modal__caption-toggle:focus-visible{background:var(--accent);color:#fff}
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
:focus-visible{outline:2px solid var(--accent);outline-offset:4px}
.is-bg-loading{background:linear-gradient(135deg,rgba(234,228,218,0.04),rgba(234,228,218,0.01))}
[hidden]{display:none !important}
.home-featured{background:radial-gradient(ellipse at 18% 0%,rgba(236,231,75,0.11),transparent 42%),linear-gradient(180deg,var(--bg-1),var(--bg-0));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.home-featured__head{display:flex;align-items:end;justify-content:space-between;gap:2rem;margin-bottom:2rem}
.home-featured__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(1rem,2vw,1.6rem)}
.featured-card{min-height:420px;border:1px solid var(--line-strong);background:var(--bg-2);position:relative;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-card)}
.featured-card__img{min-height:260px;background-size:cover;background-position:center;filter:saturate(.95) contrast(1.05);position:relative}
.featured-card__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.62))}
.featured-card__body{padding:1rem;display:grid;gap:.45rem}
.featured-card__body span{font-family:var(--font-ui);color:var(--accent);letter-spacing:.22em;text-transform:uppercase;font-size:.75rem}
.featured-card__body h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.7rem,2.2vw,2.5rem);line-height:.94}
.featured-card__body p{color:var(--ink-soft);font-size:.9rem}
.featured-card:hover .featured-card__img{transform:scale(1.035);transition:transform var(--t-med) var(--ease-out)}
.home-scan{background:var(--bg-1)}
.home-scan__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.home-scan__card{border:1px solid var(--line);background:rgba(234,228,218,.025);padding:1.3rem;min-height:170px}
.home-scan__card h3{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.14em;margin:.5rem 0}
.home-scan__card p{color:var(--ink-soft)}
.portfolio-filter{border:1px solid var(--line);background:rgba(234,228,218,.025);padding:1rem;margin:1.6rem 0 2rem;display:grid;gap:.8rem}
.portfolio-filter__search input{width:100%;border:1px solid var(--line-strong);background:rgba(0,0,0,.28);color:var(--ink);padding:.9rem 1rem;font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase}
.portfolio-filter__chips{display:flex;flex-wrap:wrap;gap:.45rem}
.portfolio-filter__chip{border:1px solid var(--line-strong);color:var(--ink-soft);padding:.45rem .75rem;font-family:var(--font-ui);letter-spacing:.15em;text-transform:uppercase;font-size:.72rem;background:rgba(234,228,218,.025)}
.portfolio-filter__chip.is-active,.portfolio-filter__chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.portfolio-filter__empty{color:var(--ink-mute);font-family:var(--font-ui);letter-spacing:.18em;text-transform:uppercase}
.portfolio-filter--media-only{padding:.85rem 1rem;margin:1.2rem 0 1.6rem}
.portfolio-filter--media-only .portfolio-filter__media{padding-top:0}
.work,.arc-item,.blog-row,.game-card{scroll-margin-top:calc(var(--header-h)+2rem)}
.work[hidden],.arc-item[hidden],.blog-row[hidden],.game-card[hidden]{display:none!important}
.work,.arc-item,.game-card,.blog-row{transition:transform var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out),box-shadow var(--t-fast) var(--ease-out)}
.work:hover,.arc-item:hover,.game-card:hover,.blog-row:hover{box-shadow:var(--shadow-glow)}
.game-detail__case-study{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin:clamp(1rem,2vw,1.5rem) 0 clamp(2rem,4vw,3rem)}
.game-detail__case-study article{border:1px solid var(--line);background:rgba(234,228,218,.035);padding:1.2rem}
.game-detail__case-study h3{font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase;margin:.5rem 0}
.game-detail__case-study p{color:var(--ink-soft)}
.post__toc{display:grid;gap:.45rem;margin-top:.6rem}
.post__toc a{color:var(--ink-soft);font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;font-size:.75rem;padding:.35rem 0;border-bottom:1px solid var(--line)}
.post__toc a:hover{color:var(--accent)}
.related-posts{margin:clamp(3rem,6vw,5rem) 0}
.related-posts header{margin-bottom:1.2rem}
.related-posts__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.related-card{border:1px solid var(--line);background:rgba(234,228,218,.025);padding:1rem;min-height:150px;display:grid;align-content:start;gap:.55rem}
.related-card span{font-family:var(--font-ui);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-size:.72rem}
.related-card strong{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.related-card em{color:var(--ink-mute);font-style:normal}
.related-card:hover{border-color:var(--accent)}
.modal__thumbs{position:fixed;left:50%;bottom:1rem;transform:translateX(-50%);z-index:9;display:flex;gap:.45rem;max-width:min(760px,70vw);overflow-x:auto;padding:.35rem;background:rgba(0,0,0,.32);border:1px solid var(--line);backdrop-filter:blur(10px)}
.modal.caption-hidden .modal__thumbs{bottom:1rem}
.modal__thumb{width:58px;height:42px;border:1px solid var(--line-strong);opacity:.62;position:relative;flex:0 0 auto;background:var(--bg-2);overflow:hidden}
.modal__thumb span{position:absolute;inset:0;background-size:cover;background-position:center}
.modal__thumb.is-active,.modal__thumb:hover{opacity:1;border-color:var(--accent)}
.status-pill{font-family:var(--font-ui);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-line);padding:.55rem .85rem;background:var(--accent-soft)}
.contact-action-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.social-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;margin-top:1rem}
.social-card{border:1px solid var(--line);background:rgba(234,228,218,.025);padding:.9rem;display:grid;gap:.2rem}
.social-card strong{font-family:var(--font-ui);letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.social-card span{color:var(--ink-mute);font-size:.85rem}
.social-card:hover{border-color:var(--accent);background:var(--accent-soft)}
.not-found{min-height:100vh;display:grid;place-content:center;gap:1rem;padding:var(--gutter);background:var(--bg-1)}
@media (max-width:1000px){.home-featured__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.home-scan__grid,.game-detail__case-study,.related-posts__grid{grid-template-columns:1fr}}
@media (max-width:640px){.home-featured__head{display:grid}.home-featured__grid,.social-card-grid{grid-template-columns:1fr}.modal__thumbs{max-width:92vw}}
html[data-motion="reduced"] .featured-card:hover .featured-card__img{transform:none!important}
.blog-row{position:relative}
.blog-row__tags{position:absolute;top:0.85rem;right:0.85rem;z-index:4;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:0.35rem;max-width:min(42vw,420px);pointer-events:none}
.blog-row__tags span{border:1px solid var(--accent-line);background:rgba(8,8,12,0.72);color:var(--accent-hot);font-family:var(--font-ui);font-size:0.62rem;letter-spacing:0.16em;text-transform:uppercase;padding:0.25rem 0.5rem;backdrop-filter:blur(8px)}
.blog-row__tags span:first-child{background:var(--accent);color:#120904;border-color:var(--accent);font-weight:700}
.blog-filter .portfolio-filter__chips{max-height:8.5rem;overflow:auto;padding-right:0.25rem}
.portfolio-filter__chip:focus-visible,.blog-row:focus-visible,.blog-row__more:focus-visible{outline:2px solid var(--accent-hot);outline-offset:4px}
@media (max-width:760px){.blog-row__tags{position:static;justify-content:flex-start;max-width:none;margin-bottom:.75rem}}
[data-owner-mode="true"] .blog-row{padding-bottom:5.25rem !important}
[data-owner-mode="true"] .blog-row>.owner-card-actions.owner-only{position:absolute !important;top:auto !important;right:1rem !important;bottom:1rem !important;left:auto !important;display:flex !important;flex-direction:row !important;flex-wrap:wrap !important;align-items:center !important;justify-content:flex-end !important;gap:0.45rem !important;width:auto !important;max-width:min(520px,calc(100% - 2rem)) !important;min-width:0 !important;padding:0.35rem !important;background:color-mix(in srgb,var(--bg-0) 86%,transparent) !important;border:1px solid var(--line-strong) !important;box-shadow:0 16px 40px -28px rgba(0,0,0,.9) !important;z-index:35 !important}
[data-owner-mode="true"] .blog-row>.owner-card-actions.owner-only>button{position:static !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;min-width:70px !important;min-height:32px !important;margin:0 !important;padding:0.4rem 0.65rem !important;white-space:nowrap !important;opacity:1 !important;transform:none !important;pointer-events:auto !important}
[data-owner-mode="true"] .blog-row>.owner-card-actions.owner-only>.owner-edit-btn{order:1 !important}
[data-owner-mode="true"] .blog-row>.owner-card-actions.owner-only>.owner-duplicate-btn{order:2 !important}
[data-owner-mode="true"] .blog-row>.owner-card-actions.owner-only>.owner-delete-btn{order:3 !important}
[data-owner-mode="true"] .blog-row__tags{top:0.85rem !important;right:1rem !important;max-width:min(48vw,540px) !important;z-index:20 !important}
@media (max-width:760px){[data-owner-mode="true"] .blog-row{padding-bottom:6rem !important}[data-owner-mode="true"] .blog-row>.owner-card-actions.owner-only{left:1rem !important;right:1rem !important;justify-content:flex-start !important;max-width:none !important}}
.case-preview{display:grid;grid-template-columns:minmax(280px,0.95fr) minmax(320px,1.05fr);gap:clamp(1.2rem,3vw,3rem);align-items:stretch;border:1px solid var(--line);background:linear-gradient(135deg,rgba(234,228,218,0.03),rgba(234,228,218,0.01));padding:clamp(1rem,2.4vw,2rem);box-shadow:var(--shadow-card)}
.case-preview__media{min-height:clamp(280px,42vw,520px);overflow:hidden;background:var(--bg-2)}
.case-preview__img{width:100%;height:100%;min-height:inherit;background-size:cover;background-position:center;filter:saturate(.96) contrast(1.04)}
.case-preview__copy{display:flex;flex-direction:column;justify-content:center;gap:1rem}
.case-preview__copy>p{color:var(--ink-soft);max-width:68ch}
.case-preview__cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin:.25rem 0}
.case-preview__cards article,.game-detail__process-strip article{border:1px solid var(--line);background:rgba(234,228,218,0.035);padding:.9rem}
.case-preview__cards span,.game-detail__process-strip span{display:block;font-family:var(--font-ui);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-size:.72rem}
.case-preview__cards strong{display:block;margin-top:.35rem;color:var(--ink);line-height:1.25}
.case-preview__systems{list-style:none;display:grid;gap:.55rem;margin:.4rem 0 .8rem}
.case-preview__systems li{display:grid;grid-template-columns:9rem 1fr;gap:.8rem;border-top:1px solid var(--line);padding-top:.55rem;color:var(--ink-soft)}
.case-preview__systems strong{color:var(--ink);font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase}
.game-detail__case-study--pro{grid-template-columns:repeat(3,minmax(0,1fr))}
.game-detail__process-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;max-width:var(--max-width);margin:clamp(1.5rem,4vw,3rem) auto;padding-inline:var(--gutter)}
.game-detail__process-strip strong{display:block;margin-top:.35rem;font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase}
.game-detail__process-strip p{color:var(--ink-soft);margin-top:.35rem;font-size:.92rem;line-height:1.55}
.before-after{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}
.before-after__pane{position:relative;border:1px solid var(--line);background:var(--bg-2)}
.before-after__pane>span{position:absolute;top:.65rem;left:.65rem;z-index:2;background:rgba(0,0,0,.62);color:var(--accent);border:1px solid var(--accent-line);padding:.25rem .55rem;font-family:var(--font-ui);letter-spacing:.18em;text-transform:uppercase;font-size:.7rem}
.before-after .post-body__img{min-height:260px}
.work,.arc-item,.game-card,.featured-card{--card-overlay-alpha:.42}
.work__overlay,.arc-item__overlay{opacity:var(--card-overlay-alpha)}
.work__img,.arc-item__img,.game-card__img,.featured-card__img{background-position:var(--media-focus,center center)}
.owner-order-note{font-family:var(--font-ui);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);font-size:.72rem}
:focus-visible{outline:2px solid var(--accent-hot);outline-offset:3px}
.modal__thumb:focus-visible,.game-detail__thumb:focus-visible,.portfolio-filter__chip:focus-visible,.owner-card-toolbar button:focus-visible{box-shadow:0 0 0 3px var(--accent-soft)}
@media (max-width:900px){.case-preview,.game-detail__case-study--pro,.game-detail__process-strip{grid-template-columns:1fr}.case-preview__cards{grid-template-columns:1fr}.case-preview__systems li{grid-template-columns:1fr}.before-after{grid-template-columns:1fr}}
.skip-link{position:absolute;top:-9999px;left:1rem;padding:.5rem 1rem;background:var(--accent);color:#fff;font-size:.85rem;font-weight:600;border-radius:0 0 4px 4px;z-index:99999;text-decoration:none;transition:top .15s}
.skip-link:focus{top:0}
.noscript-msg{background:var(--accent-hot,#ff3b30);color:#fff;text-align:center;padding:.75rem 1rem;font-size:.9rem;font-weight:500}

/* ============================================================================
   CINEMATIC CHOICE→FEATURED TRANSITION (v2.5)
   ============================================================================ */

/* Fog-out gradient at the very bottom of the sticky stage */
.page-home .choice-stage::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 18vh;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(15,17,21,0.18) 40%,
    rgba(15,17,21,0.45) 72%,
    rgba(15,17,21,0.62) 100%
  );
  z-index: 1;
  pointer-events: none;
}

/* Thin accent glow line separating sections */
.page-home .choice-section::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(236,231,75,0.22) 20%,
    rgba(236,231,75,0.48) 50%,
    rgba(236,231,75,0.22) 80%,
    transparent 100%
  );
  z-index: 10;
}

/* Featured section gets a cinematic entry with a top fade and slow reveal */
.page-home .home-featured {
  position: relative;
  isolation: isolate;
}

.page-home .home-featured::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: clamp(6rem, 14vw, 12rem);
  background: linear-gradient(
    to bottom,
    #0F1115 0%,
    rgba(15,17,21,0.82) 28%,
    rgba(15,17,21,0.40) 60%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* Reveal animation for featured header — cinematic fade+slide */
.page-home .home-featured__head {
  padding-top: clamp(2rem, 4vw, 4rem);
}

/* Slightly more dramatic reveal for home featured cards */
.page-home .featured-card.reveal {
  transition: opacity 900ms var(--ease-out), transform 900ms var(--ease-out);
  transition-delay: var(--delay, 0ms);
}

/* Light theme override for the bottom fog */
[data-theme="light"] .page-home .choice-stage::after {
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(238,242,245,0.18) 40%,
    rgba(238,242,245,0.45) 72%,
    rgba(238,242,245,0.62) 100%
  );
}

[data-theme="light"] .page-home .home-featured::before {
  background: linear-gradient(
    to bottom,
    #EEF2F5 0%,
    rgba(238,242,245,0.82) 28%,
    rgba(238,242,245,0.40) 60%,
    transparent 100%
  );
}

/* ============================================================================
   OWNER CMS — ENHANCED CONTENT MANAGER + FORM GROUPS (v9)
   ============================================================================ */

/* --- Content Manager Modal ------------------------------------------------- */
.owner-manager-modal {
  position: fixed;
  inset: 0;
  z-index: 310;
  display: none;
  background: rgba(4,4,6,0.82);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  transition: opacity 280ms ease-out;
}
.owner-manager-modal.is-open {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: clamp(1.2rem, 4vw, 3rem) var(--gutter, 1.5rem);
  overflow-y: auto;
  opacity: 1;
}
.owner-manager-panel {
  width: 100%;
  max-width: 980px;
  background: #0e0f14;
  border: 1px solid rgba(236,231,75,0.30);
  box-shadow: 0 60px 120px -40px rgba(0,0,0,0.85), 0 0 0 1px rgba(236,231,75,0.14);
  display: flex;
  flex-direction: column;
  max-height: 90vh;
  overflow: hidden;
}
.owner-manager__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 1.6rem;
  border-bottom: 1px solid rgba(236,231,75,0.20);
  flex-shrink: 0;
  gap: 1rem;
  flex-wrap: wrap;
  background: rgba(236,231,75,0.04);
}
.owner-manager__title {
  font-family: var(--font-display, 'Anton', sans-serif);
  font-size: 1.3rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink, #fff);
  margin: 0;
}
.owner-manager__title span {
  color: var(--accent, #c3601c);
}
.owner-manager__close {
  background: none;
  border: 1px solid rgba(236,231,75,0.28);
  color: var(--accent, #c3601c);
  font-size: 1.2rem;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background 200ms, transform 200ms, color 200ms;
}
.owner-manager__close:hover {
  background: rgba(236,231,75,0.15);
  transform: rotate(90deg);
}

/* Toolbar: filters + search */
.owner-manager__toolbar {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.9rem 1.6rem;
  border-bottom: 1px solid rgba(234,228,218,0.06);
  flex-shrink: 0;
  flex-wrap: wrap;
  background: rgba(0,0,0,0.22);
}
.owner-manager__search {
  flex: 1;
  min-width: 160px;
  background: rgba(234,228,218,0.04);
  border: 1px solid rgba(236,231,75,0.22);
  color: var(--ink, #fff);
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  padding: 0.5rem 0.85rem;
  outline: none;
  transition: border-color 200ms, background 200ms;
}
.owner-manager__search:focus {
  border-color: rgba(236,231,75,0.65);
  background: rgba(236,231,75,0.06);
}
.owner-manager__filter-tabs {
  display: flex;
  gap: 0.3rem;
  flex-wrap: wrap;
}
.owner-manager__tab {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.36rem 0.85rem;
  background: rgba(234,228,218,0.04);
  border: 1px solid rgba(234,228,218,0.08);
  color: rgba(234,228,218,0.55);
  cursor: pointer;
  transition: background 180ms, color 180ms, border-color 180ms;
}
.owner-manager__tab:hover {
  background: rgba(236,231,75,0.10);
  color: rgba(234,228,218,0.88);
  border-color: rgba(236,231,75,0.30);
}
.owner-manager__tab.is-active {
  background: rgba(236,231,75,0.18);
  color: var(--accent, #c3601c);
  border-color: rgba(236,231,75,0.55);
}

/* Stats bar */
.owner-manager__stats {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  padding: 0.55rem 1.6rem;
  border-bottom: 1px solid rgba(234,228,218,0.05);
  flex-shrink: 0;
  background: rgba(0,0,0,0.14);
}
.owner-manager__stat {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.45);
}
.owner-manager__stat strong {
  color: var(--accent, #c3601c);
  font-weight: 700;
}

/* Item grid */
.owner-manager__grid {
  flex: 1;
  overflow-y: auto;
  padding: 1.2rem 1.6rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.8rem;
  align-content: start;
}
.owner-manager__grid::-webkit-scrollbar { width: 5px; }
.owner-manager__grid::-webkit-scrollbar-track { background: rgba(0,0,0,0.18); }
.owner-manager__grid::-webkit-scrollbar-thumb { background: rgba(236,231,75,0.40); }

.owner-mgr-card {
  background: rgba(234,228,218,0.025);
  border: 1px solid rgba(234,228,218,0.07);
  overflow: hidden;
  transition: border-color 200ms, box-shadow 200ms, transform 200ms;
  cursor: default;
}
.owner-mgr-card:hover {
  border-color: rgba(236,231,75,0.40);
  box-shadow: 0 8px 28px -12px rgba(0,0,0,0.55);
  transform: translateY(-2px);
}
.owner-mgr-card__thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: rgba(236,231,75,0.06);
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}
.owner-mgr-card__thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.55));
}
.owner-mgr-card__type {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  padding: 0.18rem 0.5rem;
  background: rgba(236,231,75,0.82);
  color: #fff;
  z-index: 1;
}
.owner-mgr-card__status {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.18rem 0.5rem;
  z-index: 1;
}
.owner-mgr-card__status--draft {
  background: rgba(255,200,50,0.18);
  color: #f5c842;
  border: 1px solid rgba(245,200,66,0.32);
}
.owner-mgr-card__status--featured {
  background: rgba(236,231,75,0.24);
  color: var(--accent, #c3601c);
  border: 1px solid rgba(236,231,75,0.45);
}
.owner-mgr-card__status--pinned {
  background: rgba(80,160,255,0.18);
  color: #64aeff;
  border: 1px solid rgba(100,174,255,0.34);
}
.owner-mgr-card__body {
  padding: 0.75rem 0.9rem;
}
.owner-mgr-card__title {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-weight: 600;
  font-size: 0.88rem;
  letter-spacing: 0.06em;
  color: var(--ink, #fff);
  margin: 0 0 0.22rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.owner-mgr-card__meta {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.38);
  margin: 0 0 0.65rem;
}
.owner-mgr-card__actions {
  display: flex;
  gap: 0.4rem;
}
.owner-mgr-card__actions button {
  flex: 1;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.32rem 0.5rem;
  background: rgba(234,228,218,0.04);
  border: 1px solid rgba(234,228,218,0.10);
  color: rgba(234,228,218,0.7);
  cursor: pointer;
  transition: background 160ms, color 160ms, border-color 160ms;
}
.owner-mgr-card__actions button:hover {
  background: rgba(236,231,75,0.18);
  color: var(--accent, #c3601c);
  border-color: rgba(236,231,75,0.50);
}
.owner-mgr-card__actions button.del:hover {
  background: rgba(200,50,50,0.22);
  color: #ff6868;
  border-color: rgba(200,50,50,0.50);
}

.owner-manager__empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 4rem 2rem;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.82rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.28);
}

/* --- Enhanced CMS Form Sections ------------------------------------------- */

/* Form section grouping */
.owner-cms-form__section {
  border: 1px solid rgba(236,231,75,0.15);
  margin-bottom: 1rem;
  background: rgba(0,0,0,0.14);
  overflow: hidden;
}
.owner-cms-form__section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.7rem 1.1rem;
  background: rgba(236,231,75,0.06);
  border-bottom: 1px solid rgba(236,231,75,0.15);
  cursor: pointer;
  user-select: none;
  transition: background 180ms;
}
.owner-cms-form__section-head:hover {
  background: rgba(236,231,75,0.10);
}
.owner-cms-form__section-label {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent, #c3601c);
}
.owner-cms-form__section-toggle {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  color: rgba(234,228,218,0.40);
  transition: color 200ms;
}
.owner-cms-form__section-head:hover .owner-cms-form__section-toggle {
  color: rgba(234,228,218,0.70);
}
.owner-cms-form__section-body {
  padding: 0.8rem 1.1rem;
}
.owner-cms-form__section.is-collapsed .owner-cms-form__section-body {
  display: none;
}

/* Enhanced image control panel */
.owner-image-panel {
  margin-bottom: 1rem;
  border: 1px solid rgba(236,231,75,0.25);
  background: rgba(236,231,75,0.03);
  overflow: hidden;
}
.owner-image-panel__head {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.6rem 1rem;
  background: rgba(236,231,75,0.08);
  border-bottom: 1px solid rgba(236,231,75,0.20);
}
.owner-image-panel__label {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent, #c3601c);
  flex: 1;
}
.owner-image-panel__actions {
  display: flex;
  gap: 0.4rem;
}
.owner-image-panel__btn {
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  padding: 0.28rem 0.65rem;
  background: rgba(234,228,218,0.04);
  border: 1px solid rgba(234,228,218,0.12);
  color: rgba(234,228,218,0.6);
  cursor: pointer;
  transition: all 160ms;
}
.owner-image-panel__btn:hover {
  background: rgba(236,231,75,0.18);
  color: var(--accent, #c3601c);
  border-color: rgba(236,231,75,0.50);
}
.owner-image-panel__btn.clear:hover {
  background: rgba(200,50,50,0.18);
  color: #ff6868;
  border-color: rgba(200,50,50,0.40);
}
.owner-image-panel__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.owner-image-pane {
  padding: 0.8rem;
  border-right: 1px solid rgba(236,231,75,0.12);
  position: relative;
}
.owner-image-pane:last-child {
  border-right: 0;
}
.owner-image-pane--primary {
  background: linear-gradient(135deg, rgba(236,231,75,0.08), transparent 65%);
}
.owner-image-pane--primary::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--accent, #c3601c);
  opacity: 0.65;
}
.owner-image-pane--primary label {
  color: var(--accent, #c3601c);
}
.owner-image-pane label {
  display: block;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.45);
  margin-bottom: 0.45rem;
}
.owner-image-pane input {
  width: 100%;
  background: rgba(234,228,218,0.04);
  border: 1px solid rgba(236,231,75,0.20);
  color: var(--ink, #ece8df);
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.78rem;
  padding: 0.42rem 0.65rem;
  margin-bottom: 0.55rem;
  transition: border-color 180ms;
  outline: none;
}
.owner-image-pane input:focus {
  border-color: rgba(236,231,75,0.60);
}
.owner-image-thumb {
  width: 100%;
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  background-color: rgba(236,231,75,0.05);
  border: 1px dashed rgba(236,231,75,0.20);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.25);
  transition: border-color 200ms;
  position: relative;
}
.owner-image-thumb.has-image {
  border-color: rgba(236,231,75,0.40);
}
.owner-image-thumb.has-image span {
  display: none;
}

/* Manager button in admin bar */
.owner-manager-btn {
  background: rgba(236,231,75,0.14) !important;
  border-color: rgba(236,231,75,0.40) !important;
  color: var(--accent, #c3601c) !important;
}
.owner-manager-btn:hover {
  background: rgba(236,231,75,0.28) !important;
}

/* Quick status chips in editor form */
.owner-status-chips {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  margin-bottom: 0.6rem;
}
.owner-status-chip {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.28rem 0.7rem;
  background: rgba(234,228,218,0.04);
  border: 1px solid rgba(234,228,218,0.10);
  color: rgba(234,228,218,0.45);
  cursor: pointer;
  transition: all 180ms;
  user-select: none;
}
.owner-status-chip:hover { color: rgba(234,228,218,0.80); }
.owner-status-chip.active--featured { background: rgba(236,231,75,0.20); color: var(--accent,#c3601c); border-color: rgba(236,231,75,0.50); }
.owner-status-chip.active--pinned { background: rgba(80,160,255,0.14); color: #64aeff; border-color: rgba(100,174,255,0.36); }
.owner-status-chip.active--draft { background: rgba(245,200,66,0.12); color: #f5c842; border-color: rgba(245,200,66,0.34); }

/* Form note header */
.owner-cms-form__note {
  background: rgba(236,231,75,0.06);
  border: 1px solid rgba(236,231,75,0.20);
  border-left: 3px solid var(--accent, #c3601c);
  padding: 0.65rem 0.95rem;
  margin-bottom: 1rem;
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: 0.78rem;
  letter-spacing: 0.10em;
  color: rgba(234,228,218,0.68);
  line-height: 1.5;
}
.owner-cms-form__note strong {
  color: var(--accent, #c3601c);
  display: block;
  letter-spacing: 0.14em;
  font-size: 0.70rem;
  text-transform: uppercase;
  margin-bottom: 0.18rem;
}

/* Light theme overrides for manager */
[data-theme="light"] .owner-manager-panel {
  background: var(--bg-2);
  border-color: rgba(168,86,0,0.28);
}
[data-theme="light"] .owner-manager__head {
  background: rgba(168,86,0,0.05);
  border-bottom-color: rgba(168,86,0,0.18);
}
[data-theme="light"] .owner-manager__toolbar {
  background: rgba(0,0,0,0.04);
  border-bottom-color: rgba(20,30,50,0.10);
}
[data-theme="light"] .owner-manager__search {
  background: rgba(234,228,218,0.55);
  border-color: rgba(168,86,0,0.28);
  color: var(--ink);
}
[data-theme="light"] .owner-manager__tab {
  background: rgba(234,228,218,0.45);
  border-color: rgba(20,30,50,0.14);
  color: var(--ink-mute);
}
[data-theme="light"] .owner-manager__tab.is-active {
  background: rgba(168,86,0,0.12);
  color: var(--accent);
  border-color: rgba(168,86,0,0.40);
}
[data-theme="light"] .owner-mgr-card {
  background: rgba(234,228,218,0.52);
  border-color: rgba(20,30,50,0.12);
}
[data-theme="light"] .owner-mgr-card:hover {
  border-color: rgba(168,86,0,0.40);
}
[data-theme="light"] .owner-mgr-card__title { color: var(--ink); }
[data-theme="light"] .owner-mgr-card__actions button {
  background: rgba(234,228,218,0.55);
  border-color: rgba(20,30,50,0.14);
  color: var(--ink-soft);
}
[data-theme="light"] .owner-cms-form__section {
  border-color: rgba(168,86,0,0.15);
  background: rgba(234,228,218,0.22);
}
[data-theme="light"] .owner-cms-form__section-head {
  background: rgba(168,86,0,0.05);
  border-bottom-color: rgba(168,86,0,0.14);
}
[data-theme="light"] .owner-image-panel {
  border-color: rgba(168,86,0,0.24);
}
[data-theme="light"] .owner-image-panel__head {
  background: rgba(168,86,0,0.06);
  border-bottom-color: rgba(168,86,0,0.16);
}
[data-theme="light"] .owner-image-pane input {
  background: rgba(234,228,218,0.55);
  border-color: rgba(168,86,0,0.24);
  color: var(--ink);
}

/* ============================================================================
   BLOG FORM V2 — Tabbed editor, drop zones, block pills, save bar
   ============================================================================ */

/* ── Blog tab nav ── */
.owner-blog-tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:0;background:color-mix(in srgb,var(--bg-2) 86%,transparent)}
.owner-blog-tab{padding:.65rem 1.1rem;font-family:var(--font-ui);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;display:flex;align-items:center;gap:.45rem;transition:color var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out)}
.owner-blog-tab:hover{color:var(--ink)}
.owner-blog-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.owner-blog-tab-badge{background:var(--accent-soft);color:var(--accent);font-size:.68rem;font-weight:800;padding:1px 7px;border-radius:10px;min-width:18px;text-align:center;letter-spacing:0}

/* ── Status pills ── */
.owner-blog-status-bar{display:flex;align-items:center;gap:.65rem;padding:.85rem 1rem .75rem;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg-2) 72%,transparent)}
.owner-blog-status-label{font-family:var(--font-ui);font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute)}
.owner-blog-status-pills{display:flex;gap:.45rem;flex-wrap:wrap}
.owner-status-pill{padding:.35rem .9rem;border-radius:20px;font-family:var(--font-ui);font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;border:1px solid var(--line-strong);background:color-mix(in srgb,var(--bg-1) 72%,transparent);color:var(--ink-soft);transition:all var(--t-fast) var(--ease-out)}
.owner-status-pill:hover{border-color:var(--accent-line);color:var(--ink)}
.owner-status-pill.active-published{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);border-color:var(--accent)}
.owner-status-pill.active-draft{background:rgba(200,120,20,.12);color:#c07814;border-color:rgba(200,120,20,.5)}
.owner-status-pill.active-featured{background:rgba(60,100,200,.14);color:#5080d8;border-color:rgba(60,100,200,.45)}

/* ── Tab panels ── */
.owner-blog-panel{display:none}
.owner-blog-panel.active{display:block;animation:blogpanelin .18s ease}
@keyframes blogpanelin{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.owner-blog-panel-inner{padding:1.1rem 1rem;display:grid;gap:.85rem}
.owner-blog-panel-inner--blocks{padding:.5rem .5rem 0;gap:0}
.owner-blog-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
@media(max-width:640px){.owner-blog-field-row{grid-template-columns:1fr}}

/* ── Drop zones ── */
.owner-blog-drop-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.owner-blog-media-labels{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.3rem}
.owner-blog-media-labels>div strong{display:block;font-family:var(--font-ui);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}
.owner-blog-media-labels>div span{font-size:.78rem;color:var(--ink-mute)}
@media(max-width:640px){.owner-blog-drop-grid,.owner-blog-media-labels{grid-template-columns:1fr}}

.owner-blog-drop-zone{position:relative;border:1.5px dashed var(--line-strong);background:color-mix(in srgb,var(--bg-2) 76%,transparent);cursor:pointer;overflow:hidden;min-height:220px;display:flex;flex-direction:column;transition:border-color var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out)}
.owner-blog-drop-zone:hover,.owner-blog-drop-zone.dragover{border-color:var(--accent);background:var(--accent-soft)}
.owner-blog-drop-zone.has-image{border-style:solid;border-color:var(--line-strong)}
.owner-blog-drop-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:.7rem;flex:1;pointer-events:none}
.owner-blog-drop-icon{font-size:1.6rem;width:46px;height:46px;background:color-mix(in srgb,var(--bg-1) 80%,transparent);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.owner-blog-drop-title{font-family:var(--font-ui);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);text-align:center}
.owner-blog-drop-sub{font-size:.78rem;color:var(--ink-mute);text-align:center}
.owner-blog-drop-preview{display:none;flex-direction:column;flex:1}
.owner-blog-drop-bar{display:flex;align-items:center;gap:.55rem;padding:.55rem .75rem;background:color-mix(in srgb,var(--bg-2) 86%,transparent);border-top:1px solid var(--line)}
.owner-blog-drop-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;flex-shrink:0}
.owner-blog-drop-filename{font-family:var(--font-ui);font-size:.72rem;letter-spacing:.08em;color:var(--ink-soft);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.owner-blog-drop-remove{background:none;border:none;cursor:pointer;color:var(--ink-mute);font-size:1.1rem;padding:0 2px;line-height:1;display:flex;align-items:center;transition:color var(--t-fast) var(--ease-out)}
.owner-blog-drop-remove:hover{color:#ff5050}
.owner-blog-drop-note{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);text-align:center;padding:.45rem .75rem;background:color-mix(in srgb,var(--bg-2) 82%,transparent);border-top:1px solid var(--line);margin-top:auto;pointer-events:none}

/* ── Settings tab ── */
.owner-blog-settings-section{border:1px solid var(--line-strong);padding:.85rem 1rem;background:color-mix(in srgb,var(--bg-2) 72%,transparent)}
.owner-blog-settings-title{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--line)}
.owner-blog-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0}
.owner-blog-toggle-label{font-size:.9rem;color:var(--ink)}
.owner-blog-toggle-hint{font-size:.78rem;color:var(--ink-mute);margin-top:.15rem}
.owner-toggle-switch{width:40px;height:22px;-webkit-appearance:none;appearance:none;background:var(--line-strong);border-radius:11px;position:relative;cursor:pointer;flex-shrink:0;transition:background var(--t-fast) var(--ease-out)}
.owner-toggle-switch::after{content:'';position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform var(--t-fast) var(--ease-out);box-shadow:0 1px 3px rgba(0,0,0,.25)}
.owner-toggle-switch:checked{background:var(--accent)}
.owner-toggle-switch:checked::after{transform:translateX(18px)}

/* ── Block type pills ── */
.owner-block-pill{display:inline-flex;align-items:center;padding:2px 9px;border-radius:3px;font-family:var(--font-ui);font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.owner-block__head .owner-block-pill + div{margin-left:auto}
.owner-block-pill--p       {background:rgba(30,100,200,.14);color:#5080d8}
.owner-block-pill--h       {background:rgba(120,60,200,.14);color:#9060e0}
.owner-block-pill--img     {background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.owner-block-pill--video   {background:rgba(200,50,50,.13);color:#d05050}
.owner-block-pill--audio   {background:rgba(180,80,180,.13);color:#b050b0}
.owner-block-pill--embed   {background:rgba(80,80,80,.14);color:var(--ink-soft)}
.owner-block-pill--media   {background:rgba(20,140,160,.13);color:#1490a0}
.owner-block-pill--data    {background:rgba(20,160,100,.13);color:#14a060}
.owner-block-pill--layout  {background:rgba(80,80,80,.14);color:var(--ink-soft)}
.owner-block-pill--link    {background:rgba(200,120,20,.13);color:#c07014}
.owner-block-pill--note    {background:rgba(200,160,20,.13);color:#a08010}
.owner-block-pill--quote   {background:rgba(100,60,180,.14);color:#7850d0}
.owner-block-pill--list    {background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.owner-block-pill--meta    {background:rgba(80,80,80,.14);color:var(--ink-soft)}
.owner-block-pill--divider {background:rgba(200,50,50,.12);color:#cc4040}

/* ── Blog save bar ── */
.owner-blog-save-bar{display:flex !important;align-items:center;justify-content:space-between !important}
.owner-blog-save-meta{display:flex;align-items:center;gap:.55rem;font-family:var(--font-ui);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
#owner-save-dot{width:7px;height:7px;background:rgba(200,120,20,.8);border-radius:50%;flex-shrink:0;transition:background .4s ease}
.owner-save-flash{animation:saveflash .85s ease}
@keyframes saveflash{0%,100%{opacity:1}50%{opacity:.35}}



/* ============================================================================
   PROJECT/GALLERY MULTI-MEDIA VIEWER UPDATE
   Adds per-post media thumbnails and right-side suggested work cards.
   ============================================================================ */
.modal__img--embed{
  display:grid;
  place-items:center;
  background:#0F1115;
}
.modal__img--embed .post-body__video-wrap,
.modal__img--embed .post-body__video,
.modal__img--embed .post-body__audio-block,
.modal__img--embed .post-body__audio,
.modal__img--embed .post-body__embed{
  width:100%;
  height:100%;
  margin:0;
}
.modal__img--embed .post-body__iframe,
.modal__img--embed iframe{
  width:100%;
  height:100%;
  border:0;
}
.modal__img--embed .post-body__video{
  object-fit:contain;
  background:#0F1115;
}
.modal__related{
  position:absolute;
  right:clamp(1rem,2.2vw,2rem);
  top:50%;
  transform:translateY(-50%);
  z-index:6;
  width:min(230px,18vw);
  padding:0.85rem;
  background:rgba(15,17,21,0.62);
  border:1px solid var(--line);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 24px 70px -36px rgba(0,0,0,0.88);
}
.modal__related[hidden]{display:none}
.modal__related h3{
  margin:0.28rem 0 0.8rem;
  font-family:var(--font-display);
  font-size:1.15rem;
  line-height:0.95;
  font-weight:400;
  text-transform:uppercase;
  color:var(--ink);
}
.modal__related-list{display:flex;flex-direction:column;gap:0.55rem}
.modal__related-card{
  display:grid;
  grid-template-columns:58px 1fr;
  gap:0.65rem;
  align-items:center;
  width:100%;
  min-height:58px;
  padding:0.45rem;
  text-align:left;
  background:rgba(234,228,218,0.025);
  border:1px solid var(--line);
  transition:border-color 180ms var(--ease-out),background 180ms var(--ease-out),transform 180ms var(--ease-out);
}
.modal__related-card:hover,
.modal__related-card:focus-visible{
  border-color:var(--accent);
  background:rgba(236,231,75,0.10);
  transform:translateX(-3px);
  outline:none;
}
.modal__related-img{
  position:relative;
  display:block;
  width:58px;
  height:44px;
  background-size:cover;
  background-position:center;
  background-color:var(--bg-2);
  overflow:hidden;
}
.modal__related-copy strong{
  display:block;
  font-family:var(--font-ui);
  font-size:0.78rem;
  line-height:1.1;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ink);
}
.modal__related-copy em{
  display:block;
  margin-top:0.2rem;
  font-style:normal;
  font-family:var(--font-ui);
  font-size:0.62rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.modal__thumb b{
  position:absolute;
  inset:auto 4px 4px auto;
  z-index:2;
  width:18px;
  height:18px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(15,17,21,0.76);
  color:var(--accent);
  font-size:0.56rem;
  line-height:1;
}
.modal__nav[hidden]{display:none !important}

.game-detail__suggestions{
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid var(--line);
}
.game-detail__suggestions h3{
  margin:0.35rem 0 0.85rem;
  font-family:var(--font-display);
  font-size:1.25rem;
  line-height:0.95;
  font-weight:400;
  color:var(--ink);
  text-transform:uppercase;
}
.game-detail__suggestion{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:0.7rem;
  align-items:center;
  padding:0.5rem;
  margin-top:0.55rem;
  background:rgba(234,228,218,0.025);
  border:1px solid var(--line);
  transition:border-color 180ms var(--ease-out),background 180ms var(--ease-out),transform 180ms var(--ease-out);
}
.game-detail__suggestion:hover,
.game-detail__suggestion:focus-visible{
  border-color:var(--accent);
  background:rgba(236,231,75,0.08);
  transform:translateX(3px);
  outline:none;
}
.game-detail__suggestion-img{
  display:block;
  width:64px;
  height:48px;
  background-size:cover;
  background-position:center;
  background-color:var(--bg-2);
}
.game-detail__suggestion strong{
  display:block;
  font-family:var(--font-ui);
  font-size:0.82rem;
  line-height:1.1;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ink);
}
.game-detail__suggestion em{
  display:block;
  margin-top:0.22rem;
  font-style:normal;
  font-family:var(--font-ui);
  font-size:0.64rem;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--ink-mute);
}

@media (max-width:1180px){
  .modal__related{display:none}
}
@media (max-width:760px){
  .modal__thumbs{bottom:0.75rem}
  .game-detail__suggestion{grid-template-columns:56px 1fr}
  .game-detail__suggestion-img{width:56px;height:42px}
}
[data-theme="light"] .modal__related{
  background:rgba(244,246,248,0.78);
  border-color:var(--line);
}
[data-theme="light"] .modal__related-card,
[data-theme="light"] .game-detail__suggestion{
  background:rgba(30,40,50,0.035);
}


/* ============================================================================
   OWNER CMS — VISUAL MEDIA MANAGER UPDATE
   Replaces the old plain extra-images drop helper with preview cards.
   ============================================================================ */
.owner-image-panel__body {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.owner-image-pane--drop small {
  display:block;
  margin-top:0.35rem;
  color:rgba(234,228,218,0.38);
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.68rem;
  letter-spacing:0.10em;
  text-transform:uppercase;
}
.owner-image-thumb {
  min-height:180px;
  cursor:pointer;
  overflow:hidden;
  background-repeat:no-repeat;
}
.owner-image-thumb input[type="file"],
.owner-extra-media input[type="file"],
.owner-extra-card input[type="file"] {
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.owner-image-thumb.is-dragging,
.owner-extra-media__drop.is-dragging,
.owner-extra-card__preview.is-dragging {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft), var(--shadow-glow);
}
.owner-image-thumb span em,
.owner-extra-media__drop em {
  display:block;
  margin-top:0.15rem;
  color:rgba(234,228,218,0.42);
  font-style:normal;
  font-size:0.62rem;
}
.owner-image-thumb.has-non-image {
  background:linear-gradient(135deg,rgba(236,231,75,.16),rgba(0,0,0,.18)), var(--bg-2);
}
.owner-fit-row {
  display:grid;
  grid-template-columns:minmax(160px,0.35fr) minmax(190px,0.35fr) 1fr;
  gap:0.75rem;
  align-items:center;
  padding:0.85rem 1rem;
  border-top:1px solid rgba(236,231,75,0.14);
  background:rgba(0,0,0,0.14);
}
.owner-fit-row label {
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--accent);
}
.owner-fit-row select {
  width:100%;
  border:1px solid rgba(236,231,75,0.28);
  background:rgba(234,228,218,0.04);
  color:var(--ink);
  padding:0.55rem 0.7rem;
  outline:none;
}
.owner-fit-row span {
  color:rgba(234,228,218,0.48);
  font-size:0.78rem;
}
.owner-extra-media {
  border-top:1px solid rgba(236,231,75,0.18);
  padding:1rem;
  display:grid;
  gap:0.9rem;
}
.owner-extra-media__head {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}
.owner-extra-media__head strong {
  display:block;
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink);
}
.owner-extra-media__head span {
  display:block;
  margin-top:0.15rem;
  color:rgba(234,228,218,0.50);
  font-size:0.82rem;
}
.owner-extra-media__list {
  display:grid;
  gap:0.75rem;
}
.owner-extra-card {
  display:grid;
  grid-template-columns:160px 1fr;
  gap:0.75rem;
  padding:0.65rem;
  border:1px solid rgba(234,228,218,0.08);
  background:rgba(234,228,218,0.025);
}
.owner-extra-card__preview {
  min-height:104px;
  border:1px dashed rgba(236,231,75,0.26);
  background:rgba(236,231,75,0.055);
  background-position:center;
  background-repeat:no-repeat;
  display:grid;
  place-items:center;
  color:rgba(234,228,218,0.38);
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.68rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  text-align:center;
}
.owner-extra-card__preview.has-image {
  border-color:rgba(236,231,75,0.45);
}
.owner-extra-card__preview.has-image span {
  background:rgba(0,0,0,0.55);
  color:var(--ink);
  padding:0.25rem 0.45rem;
}
.owner-extra-card__preview.has-non-image {
  background:linear-gradient(135deg,rgba(236,231,75,.18),rgba(0,0,0,.18)), var(--bg-2);
}
.owner-extra-card__body {
  display:grid;
  gap:0.45rem;
  align-content:start;
}
.owner-extra-card__body label {
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.66rem;
  letter-spacing:0.20em;
  text-transform:uppercase;
  color:rgba(234,228,218,0.48);
}
.owner-extra-card__body input[type="text"] {
  width:100%;
  border:1px solid rgba(236,231,75,0.20);
  background:rgba(0,0,0,0.18);
  color:var(--ink);
  padding:0.55rem 0.7rem;
  outline:none;
}
.owner-extra-card__body input[type="text"]:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.owner-extra-card__actions {
  display:flex;
  gap:0.35rem;
  flex-wrap:wrap;
}
.owner-extra-card__actions button {
  border:1px solid rgba(234,228,218,0.12);
  color:rgba(234,228,218,0.58);
  background:rgba(234,228,218,0.04);
  padding:0.28rem 0.5rem;
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.62rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
}
.owner-extra-card__actions button:hover {
  color:var(--accent);
  border-color:var(--accent-line);
}
.owner-extra-media__drop {
  min-height:82px;
  border:1px dashed rgba(236,231,75,0.32);
  background:rgba(236,231,75,0.045);
  display:grid;
  place-items:center;
  text-align:center;
  color:rgba(234,228,218,0.42);
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:0.74rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  cursor:pointer;
  position:relative;
}
.owner-extra-media textarea[data-extra-source] {
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.modal__img {
  background-size:var(--modal-media-size, cover);
  background-repeat:no-repeat;
}
.modal__img--embed .post-body__video,
.modal__img--embed video,
.modal__img--embed img {
  object-fit:var(--media-fit, contain);
}
.work__img,
.arc-item__img,
.game-card__img,
.featured-card__img,
.modal__thumb span {
  background-repeat:no-repeat;
}
@media (max-width:760px) {
  .owner-image-panel__body,
  .owner-fit-row,
  .owner-extra-card {
    grid-template-columns:1fr;
  }
  .owner-extra-media__head {
    display:grid;
  }
}


/* ============================================================================
   OWNER CMS — MEDIA CHECKUP PATCH
   Fixes unreadable select menus and adds per-extra-image fit controls.
   ============================================================================ */
.owner-fit-row select,
.owner-extra-card__fit-row select,
.owner-field select {
  color: var(--ink) !important;
  background-color: var(--bg-2) !important;
  border-color: rgba(236,231,75,0.36) !important;
}

.owner-fit-row select option,
.owner-extra-card__fit-row select option,
.owner-field select option {
  color: #EAE4DA !important;
  background-color: #15171C !important;
}

.owner-extra-card__fit-row {
  display: grid;
  grid-template-columns: 150px minmax(180px, 260px);
  gap: 0.55rem;
  align-items: center;
}

.owner-extra-card__fit-row span {
  font-family: var(--font-ui,'Rajdhani',sans-serif);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.48);
}

.owner-extra-card__fit-row select {
  width: 100%;
  padding: 0.45rem 0.55rem;
  font-family: var(--font-ui,'Rajdhani',sans-serif);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  outline: none;
}

.owner-extra-card__fit-row select:focus,
.owner-fit-row select:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.modal__thumb span {
  background-size: inherit;
}

[data-theme="light"] .owner-fit-row select,
[data-theme="light"] .owner-extra-card__fit-row select,
[data-theme="light"] .owner-field select {
  color: var(--ink) !important;
  background-color: #F4F6F8 !important;
}

[data-theme="light"] .owner-fit-row select option,
[data-theme="light"] .owner-extra-card__fit-row select option,
[data-theme="light"] .owner-field select option {
  color: #1A1D21 !important;
  background-color: #F4F6F8 !important;
}

@media (max-width:760px) {
  .owner-extra-card__fit-row {
    grid-template-columns: 1fr;
  }
}


/* ============================================================================
   OWNER CMS — ROBUST MEDIA FINAL CHECK
   Supports long media lists, mixed image/video/audio entries, and readable thumbnails.
   ============================================================================ */
.modal__thumbs {
  max-width: min(920px, 82vw);
  scrollbar-width: thin;
  overscroll-behavior-x: contain;
}
.modal__thumb b {
  position: absolute;
  inset: auto 0.25rem 0.18rem auto;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 1.15rem;
  height: 1.15rem;
  border: 1px solid var(--accent-line);
  background: rgba(0,0,0,0.70);
  color: var(--accent-hot);
  font-size: 0.62rem;
  line-height: 1;
}
.owner-extra-card__preview.has-non-image span,
.owner-image-thumb.has-non-image span {
  background: rgba(0,0,0,0.62);
  color: var(--accent-hot);
  padding: 0.35rem 0.55rem;
  border: 1px solid rgba(236,231,75,0.24);
}
.owner-extra-media__drop span::after {
  content: "\A Images, MP4/WebM/MOV videos, audio, YouTube links, and repeated files are allowed.";
  white-space: pre-line;
  display: block;
  margin-top: 0.35rem;
  color: rgba(234,228,218,0.34);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
}
[data-theme="light"] .owner-extra-media__drop span::after {
  color: rgba(26,29,33,0.50);
}
.game-detail__thumbs {
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
}
.game-detail__media-slide .post-body__video,
.game-detail__media-slide .post-body__iframe,
.game-detail__media-slide .post-body__audio {
  width: 100%;
  height: 100%;
  max-height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
  background: #000;
  cursor: pointer;
}

/* ============================================================================
   WORK VIEWER — SIDE TOGGLE + ARTSTATION-STYLE DETAILS REFINEMENT
   ============================================================================ */
.modal__topbar {
  align-items: center;
}
.modal__counter {
  padding: 0.32rem 0.7rem;
  border: 1px solid rgba(234,228,218,0.08);
  background: rgba(15,17,21,0.34);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.modal__actions {
  padding: 0.28rem 0.55rem;
  border: 1px solid rgba(234,228,218,0.08);
  background: rgba(15,17,21,0.30);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.modal__related-toggle {
  position: absolute;
  /* Moved to bottom-right — no longer overlaps the nav arrows */
  bottom: clamp(1rem, 2.5vw, 1.6rem);
  right: clamp(1rem, 2.5vw, 1.6rem);
  top: auto;
  z-index: 8;
  transform: none;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 44px;
  padding: 0.62rem 0.82rem;
  border: 1px solid var(--line-strong);
  background: rgba(15,17,21,0.72);
  color: var(--ink);
  font-family: var(--font-ui);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  box-shadow: 0 18px 52px -28px rgba(0,0,0,0.88);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: right 360ms var(--ease-out), border-color 180ms var(--ease-out), color 180ms var(--ease-out), background 180ms var(--ease-out), transform 360ms var(--ease-out);
}
.modal__related-toggle[hidden] { display: none !important; }
.modal__related-toggle:hover,
.modal__related-toggle:focus-visible {
  border-color: var(--accent);
  color: var(--accent-hot);
  outline: none;
}
.modal__related-toggle b {
  color: var(--accent);
  font-size: 1rem;
  letter-spacing: 0;
  transition: transform 280ms var(--ease-out);
}
.modal.related-open .modal__related-toggle {
  right: calc(clamp(1rem,2.2vw,2rem) + min(280px, 20vw) + 0.75rem);
}
.modal.related-loading .modal__related-toggle::before {
  content: "";
  width: 0.62rem;
  height: 0.62rem;
  border: 1px solid var(--accent-line);
  border-top-color: var(--accent-hot);
  border-radius: 50%;
  animation: modalRelatedSpin 700ms linear infinite;
}
@keyframes modalRelatedSpin { to { transform: rotate(360deg); } }
.modal__related {
  width: min(280px,20vw);
  transform: translate(118%, -50%);
  opacity: 0;
  pointer-events: none;
  transition: transform 420ms var(--ease-out), opacity 280ms var(--ease-out), box-shadow 280ms var(--ease-out);
}
.modal.related-open .modal__related {
  transform: translate(0, -50%);
  opacity: 1;
  pointer-events: auto;
}
.modal.related-open .modal__related-card { animation: modalRelatedCardIn 420ms var(--ease-out) both; }
.modal.related-open .modal__related-card:nth-child(2) { animation-delay: 55ms; }
.modal.related-open .modal__related-card:nth-child(3) { animation-delay: 110ms; }
@keyframes modalRelatedCardIn {
  from { opacity: 0; transform: translateX(16px); }
  to { opacity: 1; transform: translateX(0); }
}
.modal__thumbs {
  bottom: 1.15rem;
  gap: 0.62rem;
  max-width: min(1040px, 84vw);
  padding: 0.48rem;
  background: rgba(0,0,0,0.42);
}
.modal__thumb {
  width: 88px;
  height: 58px;
  border-color: rgba(234,228,218,0.18);
  opacity: 0.68;
}
.modal__thumb.is-active,
.modal__thumb:hover {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px rgba(236,231,75,0.20), 0 10px 28px -18px rgba(236,231,75,0.80);
}
.modal-details__head--showcase {
  max-width: 1280px;
  margin-inline: auto;
  padding-bottom: 1.15rem;
  border-bottom: 1px solid var(--line);
}
.modal-details__head--showcase h2 {
  margin-top: 0.45rem;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.4vw, 4.2rem);
  line-height: 0.9;
  text-transform: uppercase;
  color: var(--ink);
}
.modal-details__head--showcase .dot { color: var(--accent); }
.modal-details__head--showcase p {
  margin-top: 0.8rem;
  max-width: 76ch;
  color: var(--ink-soft);
  line-height: 1.7;
}
.modal-details__grid--showcase {
  grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.75fr);
}
.modal-details__description-card,
.modal-details__meta-card,
.modal-details__software-card,
.modal-details__tags-card {
  border: 1px solid var(--line);
  background: linear-gradient(135deg, rgba(234,228,218,0.045), rgba(234,228,218,0.015));
  padding: clamp(1rem, 2vw, 1.35rem);
  box-shadow: 0 18px 50px -42px rgba(0,0,0,0.85);
}
.modal-details__description-card .modal-details__text {
  max-width: 82ch;
  font-size: clamp(1rem, 1.15vw, 1.12rem);
  line-height: 1.86;
  color: var(--ink-soft);
}
.software-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.58rem;
}
.software-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.42rem 0.58rem 0.42rem 0.44rem;
  border: 1px solid color-mix(in srgb, var(--sw-color) 45%, transparent);
  background: color-mix(in srgb, var(--sw-color) 12%, transparent);
  color: var(--ink);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.025);
}
.software-badge__icon {
  width: 1.6rem;
  height: 1.6rem;
  display: grid;
  place-items: center;
  border-radius: 0.28rem;
  background: var(--sw-color);
  color: #0F1115;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: none;
}
.software-badge__name {
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
[data-theme="light"] .modal__counter,
[data-theme="light"] .modal__actions,
[data-theme="light"] .modal__related-toggle {
  background: rgba(244,246,248,0.78);
  border-color: rgba(30,40,50,0.14);
}
[data-theme="light"] .modal__thumbs {
  background: rgba(244,246,248,0.62);
  border-color: rgba(30,40,50,0.14);
}
[data-theme="light"] .modal-details__description-card,
[data-theme="light"] .modal-details__meta-card,
[data-theme="light"] .modal-details__software-card,
[data-theme="light"] .modal-details__tags-card {
  background: linear-gradient(135deg, rgba(30,40,50,0.055), rgba(30,40,50,0.018));
}
[data-theme="light"] .software-badge__icon { color: #101216; }
@media (max-width:1180px) {
  .modal__related-toggle,
  .modal__related { display: none !important; }
}
@media (max-width:760px) {
  .modal__thumb { width: 74px; height: 50px; }
  .modal__thumbs { max-width: 92vw; bottom: 0.75rem; }
  .modal-details__grid--showcase { grid-template-columns: 1fr; }
}

/* === Final viewer/upload stability patch === */
.owner-extra-media.is-processing,
.owner-image-panel.is-processing {
  cursor: progress;
}
.owner-extra-media.is-processing .owner-extra-media__drop {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent-line), 0 0 26px -12px var(--accent);
}
.modal__nav.is-disabled {
  opacity: 0.24;
  pointer-events: none;
  filter: grayscale(1);
}
.modal__nav.is-disabled svg {
  filter: none;
}
.software-badge__icon {
  background-color: color-mix(in srgb, var(--sw-color) 88%, #111 12%);
  background-image: var(--sw-icon);
  background-size: 72% 72%;
  background-position: center;
  background-repeat: no-repeat;
  border: 1px solid color-mix(in srgb, var(--sw-color) 50%, transparent);
}
.software-badge__icon span {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: #0F1115;
  text-shadow: 0 1px 8px rgba(255,255,255,0.28);
}
.software-badge[style*="--sw-icon"] .software-badge__icon span {
  opacity: 0;
}
.software-badge {
  border-radius: 0.35rem;
}
.modal__img--embed img,
.modal__img--embed video,
.modal__img--embed iframe,
.modal__img--embed audio {
  width: 100%;
  height: 100%;
  object-fit: var(--media-fit, contain);
}
.modal__img--embed audio {
  height: auto;
  align-self: center;
  margin: auto;
}
[data-theme="light"] .software-badge__icon {
  background-color: color-mix(in srgb, var(--sw-color) 78%, #fff 22%);
}

/* === Full check: blog Lego media + stronger software icons === */
.software-badge {
  background: linear-gradient(135deg, color-mix(in srgb, var(--bg-2) 88%, transparent), color-mix(in srgb, var(--sw-color) 8%, transparent)) !important;
  border-color: color-mix(in srgb, var(--sw-color) 58%, var(--line)) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.025), 0 10px 28px -20px var(--sw-color);
}
.software-badge__icon {
  background-color: #11151b !important;
  background-image: var(--sw-icon), radial-gradient(circle at 70% 25%, color-mix(in srgb, var(--sw-color) 30%, transparent), transparent 52%) !important;
  background-size: 70% 70%, cover !important;
  border: 1px solid color-mix(in srgb, var(--sw-color) 72%, rgba(255,255,255,0.12)) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08), 0 0 18px -8px var(--sw-color);
}
.software-badge__icon span {
  color: #fff !important;
  text-shadow: 0 1px 8px rgba(0,0,0,0.75) !important;
}
.software-badge__name { color: var(--ink); }
[data-theme="light"] .software-badge {
  background: linear-gradient(135deg, rgba(255,255,255,0.72), color-mix(in srgb, var(--sw-color) 10%, transparent)) !important;
}
[data-theme="light"] .software-badge__icon { background-color: #11151b !important; }
.owner-block-fit-label { display: grid; gap: .28rem; margin: .45rem 0; }
.owner-block-fit-label > span { font-family: var(--font-ui); font-size: .65rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.owner-block-fit-select { min-height: 36px; color: var(--ink) !important; background: color-mix(in srgb, var(--bg-1) 88%, transparent) !important; }
.owner-block-fit-select option { background: var(--bg-1) !important; color: var(--ink) !important; }
.owner-block-image-preview[data-fit="contain"] { background-size: contain !important; background-repeat: no-repeat; background-position: center; }
.owner-block-image-preview[data-fit="cover"] { background-size: cover !important; background-repeat: no-repeat; background-position: center; }
.owner-block-image-preview[data-fit="auto"] { background-size: auto !important; background-repeat: no-repeat; background-position: center; }
.owner-block-image-preview[data-fit="stretch"] { background-size: 100% 100% !important; background-repeat: no-repeat; background-position: center; }
.post-body__img[data-fit="contain"] { background-size: contain !important; background-repeat: no-repeat; background-position: center; }
.post-body__img[data-fit="cover"] { background-size: cover !important; background-repeat: no-repeat; background-position: center; }
.post-body__img[data-fit="auto"] { background-size: auto !important; background-repeat: no-repeat; background-position: center; }
.post-body__img[data-fit="stretch"] { background-size: 100% 100% !important; background-repeat: no-repeat; background-position: center; }
.post-body__video, .post-body__video-wrap iframe, .post-body__media-text-media video, .post-body__media-text-media img { object-fit: var(--media-fit, contain); }
.owner-blog-drop-zone.is-processing, .owner-block-image-drop.is-processing { cursor: progress; border-color: var(--accent) !important; box-shadow: inset 0 0 0 1px var(--accent-line), 0 0 26px -12px var(--accent); }

/* === Gallery software + homepage typewriter patch === */
.hero-typewriter {
  display: flex;
  align-items: center;
  width: min(100%, var(--typewriter-reserved-width, clamp(15rem, 25vw, 23rem)));
  min-width: min(100%, var(--typewriter-reserved-width, clamp(15rem, 25vw, 23rem)));
  min-height: 1.35em;
  height: 1.35em;
  line-height: 1.12;
  white-space: nowrap;
  overflow: hidden;
}
.hero-typewriter__label { display: inline-block; min-width: 0; }
.hero-typewriter__cursor {
  display: inline-block;
  width: 0.12em;
  height: 1em;
  margin-left: 0.36em;
  background: var(--accent);
  box-shadow: 0 0 14px -4px var(--accent);
  transform: translateY(0.08em);
  animation: heroTypeCursor 920ms steps(1, end) infinite;
}
.hero-typewriter.is-static {
  display: block;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100%;
  overflow: visible !important;
  white-space: normal !important;
  height: auto !important;
  min-height: 0 !important;
}
@keyframes heroTypeCursor { 0%, 48% { opacity: 1; } 49%, 100% { opacity: 0; } }
.arc-item__software {
  display: block;
  margin-top: 0.34rem;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-ui);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(234,228,218,0.76);
}
.software-badge--has-icon .software-badge__icon {
  background-color: #10151c !important;
  background-image: var(--sw-icon), radial-gradient(circle at 72% 22%, color-mix(in srgb, var(--sw-color) 22%, transparent), transparent 54%) !important;
  background-size: 68% 68%, cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}
.software-badge--has-icon .software-badge__icon span { opacity: 0; }
[data-theme="light"] .arc-item__software { color: rgba(26,29,33,0.68); }
[data-motion="reduced"] .hero-typewriter__cursor { display: none !important; animation: none !important; }

/* === Animation toggle: static text + full-size portfolio/gallery fixes === */

/* Ensure static typewriter text is fully visible */
[data-motion="reduced"] .hero-typewriter.is-static {
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: visible !important;
  white-space: normal !important;
  height: auto !important;
  min-height: 0 !important;
  contain: none !important;
}

/* Portfolio and Gallery: keep cards full size, images filling their frames */
[data-motion="reduced"] .work {
  aspect-ratio: 16 / 11;
  height: auto !important;
  min-height: 0 !important;
}
[data-motion="reduced"] .work:nth-child(5n+2) { aspect-ratio: 1 / 1.05 !important; }
[data-motion="reduced"] .work__img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  transform: none !important;
}
[data-motion="reduced"] .arc-item {
  height: auto !important;
  min-height: 0 !important;
}
[data-motion="reduced"] .arc-item__img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  transform: none !important;
}
/* Ensure gallery/portfolio content labels show without hover requirement */
[data-motion="reduced"] .arc-item__content {
  opacity: 1 !important;
  transform: none !important;
}
[data-motion="reduced"] .work__meta {
  opacity: 1 !important;
  transform: none !important;
}
[data-motion="reduced"] .work__metaLine {
  opacity: 1 !important;
  max-height: 2rem !important;
}



/* === Patch: stable typewriter row + resilient software app icons === */
.hero-typewriter:not(.is-static) { contain: layout paint; }
.software-badge__icon { position: relative; overflow: hidden; }
.software-badge__img {
  position: absolute;
  inset: 16%;
  width: 68%;
  height: 68%;
  object-fit: contain;
  z-index: 2;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.45));
}
.software-badge__fallback {
  position: relative;
  z-index: 1;
  opacity: 1 !important;
}
.software-badge__fallback.is-visible { opacity: 1 !important; }
.software-badge--has-icon .software-badge__icon span.software-badge__fallback { opacity: 1 !important; }
.software-badge--has-icon .software-badge__icon {
  background-color: #10151c !important;
  background-image: radial-gradient(circle at 72% 22%, color-mix(in srgb, var(--sw-color) 20%, transparent), transparent 54%) !important;
  background-size: cover !important;
}
[data-theme="light"] .software-badge--has-icon .software-badge__icon { background-color: #10151c !important; }


/* === blog header spacing — consolidated (patch moved to single block below) === */

.software-badge__icon,
.owner-tool-chip__icon {
  background-color: #10151c !important;
  background-image: radial-gradient(circle at 72% 22%, color-mix(in srgb, var(--sw-color, var(--tool-color, var(--accent))) 18%, transparent), transparent 55%) !important;
  border-color: color-mix(in srgb, var(--sw-color, var(--tool-color, var(--accent))) 70%, rgba(255,255,255,.12)) !important;
  overflow: hidden;
}
.software-badge__img,
.owner-tool-icon-img {
  display: block !important;
  position: absolute;
  inset: 12%;
  width: 76%;
  height: 76%;
  object-fit: contain;
  background: transparent !important;
  z-index: 3;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.45));
}
.software-badge__fallback,
.owner-tool-icon-fallback {
  position: relative;
  z-index: 1;
  opacity: 0;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
}
.software-badge__fallback.is-visible,
.owner-tool-icon-fallback.is-visible { opacity: 1 !important; }
.software-badge--has-icon .software-badge__fallback:not(.is-visible) { opacity: 0 !important; }
.post__tools--badges { list-style: none; margin: 0; padding: 0; }
.post__tools--badges .software-badges { display: flex; flex-wrap: wrap; gap: .5rem; }

/* Owner CMS software Lego picker with transparent local logos */
.owner-field--tool-picker { display:block !important; grid-column:span 2; }
.owner-field--tool-picker > input[name="tools"] { display:none !important; }
.owner-tool-picker {
  margin-top:.65rem;
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(234,228,218,0.045), rgba(234,228,218,0.015));
  padding:clamp(.8rem,1.8vw,1.1rem);
}
.owner-tool-picker__head { display:flex; justify-content:space-between; gap:1rem; align-items:start; margin-bottom:.8rem; }
.owner-tool-picker__head strong { display:block; font-family:var(--font-ui); font-size:.82rem; letter-spacing:.24em; text-transform:uppercase; color:var(--ink); }
.owner-tool-picker__head span { display:block; margin-top:.25rem; color:var(--ink-mute); font-size:.86rem; }
.owner-tool-picker__head input { min-width:210px; background:rgba(8,8,10,.42); border:1px solid var(--line-strong); color:var(--ink); padding:.55rem .75rem; outline:none; }
.owner-tool-picker__head input:focus { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent-line); }
.owner-tool-picker__selected { min-height:74px; display:flex; flex-wrap:wrap; align-items:center; gap:.55rem; padding:.65rem; margin-bottom:.85rem; border:1px dashed var(--accent-line); background:rgba(146,92,61,.055); }
.owner-tool-picker__selected.is-dragging { background:rgba(146,92,61,.12); box-shadow:inset 0 0 0 1px var(--accent); }
.owner-tool-empty { font-family:var(--font-ui); letter-spacing:.2em; text-transform:uppercase; color:var(--ink-mute); font-size:.72rem; }
.owner-tool-picker__grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:.58rem; max-height:360px; overflow:auto; padding-right:.2rem; }
.owner-tool-chip,
.owner-tool-selected { display:flex; align-items:center; gap:.7rem; min-height:56px; padding:.55rem .72rem; border:1px solid color-mix(in srgb, var(--tool-color) 42%, var(--line)); background:linear-gradient(135deg, rgba(20,22,27,.86), color-mix(in srgb, var(--tool-color) 10%, rgba(20,22,27,.86))); color:var(--ink); text-align:left; transition:transform var(--t-fast) var(--ease-out),border-color var(--t-fast) var(--ease-out),background var(--t-fast) var(--ease-out); }
.owner-tool-chip:hover,
.owner-tool-chip.is-selected { transform:translateY(-1px); border-color:color-mix(in srgb, var(--tool-color) 74%, var(--accent)); background:linear-gradient(135deg, rgba(20,22,27,.92), color-mix(in srgb, var(--tool-color) 18%, rgba(20,22,27,.92))); }
.owner-tool-chip__icon { flex:0 0 36px; width:36px; height:36px; position:relative; display:grid; place-items:center; border-radius:.45rem; border:1px solid color-mix(in srgb, var(--tool-color) 70%, rgba(255,255,255,.12)); color:#fff; font-family:var(--font-ui); font-weight:900; font-size:.72rem; letter-spacing:.03em; text-shadow:0 1px 8px rgba(0,0,0,.82); background:#10151c; overflow:hidden; }
.owner-tool-chip em,
.owner-tool-selected em { font-style:normal; font-family:var(--font-ui); font-weight:800; font-size:.75rem; letter-spacing:.13em; text-transform:uppercase; line-height:1.08; }
.owner-tool-selected { min-height:46px; padding:.44rem .54rem; }
.owner-tool-selected b { margin-left:.15rem; color:var(--ink-mute); font-size:1rem; }
.owner-tool-selected:hover b { color:var(--accent); }
[data-theme="light"] .owner-tool-picker { background:linear-gradient(135deg, rgba(255,255,255,.62), rgba(30,40,50,.035)); }
[data-theme="light"] .owner-tool-chip,
[data-theme="light"] .owner-tool-selected { background:linear-gradient(135deg, rgba(255,255,255,.74), color-mix(in srgb, var(--tool-color) 10%, rgba(255,255,255,.74))); }
[data-theme="light"] .owner-tool-picker__head input { background:rgba(255,255,255,.72); color:var(--ink); }
@media (max-width:720px) { .owner-tool-picker__head{display:block;} .owner-tool-picker__head input{width:100%;min-width:0;margin-top:.7rem;} .owner-tool-picker__grid{grid-template-columns:1fr;} }

/* ============================================================================
   FINAL BRAND + BLOG POLISH PATCH
   Keeps previous CMS/software fixes, updates the header logo and blog spacing.
   ============================================================================ */
:root{
  --accent:#925c3d;
  --accent-btn:#925c3d;
  --accent-hot:#b98261;
  --accent-deep:#5f3828;
  --accent-soft:rgba(146,92,61,0.14);
  --accent-line:rgba(146,92,61,0.46);
  --glow-right:rgba(146,92,61,0.18);
  --shadow-glow:0 0 0 1px var(--accent-line),0 0 32px -4px rgba(146,92,61,0.30);
}
.brand__logo{
  width:42px;
  height:42px;
  border-color:var(--accent) !important;
  background-color:rgba(146,92,61,0.10) !important;
  background-image:url("../assets/ok-brand-icon.png") !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:auto 96% !important;
  color:transparent !important;
  font-size:0 !important;
  line-height:0 !important;
  text-indent:-9999px;
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(146,92,61,0.08),0 0 18px -10px rgba(146,92,61,0.75);
}
.brand__logo::before,.brand__logo::after{border-color:var(--accent) !important;}
.brand__role{color:rgba(234,228,218,0.68) !important;font-weight:700;letter-spacing:0.34em;}
[data-theme="light"] .brand__role{color:rgba(26,29,33,0.58) !important;}
.page-blog .blog-head,.blog-head{padding-top:calc(var(--header-h) + 4.55rem);padding-bottom:2.45rem;gap:2.4rem;overflow:visible;}
.page-blog .blog-head__title,.blog-head__title{padding-left:3.35rem;}
.page-blog .blog-head .title-xl,.blog-head .title-xl{font-size:clamp(3.55rem,7.6vw,5.9rem);line-height:0.86;}
.blog-head__title p{font-weight:500;color:rgba(234,228,218,0.70);max-width:42rem;}
[data-theme="light"] .blog-head__title p{color:rgba(26,29,33,0.64);}
.blog-head__updated .date{font-size:clamp(1.35rem,2.05vw,1.95rem);}
.blog-head__decor{top:calc(var(--header-h) + 4.95rem);}
.blog-head__decor span{height:68px;}
@media (max-width:1024px){.page-blog .blog-head,.blog-head{padding-top:calc(var(--header-h) + 4.6rem);}.page-blog .blog-head__title,.blog-head__title{padding-left:3.4rem;}}
@media (max-width:720px){.page-blog .blog-head__title,.blog-head__title{padding-left:2.1rem;}.page-blog .blog-head__decor,.blog-head__decor{display:none;}}
.blog-list{padding-top:1.15rem;}
.blog-row{grid-template-columns:minmax(220px,252px) 1fr;gap:clamp(1.35rem,2.55vw,2.45rem);padding:1.55rem 1.1rem;margin-bottom:0.95rem;border:1px solid rgba(234,228,218,0.08);background:linear-gradient(90deg,rgba(255,255,255,0.018),rgba(255,255,255,0.006));}
.blog-row:hover{padding-left:1.45rem;}
/* blog-row__thumb max-width removed: the grid column already constrains width */
.blog-row__meta{font-weight:800;color:rgba(234,228,218,0.70);text-shadow:0 1px 0 rgba(0,0,0,0.35);}
.blog-row__cat{font-weight:900;color:var(--accent-hot);}
.blog-row__date{font-weight:800;color:rgba(234,228,218,0.66);}
.blog-row__title{font-size:clamp(1.22rem,2.15vw,1.9rem);}
.blog-row__excerpt{font-weight:500;color:rgba(234,228,218,0.66);}
.blog-row__tags span{font-size:0.66rem;font-weight:850;letter-spacing:0.18em;color:rgba(234,228,218,0.84);border-color:rgba(146,92,61,0.58);background:rgba(20,18,18,0.86);text-shadow:0 1px 0 rgba(0,0,0,0.35);}
.blog-row__tags span:first-child{background:var(--accent);color:#140b07;border-color:var(--accent);font-weight:900;}
[data-theme="light"] .blog-row{border-color:rgba(30,40,50,0.12);background:linear-gradient(90deg,rgba(255,255,255,0.42),rgba(255,255,255,0.22));}
[data-theme="light"] .blog-row__meta{color:rgba(26,29,33,0.64);text-shadow:none;}
[data-theme="light"] .blog-row__cat{color:var(--accent-deep);}
[data-theme="light"] .blog-row__date{color:rgba(26,29,33,0.55);}
[data-theme="light"] .blog-row__excerpt{color:rgba(26,29,33,0.66);}
[data-theme="light"] .blog-row__tags span{color:rgba(26,29,33,0.78);background:rgba(255,255,255,0.82);text-shadow:none;}
[data-theme="light"] .blog-row__tags span:first-child{background:var(--accent);color:#fff;}
@media (max-width:760px){.page-blog .blog-head,.blog-head{padding-top:calc(var(--header-h) + 2.4rem);grid-template-columns:1fr;}.page-blog .blog-head__title,.blog-head__title{padding-left:2.1rem;}.blog-row{grid-template-columns:1fr;padding:1.25rem;}.blog-row__thumb{max-width:none;width:100%;}.blog-row__tags{position:static;justify-content:flex-start;margin-top:0.9rem;max-width:100%;}}

/* ============================================================================
   VIDEO THUMBNAILS — image-safe card support
   Muted video thumbnails stay paused until the card is hovered or focused.
   ============================================================================ */
.has-video-thumb {
  background-image: none !important;
}
.card-video-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  pointer-events: none;
  background: var(--bg-2);
}
[data-motion="reduced"] .card-video-thumb {
  animation: none !important;
}

/* Owner CMS video previews */
.owner-image-thumb,
.owner-mgr-card__thumb {
  position: relative;
  overflow: hidden;
}
.owner-thumb-vid-preview,
.owner-blog-drop-vid,
.owner-mgr-card__video,
.owner-extra-card__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  pointer-events: none;
  background: var(--bg-2);
}
.owner-mgr-card__thumb.has-video {
  background-image: none !important;
}
.owner-mgr-card__thumb.has-video .owner-mgr-card__type,
.owner-mgr-card__thumb.has-video .owner-mgr-card__status {
  position: relative;
  z-index: 2;
}


/* CMS video upload preview stability */
.owner-extra-card__preview.has-video {
  position: relative;
  overflow: hidden;
  background-image: none !important;
}
.owner-extra-card__preview.has-video span,
.owner-image-thumb.has-image span {
  position: relative;
  z-index: 2;
}
.owner-extra-card__video {
  z-index: 1;
}
.owner-extra-card__preview.has-video::after,
.owner-image-thumb .owner-thumb-vid-preview + span::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.48));
  pointer-events: none;
  z-index: 1;
}

/* ============================================================================
   OWNER CMS HOTFIX — software picker overlap + video media fit labels
   Keeps existing UI, only prevents sticky footer overlap and makes video fit consistent.
   ============================================================================ */
.owner-cms-form {
  padding-bottom: calc(clamp(1rem, 2.4vw, 1.5rem) + 6.5rem) !important;
}
.owner-cms-form__footer {
  bottom: 0 !important;
  z-index: 60 !important;
  margin-bottom: calc(-1 * clamp(1rem, 2.4vw, 1.5rem)) !important;
}
.owner-field--tool-picker {
  margin-bottom: 1.25rem;
}
.owner-tool-picker {
  overflow: hidden;
}
.owner-tool-picker__grid {
  max-height: min(300px, 36vh) !important;
  padding-bottom: .85rem;
  scrollbar-gutter: stable;
}
.owner-tool-picker__selected {
  overflow: auto;
  max-height: 128px;
}
.owner-image-thumb .owner-thumb-vid-preview,
.owner-extra-card__preview .owner-extra-card__video,
.card-video-thumb {
  object-fit: var(--media-fit, cover);
}
.modal__img--embed .post-body__video {
  object-fit: var(--media-fit, contain);
}
.owner-image-thumb[data-media-fit="contain"] .owner-thumb-vid-preview,
.owner-extra-card__preview[data-media-fit="contain"] .owner-extra-card__video {
  object-fit: contain !important;
}
.owner-image-thumb[data-media-fit="auto"] .owner-thumb-vid-preview,
.owner-extra-card__preview[data-media-fit="auto"] .owner-extra-card__video {
  object-fit: scale-down !important;
}
.owner-image-thumb[data-media-fit="stretch"] .owner-thumb-vid-preview,
.owner-extra-card__preview[data-media-fit="stretch"] .owner-extra-card__video {
  object-fit: fill !important;
}
.owner-image-thumb.has-image span,
.owner-extra-card__preview.has-video span {
  display: inline-block !important;
  position: relative;
  z-index: 3;
  background: rgba(0,0,0,.52);
  color: var(--ink);
  padding: .32rem .5rem;
}
.owner-image-thumb.has-image .owner-thumb-vid-preview + span,
.owner-extra-card__preview.has-video span {
  border: 1px solid rgba(234,228,218,.12);
}
.owner-fit-row label::after {
  content: "";
}

/* Owner Mode clean control groups */
.owner-admin-bar--clean{
  max-width:min(98vw,1180px);
  align-items:stretch;
  gap:0.65rem;
  padding:0.65rem;
}
.owner-admin-bar--clean>strong{
  display:flex;
  align-items:center;
  padding-inline:0.85rem;
  border-right:1px solid var(--line-strong);
}
.owner-admin-group{
  display:flex;
  align-items:center;
  gap:0.35rem;
  padding:0.35rem;
  border:1px solid color-mix(in srgb,var(--line-strong) 72%,transparent);
  background:color-mix(in srgb,var(--bg-0) 36%,transparent);
}
.owner-admin-group>span{
  padding:0 0.55rem;
  color:var(--ink-mute);
  font-family:var(--font-ui);
  font-size:0.62rem;
  font-weight:700;
  letter-spacing:0.24em;
  text-transform:uppercase;
  white-space:nowrap;
}
.owner-admin-bar--clean .owner-admin-group button{
  white-space:nowrap;
  padding:0.55rem 0.72rem;
}
.owner-admin-group--session button{
  border-color:var(--accent-line);
}
@media (max-width:980px){
  .owner-admin-bar--clean{align-items:center;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;left:0.75rem;right:0.75rem;transform:none;max-width:none;}
  .owner-admin-bar--clean>strong{border-right:0;min-width:max-content;}
  .owner-admin-group{min-width:max-content;}
}

/* ============================================================================
   OWNER CMS HOTFIX V4 — modal body/footer separation + shared video cards
   This keeps the current style but makes the CMS modal structure explicit:
   header / scrollable body / footer.
   ============================================================================ */
.owner-cms-modal__panel {
  height: min(88vh, 900px);
  max-height: min(88vh, 900px);
}
.owner-cms-form {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden !important;
  padding: 0 !important;
}
.owner-cms-form__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  padding: clamp(1rem, 2.4vw, 1.5rem);
  padding-bottom: 2rem;
  scrollbar-gutter: stable;
}
.owner-cms-form__footer {
  position: static !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  flex: 0 0 auto;
  margin: 0 !important;
  padding: 1rem clamp(1rem, 2.4vw, 1.5rem) !important;
  border-top: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 96%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 70 !important;
}
.owner-cms-form > .owner-blog-form {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.owner-blog-form > .owner-blog-panel.active {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
}
.owner-blog-form > .owner-cms-form__footer {
  flex-shrink: 0;
}
.work__img.has-video-thumb,
.arc-item__img.has-video-thumb,
.blog-row__thumb-img.has-video-thumb,
.game-card__img.has-video-thumb,
.featured-card__img.has-video-thumb {
  background-image: none !important;
  background-color: var(--bg-3);
  /* Lift out of negative z-index so the video element is visible */
  z-index: 0;
  /* Remove the scale transform so it doesn't create a stacking context
     that fights with the parent's isolation:isolate; the video handles
     its own rendering */
  transform: none;
}
.work__img.has-video-thumb .card-video-thumb,
.arc-item__img.has-video-thumb .card-video-thumb,
.blog-row__thumb-img.has-video-thumb .card-video-thumb,
.game-card__img.has-video-thumb .card-video-thumb,
.featured-card__img.has-video-thumb .card-video-thumb {
  opacity: 1;
  visibility: visible;
  z-index: 0;
}
/* Keep hover-scale on the video itself when parent had it */
.work:hover .work__img.has-video-thumb .card-video-thumb,
.arc-item:hover .arc-item__img.has-video-thumb .card-video-thumb {
  transform: scale(1.12);
  transition: transform 1.6s var(--ease-out);
}
/* Blog thumb container already has overflow:hidden, video is inside .blog-row__thumb-img */
.blog-row__thumb-img.has-video-thumb {
  transform: none;
}
.blog-row:hover .blog-row__thumb-img.has-video-thumb .card-video-thumb {
  transform: scale(1.12);
  transition: transform 1.4s var(--ease-out);
}
.owner-cms-form__body .owner-tool-picker__grid {
  max-height: min(300px, 36vh) !important;
}
@media (max-width: 760px) {
  .owner-cms-modal__panel {
    height: calc(100dvh - 1.5rem);
    max-height: calc(100dvh - 1.5rem);
  }
  .owner-cms-form__body {
    padding: 1rem;
  }
  .owner-cms-form__footer {
    padding-inline: 1rem !important;
    flex-wrap: wrap;
  }
}

/* ============================================================================
   OWNER CMS HOTFIX V5 — add Gallery action + collapsible Owner controls
   Keeps the existing style. The Owner bar can collapse into a small bottom tab
   so it does not cover the page while reviewing work.
   ============================================================================ */
.owner-admin-collapse {
  flex: 0 0 auto;
  border-color: var(--accent-line) !important;
  color: var(--accent) !important;
  background: color-mix(in srgb, var(--accent-soft) 68%, transparent) !important;
}
.owner-admin-bar.is-collapsed {
  left: 50% !important;
  right: auto !important;
  bottom: max(0.45rem, env(safe-area-inset-bottom)) !important;
  width: auto !important;
  max-width: max-content !important;
  min-width: 0 !important;
  padding: 0.35rem !important;
  gap: 0 !important;
  transform: translateX(-50%) !important;
  overflow: visible !important;
  border-color: var(--accent-line);
  background: color-mix(in srgb, var(--bg-2) 94%, transparent);
}
.owner-admin-bar.is-collapsed > strong,
.owner-admin-bar.is-collapsed .owner-admin-group,
.owner-admin-bar.is-collapsed #owner-import-file {
  display: none !important;
}
.owner-admin-bar.is-collapsed .owner-admin-collapse {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  min-height: 36px;
  padding: 0.55rem 0.9rem !important;
  white-space: nowrap;
}
.owner-admin-bar.is-collapsed .owner-admin-collapse:hover,
.owner-admin-bar.is-collapsed .owner-admin-collapse:focus-visible {
  transform: translateY(-1px);
  outline: none;
}
@media (max-width: 760px) {
  .owner-admin-bar.is-collapsed {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
  }
  .owner-admin-bar.is-collapsed .owner-admin-collapse {
    min-width: 138px;
  }
}

/* ============================================================================
   VIDEO CARD THUMBNAILS V3 — shared outside-card media layer
   Portfolio / Gallery / Blog now mount videos like Games without changing layout.
   ============================================================================ */
.card-video-thumb {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  display: block !important;
  object-fit: cover;
  object-position: center center;
  pointer-events: none !important;
  border: 0 !important;
  background: transparent !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.has-video-thumb,
.has-card-video-thumb {
  background-image: none !important;
}

.work.has-card-video-thumb,
.arc-item.has-card-video-thumb,
.blog-row__thumb.has-card-video-thumb,
.game-card__img.has-card-video-thumb,
.featured-card__img.has-card-video-thumb {
  position: relative;
  overflow: hidden;
  background-color: var(--bg-2);
}

/* Keep the old background div present for layout, but do not let it hide the video. */
.work.has-card-video-thumb .work__img.has-video-thumb,
.arc-item.has-card-video-thumb .arc-item__img.has-video-thumb,
.blog-row__thumb.has-card-video-thumb .blog-row__thumb-img.has-video-thumb {
  background-image: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

/* Portfolio / Gallery: video is mounted directly on the card because the old image layer uses z-index:-2. */
.work.has-card-video-thumb > .card-video-thumb,
.arc-item.has-card-video-thumb > .card-video-thumb {
  z-index: 0 !important;
  transform-origin: center center;
  transition: transform 1.6s var(--ease-out), filter var(--t-med) var(--ease-out);
}

.work.has-card-video-thumb > .card-video-thumb {
  transform: scale(1.04);
}

.arc-item.has-card-video-thumb > .card-video-thumb {
  transform: scale(1.05);
}

.work.has-card-video-thumb:hover > .card-video-thumb {
  transform: scale(1.12);
  filter: brightness(1.1) saturate(1.05);
}

.arc-item.has-card-video-thumb:hover > .card-video-thumb {
  transform: scale(1.16);
  filter: brightness(0.7);
}

/* Put existing overlays/text back above the new video layer. */
.work.has-card-video-thumb .work__overlay,
.arc-item.has-card-video-thumb .arc-item__overlay {
  z-index: 1 !important;
}

.work.has-card-video-thumb .work__content,
.work.has-card-video-thumb .work__line,
.arc-item.has-card-video-thumb .arc-item__content {
  position: relative;
  z-index: 2 !important;
}

/* Blog: video is mounted inside the existing thumbnail box. */
.blog-row__thumb.has-card-video-thumb > .card-video-thumb {
  z-index: 0 !important;
  transform: scale(1.03);
  transform-origin: center center;
  transition: transform 1.4s var(--ease-out), filter var(--t-med) var(--ease-out);
}

.blog-row:hover .blog-row__thumb.has-card-video-thumb > .card-video-thumb {
  transform: scale(1.12);
}

/* Games / Featured: keep their normal structure, only ensure the child video fills the image box. */
.game-card__img.has-video-thumb,
.featured-card__img.has-video-thumb {
  position: relative;
  overflow: hidden;
  background-image: none !important;
}

.game-card__img.has-video-thumb > .card-video-thumb,
.featured-card__img.has-video-thumb > .card-video-thumb {
  z-index: 0 !important;
}

[data-motion="reduced"] .card-video-thumb {
  transform: none !important;
  filter: none !important;
}


/* ============================================================================
   BLOG VIDEO THUMBNAIL TONE FIX V4
   Keep blog video thumbnails visually consistent with normal image thumbnails.
   ============================================================================ */
.blog-row__thumb.has-card-video-thumb {
  background: var(--bg-0) !important;
  border-color: var(--line-strong) !important;
}
.blog-row__thumb.has-card-video-thumb > .card-video-thumb--blog-layer {
  background-color: var(--bg-0) !important;
  object-fit: cover !important;
  object-position: center center !important;
  filter: none !important;
}
.blog-row:hover .blog-row__thumb.has-card-video-thumb > .card-video-thumb--blog-layer {
  filter: none !important;
}
.blog-row__thumb.has-card-video-thumb .blog-row__thumb-img.has-video-thumb {
  background: transparent !important;
}
[data-theme="light"] .blog-row__thumb.has-card-video-thumb {
  background: var(--bg-0) !important;
}

/* ============================================================================
   FINAL CMS MEDIA + FILTER POLISH — tag blocks, media filters, blog video tone
   ============================================================================ */
.portfolio-filter__media{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.45rem;
  padding-top:.2rem;
}
.portfolio-filter__media>span{
  font-family:var(--font-ui);
  font-size:.68rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-right:.15rem;
}

/* Hide the browser's black video pre-paint frame on blog cards. */
.blog-row__thumb.has-card-video-thumb{
  background:var(--bg-0) !important;
}
.blog-row__thumb.has-card-video-thumb > .card-video-thumb--blog-layer:not(.is-ready){
  opacity:0 !important;
}
.blog-row__thumb.has-card-video-thumb > .card-video-thumb--blog-layer.is-ready{
  opacity:1 !important;
  background:transparent !important;
  filter:none !important;
}
.blog-row__thumb.has-card-video-thumb.is-bg-loading::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.018),rgba(255,255,255,0.006));
  pointer-events:none;
}
[data-theme="light"] .blog-row__thumb.has-card-video-thumb.is-bg-loading::after{
  background:linear-gradient(135deg,rgba(255,255,255,0.40),rgba(255,255,255,0.18));
}

.owner-blog-media-options{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.85rem;
  margin-top:1rem;
}
@media(max-width:640px){.owner-blog-media-options{grid-template-columns:1fr}}

.owner-blog-media-options--split{
  grid-template-columns:1fr 1fr;
  align-items:start;
}
.owner-blog-media-option-card{
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,0.018);
  padding:.9rem;
  min-width:0;
}
.owner-blog-media-option-card__title{
  font-family:var(--font-ui);
  font-size:.72rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:.7rem;
}
.owner-blog-media-option-card__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.75rem;
}
@media(max-width:900px){.owner-blog-media-option-card__grid{grid-template-columns:1fr}}
@media(max-width:640px){.owner-blog-media-options--split{grid-template-columns:1fr}}

.owner-field--tax-picker>input[type="hidden"]{
  display:none !important;
}
.owner-tax-picker{
  display:grid;
  gap:.65rem;
  width:100%;
}
.owner-tax-picker__selected,
.owner-tax-picker__grid{
  display:flex;
  flex-wrap:wrap;
  gap:.42rem;
}
.owner-tax-picker__selected{
  min-height:38px;
  align-items:center;
  padding:.45rem;
  border:1px dashed var(--line-strong);
  background:rgba(234,228,218,.02);
}
.owner-tax-empty{
  font-size:.78rem;
  color:var(--ink-mute);
}
.owner-tax-chip,
.owner-tax-selected{
  border:1px solid var(--line-strong);
  background:rgba(234,228,218,.025);
  color:var(--ink-soft);
  padding:.42rem .65rem;
  font-family:var(--font-ui);
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.13em;
  text-transform:uppercase;
  line-height:1;
  cursor:pointer;
}
.owner-tax-chip:hover,
.owner-tax-chip.is-selected,
.owner-tax-selected{
  border-color:var(--accent);
  background:var(--accent-soft);
  color:var(--accent-hot);
}
.owner-tax-selected b{
  margin-left:.35rem;
  font-size:.9em;
}
.owner-tax-picker__custom{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:.45rem;
}
.owner-tax-picker__custom input{
  width:100%;
  border:1px solid var(--line-strong);
  background:rgba(0,0,0,.24);
  color:var(--ink);
  padding:.6rem .7rem;
}
.owner-tax-picker__custom button{
  border:1px solid var(--accent-line);
  background:var(--accent-soft);
  color:var(--accent);
  padding:.6rem .85rem;
  font-family:var(--font-ui);
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}
[data-theme="light"] .owner-tax-picker__custom input{
  background:rgba(255,255,255,.68);
}

/* ============================================================================
   BLOG CMS POLISH — cleaner Basic Info layout + compact category/tag blocks
   ============================================================================ */
.owner-cms-modal__panel{
  width:min(1180px,96vw) !important;
}
.owner-cms-modal__head{
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.006));
}
.owner-cms-modal__head h2{
  letter-spacing:-.015em;
}
.owner-blog-status-bar{
  padding:1rem clamp(1rem,2vw,1.35rem) !important;
  background:linear-gradient(90deg,rgba(236,231,75,.055),rgba(255,255,255,.018));
}
.owner-blog-tabs{
  padding-inline:clamp(.55rem,1.4vw,1rem);
  background:rgba(12,14,18,.28) !important;
  overflow-x:auto;
  scrollbar-width:thin;
}
.owner-blog-tab{
  min-height:52px;
  padding:.85rem 1.15rem !important;
  border-bottom-width:3px !important;
  opacity:.82;
}
.owner-blog-tab.active{
  opacity:1;
  background:linear-gradient(180deg,rgba(236,231,75,.07),rgba(236,231,75,.025));
}
.owner-blog-panel-inner--basic{
  grid-template-columns:minmax(0,1.18fr) minmax(330px,.82fr) !important;
  gap:1rem !important;
  align-items:start !important;
  padding:clamp(1rem,2vw,1.35rem) !important;
}
.owner-blog-card{
  min-width:0;
  border:1px solid color-mix(in srgb,var(--line-strong) 78%,var(--accent-line));
  background:
    linear-gradient(135deg,rgba(234,228,218,.045),rgba(234,228,218,.012)),
    color-mix(in srgb,var(--bg-2) 86%,transparent);
  box-shadow:0 16px 42px -32px rgba(0,0,0,.82);
  padding:clamp(.95rem,1.8vw,1.15rem);
}
.owner-blog-card--details{
  display:grid;
  gap:1rem;
}
.owner-blog-card--taxonomy{
  display:grid;
  gap:.95rem;
}
.owner-blog-card--tools{
  grid-column:1 / -1;
  display:grid;
  gap:.75rem;
}
.owner-blog-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  padding-bottom:.8rem;
  border-bottom:1px solid var(--line);
  margin-bottom:.1rem;
}
.owner-blog-card__head strong{
  display:block;
  font-family:var(--font-ui);
  font-size:.8rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
}
.owner-blog-card__head span{
  display:block;
  margin-top:.22rem;
  font-size:.82rem;
  color:var(--ink-mute);
  line-height:1.35;
}
.owner-blog-field-row--compact{
  align-items:start !important;
  grid-template-columns:minmax(0,1.35fr) minmax(180px,.65fr) !important;
}
.owner-blog-panel-inner--basic .owner-field{
  align-self:start !important;
  min-height:0 !important;
}
.owner-blog-panel-inner--basic .owner-field>span{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.6rem;
  margin-bottom:.15rem;
}
.owner-blog-panel-inner--basic .owner-field>span em{
  font-style:normal;
  font-size:.75em;
  letter-spacing:.04em;
  text-transform:none;
  color:var(--ink-mute);
}
.owner-blog-panel-inner--basic .owner-field input,
.owner-blog-panel-inner--basic .owner-field select{
  min-height:54px;
  height:54px;
  padding:.82rem .9rem;
  background:rgba(6,8,12,.34);
}
.owner-blog-panel-inner--basic .owner-field textarea{
  min-height:170px;
  resize:vertical;
  background:rgba(6,8,12,.34);
}
.owner-blog-panel-inner--basic .owner-field--tax-picker>input[type="hidden"]{
  height:0 !important;
  min-height:0 !important;
  padding:0 !important;
  border:0 !important;
}
.owner-blog-panel-inner--basic .owner-tax-picker{
  gap:.55rem;
}
.owner-blog-panel-inner--basic .owner-tax-picker__selected{
  min-height:46px;
  align-items:center;
  padding:.5rem;
  border:1px dashed var(--accent-line);
  background:linear-gradient(135deg,rgba(236,231,75,.065),rgba(255,255,255,.018));
}
.owner-blog-panel-inner--basic .owner-tax-picker__grid{
  display:flex;
  flex-wrap:wrap;
  gap:.38rem;
  max-height:142px;
  overflow:auto;
  padding:.2rem .15rem .25rem 0;
  scrollbar-gutter:stable;
}
.owner-blog-panel-inner--basic .owner-tax-picker--single .owner-tax-picker__grid{
  max-height:92px;
}
.owner-blog-panel-inner--basic .owner-tax-chip,
.owner-blog-panel-inner--basic .owner-tax-selected{
  min-height:34px;
  display:inline-flex;
  align-items:center;
  padding:.48rem .68rem;
  border-radius:999px;
  letter-spacing:.12em;
  background:rgba(234,228,218,.035);
}
.owner-blog-panel-inner--basic .owner-tax-chip:hover{
  transform:translateY(-1px);
}
.owner-blog-panel-inner--basic .owner-tax-chip.is-selected,
.owner-blog-panel-inner--basic .owner-tax-selected{
  box-shadow:0 0 0 1px rgba(236,231,75,.06),0 10px 28px -22px var(--accent);
}
.owner-blog-panel-inner--basic .owner-tax-picker__custom{
  grid-template-columns:minmax(0,1fr) 70px;
}
.owner-blog-panel-inner--basic .owner-tax-picker__custom input,
.owner-blog-panel-inner--basic .owner-tax-picker__custom button{
  height:44px;
  min-height:44px;
}
.owner-blog-panel-inner--basic .owner-tax-empty{
  padding-inline:.35rem;
  line-height:1.35;
}
.owner-blog-card--tools .owner-field--tool-picker{
  display:block !important;
  margin-bottom:0 !important;
}
.owner-blog-card--tools .owner-field--tool-picker>span{
  display:none !important;
}
.owner-blog-card--tools .owner-tool-picker{
  margin-top:0 !important;
  border-color:var(--line-strong);
  background:rgba(6,8,12,.24);
}
.owner-blog-card--tools .owner-tool-picker__head{
  align-items:center;
}
.owner-blog-card--tools .owner-tool-picker__selected{
  min-height:58px;
  max-height:102px;
}
.owner-blog-card--tools .owner-tool-picker__grid{
  max-height:190px !important;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
}
.owner-blog-save-bar{
  gap:1rem;
  box-shadow:0 -18px 50px -38px rgba(0,0,0,.8);
}
@media(max-width:900px){
  .owner-blog-panel-inner--basic{
    grid-template-columns:1fr !important;
  }
  .owner-blog-card--tools{
    grid-column:auto;
  }
}
@media(max-width:640px){
  .owner-blog-field-row--compact{
    grid-template-columns:1fr !important;
  }
  .owner-blog-status-bar{
    align-items:flex-start;
    flex-direction:column;
  }
  .owner-blog-save-bar{
    align-items:stretch !important;
    flex-direction:column;
  }
  .owner-blog-save-bar>div:last-child{
    display:grid !important;
    grid-template-columns:1fr;
  }
}
[data-theme="light"] .owner-blog-card{
  background:linear-gradient(135deg,rgba(255,255,255,.76),rgba(30,40,50,.035));
}
[data-theme="light"] .owner-blog-panel-inner--basic .owner-field input,
[data-theme="light"] .owner-blog-panel-inner--basic .owner-field select,
[data-theme="light"] .owner-blog-panel-inner--basic .owner-field textarea,
[data-theme="light"] .owner-blog-card--tools .owner-tool-picker{
  background:rgba(255,255,255,.72);
}

/* ============================================================================
   QUICK FIX — Blog CMS tab bar visibility
   Keeps the Basic Info / Media / Content Blocks / Settings row readable below
   the status bar instead of appearing clipped or hidden.
   ============================================================================ */
.owner-blog-status-bar{
  position:relative !important;
  z-index:12 !important;
  flex-shrink:0 !important;
}
.owner-blog-status-bar + .owner-blog-tabs,
.owner-blog-tabs{
  position:relative !important;
  z-index:11 !important;
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:.35rem .45rem !important;
  min-height:64px !important;
  height:auto !important;
  padding:.65rem clamp(.75rem,1.6vw,1.15rem) !important;
  margin:0 !important;
  overflow:visible !important;
  border-top:1px solid rgba(234,228,218,.06) !important;
  border-bottom:1px solid var(--line) !important;
  background:linear-gradient(180deg,rgba(18,21,27,.98),rgba(14,16,21,.96)) !important;
}
.owner-blog-tab{
  position:relative !important;
  flex:0 0 auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:38px !important;
  height:auto !important;
  padding:.68rem 1rem !important;
  margin:0 !important;
  line-height:1 !important;
  white-space:nowrap !important;
  overflow:visible !important;
  border:1px solid transparent !important;
  border-bottom:1px solid transparent !important;
  color:var(--ink-soft) !important;
  background:transparent !important;
}
.owner-blog-tab:hover{
  color:var(--ink) !important;
  border-color:var(--line-strong) !important;
  background:rgba(234,228,218,.035) !important;
}
.owner-blog-tab.active{
  color:var(--accent) !important;
  border-color:var(--accent-line) !important;
  background:rgba(236,231,75,.10) !important;
  box-shadow:inset 0 -2px 0 var(--accent) !important;
}
.owner-blog-tab-badge{
  position:static !important;
  transform:none !important;
  margin-left:.15rem !important;
}
@media(max-width:640px){
  .owner-blog-tabs{
    min-height:auto !important;
    padding:.55rem .65rem !important;
  }
  .owner-blog-tab{
    flex:1 1 calc(50% - .45rem) !important;
  }
}

/* ============================================================================
   AUTO MEDIA FORMAT PATCH
   Wide uploads render as wide cards. Portrait/tall uploads render as tall cards.
   The JS adds one of these classes after reading the image/video dimensions.
   ============================================================================ */
@media (min-width: 1025px) {
  .work.media-shape-wide {
    grid-column: span 4 !important;
    aspect-ratio: 16 / 9 !important;
  }

  .work.media-shape-landscape {
    grid-column: span 3 !important;
    aspect-ratio: 16 / 11 !important;
  }

  .work.media-shape-square {
    grid-column: span 3 !important;
    aspect-ratio: 1 / 1 !important;
  }

  .work.media-shape-portrait {
    grid-column: span 2 !important;
    aspect-ratio: 4 / 5 !important;
  }

  .work.media-shape-tall {
    grid-column: span 2 !important;
    aspect-ratio: 3 / 4 !important;
  }

  .arc-item.media-shape-wide {
    grid-column: span 6 !important;
    aspect-ratio: 16 / 9 !important;
  }

  .arc-item.media-shape-landscape {
    grid-column: span 4 !important;
    aspect-ratio: 4 / 3 !important;
  }

  .arc-item.media-shape-square {
    grid-column: span 4 !important;
    aspect-ratio: 1 / 1 !important;
  }

  .arc-item.media-shape-portrait,
  .arc-item.media-shape-tall {
    grid-column: span 3 !important;
    aspect-ratio: 3 / 4 !important;
  }
}

@media (max-width: 1024px) {
  .work.media-shape-wide,
  .work.media-shape-landscape,
  .arc-item.media-shape-wide,
  .arc-item.media-shape-landscape {
    aspect-ratio: 16 / 10 !important;
  }

  .work.media-shape-square,
  .arc-item.media-shape-square {
    aspect-ratio: 1 / 1 !important;
  }

  .work.media-shape-portrait,
  .work.media-shape-tall,
  .arc-item.media-shape-portrait,
  .arc-item.media-shape-tall {
    aspect-ratio: 4 / 5 !important;
  }
}

@media (max-width: 720px) {
  .work.media-shape-wide,
  .work.media-shape-landscape,
  .arc-item.media-shape-wide,
  .arc-item.media-shape-landscape {
    aspect-ratio: 16 / 10 !important;
  }

  .work.media-shape-portrait,
  .work.media-shape-tall,
  .arc-item.media-shape-portrait,
  .arc-item.media-shape-tall {
    aspect-ratio: 4 / 5 !important;
  }
}

[data-motion="reduced"] .work.media-shape-wide,
[data-motion="reduced"] .work.media-shape-landscape,
[data-motion="reduced"] .work.media-shape-square,
[data-motion="reduced"] .work.media-shape-portrait,
[data-motion="reduced"] .work.media-shape-tall,
[data-motion="reduced"] .arc-item.media-shape-wide,
[data-motion="reduced"] .arc-item.media-shape-landscape,
[data-motion="reduced"] .arc-item.media-shape-square,
[data-motion="reduced"] .arc-item.media-shape-portrait,
[data-motion="reduced"] .arc-item.media-shape-tall {
  height: auto !important;
  min-height: 0 !important;
}

/* ============================================================================
   PORTFOLIO / GALLERY CARDS-PER-ROW SLIDER
   Only affects normal Portfolio work grids and Gallery grids.
   Game project cards and Blog posts keep their existing layouts.
   ============================================================================ */
.cards-per-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 320px);
  gap: 1rem;
  align-items: center;
  width: 100%;
  margin: -0.6rem 0 1.6rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--line);
  background: rgba(234, 228, 218, 0.025);
}

.cards-per-row__text {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  min-width: 0;
}

.cards-per-row label,
.cards-per-row output {
  font-family: var(--font-ui);
  text-transform: uppercase;
}

.cards-per-row label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--ink-soft);
}

.cards-per-row output {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  color: var(--accent);
}

.cards-per-row input[type="range"] {
  width: 100%;
  accent-color: var(--accent);
  cursor: pointer;
}

.works--cards-controlled {
  --cards-per-row: 3;
}

.archive-grid--cards-controlled {
  --cards-per-row: 4;
}

@media (max-width: 720px) {
  .cards-per-row {
    grid-template-columns: 1fr;
    margin-top: -0.25rem;
  }
}

/* CSS var defaults — masonry block below uses column-count: var(--cards-per-row) */

/* ============================================================================
   ZERO-GAP MASONRY + CARD TEXT READABILITY PATCH
   Fixes Portfolio/Gallery controlled card views only.
   - Removes gutters and row holes between controlled cards.
   - Keeps uploaded media aspect ratios while packing cards tightly.
   - Forces readable card text in dark and light themes.
   ============================================================================ */
.works--cards-controlled,
.archive-grid--cards-controlled {
  display: block !important;
  column-count: var(--cards-per-row) !important;
  column-gap: 0 !important;
  gap: 0 !important;
}

.works--cards-controlled .work,
.archive-grid--cards-controlled .arc-item {
  display: inline-block !important;
  width: 100% !important;
  margin: 0 !important;
  vertical-align: top !important;
  break-inside: avoid !important;
  page-break-inside: avoid !important;
  grid-column: auto !important;
  border-color: rgba(234, 228, 218, 0.12) !important;
  box-shadow: none;
}

.works--cards-controlled .work:hover,
.archive-grid--cards-controlled .arc-item:hover {
  z-index: 3;
}

.works--cards-controlled .work__overlay,
.archive-grid--cards-controlled .arc-item__overlay,
.work__overlay,
.arc-item__overlay {
  background:
    linear-gradient(180deg,
      rgba(3, 5, 9, 0.06) 0%,
      rgba(3, 5, 9, 0.18) 36%,
      rgba(3, 5, 9, 0.72) 74%,
      rgba(3, 5, 9, 0.94) 100%) !important;
  opacity: 1 !important;
}

.work__content,
.arc-item__content {
  text-shadow:
    0 2px 10px rgba(0, 0, 0, 0.92),
    0 1px 2px rgba(0, 0, 0, 0.95) !important;
}

.work__title,
.arc-item__title,
[data-theme="light"] .work__title,
[data-theme="light"] .arc-item__title {
  color: #fff4e8 !important;
  text-shadow:
    0 2px 12px rgba(0, 0, 0, 0.95),
    0 0 1px rgba(0, 0, 0, 1) !important;
}

.work__type,
.arc-item__type,
[data-theme="light"] .work__type,
[data-theme="light"] .arc-item__type {
  color: #ffb66d !important;
  opacity: 1 !important;
  font-weight: 800 !important;
  text-shadow:
    0 2px 8px rgba(0, 0, 0, 0.96),
    0 0 1px rgba(0, 0, 0, 1) !important;
}

.work__metaLine,
.arc-item__software,
[data-theme="light"] .work__metaLine,
[data-theme="light"] .arc-item__software {
  color: rgba(255, 244, 232, 0.92) !important;
  text-shadow:
    0 2px 8px rgba(0, 0, 0, 0.96),
    0 0 1px rgba(0, 0, 0, 1) !important;
}

[data-theme="light"] .work__overlay,
[data-theme="light"] .arc-item__overlay {
  background:
    linear-gradient(180deg,
      rgba(3, 5, 9, 0.05) 0%,
      rgba(3, 5, 9, 0.18) 36%,
      rgba(3, 5, 9, 0.74) 74%,
      rgba(3, 5, 9, 0.94) 100%) !important;
}

[data-theme="light"] .cards-per-row {
  background: rgba(248, 250, 252, 0.72) !important;
  border-color: rgba(20, 30, 50, 0.22) !important;
}

[data-theme="light"] .cards-per-row label {
  color: #3A4047 !important;
}

[data-theme="light"] .cards-per-row output {
  color: #7A3E00 !important;
}

@media (max-width: 1024px) {
  .works--cards-controlled,
  .archive-grid--cards-controlled {
    column-count: 3 !important;
  }

  .works--cards-controlled[data-cards-per-row="1"],
  .archive-grid--cards-controlled[data-cards-per-row="1"] {
    column-count: 1 !important;
  }

  .works--cards-controlled[data-cards-per-row="2"],
  .archive-grid--cards-controlled[data-cards-per-row="2"] {
    column-count: 2 !important;
  }
}

@media (max-width: 720px) {
  .works--cards-controlled,
  .archive-grid--cards-controlled,
  .works--cards-controlled[data-cards-per-row],
  .archive-grid--cards-controlled[data-cards-per-row] {
    column-count: 1 !important;
    column-gap: 0 !important;
  }
}


/* ============================================================================
   ARTSTATION-STYLE GUTTER PATCH
   Keeps the tight masonry layout, but adds a small visual gutter so cards read
   as separate posts instead of one merged wall. Portfolio + Gallery only.
   ============================================================================ */
:root {
  --portfolio-gallery-card-gap: clamp(8px, 0.75vw, 14px);
  --portfolio-gallery-card-radius: 6px;
}

.works--cards-controlled,
.archive-grid--cards-controlled {
  column-gap: var(--portfolio-gallery-card-gap) !important;
  gap: var(--portfolio-gallery-card-gap) !important;
}

.works--cards-controlled .work,
.archive-grid--cards-controlled .arc-item {
  margin: 0 0 var(--portfolio-gallery-card-gap) !important;
  border-radius: var(--portfolio-gallery-card-radius) !important;
  border: 1px solid rgba(234, 228, 218, 0.18) !important;
  box-shadow: 0 12px 30px -24px rgba(0, 0, 0, 0.88) !important;
  background: var(--bg-2) !important;
}

.works--cards-controlled .work__img,
.archive-grid--cards-controlled .arc-item__img,
.works--cards-controlled .work__overlay,
.archive-grid--cards-controlled .arc-item__overlay {
  border-radius: inherit !important;
}

.works--cards-controlled .work__content,
.archive-grid--cards-controlled .arc-item__content {
  padding: clamp(1.05rem, 1.5vw, 1.45rem) !important;
  max-width: 100% !important;
  overflow: hidden !important;
}

.works--cards-controlled .work__title,
.archive-grid--cards-controlled .arc-item__title {
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: break-word !important;
  word-break: normal !important;
  text-wrap: balance;
}

.works--cards-controlled .work__type,
.archive-grid--cards-controlled .arc-item__type {
  display: block !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: break-word !important;
}

.works--cards-controlled .work__metaLine,
.archive-grid--cards-controlled .arc-item__software {
  white-space: normal !important;
  max-height: none !important;
}

[data-theme="light"] .works--cards-controlled .work,
[data-theme="light"] .archive-grid--cards-controlled .arc-item {
  border-color: rgba(20, 30, 50, 0.18) !important;
  box-shadow: 0 12px 30px -24px rgba(20, 30, 50, 0.45) !important;
  background: #eef2f5 !important;
}

@media (max-width: 720px) {
  :root { --portfolio-gallery-card-gap: 8px; }

  .works--cards-controlled,
  .archive-grid--cards-controlled,
  .works--cards-controlled[data-cards-per-row],
  .archive-grid--cards-controlled[data-cards-per-row] {
    column-gap: var(--portfolio-gallery-card-gap) !important;
  }
}

/* HOME VIDEO VISIBILITY BOOST — makes the hero background video clearer while keeping text readable */
.page-home .hero__bg{
  filter:saturate(1.16) contrast(1.12) brightness(1.18);
}
.page-home .hero__video.is-ready{
  opacity:1;
}
.page-home .hero__overlay{
  background:
    linear-gradient(90deg,
      rgba(15,17,21,0.88) 0%,
      rgba(15,17,21,0.68) 24%,
      rgba(15,17,21,0.24) 50%,
      rgba(15,17,21,0.04) 72%,
      rgba(15,17,21,0.36) 100%),
    linear-gradient(180deg,
      rgba(15,17,21,0.24) 0%,
      rgba(15,17,21,0.04) 45%,
      rgba(15,17,21,0.66) 100%);
}
.page-home .hero .vignette{
  opacity:0.62;
  background:
    radial-gradient(ellipse at 62% 48%, transparent 25%, rgba(8,7,5,0.16) 58%, rgba(6,5,4,0.62) 100%),
    linear-gradient(180deg, rgba(8,7,5,0.12), rgba(6,5,4,0.42));
}


/* HERO VIDEO 3 NO-ZOOM FIX
   Portrait/long videos use contain mode with a blurred cover copy behind them.
   This prevents the video from being cropped/zoomed and keeps it from looking low-quality. */
.page-home .hero__bg.has-hero-video.has-contain-video{
  background:#090a0d;
}
.page-home .hero__bg.has-contain-video .hero__video--contain{
  object-fit:contain !important;
  object-position:center center !important;
}
.page-home .hero__bg.has-contain-video .hero__video--backdrop{
  display:block;
}
.page-home .hero__bg:not(.has-contain-video) .hero__video--backdrop{
  display:none;
}
[data-theme="light"] .page-home .hero__bg.has-contain-video .hero__video--contain.is-ready{
  filter:saturate(0.96) contrast(1.06) brightness(0.84);
}
[data-theme="light"] .page-home .hero__bg.has-contain-video .hero__video--backdrop.is-ready{
  opacity:0.52;
  filter:blur(30px) saturate(0.9) contrast(1.05) brightness(0.72);
}


/* HERO VIDEO 3 SIDE POSITION FIX
   Portrait/long hero video stays unzoomed, but sits on the right side instead of the middle. */
.page-home .hero__bg.has-contain-video .hero__video--contain{
  object-fit:contain !important;
  object-position:right center !important;
}
.page-home .hero__bg.has-contain-video .hero__video--backdrop{
  object-fit:cover !important;
  object-position:center center !important;
  opacity:0.42;
  transform:scale(1.08);
  filter:blur(26px) saturate(0.9) contrast(1.08) brightness(0.58);
}
.page-home .hero__bg.has-contain-video::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  background:
    linear-gradient(90deg,
      rgba(6,7,10,0.68) 0%,
      rgba(6,7,10,0.42) 28%,
      rgba(6,7,10,0.10) 58%,
      rgba(6,7,10,0.00) 100%);
}
[data-theme="light"] .page-home .hero__bg.has-contain-video::after{
  background:
    linear-gradient(90deg,
      rgba(244,246,248,0.74) 0%,
      rgba(244,246,248,0.46) 30%,
      rgba(244,246,248,0.12) 58%,
      rgba(244,246,248,0.00) 100%);
}
@media (max-width: 900px){
  .page-home .hero__bg.has-contain-video .hero__video--contain{
    object-position:center center !important;
  }
}

/* HERO VIDEO 3 SOFT SIDE BLEND FIX
   Removes the vertical hard cut by fading the portrait video into the dark hero area.
   Uses a CSS gradient mask plus a blurred duplicate behind the video. */
.page-home .hero__bg.has-contain-video .hero__video--contain{
  object-fit:contain !important;
  object-position:right center !important;
  -webkit-mask-image:linear-gradient(90deg,
    transparent 0%,
    transparent 42%,
    rgba(0,0,0,0.18) 50%,
    rgba(0,0,0,0.68) 60%,
    #000 72%,
    #000 100%);
  mask-image:linear-gradient(90deg,
    transparent 0%,
    transparent 42%,
    rgba(0,0,0,0.18) 50%,
    rgba(0,0,0,0.68) 60%,
    #000 72%,
    #000 100%);
  -webkit-mask-size:100% 100%;
  mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
}
.page-home .hero__bg.has-contain-video .hero__video--backdrop{
  display:block !important;
  object-fit:cover !important;
  object-position:right center !important;
  opacity:0.58 !important;
  transform:scale(1.22);
  filter:blur(44px) saturate(0.9) contrast(1.08) brightness(0.48) !important;
}
.page-home .hero__bg.has-contain-video::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    linear-gradient(90deg,
      rgba(6,7,10,0.90) 0%,
      rgba(6,7,10,0.74) 38%,
      rgba(6,7,10,0.42) 54%,
      rgba(6,7,10,0.12) 70%,
      rgba(6,7,10,0.00) 100%),
    radial-gradient(ellipse at 62% 50%, rgba(236,231,75,0.13) 0%, rgba(236,231,75,0.05) 22%, transparent 54%);
}
.page-home .hero__bg.has-contain-video::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    linear-gradient(90deg,
      rgba(6,7,10,0.30) 0%,
      rgba(6,7,10,0.18) 48%,
      rgba(6,7,10,0.08) 62%,
      rgba(6,7,10,0.00) 76%,
      rgba(6,7,10,0.20) 100%),
    linear-gradient(180deg,
      rgba(6,7,10,0.24) 0%,
      rgba(6,7,10,0.00) 42%,
      rgba(6,7,10,0.55) 100%);
}
@media (max-width: 900px){
  .page-home .hero__bg.has-contain-video .hero__video--contain{
    object-position:center center !important;
    -webkit-mask-image:linear-gradient(90deg, transparent 0%, rgba(0,0,0,0.85) 12%, #000 24%, #000 76%, rgba(0,0,0,0.85) 88%, transparent 100%);
    mask-image:linear-gradient(90deg, transparent 0%, rgba(0,0,0,0.85) 12%, #000 24%, #000 76%, rgba(0,0,0,0.85) 88%, transparent 100%);
  }
  .page-home .hero__bg.has-contain-video::before{
    background:linear-gradient(90deg, rgba(6,7,10,0.68) 0%, rgba(6,7,10,0.20) 50%, rgba(6,7,10,0.68) 100%);
  }
}


/* HOME HERO VIDEO — LIGHT MODE + MOTION FIX
   Light mode was washing the portrait hero video into a flat gray panel.
   When a hero video is active, keep the hero section cinematic/dark even if
   the rest of the website is in light mode. */
[data-theme="light"] .page-home .hero.hero--video-active{
  background:#0F1115 !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg{
  filter:saturate(1.02) contrast(1.10) brightness(0.82) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__overlay{
  background:
    linear-gradient(90deg,
      rgba(15,17,21,0.96) 0%,
      rgba(15,17,21,0.82) 26%,
      rgba(15,17,21,0.44) 52%,
      rgba(15,17,21,0.14) 72%,
      rgba(15,17,21,0.58) 100%),
    linear-gradient(180deg,
      rgba(15,17,21,0.34) 0%,
      rgba(15,17,21,0.08) 46%,
      rgba(15,17,21,0.86) 100%) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .vignette{
  opacity:0.78 !important;
  background:
    radial-gradient(ellipse at 62% 48%, transparent 22%, rgba(8,7,5,0.24) 58%, rgba(6,5,4,0.78) 100%),
    linear-gradient(180deg, rgba(8,7,5,0.18), rgba(6,5,4,0.56)) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__title{
  color:transparent !important;
  -webkit-text-fill-color:transparent !important;
  background:
    linear-gradient(180deg,#f7f4ec 0%,#d7d3c8 48%,#8b867b 100%),
    repeating-linear-gradient(90deg,rgba(234,228,218,0.2) 0 1px,rgba(0,0,0,0.16) 1px 3px) !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  filter:drop-shadow(0 6px 0 rgba(8,6,4,0.50)) drop-shadow(0 22px 42px rgba(8,6,4,0.48)) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__title .dot{
  color:var(--accent) !important;
  -webkit-text-fill-color:var(--accent) !important;
  background:none !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__sub,
[data-theme="light"] .page-home .hero.hero--video-active .hero__desc{
  color:rgba(234,228,218,0.76) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__role{
  color:var(--accent) !important;
  text-shadow:0 2px 0 rgba(8,6,4,0.52) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .page-home .hero__buttons .btn--ghost,
[data-theme="light"] .page-home .hero.hero--video-active .hero__buttons .btn--ghost{
  background:rgba(4,4,6,0.38) !important;
  border-color:rgba(236,231,75,0.55) !important;
  color:var(--ink) !important;
}

/* The motion toggle should remove the video completely and fall back to the
   static hero background, instead of freezing a video frame. */
[data-motion="reduced"] .page-home .hero__video{
  display:none !important;
}
[data-motion="reduced"] .page-home .hero__bg{
  animation:none !important;
}

[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video::before{
  background:
    linear-gradient(90deg,
      rgba(6,7,10,0.92) 0%,
      rgba(6,7,10,0.76) 38%,
      rgba(6,7,10,0.44) 54%,
      rgba(6,7,10,0.12) 70%,
      rgba(6,7,10,0.00) 100%),
    radial-gradient(ellipse at 62% 50%, rgba(236,231,75,0.13) 0%, rgba(236,231,75,0.05) 22%, transparent 54%) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video::after{
  background:
    linear-gradient(90deg,
      rgba(6,7,10,0.30) 0%,
      rgba(6,7,10,0.18) 48%,
      rgba(6,7,10,0.08) 62%,
      rgba(6,7,10,0.00) 76%,
      rgba(6,7,10,0.20) 100%),
    linear-gradient(180deg,
      rgba(6,7,10,0.24) 0%,
      rgba(6,7,10,0.00) 42%,
      rgba(6,7,10,0.55) 100%) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video .hero__video--contain.is-ready{
  filter:saturate(0.96) contrast(1.08) brightness(0.74) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video .hero__video--backdrop.is-ready{
  opacity:0.56 !important;
  filter:blur(44px) saturate(0.9) contrast(1.08) brightness(0.44) !important;
}


/* LIGHT MODE HERO VIDEO REDO — keep animation-off behavior, but restore a real light theme.
   This overrides the previous too-dark light-mode treatment. */
[data-theme="light"] .page-home .hero.hero--video-active{
  background:var(--bg-0) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg{
  filter:saturate(0.96) contrast(1.04) brightness(0.98) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__video.is-ready{
  opacity:0.82 !important;
  filter:saturate(0.95) contrast(1.03) brightness(0.94) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__overlay{
  background:
    linear-gradient(90deg,
      rgba(239,243,247,0.90) 0%,
      rgba(239,243,247,0.78) 27%,
      rgba(239,243,247,0.42) 52%,
      rgba(239,243,247,0.14) 74%,
      rgba(20,30,50,0.10) 100%),
    linear-gradient(180deg,
      rgba(255,255,255,0.18) 0%,
      rgba(255,255,255,0.04) 46%,
      rgba(20,30,50,0.30) 100%) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .vignette{
  opacity:0.50 !important;
  background:
    radial-gradient(ellipse at 62% 48%, transparent 28%, rgba(20,30,50,0.12) 62%, rgba(20,30,50,0.28) 100%),
    linear-gradient(180deg, rgba(20,30,50,0.04), rgba(20,30,50,0.18)) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__title{
  background:none !important;
  -webkit-background-clip:unset !important;
  background-clip:unset !important;
  -webkit-text-fill-color:#171B21 !important;
  color:#171B21 !important;
  filter:none !important;
  text-shadow:0 1px 0 rgba(248,250,252,0.30) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__title .dot{
  color:var(--accent) !important;
  -webkit-text-fill-color:var(--accent) !important;
  background:none !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__role{
  color:var(--accent-deep) !important;
  text-shadow:0 1px 0 rgba(248,250,252,0.35) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__sub,
[data-theme="light"] .page-home .hero.hero--video-active .hero__desc{
  color:rgba(26,29,33,0.76) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__buttons .btn--ghost{
  background:rgba(248,250,252,0.56) !important;
  border-color:rgba(168,86,0,0.55) !important;
  color:#1A1D21 !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__buttons .btn--primary{
  color:#F8FAFC !important;
  box-shadow:0 0 0 1px rgba(168,86,0,0.78),0 18px 40px -24px rgba(168,86,0,0.75) !important;
}

/* Light-mode portrait/side video: smooth bright blend, not a dark panel. */
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video{
  background:#EEF2F5 !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video .hero__video--contain{
  object-position:right center !important;
  -webkit-mask-image:linear-gradient(90deg,
    transparent 0%,
    transparent 30%,
    rgba(0,0,0,0.12) 42%,
    rgba(0,0,0,0.62) 56%,
    #000 70%,
    #000 100%) !important;
  mask-image:linear-gradient(90deg,
    transparent 0%,
    transparent 30%,
    rgba(0,0,0,0.12) 42%,
    rgba(0,0,0,0.62) 56%,
    #000 70%,
    #000 100%) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video .hero__video--contain.is-ready{
  opacity:0.88 !important;
  filter:saturate(0.96) contrast(1.02) brightness(0.96) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video .hero__video--backdrop.is-ready{
  opacity:0.30 !important;
  filter:blur(42px) saturate(0.88) contrast(1.02) brightness(0.94) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video::before{
  background:
    linear-gradient(90deg,
      rgba(239,243,247,0.96) 0%,
      rgba(239,243,247,0.88) 38%,
      rgba(239,243,247,0.52) 54%,
      rgba(239,243,247,0.18) 70%,
      rgba(239,243,247,0.04) 100%),
    radial-gradient(ellipse at 63% 50%, rgba(168,86,0,0.08) 0%, rgba(168,86,0,0.03) 24%, transparent 56%) !important;
}
[data-theme="light"] .page-home .hero.hero--video-active .hero__bg.has-contain-video::after{
  background:
    linear-gradient(90deg,
      rgba(239,243,247,0.26) 0%,
      rgba(239,243,247,0.18) 46%,
      rgba(239,243,247,0.06) 62%,
      rgba(20,30,50,0.04) 78%,
      rgba(20,30,50,0.18) 100%),
    linear-gradient(180deg,
      rgba(255,255,255,0.18) 0%,
      rgba(255,255,255,0.00) 42%,
      rgba(20,30,50,0.22) 100%) !important;
}

/* Keep the animation toggle behavior from the previous fix. */
[data-motion="reduced"] .page-home .hero__video{
  display:none !important;
}
[data-motion="reduced"] .page-home .hero__bg{
  animation:none !important;
}
[data-motion="reduced"] .page-home .hero.hero--video-active{
  background:var(--bg-0) !important;
}

.noscript-msg{position:fixed;inset:0;z-index:9999;background:var(--bg-0);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:1rem;letter-spacing:0.18em;text-transform:uppercase;text-align:center;padding:2rem}
@media (max-width:760px){.modal__nav{width:36px;height:60px}.modal__nav svg{width:14px;height:14px}}
.idb-missing{position:relative}
.idb-missing::before{content:"// Image stored locally —\A not available in this browser";white-space:pre;position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui,'Rajdhani',sans-serif);font-size:clamp(0.7rem,1.4vw,0.85rem);letter-spacing:0.12em;text-transform:uppercase;color:rgba(236,231,75,0.75);text-align:center;line-height:1.7;pointer-events:none}
.work__img.idb-missing::before,.arc-item__img.idb-missing::before,.game-card__img.idb-missing::before,.featured-card__img.idb-missing::before,.blog-row__thumb-img.idb-missing::before{display:none}
.modal__img.idb-missing{outline:1px solid rgba(236,231,75,0.18);outline-offset:-1px}
.modal__img.idb-missing::before{font-size:clamp(0.75rem,1.8vw,1rem)}

/* ============================================================
   FOOTER CONTACT LINK — appears in every page footer
   ============================================================ */
.footer-contact-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin-left: 0.6rem;
  color: var(--accent);
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 1px solid var(--accent-line);
  padding-bottom: 1px;
  transition: color 180ms var(--ease-out), border-color 180ms var(--ease-out), letter-spacing 180ms var(--ease-out);
}
.footer-contact-link:hover,
.footer-contact-link:focus-visible {
  color: var(--accent-hot);
  border-color: var(--accent-hot);
  letter-spacing: 0.30em;
  outline: none;
}
[data-theme="light"] .footer-contact-link { color: var(--accent-deep); border-color: var(--accent-line); }
[data-theme="light"] .footer-contact-link:hover { color: var(--accent); border-color: var(--accent); }

/* ============================================================
   FLOATING CONTACT ICON — left-side scroll reveal
   Hidden at page top, then fades in after a short scroll.
   ============================================================ */
.float-contact-btn {
  position: fixed;
  left: max(0.9rem, env(safe-area-inset-left));
  top: 50%;
  bottom: auto;
  transform: translate(-12px, -50%);
  z-index: 120;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  background: var(--bg-glass);
  border: 1px solid var(--accent);
  color: var(--accent);
  cursor: pointer;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  isolation: isolate;
  text-decoration: none;
  box-shadow: 0 8px 28px -10px rgba(0,0,0,0.55);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    background 220ms var(--ease-out),
    color 220ms var(--ease-out),
    border 220ms var(--ease-out),
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out),
    opacity 240ms var(--ease-out),
    visibility 0s linear 240ms;
}
.float-contact-btn.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(0, -50%);
  transition:
    background 220ms var(--ease-out),
    color 220ms var(--ease-out),
    border 220ms var(--ease-out),
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out),
    opacity 240ms var(--ease-out),
    visibility 0s linear 0s;
}
.float-contact-btn::before,
.float-contact-btn::after {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  border: 1px solid var(--accent);
  pointer-events: none;
  transition: width 220ms var(--ease-out), height 220ms var(--ease-out), border-color 220ms var(--ease-out);
}
.float-contact-btn::before { top: -2px; left: -2px; border-right: 0; border-bottom: 0; }
.float-contact-btn::after  { bottom: -2px; right: -2px; border-left: 0; border-top: 0; }
.float-contact-btn.is-visible:hover,
.float-contact-btn.is-visible:focus-visible {
  outline: none;
  color: var(--accent-hot);
  border-color: var(--accent-hot);
  background: var(--accent-soft);
  transform: translate(0, calc(-50% - 2px));
  box-shadow: 0 14px 36px -10px rgba(0,0,0,0.65), 0 0 24px -4px rgba(236,231,75,0.45);
}
.float-contact-btn:hover::before,
.float-contact-btn:hover::after { width: 10px; height: 10px; border-color: var(--accent-hot); }
/* Hide on the contact page itself */
.page-contact .float-contact-btn { display: none !important; }
/* Light theme */
[data-theme="light"] .float-contact-btn {
  background: rgba(248,250,252,0.96);
  color: var(--accent-deep);
  border-color: var(--accent-line);
  box-shadow: 0 8px 28px -10px rgba(20,30,50,0.30);
}
[data-theme="light"] .float-contact-btn.is-visible:hover,
[data-theme="light"] .float-contact-btn.is-visible:focus-visible {
  color: var(--accent-deep);
  border-color: var(--accent);
  background: var(--accent-soft);
  box-shadow: 0 14px 36px -10px rgba(20,30,50,0.40), 0 0 24px -4px rgba(168,86,0,0.45);
}
/* Hide during modal/owner modal open so it does not sit over gallery/portfolio overlays */
body.modal-open .float-contact-btn,
body.owner-modal-open .float-contact-btn { opacity: 0; visibility: hidden; pointer-events: none; }

/* Owner mode keeps the contact button on the left side; reveal is still scroll-based. */
[data-owner-mode="true"] .float-contact-btn {
  top: 50%;
  bottom: auto;
}
@media (max-width: 720px) {
  .float-contact-btn {
    width: 42px;
    height: 42px;
    left: max(0.75rem, env(safe-area-inset-left));
    top: auto;
    bottom: max(0.85rem, env(safe-area-inset-bottom));
    transform: translateX(-12px);
  }
  .float-contact-btn.is-visible {
    transform: translateX(0);
  }
  .float-contact-btn.is-visible:hover,
  .float-contact-btn.is-visible:focus-visible {
    transform: translate(0, -2px);
  }
}

/* ═══════════════════════════════════════════════════════════════
   POST READER IMPROVEMENTS — v10
   Better spacing, visual hierarchy, image presentation
   ═══════════════════════════════════════════════════════════════ */

/* Reading column improvements */
.post__body { max-width: none; }
.post-body__p { font-size: 1.05rem; line-height: 1.82; color: var(--ink-soft); margin: 0 0 1.4rem; }
.post-body__h {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.2vw, 1.8rem);
  line-height: 1.05;
  text-transform: uppercase;
  color: var(--ink);
  margin: 3rem 0 1rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--line);
  letter-spacing: 0.01em;
}
.post-body__h:first-child { margin-top: 0; border-top: none; }

/* Image block improvements — cleaner, larger, clickable */
.post-body__fig { margin: 2.5rem 0; }
.post-body__img {
  aspect-ratio: 16 / 9;
  background: var(--bg-2);
  background-size: cover;
  background-position: center;
  cursor: zoom-in;
  transition: filter 220ms var(--ease-out), transform 220ms var(--ease-out);
  display: block;
  width: 100%;
}
.post-body__img:hover { filter: brightness(1.05); transform: scale(1.005); }
.post-body__fig figcaption {
  margin-top: 0.65rem;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
  line-height: 1.5;
}

/* Image pairs & triple — more breathing room */
.post-body__pair,
.post-body__triple { gap: 1rem; }
.post-body__pair > div .post-body__img,
.post-body__triple > div .post-body__img { aspect-ratio: 4/3; }
.post-body__fig--pair .post-body__pair figcaption,
.post-body__fig--triple .post-body__triple figcaption { font-size: 0.68rem; margin-top: 0.4rem; }

/* 4-image grid */
.post-body__image-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.post-body__image-grid > div .post-body__img { aspect-ratio: 4/3; }

/* Before/after */
.before-after { gap: 1rem; }
.before-after__pane { position: relative; }
.before-after__pane > span {
  position: absolute; top: 0.7rem; left: 0.7rem;
  font-family: var(--font-ui); font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  background: var(--accent); color: #120904;
  padding: 0.2rem 0.55rem; z-index: 2; pointer-events: none;
}
.before-after__pane:last-child > span { background: var(--bg-2); color: var(--ink); border: 1px solid var(--line-strong); }

/* Quote — more prominent */
.post-body__quote {
  margin: 2.5rem 0;
  padding: 1.4rem 1.8rem;
  border-left: 3px solid var(--accent);
  background: rgba(236,231,75,0.05);
  position: relative;
}
.post-body__quote::before {
  content: '"';
  position: absolute;
  top: -0.2rem; left: 1.2rem;
  font-family: var(--font-display);
  font-size: 3.5rem;
  color: var(--accent);
  opacity: 0.25;
  line-height: 1;
  pointer-events: none;
}
.post-body__quote p { font-size: 1.15rem; line-height: 1.55; }

/* Callout / note — cleaner */
.post-body__callout {
  margin: 2rem 0;
  padding: 1.1rem 1.4rem;
  border: 1px solid var(--accent-line);
  background: rgba(236,231,75,0.04);
  display: grid; gap: 0.4rem;
}
.post-body__callout > span {
  font-family: var(--font-ui);
  font-size: 0.68rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--accent);
}
.post-body__callout h4 { margin: 0; font-size: 0.95rem; color: var(--ink); }
.post-body__callout p { margin: 0; font-size: 0.95rem; color: var(--ink-soft); }
.post-body__note {
  margin: 1.5rem 0;
  padding: 1rem 1.25rem;
  border-left: 2px solid var(--line-strong);
  background: color-mix(in srgb, var(--bg-2) 80%, transparent);
  display: grid; gap: 0.3rem;
}
.post-body__note > span {
  font-family: var(--font-ui); font-size: 0.68rem;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute);
}
.post-body__note p { margin: 0; font-size: 0.92rem; color: var(--ink-soft); }

/* Stats row — wider, more visual */
.post-body__stats {
  display: flex; flex-wrap: wrap; gap: 0;
  margin: 2rem 0;
  border: 1px solid var(--line-strong);
}
.post-body__stat {
  flex: 1 1 120px;
  padding: 1.2rem 1.4rem;
  border-right: 1px solid var(--line-strong);
  display: flex; flex-direction: column; gap: 0.2rem;
}
.post-body__stat:last-child { border-right: none; }
.post-body__stat strong {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--accent); line-height: 1;
}
.post-body__stat span { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }

/* Features block */
.post-body__features { margin: 2rem 0; }
.post-body__features h4 { margin: 0 0 1rem; font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-mute); }
.post-body__feature-grid { display: grid; gap: 0.5rem; }
.post-body__feature {
  display: grid; grid-template-columns: 2.5rem 1fr;
  gap: 0.6rem 1rem; align-items: start;
  padding: 0.85rem 1rem;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 72%, transparent);
}
.post-body__feature > span { font-family: var(--font-ui); font-size: 0.72rem; font-weight: 800; color: var(--accent); line-height: 2; }
.post-body__feature > strong { font-size: 0.95rem; color: var(--ink); }
.post-body__feature > p { grid-column: 2; margin: 0; font-size: 0.88rem; color: var(--ink-soft); line-height: 1.55; }

/* 2-column layout */
.post-body__columns {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
  margin: 2rem 0;
  padding: 1.4rem;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 60%, transparent);
}
.post-body__columns h4 { font-size: 0.88rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink); margin: 0 0 0.6rem; }
.post-body__columns p { font-size: 0.92rem; color: var(--ink-soft); margin: 0; line-height: 1.65; }
@media (max-width: 640px) { .post-body__columns { grid-template-columns: 1fr; } }

/* Table */
.post-body__table { margin: 2rem 0; overflow-x: auto; }
.post-body__table h4 { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 0.75rem; }
.post-body__table table { width: 100%; border-collapse: collapse; }
.post-body__table th { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); padding: 0.75rem 1rem; text-align: left; border-bottom: 2px solid var(--accent-line); }
.post-body__table td { padding: 0.7rem 1rem; border-bottom: 1px solid var(--line); font-size: 0.92rem; color: var(--ink-soft); }
.post-body__table tr:hover td { background: rgba(236,231,75,0.03); }

/* Timeline */
.post-body__timeline { margin: 2rem 0; }
.post-body__timeline h4 { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 1rem; }
.post-body__timeline ol { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.5rem; }
.post-body__timeline li {
  display: grid; grid-template-columns: auto 1fr;
  gap: 0 1.1rem; align-items: baseline;
  padding: 0.7rem 0;
  border-bottom: 1px solid var(--line);
  counter-increment: timeline;
}
.post-body__timeline li::before {
  content: counter(timeline, decimal-leading-zero);
  font-family: var(--font-ui); font-size: 0.68rem; font-weight: 800;
  color: var(--accent); letter-spacing: 0.08em; line-height: 1.8;
}
.post-body__timeline li strong { font-size: 0.92rem; color: var(--ink); }
.post-body__timeline li span { grid-column: 2; font-size: 0.88rem; color: var(--ink-soft); margin-top: 0.15rem; }

/* CTA block */
.post-body__cta {
  margin: 2rem 0;
  padding: 1.4rem 1.6rem;
  border: 1px solid var(--accent-line);
  background: rgba(236,231,75,0.04);
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
}
.post-body__cta h4 { margin: 0 0 0.3rem; font-size: 1rem; color: var(--ink); }
.post-body__cta p { margin: 0; font-size: 0.9rem; color: var(--ink-soft); }

/* Download */
.post-body__download {
  margin: 2rem 0;
  padding: 1.2rem 1.4rem;
  border: 1px solid var(--line-strong);
  background: color-mix(in srgb, var(--bg-2) 72%, transparent);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}
.post-body__download strong { display: block; font-size: 0.92rem; color: var(--ink); }
.post-body__download span { font-size: 0.85rem; color: var(--ink-soft); }

/* Divider */
.post-body__divider {
  margin: 2.5rem 0;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 1rem;
}
.post-body__divider::before,
.post-body__divider::after { content: ''; height: 1px; background: var(--line-strong); }
.post-body__divider::before { content: '···'; font-size: 1.2rem; color: var(--accent); letter-spacing: 0.4em; display: block; text-align: center; grid-column: 1 / -1; background: none; height: auto; }

/* List block */
.post-body__list { margin: 1.5rem 0; }
.post-body__list h4 { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 0.65rem; }
.post-body__list ul { padding-left: 1.2rem; margin: 0; }
.post-body__list li { font-size: 0.95rem; color: var(--ink-soft); line-height: 1.65; padding: 0.2rem 0; }

/* Embed */
.post-body__embed { margin: 2rem 0; position: relative; padding-top: var(--embed-h, 480px); }
.post-body__embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

/* Media+Text block */
.post-body__media-text {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
  margin: 2rem 0; align-items: start;
}
.post-body__media-text.is-reverse { direction: rtl; }
.post-body__media-text.is-reverse > * { direction: ltr; }
.post-body__media-text-media .post-body__img { aspect-ratio: 4/3; }
.post-body__media-text-copy { padding-top: 0.3rem; }
.post-body__media-text-copy h3 { font-family: var(--font-display); font-size: clamp(1.2rem, 2vw, 1.55rem); text-transform: uppercase; color: var(--ink); margin: 0 0 0.8rem; }
.post-body__media-text-copy p { font-size: 0.95rem; color: var(--ink-soft); line-height: 1.72; margin: 0; }
@media (max-width: 640px) { .post-body__media-text { grid-template-columns: 1fr; } }

/* Audio block */
.post-body__audio-block { margin: 1.5rem 0; padding: 1.2rem 1.4rem; border: 1px solid var(--line); background: color-mix(in srgb, var(--bg-2) 72%, transparent); }
.post-body__audio-block h4 { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 0.65rem; }
.post-body__audio-block audio { width: 100%; }

/* Video block */
.post-body__fig--video .post-body__video {
  width: 100%; max-height: 480px; display: block;
  background: var(--bg-0);
}

/* ═══════════════════════════════════════════════════════════════
   IMAGE LIGHTBOX — full-screen viewer for post images
   ═══════════════════════════════════════════════════════════════ */
.post-lightbox {
  position: fixed; inset: 0; z-index: 2000;
  display: none; align-items: center; justify-content: center;
  background: rgba(8,7,5,0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  cursor: zoom-out;
}
.post-lightbox.is-open { display: flex; animation: lightboxIn 200ms var(--ease-out) both; }
@keyframes lightboxIn { from { opacity: 0; } to { opacity: 1; } }
.post-lightbox__img {
  max-width: 92vw;
  max-height: 90vh;
  object-fit: contain;
  cursor: default;
  box-shadow: 0 40px 120px -40px rgba(0,0,0,0.9);
  user-select: none;
  display: block;
}
.post-lightbox__close {
  position: absolute; top: 1rem; right: 1rem;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: rgba(234,228,218,0.08);
  border: 1px solid rgba(234,228,218,0.15);
  color: var(--ink-soft); font-size: 1.25rem;
  cursor: pointer;
  transition: background 180ms, color 180ms;
}
.post-lightbox__close:hover { background: rgba(236,231,75,0.18); color: var(--accent); }
.post-lightbox__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 48px; height: 80px;
  display: grid; place-items: center;
  background: rgba(234,228,218,0.06);
  border: 1px solid rgba(234,228,218,0.12);
  color: var(--ink-soft); font-size: 1.2rem;
  cursor: pointer;
  transition: background 180ms, color 180ms;
}
.post-lightbox__nav:hover { background: rgba(236,231,75,0.18); color: var(--accent); }
.post-lightbox__prev { left: 0.75rem; }
.post-lightbox__next { right: 0.75rem; }
.post-lightbox__caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 0.75rem 2rem;
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute); text-align: center;
  background: linear-gradient(transparent, rgba(8,7,5,0.7));
}
.post-lightbox__counter {
  position: absolute; top: 1.1rem; left: 50%; transform: translateX(-50%);
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
}
/* Make post-body images show zoom cursor */
.post__body .post-body__img[data-src] { cursor: zoom-in; }

/* ═══════════════════════════════════════════════════════════════
   BLOG LISTING IMPROVEMENTS
   ═══════════════════════════════════════════════════════════════ */
.blog-row__read-time {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-family: var(--font-ui); font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute);
}

/* ═══════════════════════════════════════════════════════════════
   BLOCK EDITOR IMPROVEMENTS — v10
   Cleaner add-block toolbar, better block cards, drag handles
   ═══════════════════════════════════════════════════════════════ */

/* Block toolbar — grouped by category */
.owner-builder__actions { gap: 0.35rem; align-items: center; }
.owner-builder__action-group {
  display: flex; flex-wrap: wrap; gap: 0.3rem;
  padding: 0.4rem 0.6rem;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-1) 70%, transparent);
}
.owner-builder__action-label {
  width: 100%; font-family: var(--font-ui); font-size: 0.6rem; font-weight: 800;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute);
  margin-bottom: 0.2rem; padding: 0;
}
.owner-builder__actions--templates { flex-direction: column; gap: 0.5rem; }

/* Block cards */
.owner-block {
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-1) 82%, transparent);
  position: relative;
  transition: border-color 150ms, box-shadow 150ms;
}
.owner-block:focus-within { border-color: var(--accent-line); }
.owner-block__head {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.6rem 0.75rem;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 60%, transparent);
  cursor: grab;
  user-select: none;
}
.owner-block__drag-handle {
  flex-shrink: 0;
  display: grid; place-items: center;
  width: 22px; height: 22px;
  color: var(--ink-mute);
  opacity: 0.5;
  cursor: grab;
  font-size: 0.9rem;
}
.owner-block__drag-handle:hover { opacity: 1; color: var(--accent); }
.owner-block__actions { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-left: auto; }
.owner-block__actions button {
  border: 1px solid var(--line-strong);
  background: rgba(234,228,218,0.035);
  color: var(--ink-soft);
  font-family: var(--font-ui); font-size: 0.62rem;
  font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.3rem 0.55rem;
  cursor: pointer;
  transition: border-color 120ms, background 120ms, color 120ms;
}
.owner-block__actions button:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.owner-block__actions button.del-btn:hover { border-color: #ff5050; color: #ff5050; background: rgba(255,80,80,0.08); }
.owner-block__body { display: grid; gap: 0.6rem; padding: 0.85rem; }
.owner-block-input { font-family: inherit; font-size: 0.9rem; }

/* Drop zone improvements */
.owner-block-image-drop {
  min-height: 90px;
  border: 1px dashed var(--accent-line);
  background: color-mix(in srgb, var(--bg-2) 64%, transparent);
  cursor: pointer;
  transition: border-color 150ms, background 150ms, transform 150ms;
}
.owner-block-image-drop:hover,
.owner-block-image-drop.is-dragging {
  border-color: var(--accent);
  background: var(--accent-soft);
  transform: scale(1.005);
}
.owner-block-image-drop span {
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-mute); text-align: center;
  padding: 1rem;
  display: flex; align-items: center; justify-content: center; height: 100%;
}

/* Block preview images */
.owner-block-image-preview {
  min-height: 140px; background-size: cover; background-position: center;
  border: 1px solid var(--line-strong);
  position: relative;
  overflow: hidden;
}
.owner-block-image-preview::after {
  content: '🔍 Click image to zoom';
  display: none;
}

/* Two-image/three-image side-by-side layout inside blocks */
.owner-two-image-editor { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.owner-three-image-editor { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.6rem; }
@media (max-width: 640px) {
  .owner-two-image-editor { grid-template-columns: 1fr; }
  .owner-three-image-editor { grid-template-columns: 1fr 1fr; }
}

/* Fit label inside block */
.owner-block-fit-label {
  display: flex; align-items: center; gap: 0.6rem;
  font-family: var(--font-ui); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute);
}
.owner-block-fit-label .owner-block-fit-select { font-size: 0.75rem; flex: 1; min-width: 0; }

/* Block section builder header improvements */
.owner-builder__head { flex-wrap: wrap; }
.owner-builder__head > div { flex: 1 1 auto; }
.owner-builder__head .owner-builder__actions--templates { flex: 1 1 100%; }

/* Builder empty state */
.owner-builder__empty {
  text-align: center; padding: 2.5rem 1rem;
  font-family: var(--font-ui); font-size: 0.82rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute);
}
.owner-builder__tip {
  display: flex; flex-wrap: wrap; gap: 0.4rem 0.65rem;
  align-items: center; padding: 0.65rem 1rem;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 60%, transparent);
}

/* Block type badge improvements — clearer visual weight */
.owner-block-pill { font-size: 0.65rem; letter-spacing: 0.06em; padding: 3px 10px; border-radius: 2px; }

/* Blog editor tabs — cleaner panel switch */
.owner-blog-panel-inner--basic { display: grid; gap: 1.1rem; }
.owner-blog-card {
  padding: 1.1rem 1rem;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 72%, transparent);
  display: grid; gap: 0.85rem;
}
.owner-blog-card__head { display: flex; flex-direction: column; gap: 0.1rem; margin-bottom: 0.2rem; }
.owner-blog-card__head strong { font-family: var(--font-ui); font-size: 0.8rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink); }
.owner-blog-card__head span { font-size: 0.82rem; color: var(--ink-mute); }

/* Blog save bar improvements */
.owner-blog-save-bar {
  position: sticky; bottom: 0;
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.75rem; padding: 0.85rem 1rem;
  border-top: 1px solid var(--accent-line);
  background: color-mix(in srgb, var(--bg-2) 96%, transparent);
  backdrop-filter: blur(12px);
  margin: 0;
}
.owner-blog-save-meta {
  display: flex; align-items: center; gap: 0.55rem;
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute);
}
.owner-save-dot { width: 8px; height: 8px; background: rgba(245,200,66,0.8); border-radius: 50%; flex-shrink: 0; }
.owner-save-flash { animation: saveFlash 0.5s ease; }
@keyframes saveFlash { 0%,100% { color: var(--ink-mute); } 50% { color: var(--accent); } }

/* Status pills */
.owner-status-pill {
  padding: 0.35rem 0.8rem;
  font-family: var(--font-ui); font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  border: 1px solid var(--line-strong);
  background: transparent; color: var(--ink-soft);
  cursor: pointer;
  transition: border-color 150ms, background 150ms, color 150ms;
}
.owner-status-pill:hover { border-color: var(--accent); color: var(--ink); }
.owner-status-pill.active-published { background: rgba(20,180,90,0.14); border-color: rgba(20,180,90,0.35); color: #20c060; }
.owner-status-pill.active-draft { background: rgba(245,200,66,0.12); border-color: rgba(245,200,66,0.34); color: #f5c842; }
.owner-status-pill.active-featured { background: rgba(236,231,75,0.20); border-color: rgba(236,231,75,0.50); color: var(--accent); }

/* Toggle switch in settings */
.owner-toggle-switch {
  appearance: none;
  width: 40px; height: 22px;
  background: var(--line-strong);
  border-radius: 11px;
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 200ms;
}
.owner-toggle-switch::after {
  content: ''; position: absolute;
  top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--ink-soft);
  transition: transform 200ms var(--ease-out), background 200ms;
}
.owner-toggle-switch:checked { background: var(--accent); }
.owner-toggle-switch:checked::after { transform: translateX(18px); background: #fff; }

/* Extra media cards — improved layout */
.owner-extra-card {
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-1) 80%, transparent);
  display: grid; grid-template-columns: 140px 1fr;
}
.owner-extra-card__preview {
  aspect-ratio: 4/3;
  background-size: cover; background-position: center;
  position: relative; overflow: hidden;
  border-right: 1px solid var(--line);
  cursor: pointer;
}
.owner-extra-card__body { padding: 0.7rem 0.75rem; display: grid; gap: 0.45rem; }
.owner-extra-card__body > label { font-family: var(--font-ui); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.owner-extra-card__fit-row { display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-ui); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); }
.owner-extra-card__actions { display: flex; flex-wrap: wrap; gap: 0.3rem; }
.owner-extra-card__actions button {
  font-family: var(--font-ui); font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.3rem 0.55rem;
  border: 1px solid var(--line-strong);
  background: transparent; color: var(--ink-soft);
  cursor: pointer;
  transition: border-color 120ms, color 120ms, background 120ms;
}
.owner-extra-card__actions button:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
@media (max-width: 540px) {
  .owner-extra-card { grid-template-columns: 1fr; }
  .owner-extra-card__preview { aspect-ratio: 16/9; border-right: none; border-bottom: 1px solid var(--line); }
}


/* Block drag state */
.owner-block.is-dragging { opacity: 0.45; border-color: var(--accent); }
.owner-block[draggable="true"] { cursor: default; }
.owner-block__head { cursor: grab; }
.owner-block__head:active { cursor: grabbing; }

/* Media loading state in lightbox */
.post-lightbox__img { transition: opacity 200ms; }
.post-lightbox.is-loading .post-lightbox__img { opacity: 0.3; }

/* Post hero improvements */
/* post container — see layout overhaul block below for active rules */
.post__head { padding: clamp(1.5rem, 3vw, 2.5rem); }
.post__body { padding: clamp(1.25rem, 2.4vw, 2.5rem); }

/* ─── Improved block add buttons within groups ─── */
.owner-builder__action-group button {
  padding: 0.38rem 0.65rem;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
}
.owner-builder__action-group {
  border-radius: 2px;
}

/* Image zoom click hint */
.post__body .post-body__fig:hover figcaption::after {
  content: ' — click to enlarge';
  color: var(--accent);
  opacity: 0.7;
  font-style: italic;
}


/* ═══════════════════════════════════════════════════════════════
   POST PAGE — LAYOUT OVERHAUL (replaces cramped defaults)
   Goals: wider reading column, sidebar doesn't choke body,
          typography breathes, hero and body feel aligned.
   ═══════════════════════════════════════════════════════════════ */

/* 1. Hide the read-time pill entirely */
.post__read-time { display: none !important; }

/* 2. Widen the overall post container so it matches the hero width */
.post {
  max-width: 1280px !important;
  padding: calc(var(--header-h) + 2.5rem) var(--gutter) 5rem !important;
}

/* 3. Post head — let it breathe, remove the 78ch cap */
.post__head {
  max-width: none !important;
  gap: 1rem !important;
  margin-bottom: 2.5rem !important;
  padding: clamp(1.5rem, 3vw, 2.5rem) !important;
}

/* 4. Hero — full width of the post container, taller on widescreen */
.post__hero {
  aspect-ratio: 21 / 8 !important;
  margin-bottom: 0 !important;
  width: 100% !important;
}
@media (max-width: 880px) {
  .post__hero { aspect-ratio: 16 / 9 !important; }
}

/* 5. Post layout — body gets most space, sidebar is narrower and optional */
.post__layout {
  display: grid !important;
  grid-template-columns: 1fr 240px !important;
  gap: clamp(1.5rem, 3vw, 2.5rem) !important;
  align-items: start !important;
  margin-bottom: 4rem !important;
  margin-top: 0 !important;
}

/* 6. Body — remove the hard 72ch cap, let it expand with the grid */
.post__body {
  max-width: none !important;
  min-width: 0 !important;
  padding: clamp(1.75rem, 3vw, 2.75rem) !important;
}

/* 7. Sidebar — narrower, less dominant */
.post__aside {
  padding: 1.1rem !important;
  padding-left: 1.1rem !important;
  border-left: 1px solid var(--line) !important;
  gap: 1.4rem !important;
}

/* 8. Typography — better paragraph size and rhythm */
.post-body__p {
  font-size: 1.08rem !important;
  line-height: 1.85 !important;
  color: var(--ink-soft) !important;
  margin: 0 0 1.5rem !important;
  letter-spacing: 0.01em !important;
}
.post-body__p:last-child { margin-bottom: 0 !important; }

/* 9. Section headings — larger, better separation */
.post-body__h {
  font-size: clamp(1.35rem, 2.4vw, 1.95rem) !important;
  margin: 3.5rem 0 1.1rem !important;
  letter-spacing: 0.015em !important;
  line-height: 1.05 !important;
  padding-top: 0 !important;
  border-top: none !important;
}
.post-body__h:first-child { margin-top: 0 !important; }

/* 10. Post title — bigger and bolder */
.post__title {
  font-size: clamp(2.6rem, 5.5vw, 4.8rem) !important;
  max-width: none !important;
  line-height: 0.94 !important;
}

/* 11. Excerpt — slightly larger for better hierarchy */
.post__excerpt {
  font-size: 1.1rem !important;
  line-height: 1.7 !important;
  max-width: none !important;
  color: var(--ink-soft) !important;
}

/* 12. Figure / image blocks — match body width */
.post-body__fig {
  margin: 2.5rem -0.5rem !important;
}
.post-body__fig figcaption {
  font-size: 0.73rem !important;
  letter-spacing: 0.18em !important;
  margin-top: 0.7rem !important;
  padding: 0 0.5rem !important;
}

/* 13. Hero + body visually aligned — zero gap between hero and body section */
.post__layout {
  border-top: 1px solid var(--line) !important;
  padding-top: 0 !important;
}
.post__body {
  border-right: 1px solid var(--line) !important;
}

/* 14. Responsive — sidebar collapses below article on narrow screens */
@media (max-width: 1000px) {
  .post__layout {
    grid-template-columns: 1fr 200px !important;
  }
}
@media (max-width: 800px) {
  .post__layout {
    grid-template-columns: 1fr !important;
  }
  .post__aside {
    position: static !important;
    padding-left: 0 !important;
    border-left: none !important;
    border-top: 1px solid var(--line) !important;
    padding-top: 1.4rem !important;
  }
  .post__body {
    border-right: none !important;
  }
}

/* 15. TOC links — more readable */
.post__toc a {
  font-size: 0.8rem !important;
  line-height: 1.6 !important;
  letter-spacing: 0.04em !important;
  text-transform: none !important;
}

/* 16. Meta row — keep it minimal without the read-time clutter */
.post__meta {
  gap: 0.5rem !important;
  font-size: 0.74rem !important;
  letter-spacing: 0.26em !important;
}

/* 17. Aside labels */
.post__aside-block .label {
  font-size: 0.68rem !important;
  letter-spacing: 0.28em !important;
  margin-bottom: 0.5rem !important;
}

/* 18. Post-breakdown section — full width alignment */
.post-breakdown {
  padding: clamp(1.5rem, 3vw, 2.5rem) !important;
  margin-bottom: 2rem !important;
}

/* 19. Post nav — full width */
.post__nav { margin-bottom: 3rem !important; }


/* Game post extra-media uploader — drag/drop improvements */
.owner-extra-media--game {
  position: relative;
  border-top-color: var(--accent-line);
  background: linear-gradient(180deg, rgba(236,231,75,0.055), rgba(0,0,0,0.08));
}
.owner-extra-media--game .owner-extra-media__head strong {
  color: var(--accent);
}
.owner-extra-media__drop--top {
  min-height: 116px;
  border-width: 2px;
  border-style: dashed;
  border-radius: 0.75rem;
  background: linear-gradient(135deg, rgba(236,231,75,0.10), rgba(234,228,218,0.025));
}
.owner-extra-media--game .owner-extra-media__drop--top span {
  max-width: 520px;
  line-height: 1.55;
}
.owner-extra-media--game .owner-extra-media__drop--top span::after {
  content: 'Adds to the game media carousel automatically';
  display: block;
  margin-top: 0.35rem;
  font-size: 0.64rem;
  letter-spacing: 0.14em;
  color: var(--accent);
}
.owner-extra-media.is-dragging-files {
  outline: 2px dashed var(--accent);
  outline-offset: -6px;
  box-shadow: 0 0 0 3px var(--accent-soft), var(--shadow-glow);
}
.owner-extra-media.is-dragging-files .owner-extra-media__drop--top {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(236,231,75,0.16);
}
.owner-extra-card__preview::after {
  content: 'drop / click replace';
  position: absolute;
  left: 0.45rem;
  bottom: 0.45rem;
  padding: 0.18rem 0.38rem;
  border: 1px solid rgba(234,228,218,0.16);
  background: rgba(0,0,0,0.58);
  color: rgba(234,228,218,0.78);
  font-family: var(--font-ui);
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity 140ms ease;
  pointer-events: none;
}
.owner-extra-card__preview:hover::after,
.owner-extra-card__preview.is-dragging::after {
  opacity: 1;
}
[data-theme="light"] .owner-extra-media--game {
  background: linear-gradient(180deg, rgba(146,92,61,0.08), rgba(255,255,255,0.4));
}
[data-theme="light"] .owner-extra-card__preview::after {
  background: rgba(252,248,239,0.88);
  color: var(--accent);
}

/* ==========================================================================
   SEAMLESS SMART LAZY-LOAD PATCH — v11
   Visible cards load immediately; near-next cards preload before the user sees
   them; far-away media stays deferred to keep the gallery light.
   ========================================================================== */
.work__img,
.arc-item__img,
.blog-row__thumb-img,
.game-card__img,
.featured-card__img,
.case-preview__img,
.post-body__img {
  background-color: rgba(234, 228, 218, 0.025);
}

.work__img.is-bg-loading,
.arc-item__img.is-bg-loading,
.blog-row__thumb-img.is-bg-loading,
.game-card__img.is-bg-loading,
.featured-card__img.is-bg-loading,
.case-preview__img.is-bg-loading,
.post-body__img.is-bg-loading {
  background-image:
    linear-gradient(105deg,
      rgba(234, 228, 218, 0.025) 0%,
      rgba(234, 228, 218, 0.07) 42%,
      rgba(234, 228, 218, 0.025) 78%) !important;
  background-size: 220% 100% !important;
  animation: ok-media-loading-sweep 1.15s linear infinite;
}

.work__img.is-bg-ready,
.arc-item__img.is-bg-ready,
.blog-row__thumb-img.is-bg-ready,
.game-card__img.is-bg-ready,
.featured-card__img.is-bg-ready,
.case-preview__img.is-bg-ready,
.post-body__img.is-bg-ready {
  animation: none;
}

@keyframes ok-media-loading-sweep {
  from { background-position: 140% 0; }
  to { background-position: -80% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .work__img.is-bg-loading,
  .arc-item__img.is-bg-loading,
  .blog-row__thumb-img.is-bg-loading,
  .game-card__img.is-bg-loading,
  .featured-card__img.is-bg-loading,
  .case-preview__img.is-bg-loading,
  .post-body__img.is-bg-loading {
    animation: none !important;
  }
}

/* PATCH — clearer game post media flow + per-picture fit controls */
.owner-cms-flow{
  display:grid;
  gap:.35rem;
  margin-top:.65rem;
  padding:.65rem .75rem;
  border:1px solid rgba(236,231,75,.24);
  background:rgba(0,0,0,.18);
}
.owner-cms-flow b,
.owner-cms-flow strong{
  color:var(--accent);
}
.owner-cms-flow span{
  display:block;
  color:rgba(234,228,218,.72);
  letter-spacing:.06em;
}
.owner-image-panel__guide{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.6rem;
  padding:.75rem 1rem;
  border-bottom:1px solid rgba(236,231,75,.16);
  background:linear-gradient(135deg,rgba(236,231,75,.08),rgba(0,0,0,.08));
  font-family:var(--font-ui,'Rajdhani',sans-serif);
  font-size:.72rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(234,228,218,.56);
}
.owner-image-panel__guide b{
  color:var(--accent);
}
.owner-fit-row--split{
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-items:start;
}
.owner-fit-control{
  display:grid;
  gap:.42rem;
}
.owner-fit-control span{
  color:rgba(234,228,218,.48);
  font-size:.72rem;
  line-height:1.45;
}
.owner-extra-card__hint{
  color:rgba(234,228,218,.45);
  font-size:.7rem;
  line-height:1.35;
}
.game-detail__media-kind{
  min-width:92px;
  text-align:center;
}
.game-detail__thumb-label{
  text-shadow:0 1px 10px rgba(0,0,0,.85);
}
[data-theme="light"] .owner-cms-flow,
[data-theme="light"] .owner-image-panel__guide{
  background:rgba(236,231,75,.06);
}
[data-theme="light"] .owner-cms-flow span,
[data-theme="light"] .owner-image-panel__guide,
[data-theme="light"] .owner-fit-control span,
[data-theme="light"] .owner-extra-card__hint{
  color:rgba(20,20,24,.68);
}
@media (max-width:760px){
  .owner-image-panel__guide,
  .owner-fit-row--split{
    grid-template-columns:1fr;
  }
}

/* ── Contact social links with icons ── */
.contact-social-links{display:flex;flex-direction:column;gap:0.1rem}
.contact-social-link{display:flex;align-items:center;gap:0.75rem;padding:0.55rem 0.7rem;color:var(--ink-soft);font-family:var(--font-ui);font-size:0.82rem;letter-spacing:0.14em;text-transform:uppercase;border:1px solid transparent;border-radius:2px;transition:color 180ms var(--ease-out),background 180ms var(--ease-out),border-color 180ms var(--ease-out)}
.contact-social-link:hover{color:var(--ink);background:rgba(234,228,218,0.04);border-color:var(--line)}
.contact-social-icon{width:1.1rem;height:1.1rem;flex-shrink:0;opacity:0.7;transition:opacity 180ms var(--ease-out)}
.contact-social-link:hover .contact-social-icon{opacity:1}

/* ── About page tool badges with icons ── */
.about-tools-list{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:0.9rem}
.about-tool-badge{display:inline-flex;align-items:center;gap:0.45rem;padding:0.3rem 0.7rem 0.3rem 0.4rem;background:rgba(234,228,218,0.05);border:1px solid var(--line);font-family:var(--font-ui);font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft);transition:border-color 180ms,background 180ms}
.about-tool-badge:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--ink)}
.about-tool-badge__icon{width:18px;height:18px;flex-shrink:0;object-fit:contain;display:block}
.about-tool-badge__fallback{width:18px;height:18px;flex-shrink:0;border-radius:3px;display:grid;place-items:center;font-size:0.55rem;font-weight:700;color:#fff;background:var(--bg-3)}

/* ── Gallery / Portfolio section header — prevent title clip ── */
.page-archive section:first-of-type,
.page-portfolio .selector__inner,
.category-view{overflow:visible}
.page-archive .title-xxl,
.category-view .title-xl,
.about-section .title-xxl{overflow:visible;clip:unset;-webkit-clip-path:none;clip-path:none}

/* ── About header responsive ── */
@media(max-width:860px){
  .about-header{grid-template-columns:1fr}
  .about-header__meta{display:none}
  .about-grid{grid-template-columns:1fr}
  .about-portrait{max-width:360px}
}

/* ── Blog post wider layout + sticky TOC sidebar ── */
.post__aside{position:sticky;top:calc(var(--header-h) + 1.5rem);max-height:calc(100vh - var(--header-h) - 3rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--accent) transparent;font-size:0.82rem}
.post__toc{display:flex;flex-direction:column;gap:0.15rem}
.post__toc a{display:block;padding:0.35rem 0.5rem;color:var(--ink-mute);font-family:var(--font-ui);font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;line-height:1.35;border-left:2px solid transparent;transition:color 180ms,border-color 180ms,background 180ms}
.post__toc a:hover{color:var(--ink);border-left-color:var(--accent-line);background:rgba(236,231,75,0.06)}
.post__head{max-width:none}
.post__title{max-width:none}
.post__excerpt{max-width:none}

/* Blog video hover play indicator */
.post-body__fig--video{position:relative;cursor:pointer}
.post-body__video{width:100%;display:block;background:#000}

/* YouTube embed stability / Error 153 fallback */
.post-body__embed--youtube,
.post-body__video-wrap--youtube {
  overflow: hidden;
  border-radius: var(--radius-md, 18px);
  background: rgba(4, 13, 17, 0.78);
  border: 1px solid rgba(116, 255, 242, 0.16);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.34), inset 0 0 0 1px rgba(232, 192, 32, 0.05);
}

.post-body__embed--youtube iframe,
.post-body__video-wrap--youtube iframe {
  background: #05080a;
}

.post-body__embed-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  min-height: 44px;
  padding: .85rem 1rem;
  border-top: 1px solid rgba(116, 255, 242, 0.13);
  background: linear-gradient(90deg, rgba(1, 18, 24, 0.82), rgba(16, 31, 33, 0.72));
  color: var(--accent, #74fff2);
  font-family: var(--font-ui, inherit);
  font-size: .82rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-decoration: none;
}

.post-body__embed-fallback:hover {
  color: var(--gold, #e8c020);
  background: linear-gradient(90deg, rgba(6, 28, 34, 0.92), rgba(26, 40, 37, 0.82));
}

/* Robust YouTube embed fallback: avoids showing a broken Error 153 player in file:// mode. */
.post-body__embed--youtube-card {
  padding-top: 0 !important;
  min-height: var(--embed-h, 480px);
}

.post-body__embed--youtube-card .youtube-card {
  position: relative;
  min-height: var(--embed-h, 480px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(3, 18, 22, .38), rgba(7, 8, 10, .92)),
    var(--youtube-thumb) center/cover no-repeat,
    radial-gradient(circle at 30% 20%, rgba(116,255,242,.16), transparent 36%),
    #05080a;
}

.youtube-card__shade {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 74% 22%, rgba(232,192,32,.18), transparent 28%),
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.74));
  pointer-events: none;
}

.youtube-card__content {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100% - 2rem));
  margin: clamp(1rem, 4vw, 2.4rem);
  padding: clamp(1.1rem, 3vw, 1.7rem);
  border: 1px solid rgba(116, 255, 242, .18);
  border-radius: var(--radius-md, 18px);
  background: rgba(2, 12, 16, .72);
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 70px rgba(0,0,0,.45), inset 0 0 0 1px rgba(232,192,32,.05);
}

.youtube-card__eyebrow {
  display: inline-flex;
  margin-bottom: .45rem;
  font-family: var(--font-ui, inherit);
  font-size: .72rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--accent, #74fff2);
}

.youtube-card__content h4 {
  margin: 0 0 .6rem;
  color: var(--ink, #f4f4ef);
  font-size: clamp(1.25rem, 3vw, 2rem);
}

.youtube-card__content p {
  max-width: 62ch;
  margin: 0 0 1rem;
  color: var(--ink-soft, rgba(244,244,239,.72));
  line-height: 1.65;
}

.youtube-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.post-body__embed--youtube .post-body__embed-fallback {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .65rem 1rem;
  padding: .9rem 1rem;
}

.post-body__embed--youtube .post-body__embed-fallback span {
  color: var(--ink-soft, rgba(244,244,239,.7));
}

.post-body__embed--youtube .post-body__embed-fallback a {
  color: var(--accent, #74fff2);
  text-decoration: none;
}

.post-body__embed--youtube .post-body__embed-fallback a:hover {
  color: var(--gold, #e8c020);
}

@media (max-width: 680px) {
  .post-body__embed--youtube-card,
  .post-body__embed--youtube-card .youtube-card {
    min-height: min(var(--embed-h, 420px), 440px);
  }

  .youtube-card__actions .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════════════════
   BLOG POST READABILITY + SIDE TOC POLISH
   - Wider main article column so text/media line up with the hero
   - Cleaner sticky table of contents on the right side
   - Larger clickable TOC targets and active section highlight
   ═══════════════════════════════════════════════════════════════ */
.page-post .post{
  max-width:min(96vw,1660px) !important;
  padding-left:clamp(1.25rem,2.5vw,3rem) !important;
  padding-right:clamp(1.25rem,2.5vw,3rem) !important;
}
.page-post .post__hero{
  border-bottom:1px solid var(--line-strong) !important;
}
.page-post .post__layout{
  grid-template-columns:minmax(0,1fr) clamp(260px,19vw,330px) !important;
  gap:clamp(1rem,2.1vw,2.4rem) !important;
  border-top:0 !important;
  align-items:start !important;
}
.page-post .post__body{
  padding:clamp(2rem,3.2vw,3.4rem) !important;
  border-right:0 !important;
  background:linear-gradient(180deg,rgba(21,23,28,.72),rgba(11,12,16,.86)) !important;
}
.page-post .post-body__p,
.page-post .post-body__h,
.page-post .post-body__quote,
.page-post .post-body__callout,
.page-post .post-body__note,
.page-post .post-body__list,
.page-post .post-body__columns,
.page-post .post-body__features,
.page-post .post-body__table,
.page-post .post-body__timeline,
.page-post .post-body__cta,
.page-post .post-body__download{
  max-width:112ch;
}
.page-post .post-body__fig,
.page-post .post-body__stats,
.page-post .post-body__image-grid,
.page-post .post-body__media-text{
  max-width:none;
}
.page-post .post-body__p{
  font-size:clamp(1.04rem,.62vw + .88rem,1.18rem) !important;
  line-height:1.88 !important;
}
.page-post .post-body__h{
  max-width:34ch;
  scroll-margin-top:calc(var(--header-h) + 2rem);
}
.page-post .post-body__fig{
  margin:2.6rem 0 !important;
}
.page-post .post-body__img,
.page-post .post-body__video-wrap,
.page-post .post-body__video,
.page-post .post-body__embed{
  border-radius:0 !important;
  border:1px solid var(--line-strong) !important;
  box-shadow:0 28px 90px -62px rgba(0,0,0,.9) !important;
}

/* Sidebar becomes a real side panel, not a thin hard-to-read strip */
.page-post .post__aside{
  position:sticky !important;
  top:calc(var(--header-h) + 1.2rem) !important;
  max-height:calc(100vh - var(--header-h) - 2.4rem) !important;
  overflow-y:auto !important;
  padding:1.25rem !important;
  border:1px solid var(--line-strong) !important;
  border-left:1px solid var(--accent-line) !important;
  background:linear-gradient(180deg,rgba(24,26,31,.94),rgba(10,11,15,.96)) !important;
  box-shadow:0 24px 80px -60px rgba(0,0,0,.92),inset 1px 0 0 rgba(236,231,75,.09) !important;
  backdrop-filter:blur(14px);
}
.page-post .post__aside::-webkit-scrollbar{width:7px}
.page-post .post__aside::-webkit-scrollbar-track{background:transparent}
.page-post .post__aside::-webkit-scrollbar-thumb{background:var(--accent-line);border-radius:999px}
.page-post .post__aside-block{
  padding-bottom:1.25rem;
  margin-bottom:1.25rem;
  border-bottom:1px solid var(--line);
}
.page-post .post__aside-block:last-child{
  margin-bottom:0;
  padding-bottom:0;
  border-bottom:0;
}
.page-post .post__aside-block .label{
  display:flex !important;
  align-items:center;
  gap:.5rem;
  margin-bottom:.85rem !important;
  color:var(--accent) !important;
  opacity:1 !important;
}
.page-post .post__aside-block .label::after{
  content:'';
  height:1px;
  flex:1;
  background:linear-gradient(90deg,var(--accent-line),transparent);
}
.page-post .post__toc{
  counter-reset:postToc;
  display:flex !important;
  flex-direction:column;
  gap:.45rem !important;
}
.page-post .post__toc a{
  counter-increment:postToc;
  position:relative;
  display:grid !important;
  grid-template-columns:2.05rem 1fr;
  align-items:center;
  min-height:42px;
  padding:.55rem .7rem .55rem .55rem !important;
  border:1px solid var(--line) !important;
  border-left:2px solid transparent !important;
  background:rgba(234,228,218,.025) !important;
  color:var(--ink-soft) !important;
  font-size:.78rem !important;
  font-weight:700 !important;
  letter-spacing:.08em !important;
  line-height:1.35 !important;
  text-transform:none !important;
  text-decoration:none;
  transition:color 180ms var(--ease-out),border-color 180ms var(--ease-out),background 180ms var(--ease-out),transform 180ms var(--ease-out);
}
.page-post .post__toc a::before{
  content:counter(postToc,decimal-leading-zero);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:1.45rem;
  height:1.45rem;
  border:1px solid var(--line-strong);
  color:var(--accent);
  font-size:.62rem;
  letter-spacing:.04em;
  background:rgba(236,231,75,.055);
}
.page-post .post__toc a:hover,
.page-post .post__toc a:focus-visible{
  color:var(--ink) !important;
  border-color:var(--accent-line) !important;
  border-left-color:var(--accent) !important;
  background:rgba(236,231,75,.07) !important;
  transform:translateX(-2px);
  outline:none;
}
.page-post .post__toc a.is-active{
  color:var(--ink) !important;
  border-color:var(--accent-line) !important;
  border-left-color:var(--accent) !important;
  background:linear-gradient(90deg,rgba(236,231,75,.12),rgba(236,231,75,.035)) !important;
}
.page-post .post__toc a.is-active::before{
  background:var(--accent);
  color:#11120c;
  border-color:var(--accent);
}
.page-post .post__tools--badges{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:.45rem !important;
}
.page-post .post__tools--badges .tag,
.page-post .post__context-badge{
  min-height:36px;
  display:inline-flex;
  align-items:center;
}
.page-post .post__share{
  gap:.55rem !important;
}
.page-post .post__share button{
  min-height:44px;
  padding:.7rem .85rem !important;
  background:rgba(234,228,218,.025) !important;
  border-color:var(--line-strong) !important;
}
.page-post .post__share button:hover{
  background:rgba(236,231,75,.08) !important;
  border-color:var(--accent-line) !important;
}

/* Light theme keeps the same structure but with softer surfaces */
[data-theme="light"] .page-post .post__body{
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(246,242,233,.96)) !important;
}
[data-theme="light"] .page-post .post__aside{
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,244,235,.96)) !important;
  box-shadow:0 24px 70px -58px rgba(80,56,25,.45),inset 1px 0 0 rgba(168,86,0,.09) !important;
}
[data-theme="light"] .page-post .post__toc a{
  background:rgba(168,86,0,.035) !important;
}
[data-theme="light"] .page-post .post__toc a:hover,
[data-theme="light"] .page-post .post__toc a:focus-visible,
[data-theme="light"] .page-post .post__toc a.is-active{
  background:rgba(168,86,0,.08) !important;
}

@media (max-width:1200px){
  .page-post .post__layout{grid-template-columns:minmax(0,1fr) 260px !important;gap:1rem !important}
  .page-post .post__body{padding:clamp(1.6rem,2.6vw,2.4rem) !important}
}
@media (max-width:900px){
  .page-post .post{max-width:100% !important}
  .page-post .post__layout{grid-template-columns:1fr !important}
  .page-post .post__aside{
    position:static !important;
    max-height:none !important;
    overflow:visible !important;
    border-left:1px solid var(--line-strong) !important;
    border-top:1px solid var(--accent-line) !important;
  }
  .page-post .post__toc{display:grid !important;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
}
@media (max-width:640px){
  .page-post .post__body{padding:1.25rem !important}
  .page-post .post__toc{grid-template-columns:1fr !important}
  .page-post .post__toc a{min-height:46px}
}

/* ==========================================================================
   HARD FIX — BLOG POST LAYOUT v12
   This intentionally overrides every older blog-post layout rule.
   Result: hero/media and article body share the same wide main column,
   while the Table of Contents becomes a clearer separate side panel.
   ========================================================================== */
body.page-post main{
  overflow:visible !important;
}
body.page-post .post{
  --post-aside-w:clamp(300px,22vw,380px);
  --post-gap:clamp(1.25rem,2.8vw,3.2rem);
  display:grid !important;
  grid-template-columns:minmax(0,1fr) var(--post-aside-w) !important;
  column-gap:var(--post-gap) !important;
  row-gap:0 !important;
  align-items:start !important;
  max-width:min(96vw,1720px) !important;
  margin-inline:auto !important;
  padding:calc(var(--header-h) + 2.25rem) clamp(1rem,2vw,2rem) 5rem !important;
}
body.page-post .post__back,
body.page-post .post__head,
body.page-post .post__hero,
body.page-post .post__body{
  grid-column:1 !important;
  width:100% !important;
  max-width:none !important;
}
body.page-post .post__layout{
  display:contents !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
body.page-post .post__head{
  margin:0 0 clamp(1.4rem,2.6vw,2.8rem) !important;
  padding:clamp(1.5rem,2.8vw,2.8rem) !important;
}
body.page-post .post__hero{
  margin:0 !important;
  aspect-ratio:16 / 7 !important;
  border:1px solid var(--line-strong) !important;
  border-bottom:0 !important;
}
body.page-post .post__body{
  margin:0 0 4rem !important;
  padding:clamp(2.4rem,4.2vw,5rem) !important;
  border:1px solid var(--line-strong) !important;
  border-top:1px solid var(--line) !important;
  border-right:1px solid var(--line-strong) !important;
  background:
    radial-gradient(circle at 94% 8%,rgba(236,231,75,.055),transparent 28%),
    linear-gradient(180deg,rgba(20,22,27,.88),rgba(8,9,12,.94)) !important;
  box-shadow:0 34px 110px -82px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.035) !important;
}
body.page-post .post__aside{
  grid-column:2 !important;
  grid-row:1 / span 5 !important;
  width:100% !important;
  min-width:0 !important;
  position:sticky !important;
  top:calc(var(--header-h) + 1rem) !important;
  max-height:calc(100vh - var(--header-h) - 2rem) !important;
  overflow-y:auto !important;
  display:flex !important;
  flex-direction:column !important;
  gap:1.15rem !important;
  padding:1.2rem !important;
  border:1px solid rgba(236,231,75,.25) !important;
  border-left:3px solid var(--accent) !important;
  background:
    linear-gradient(180deg,rgba(25,27,32,.98),rgba(9,10,14,.98)),
    var(--bg-1) !important;
  box-shadow:0 30px 90px -62px rgba(0,0,0,.95),0 0 0 1px rgba(236,231,75,.035) inset !important;
  backdrop-filter:blur(16px) !important;
  z-index:3 !important;
  scrollbar-width:thin;
  scrollbar-color:var(--accent-line) transparent;
}
body.page-post .post__aside::-webkit-scrollbar{width:8px}
body.page-post .post__aside::-webkit-scrollbar-track{background:transparent}
body.page-post .post__aside::-webkit-scrollbar-thumb{background:var(--accent-line);border-radius:999px}
body.page-post .post__aside-block{
  margin:0 !important;
  padding:0 0 1.15rem !important;
  border:0 !important;
  border-bottom:1px solid rgba(234,228,218,.12) !important;
}
body.page-post .post__aside-block:last-child{
  padding-bottom:0 !important;
  border-bottom:0 !important;
}
body.page-post .post__aside-block .label{
  display:flex !important;
  align-items:center !important;
  gap:.55rem !important;
  margin:0 0 .85rem !important;
  color:var(--accent) !important;
  opacity:1 !important;
  font-size:.72rem !important;
  letter-spacing:.28em !important;
  line-height:1.2 !important;
}
body.page-post .post__aside-block .label::after{
  content:'';
  height:1px;
  flex:1;
  background:linear-gradient(90deg,var(--accent-line),transparent);
}
body.page-post .post__toc{
  counter-reset:postToc !important;
  display:grid !important;
  gap:.55rem !important;
  margin:0 !important;
}
body.page-post .post__toc a{
  counter-increment:postToc !important;
  display:grid !important;
  grid-template-columns:2.2rem 1fr !important;
  align-items:center !important;
  min-height:48px !important;
  padding:.65rem .75rem .65rem .6rem !important;
  border:1px solid rgba(234,228,218,.14) !important;
  border-left:3px solid transparent !important;
  background:rgba(234,228,218,.035) !important;
  color:rgba(234,228,218,.82) !important;
  font-family:var(--font-ui) !important;
  font-size:.82rem !important;
  font-weight:700 !important;
  letter-spacing:.04em !important;
  line-height:1.35 !important;
  text-transform:none !important;
  text-decoration:none !important;
  transition:transform 160ms var(--ease-out),background 160ms var(--ease-out),border-color 160ms var(--ease-out),color 160ms var(--ease-out) !important;
}
body.page-post .post__toc a::before{
  content:counter(postToc,decimal-leading-zero) !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:1.55rem !important;
  height:1.55rem !important;
  border:1px solid rgba(236,231,75,.28) !important;
  background:rgba(236,231,75,.08) !important;
  color:var(--accent) !important;
  font-size:.62rem !important;
  letter-spacing:.03em !important;
}
body.page-post .post__toc a:hover,
body.page-post .post__toc a:focus-visible,
body.page-post .post__toc a.is-active{
  color:var(--ink) !important;
  border-color:var(--accent-line) !important;
  border-left-color:var(--accent) !important;
  background:linear-gradient(90deg,rgba(236,231,75,.14),rgba(236,231,75,.045)) !important;
  transform:translateX(-3px) !important;
  outline:none !important;
}
body.page-post .post__toc a.is-active::before{
  background:var(--accent) !important;
  color:#11120c !important;
  border-color:var(--accent) !important;
}
body.page-post .post-body__p,
body.page-post .post-body__quote,
body.page-post .post-body__callout,
body.page-post .post-body__note,
body.page-post .post-body__list,
body.page-post .post-body__columns,
body.page-post .post-body__features,
body.page-post .post-body__table,
body.page-post .post-body__timeline,
body.page-post .post-body__cta,
body.page-post .post-body__download{
  max-width:100% !important;
}
body.page-post .post-body__p{
  font-size:clamp(1.08rem,.55vw + .95rem,1.24rem) !important;
  line-height:1.9 !important;
}
body.page-post .post-body__h{
  max-width:100% !important;
  margin-top:clamp(3rem,5vw,5rem) !important;
  scroll-margin-top:calc(var(--header-h) + 2rem) !important;
}
body.page-post .post-body__fig,
body.page-post .post-body__stats,
body.page-post .post-body__image-grid,
body.page-post .post-body__media-text,
body.page-post .post-body__embed,
body.page-post .post-body__video-wrap{
  max-width:100% !important;
  margin-left:0 !important;
  margin-right:0 !important;
}
body.page-post .post__tools--badges,
body.page-post .post__share{
  display:grid !important;
  gap:.6rem !important;
}
body.page-post .post__tools--badges .tag,
body.page-post .post__context-badge,
body.page-post .post__share button{
  min-height:46px !important;
  width:100% !important;
  justify-content:flex-start !important;
  padding:.75rem .85rem !important;
  border-color:rgba(236,231,75,.24) !important;
  background:rgba(236,231,75,.045) !important;
}
body.page-post .post-breakdown,
body.page-post .post-comments,
body.page-post .post__nav{
  grid-column:1 / -1 !important;
}
[data-theme="light"] body.page-post .post__body{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,242,233,.98)) !important;
}
[data-theme="light"] body.page-post .post__aside{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,242,232,.98)) !important;
  box-shadow:0 30px 80px -66px rgba(70,45,15,.55),0 0 0 1px rgba(168,86,0,.035) inset !important;
}
[data-theme="light"] body.page-post .post__toc a{
  color:var(--ink-soft) !important;
  background:rgba(168,86,0,.045) !important;
  border-color:rgba(30,40,50,.14) !important;
}
[data-theme="light"] body.page-post .post__toc a:hover,
[data-theme="light"] body.page-post .post__toc a:focus-visible,
[data-theme="light"] body.page-post .post__toc a.is-active{
  color:var(--ink) !important;
  background:rgba(168,86,0,.10) !important;
  border-color:var(--accent-line) !important;
}
@media (max-width:1180px){
  body.page-post .post{
    --post-aside-w:290px;
    --post-gap:1.25rem;
  }
  body.page-post .post__body{
    padding:clamp(1.75rem,3vw,3rem) !important;
  }
}
@media (max-width:980px){
  body.page-post .post{
    display:block !important;
    max-width:100% !important;
  }
  body.page-post .post__layout{
    display:block !important;
  }
  body.page-post .post__aside{
    position:static !important;
    max-height:none !important;
    overflow:visible !important;
    margin:1rem 0 3rem !important;
    border-left:1px solid rgba(236,231,75,.25) !important;
    border-top:3px solid var(--accent) !important;
  }
  body.page-post .post__toc{
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) !important;
  }
}
@media (max-width:640px){
  body.page-post .post{
    padding:calc(var(--header-h) + 1.25rem) .85rem 3rem !important;
  }
  body.page-post .post__head,
  body.page-post .post__body,
  body.page-post .post__aside{
    padding:1.15rem !important;
  }
  body.page-post .post__hero{
    aspect-ratio:16 / 9 !important;
  }
  body.page-post .post__toc{
    grid-template-columns:1fr !important;
  }
}

/* ========================================================================== 
   HARD FIX — BLOG POST LAYOUT v13
   - Side panel is constrained to the article body only, so it never covers comments.
   - Side panel is open by default and can collapse into a full-width article.
   - Aside section labels get small arrow markers for clearer hierarchy.
   ========================================================================== */
body.page-post .post__layout{
  grid-column:1 / -1 !important;
  display:grid !important;
  grid-template-columns:minmax(0,1fr) var(--post-aside-w) !important;
  column-gap:var(--post-gap) !important;
  align-items:start !important;
  position:relative !important;
  width:100% !important;
  margin:0 0 4rem !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
body.page-post .post__body{
  grid-column:1 !important;
  margin:0 !important;
}
body.page-post .post__aside{
  grid-column:2 !important;
  grid-row:auto !important;
  align-self:start !important;
  /* Sticky now lives inside .post__layout, so it stops before comments. */
  position:sticky !important;
  top:calc(var(--header-h) + 1rem) !important;
  max-height:calc(100vh - var(--header-h) - 2rem) !important;
  z-index:4 !important;
}
body.page-post .post-breakdown,
body.page-post .post-comments,
body.page-post .post__nav{
  position:relative !important;
  z-index:1 !important;
}
body.page-post .post__aside-block .label::before{
  content:'▸';
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:1rem;
  height:1rem;
  margin-right:.05rem;
  color:var(--accent);
  border:1px solid rgba(236,231,75,.24);
  background:rgba(236,231,75,.055);
  font-size:.62rem;
  line-height:1;
}
body.page-post .post__aside-toggle{
  position:fixed !important;
  right:0 !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  z-index:90 !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:.55rem !important;
  min-height:46px !important;
  padding:.75rem .85rem !important;
  border:1px solid var(--accent-line) !important;
  border-right:0 !important;
  background:linear-gradient(180deg,rgba(24,25,30,.98),rgba(8,9,12,.98)) !important;
  color:var(--accent) !important;
  font-family:var(--font-ui) !important;
  font-size:.72rem !important;
  font-weight:800 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  writing-mode:vertical-rl !important;
  box-shadow:0 16px 50px -30px rgba(0,0,0,.85),0 0 0 1px rgba(236,231,75,.04) inset !important;
  cursor:pointer !important;
  transition:background 180ms var(--ease-out),color 180ms var(--ease-out),transform 180ms var(--ease-out),border-color 180ms var(--ease-out) !important;
}
body.page-post .post__aside-toggle:hover,
body.page-post .post__aside-toggle:focus-visible{
  background:linear-gradient(180deg,rgba(236,231,75,.16),rgba(18,19,22,.98)) !important;
  color:var(--ink) !important;
  outline:none !important;
}
body.page-post .post__aside-toggle-icon{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:1.25rem !important;
  height:1.25rem !important;
  writing-mode:horizontal-tb !important;
  border:1px solid rgba(236,231,75,.3) !important;
  background:rgba(236,231,75,.08) !important;
  line-height:1 !important;
}
body.page-post .post__aside-toggle-text{
  line-height:1 !important;
}
body.page-post .post.post--aside-collapsed{
  grid-template-columns:minmax(0,1fr) !important;
  max-width:min(96vw,1720px) !important;
}
body.page-post .post.post--aside-collapsed .post__back,
body.page-post .post.post--aside-collapsed .post__head,
body.page-post .post.post--aside-collapsed .post__hero,
body.page-post .post.post--aside-collapsed .post__layout,
body.page-post .post.post--aside-collapsed .post-breakdown,
body.page-post .post.post--aside-collapsed .post-comments,
body.page-post .post.post--aside-collapsed .post__nav{
  grid-column:1 !important;
}
body.page-post .post.post--aside-collapsed .post__layout{
  grid-template-columns:minmax(0,1fr) !important;
}
body.page-post .post.post--aside-collapsed .post__aside{
  display:none !important;
}
body.page-post .post.post--aside-collapsed .post__body{
  max-width:none !important;
  width:100% !important;
}
body.page-post .post.post--aside-collapsed .post__aside-toggle{
  color:var(--ink) !important;
  background:linear-gradient(180deg,rgba(236,231,75,.18),rgba(12,13,16,.98)) !important;
}
[data-theme="light"] body.page-post .post__aside-toggle{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,242,232,.98)) !important;
  color:var(--accent) !important;
}
[data-theme="light"] body.page-post .post__aside-toggle:hover,
[data-theme="light"] body.page-post .post__aside-toggle:focus-visible,
[data-theme="light"] body.page-post .post.post--aside-collapsed .post__aside-toggle{
  background:linear-gradient(180deg,rgba(168,86,0,.14),rgba(255,255,255,.98)) !important;
  color:var(--ink) !important;
}
@media (max-width:980px){
  body.page-post .post__layout{
    display:block !important;
    margin-bottom:3rem !important;
  }
  body.page-post .post__aside-toggle{
    display:none !important;
  }
}

/* ========================================================================== 
   HARD FIX — BLOG POST SIDEBAR v14
   - Restores the old behavior: sidebar starts naturally in the article layout,
     then sticks while reading.
   - The sticky shell is inside .post__layout, so it stops at the end of the
     article body and never crosses over the comments.
   - The hide/show tab is attached to the sidebar shell, not the viewport.
   ========================================================================== */
body.page-post .post__layout{
  grid-column:1 / -1 !important;
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(320px,var(--post-aside-w)) !important;
  column-gap:var(--post-gap) !important;
  align-items:start !important;
  position:relative !important;
  overflow:visible !important;
  width:100% !important;
  margin:0 0 4rem !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  transition:grid-template-columns 260ms var(--ease-out),column-gap 260ms var(--ease-out) !important;
}
body.page-post .post__body{
  grid-column:1 !important;
  min-width:0 !important;
}
body.page-post .post__side-shell{
  grid-column:2 !important;
  align-self:start !important;
  position:sticky !important;
  top:calc(var(--header-h) + 1rem) !important;
  z-index:8 !important;
  width:100% !important;
  max-height:calc(100vh - var(--header-h) - 2rem) !important;
  overflow:visible !important;
  transform:none !important;
  transition:width 260ms var(--ease-out),opacity 220ms var(--ease-out),transform 260ms var(--ease-out) !important;
}
body.page-post .post__aside{
  grid-column:auto !important;
  position:relative !important;
  top:auto !important;
  right:auto !important;
  left:auto !important;
  z-index:1 !important;
  width:100% !important;
  max-height:calc(100vh - var(--header-h) - 2rem) !important;
  overflow:auto !important;
  margin:0 !important;
  transform:none !important;
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transition:opacity 220ms var(--ease-out),transform 260ms var(--ease-out),visibility 220ms var(--ease-out) !important;
}
body.page-post .post__aside-toggle{
  position:absolute !important;
  left:calc(-1 * clamp(4.1rem,5vw,5.25rem)) !important;
  right:auto !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  z-index:10 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:.55rem !important;
  min-width:clamp(3.85rem,4.8vw,5rem) !important;
  min-height:46px !important;
  padding:.75rem .85rem !important;
  border:1px solid var(--accent-line) !important;
  border-right:0 !important;
  background:linear-gradient(180deg,rgba(24,25,30,.98),rgba(8,9,12,.98)) !important;
  color:var(--accent) !important;
  font-family:var(--font-ui) !important;
  font-size:.72rem !important;
  font-weight:800 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  writing-mode:vertical-rl !important;
  box-shadow:0 16px 50px -30px rgba(0,0,0,.85),0 0 0 1px rgba(236,231,75,.04) inset !important;
  cursor:pointer !important;
  transition:background 180ms var(--ease-out),color 180ms var(--ease-out),transform 180ms var(--ease-out),border-color 180ms var(--ease-out),left 260ms var(--ease-out) !important;
}
body.page-post .post__aside-toggle:hover,
body.page-post .post__aside-toggle:focus-visible{
  background:linear-gradient(180deg,rgba(236,231,75,.16),rgba(18,19,22,.98)) !important;
  color:var(--ink) !important;
  outline:none !important;
}
body.page-post .post__aside-toggle-icon{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:1.25rem !important;
  height:1.25rem !important;
  writing-mode:horizontal-tb !important;
  border:1px solid rgba(236,231,75,.3) !important;
  background:rgba(236,231,75,.08) !important;
  line-height:1 !important;
}
body.page-post .post__aside-toggle-text{
  line-height:1 !important;
}
body.page-post .post.post--aside-collapsed{
  max-width:min(96vw,1720px) !important;
}
body.page-post .post.post--aside-collapsed .post__layout{
  grid-template-columns:minmax(0,1fr) 0px !important;
  column-gap:0 !important;
}
body.page-post .post.post--aside-collapsed .post__side-shell{
  width:0 !important;
  min-width:0 !important;
  max-width:0 !important;
  pointer-events:none !important;
}
body.page-post .post.post--aside-collapsed .post__aside{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transform:translateX(1.25rem) !important;
  overflow:hidden !important;
}
body.page-post .post.post--aside-collapsed .post__aside-toggle{
  pointer-events:auto !important;
  left:calc(-1 * clamp(4.1rem,5vw,5.25rem)) !important;
  color:var(--ink) !important;
  background:linear-gradient(180deg,rgba(236,231,75,.18),rgba(12,13,16,.98)) !important;
}
body.page-post .post.post--aside-collapsed .post__body{
  max-width:none !important;
  width:100% !important;
}
body.page-post .post.post--aside-collapsed .post__back,
body.page-post .post.post--aside-collapsed .post__head,
body.page-post .post.post--aside-collapsed .post__hero,
body.page-post .post.post--aside-collapsed .post__layout,
body.page-post .post.post--aside-collapsed .post-breakdown,
body.page-post .post.post--aside-collapsed .post-comments,
body.page-post .post.post--aside-collapsed .post__nav{
  grid-column:1 !important;
}
[data-theme="light"] body.page-post .post__aside-toggle{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,242,232,.98)) !important;
  color:var(--accent) !important;
}
[data-theme="light"] body.page-post .post__aside-toggle:hover,
[data-theme="light"] body.page-post .post__aside-toggle:focus-visible,
[data-theme="light"] body.page-post .post.post--aside-collapsed .post__aside-toggle{
  background:linear-gradient(180deg,rgba(168,86,0,.14),rgba(255,255,255,.98)) !important;
  color:var(--ink) !important;
}
@media (max-width:980px){
  body.page-post .post__layout{
    display:block !important;
    margin-bottom:3rem !important;
  }
  body.page-post .post__side-shell{
    position:static !important;
    width:100% !important;
    max-width:none !important;
    max-height:none !important;
  }
  body.page-post .post__aside{
    position:static !important;
    max-height:none !important;
    overflow:visible !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
  }
  body.page-post .post__aside-toggle{
    display:none !important;
  }
}

/* ========================================================================== 
   FINAL FIX — BLOG SIDEBAR BEHAVIOR v15
   - Sidebar starts at the very top of the post area again, like the earlier V1/V2.
   - Sidebar sticks while reading, but is constrained to the reading shell so it
     stops before the comments section.
   - Toggle is a clean attached tab, not a squished vertical button.
   ========================================================================== */
body.page-post main{
  overflow:visible !important;
}
body.page-post .post{
  --post-aside-w:clamp(310px,22vw,390px);
  --post-gap:clamp(1.25rem,2.8vw,3.2rem);
  display:block !important;
  max-width:min(96vw,1720px) !important;
  width:100% !important;
  margin-inline:auto !important;
  padding:calc(var(--header-h) + 2.25rem) clamp(1rem,2vw,2rem) 5rem !important;
  overflow:visible !important;
}
body.page-post .post__reading-shell{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) var(--post-aside-w) !important;
  column-gap:var(--post-gap) !important;
  align-items:start !important;
  position:relative !important;
  width:100% !important;
  margin:0 0 4rem !important;
  padding:0 !important;
  overflow:visible !important;
  transition:grid-template-columns 280ms var(--ease-out),column-gap 280ms var(--ease-out) !important;
}
body.page-post .post__main-column{
  grid-column:1 !important;
  min-width:0 !important;
  width:100% !important;
}
body.page-post .post__back,
body.page-post .post__head,
body.page-post .post__hero,
body.page-post .post__layout,
body.page-post .post__body,
body.page-post .post-breakdown{
  grid-column:auto !important;
  width:100% !important;
  max-width:none !important;
}
body.page-post .post__layout{
  display:block !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
body.page-post .post__head{
  margin:0 0 clamp(1.4rem,2.6vw,2.8rem) !important;
  padding:clamp(1.5rem,2.8vw,2.8rem) !important;
}
body.page-post .post__hero{
  margin:0 !important;
  aspect-ratio:16 / 7 !important;
  border:1px solid var(--line-strong) !important;
  border-bottom:0 !important;
}
body.page-post .post__body{
  margin:0 0 4rem !important;
  padding:clamp(2.4rem,4.2vw,5rem) !important;
  border:1px solid var(--line-strong) !important;
  border-top:1px solid var(--line) !important;
  background:
    radial-gradient(circle at 94% 8%,rgba(236,231,75,.055),transparent 28%),
    linear-gradient(180deg,rgba(20,22,27,.88),rgba(8,9,12,.94)) !important;
  box-shadow:0 34px 110px -82px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.035) !important;
}
body.page-post .post__side-shell{
  grid-column:2 !important;
  align-self:start !important;
  position:sticky !important;
  top:calc(var(--header-h) + 1rem) !important;
  z-index:8 !important;
  width:100% !important;
  max-width:100% !important;
  max-height:calc(100vh - var(--header-h) - 2rem) !important;
  overflow:visible !important;
  transform:none !important;
  pointer-events:auto !important;
  transition:width 280ms var(--ease-out),max-width 280ms var(--ease-out),opacity 200ms var(--ease-out) !important;
}
body.page-post .post__aside{
  position:relative !important;
  top:auto !important;
  right:auto !important;
  left:auto !important;
  z-index:1 !important;
  width:100% !important;
  max-height:calc(100vh - var(--header-h) - 2rem) !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  margin:0 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:1.15rem !important;
  padding:1.2rem !important;
  border:1px solid rgba(236,231,75,.25) !important;
  border-left:3px solid var(--accent) !important;
  background:
    linear-gradient(180deg,rgba(25,27,32,.98),rgba(9,10,14,.98)),
    var(--bg-1) !important;
  box-shadow:0 30px 90px -62px rgba(0,0,0,.95),0 0 0 1px rgba(236,231,75,.035) inset !important;
  backdrop-filter:blur(16px) !important;
  opacity:1 !important;
  visibility:visible !important;
  transform:none !important;
  pointer-events:auto !important;
  transition:opacity 210ms var(--ease-out),transform 260ms var(--ease-out),visibility 210ms var(--ease-out) !important;
}
body.page-post .post__aside-toggle{
  position:absolute !important;
  left:-48px !important;
  right:auto !important;
  top:1.15rem !important;
  transform:none !important;
  z-index:12 !important;
  display:grid !important;
  place-items:center !important;
  width:48px !important;
  min-width:48px !important;
  height:48px !important;
  min-height:48px !important;
  padding:0 !important;
  border:1px solid rgba(236,231,75,.32) !important;
  border-right:0 !important;
  border-radius:14px 0 0 14px !important;
  background:
    radial-gradient(circle at 50% 0%,rgba(236,231,75,.18),transparent 56%),
    linear-gradient(180deg,rgba(25,27,32,.98),rgba(8,9,12,.98)) !important;
  color:var(--accent) !important;
  font-family:var(--font-ui) !important;
  font-size:0 !important;
  font-weight:800 !important;
  letter-spacing:0 !important;
  text-transform:uppercase !important;
  writing-mode:horizontal-tb !important;
  box-shadow:0 18px 50px -34px rgba(0,0,0,.95),inset 0 0 0 1px rgba(236,231,75,.04) !important;
  cursor:pointer !important;
  pointer-events:auto !important;
  transition:background 180ms var(--ease-out),color 180ms var(--ease-out),transform 180ms var(--ease-out),border-color 180ms var(--ease-out),box-shadow 180ms var(--ease-out) !important;
}
body.page-post .post__aside-toggle:hover,
body.page-post .post__aside-toggle:focus-visible{
  transform:translateX(-3px) !important;
  background:
    radial-gradient(circle at 50% 0%,rgba(236,231,75,.28),transparent 58%),
    linear-gradient(180deg,rgba(36,38,42,.98),rgba(12,13,16,.98)) !important;
  color:var(--ink) !important;
  border-color:var(--accent) !important;
  outline:none !important;
}
body.page-post .post__aside-toggle-icon{
  display:grid !important;
  place-items:center !important;
  width:26px !important;
  height:26px !important;
  writing-mode:horizontal-tb !important;
  border:1px solid rgba(236,231,75,.35) !important;
  background:rgba(236,231,75,.09) !important;
  color:inherit !important;
  font-size:1.05rem !important;
  line-height:1 !important;
}
body.page-post .post__aside-toggle-text{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  clip:rect(0 0 0 0) !important;
  white-space:nowrap !important;
}
body.page-post .post__aside-block .label{
  display:flex !important;
  align-items:center !important;
  gap:.55rem !important;
}
body.page-post .post__aside-block .label::before{
  content:'›' !important;
  display:grid !important;
  place-items:center !important;
  width:1.2rem !important;
  height:1.2rem !important;
  border:1px solid rgba(236,231,75,.24) !important;
  background:rgba(236,231,75,.06) !important;
  color:var(--accent) !important;
  font-size:.85rem !important;
  line-height:1 !important;
  letter-spacing:0 !important;
}
body.page-post .post.post--aside-collapsed .post__reading-shell{
  grid-template-columns:minmax(0,1fr) 0px !important;
  column-gap:0 !important;
}
body.page-post .post.post--aside-collapsed .post__side-shell{
  width:0 !important;
  min-width:0 !important;
  max-width:0 !important;
  pointer-events:none !important;
}
body.page-post .post.post--aside-collapsed .post__aside{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transform:translateX(1.5rem) !important;
  overflow:hidden !important;
}
body.page-post .post.post--aside-collapsed .post__aside-toggle{
  pointer-events:auto !important;
  left:-48px !important;
  transform:none !important;
  color:#101108 !important;
  border-color:rgba(236,231,75,.65) !important;
  background:linear-gradient(180deg,var(--accent),rgba(236,231,75,.68)) !important;
  box-shadow:0 18px 55px -34px rgba(236,231,75,.65),inset 0 0 0 1px rgba(0,0,0,.18) !important;
}
body.page-post .post.post--aside-collapsed .post__aside-toggle:hover,
body.page-post .post.post--aside-collapsed .post__aside-toggle:focus-visible{
  transform:translateX(-3px) !important;
}
body.page-post .post-comments,
body.page-post .post__nav{
  max-width:100% !important;
  width:100% !important;
  margin-inline:0 !important;
}
[data-theme="light"] body.page-post .post__body{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,242,233,.98)) !important;
}
[data-theme="light"] body.page-post .post__aside,
[data-theme="light"] body.page-post .post__aside-toggle{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,242,232,.98)) !important;
  color:var(--accent) !important;
}
[data-theme="light"] body.page-post .post.post--aside-collapsed .post__aside-toggle{
  background:linear-gradient(180deg,rgba(236,178,76,.95),rgba(236,231,75,.72)) !important;
  color:#1c160b !important;
}
@media (max-width:980px){
  body.page-post .post{
    display:block !important;
    max-width:100% !important;
    padding:calc(var(--header-h) + 1.4rem) clamp(.85rem,3vw,1.25rem) 4rem !important;
  }
  body.page-post .post__reading-shell{
    display:block !important;
    margin-bottom:3rem !important;
  }
  body.page-post .post__side-shell{
    position:static !important;
    width:100% !important;
    max-width:none !important;
    max-height:none !important;
  }
  body.page-post .post__aside{
    position:static !important;
    max-height:none !important;
    overflow:visible !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
    margin:1rem 0 0 !important;
    border-left:1px solid rgba(236,231,75,.25) !important;
    border-top:3px solid var(--accent) !important;
  }
  body.page-post .post__aside-toggle{
    display:none !important;
  }
}

/* -------------------------------------------------------------------------
   ABOUT FINAL BALANCE PASS — old readability + simplified structure
   ------------------------------------------------------------------------- */
.about-section--final{
  padding:calc(var(--header-h) + 1.2rem) var(--gutter) 6rem;
  max-width:min(1480px, calc(100vw - (var(--gutter) * 2)));
}
.about-hero-final{
  position:relative;
  min-height:clamp(360px, 44vh, 540px);
  display:grid;
  align-items:end;
  padding:clamp(2.2rem, 6vw, 5.5rem) clamp(0rem, 2vw, 1rem) clamp(2.2rem, 5vw, 4.8rem);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.about-hero-final::before{
  content:"";
  position:absolute;
  inset:-18% -8% auto 35%;
  height:70%;
  background:radial-gradient(circle at 70% 20%, rgba(245,241,92,.18), transparent 52%);
  filter:blur(18px);
  pointer-events:none;
}
.about-hero-final::after{
  content:"ABOUT";
  position:absolute;
  right:-0.08em;
  bottom:-0.34em;
  font-family:var(--font-display);
  font-size:clamp(8rem, 23vw, 23rem);
  line-height:.8;
  color:rgba(250,248,137,.035);
  letter-spacing:.02em;
  pointer-events:none;
  user-select:none;
}
.about-hero-final__copy{
  position:relative;
  z-index:1;
  max-width:1180px;
}
.about-hero-final__title{
  margin:.65rem 0 1.25rem;
  max-width:920px;
  font-family:var(--font-display);
  font-size:clamp(4rem, 8.4vw, 9.6rem);
  line-height:.86;
  letter-spacing:-.035em;
  color:var(--accent);
  text-transform:uppercase;
  text-shadow:0 12px 0 rgba(0,0,0,.28);
}
.about-hero-final__lead{
  max-width:1040px;
  margin:0;
  color:var(--ink);
  font-size:clamp(1.45rem, 2.25vw, 2.35rem);
  line-height:1.48;
  letter-spacing:-.035em;
}
.about-hero-final__body{
  max-width:1140px;
  margin:clamp(1.4rem, 2.4vw, 2.3rem) 0 0;
  color:var(--ink-soft);
  font-size:clamp(1rem, 1.25vw, 1.25rem);
  line-height:1.75;
}
.about-identity-tags--final{
  margin-top:clamp(1.4rem, 2vw, 2rem);
}
.about-intro-final{
  display:grid;
  grid-template-columns:minmax(300px, .72fr) minmax(0, 1.35fr);
  gap:clamp(2rem, 5vw, 5rem);
  align-items:stretch;
  margin-top:clamp(2rem, 4vw, 4rem);
}
.about-intro-final .about-portrait{
  width:100%;
  max-width:none;
  min-height:clamp(360px, 36vw, 560px);
  aspect-ratio:1/1.08;
  align-self:stretch;
}
.about-identity-card{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:clamp(360px, 36vw, 560px);
  padding:clamp(2rem, 5vw, 4.4rem);
  border:1px solid var(--line);
  border-left:4px solid var(--accent);
  background:
    radial-gradient(circle at 100% 0%, rgba(245,241,92,.12), transparent 42%),
    linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  box-shadow:0 24px 80px rgba(0,0,0,.22);
  overflow:hidden;
}
.about-identity-card h2{
  margin:.7rem 0 .65rem;
  font-family:var(--font-display);
  font-size:clamp(3.2rem, 7vw, 7.2rem);
  line-height:.88;
  letter-spacing:-.035em;
  text-transform:uppercase;
  color:var(--accent);
  text-shadow:0 9px 0 rgba(0,0,0,.25);
}
.about-identity-card p{
  max-width:72ch;
  color:var(--ink-soft);
  font-size:clamp(1rem, 1.22vw, 1.22rem);
  line-height:1.68;
  margin:1rem 0 0;
}
.about-identity-card__lead{
  color:var(--ink) !important;
  font-size:clamp(1.15rem, 1.55vw, 1.55rem) !important;
  line-height:1.55 !important;
}
.about-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
  margin-top:clamp(1.6rem, 2.6vw, 2.4rem);
}
.about-panel-final{
  margin-top:clamp(2rem, 4vw, 4.5rem);
  padding:clamp(1.4rem, 2.5vw, 2.25rem);
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
}
.about-panel-final__head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:2rem;
  margin-bottom:1.35rem;
}
.about-panel-final__head p{
  max-width:520px;
  margin:0;
  color:var(--ink-dim);
  font-size:.98rem;
  line-height:1.6;
}
.skill-list--final{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:.75rem;
}
.skill-list--final li{
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-areas:"num name" "num tag";
  gap:.15rem .8rem;
  align-items:center;
  padding:1rem;
  min-height:92px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.14);
}
.skill-list--final .skill-num{grid-area:num}
.skill-list--final .skill-name{grid-area:name}
.skill-list--final .skill-tag{grid-area:tag}
.about-tools-list--final{
  gap:.7rem;
}
.about-tools-list--final .about-tool-badge{
  padding:.5rem .85rem .5rem .5rem;
  background:rgba(0,0,0,.18);
  border-color:var(--line);
  font-size:.76rem;
}
.about-tools-list--final .about-tool-badge__icon,
.about-tools-list--final .about-tool-badge__fallback{
  width:24px;
  height:24px;
}
@media (max-width:1100px){
  .about-intro-final{grid-template-columns:1fr;gap:1.5rem}
  .about-intro-final .about-portrait{max-width:520px;min-height:auto;aspect-ratio:1/1}
  .skill-list--final{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .about-panel-final__head{display:block}
  .about-panel-final__head p{margin-top:.75rem}
}
@media (max-width:720px){
  .about-section--final{padding-top:calc(var(--header-h) + .8rem)}
  .about-hero-final{min-height:auto;padding:2.2rem 0 2.6rem}
  .about-hero-final__title{font-size:clamp(3.2rem, 18vw, 5.3rem)}
  .about-hero-final__lead{font-size:1.18rem;line-height:1.6;letter-spacing:-.02em}
  .about-hero-final__body{font-size:1rem;line-height:1.65}
  .about-identity-card{min-height:auto;padding:1.5rem;border-left-width:3px}
  .about-identity-card h2{font-size:clamp(3rem, 15vw, 4.8rem)}
  .skill-list--final{grid-template-columns:1fr}
}

/* -------------------------------------------------------------------------
   ABOUT V7 — rebuilt from scratch: readable, cinematic, personal, not cluttered
   ------------------------------------------------------------------------- */
body.page-about .about-section.about-v7{
  max-width:min(1500px, calc(100vw - (var(--gutter) * 2)));
  padding:calc(var(--header-h) + 2rem) var(--gutter) 6rem;
}
.about-v7{
  --about-card-bg:linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  --about-soft-border:rgba(236,231,75,.18);
}
.about-v7-hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(320px, .55fr);
  gap:clamp(2rem, 5vw, 5.5rem);
  align-items:start;
  min-height:auto;
  padding:clamp(2.2rem, 5vw, 4.6rem) 0 clamp(2rem, 4vw, 4.2rem);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.about-v7-hero::before{
  content:"";
  position:absolute;
  inset:-24% -12% auto 46%;
  height:78%;
  background:radial-gradient(circle at 70% 30%, rgba(245,241,92,.18), transparent 55%);
  filter:blur(20px);
  pointer-events:none;
}
.about-v7-hero::after{
  content:"ABOUT";
  position:absolute;
  right:-0.06em;
  bottom:-0.26em;
  font-family:var(--font-display);
  font-size:clamp(8rem, 21vw, 22rem);
  line-height:.8;
  letter-spacing:.02em;
  color:rgba(250,248,137,.025);
  pointer-events:none;
  user-select:none;
}
.about-v7-copy,
.about-v7-profile{
  position:relative;
  z-index:1;
}
.about-v7-copy{
  max-width:950px;
  padding-top:.25rem;
}
.about-v7-title{
  margin:.75rem 0 1.35rem;
  max-width:900px;
  font-family:var(--font-display);
  font-size:clamp(4rem, 7.2vw, 7.9rem);
  line-height:.95;
  letter-spacing:-.025em;
  text-transform:uppercase;
  color:var(--accent);
  text-shadow:0 10px 0 rgba(0,0,0,.26);
  text-wrap:balance;
}
.about-v7-lead{
  max-width:900px;
  margin:0;
  color:var(--ink);
  font-size:clamp(1.35rem, 2.05vw, 2.05rem);
  line-height:1.52;
  letter-spacing:-.025em;
}
.about-v7-body{
  max-width:920px;
  margin:clamp(1.15rem, 2vw, 1.75rem) 0 0;
  color:var(--ink-soft);
  font-size:clamp(1rem, 1.12vw, 1.16rem);
  line-height:1.78;
}
.about-v7-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:clamp(1.25rem, 2vw, 1.8rem);
}
.about-v7-tags span{
  font-family:var(--font-ui);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--accent);
  border:1px solid var(--accent-line);
  background:rgba(236,231,75,.055);
  padding:.42rem .78rem;
}
.about-v7-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
  margin-top:clamp(1.5rem, 2.5vw, 2.15rem);
}
.about-v7-profile{
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.about-v7-portrait{
  position:relative;
  width:100%;
  aspect-ratio:1/1.08;
  min-height:360px;
  overflow:hidden;
  border:1px solid var(--line-strong);
  background:var(--bg-2);
  box-shadow:0 30px 90px rgba(0,0,0,.25);
}
.about-v7-portrait picture,
.about-v7-portrait__img{
  position:absolute;
  inset:0;
  display:block;
  width:100%;
  height:100%;
}
.about-v7-portrait__img{
  object-fit:cover;
  object-position:center top;
  transform:scale(1.02);
  animation:heroZoom 32s var(--ease-out) infinite alternate;
}
.about-v7-id-card{
  border:1px solid var(--line);
  border-left:3px solid var(--accent);
  background:var(--about-card-bg);
  padding:clamp(1.25rem, 2vw, 1.7rem);
}
.about-v7-id-card h2{
  margin:.55rem 0 .45rem;
  font-family:var(--font-display);
  font-size:clamp(2.6rem, 4.4vw, 4.9rem);
  line-height:.92;
  letter-spacing:-.02em;
  text-transform:uppercase;
  color:var(--accent);
  text-shadow:0 7px 0 rgba(0,0,0,.22);
}
.about-v7-id-card p{
  margin:0;
  color:var(--ink-soft);
  font-size:clamp(.98rem, 1.1vw, 1.08rem);
  line-height:1.65;
}
.about-v7-section{
  margin-top:clamp(2rem, 4vw, 4rem);
  padding:clamp(1.25rem, 2.5vw, 2rem);
  border:1px solid var(--line);
  background:var(--about-card-bg);
}
.about-v7-section-head{
  display:grid;
  grid-template-columns:1fr minmax(260px, 460px);
  gap:1.5rem;
  align-items:end;
  margin-bottom:1.2rem;
}
.about-v7-section-head p{
  margin:0;
  color:var(--ink-dim);
  font-size:.98rem;
  line-height:1.6;
}
.about-v7-skill-list{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:.75rem;
  margin:0;
  padding:0;
}
.about-v7-skill-list li{
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-areas:"num name" "num tag";
  gap:.12rem .8rem;
  align-items:center;
  min-height:88px;
  padding:1rem;
  border:1px solid var(--line);
  background:rgba(0,0,0,.16);
}
.about-v7-skill-list .skill-num{
  grid-area:num;
  display:grid;
  place-items:center;
  width:36px;
  height:36px;
  border:1px solid var(--accent-line);
  background:rgba(236,231,75,.08);
  letter-spacing:.12em;
}
.about-v7-skill-list .skill-name{
  grid-area:name;
  font-size:clamp(1.18rem, 1.5vw, 1.55rem);
  line-height:1;
}
.about-v7-skill-list .skill-tag{
  grid-area:tag;
  font-size:.66rem;
  letter-spacing:.2em;
}
.about-v7-tools-list{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  margin:0;
}
.about-v7-tools-list .about-tool-badge{
  padding:.55rem .9rem .55rem .55rem;
  background:rgba(0,0,0,.18);
  border-color:var(--line);
  font-size:.76rem;
}
.about-v7-tools-list .about-tool-badge__icon,
.about-v7-tools-list .about-tool-badge__fallback{
  width:24px;
  height:24px;
}
@media (max-width:1120px){
  .about-v7-hero{grid-template-columns:1fr;gap:1.75rem}
  .about-v7-profile{display:grid;grid-template-columns:minmax(240px, 380px) minmax(0, 1fr);align-items:stretch}
  .about-v7-portrait{min-height:auto;aspect-ratio:1/1}
  .about-v7-id-card{display:flex;flex-direction:column;justify-content:center}
  .about-v7-skill-list{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .about-v7-section-head{grid-template-columns:1fr}
}
@media (max-width:760px){
  body.page-about .about-section.about-v7{padding-top:calc(var(--header-h) + 1.15rem)}
  .about-v7-hero{padding-block:1.6rem 2.4rem}
  .about-v7-hero::after{display:none}
  .about-v7-title{font-size:clamp(3.1rem, 15.5vw, 5rem);line-height:.98;text-shadow:0 6px 0 rgba(0,0,0,.26)}
  .about-v7-lead{font-size:1.15rem;line-height:1.58;letter-spacing:-.015em}
  .about-v7-body{font-size:.98rem;line-height:1.68}
  .about-v7-profile{display:flex}
  .about-v7-portrait{min-height:auto;aspect-ratio:1/1}
  .about-v7-id-card h2{font-size:clamp(2.6rem, 13vw, 4rem)}
  .about-v7-skill-list{grid-template-columns:1fr}
  .about-v7-section{padding:1rem}
}

/* =======================================================================
   About V8 — final clean two-column profile layout
   ======================================================================= */
body.page-about .about-section.about-v8{
  max-width:min(1540px, calc(100vw - (var(--gutter) * 2)));
  padding:calc(var(--header-h) + 1.45rem) var(--gutter) 5.5rem;
  margin-inline:auto;
}
.about-v8{
  position:relative;
}
.about-v8::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 82% 8%, rgba(252,252,118,.11), transparent 34%),
    radial-gradient(ellipse at 12% 18%, rgba(255,255,255,.035), transparent 30%);
  z-index:-1;
}
.about-v8-shell{
  display:grid;
  grid-template-columns:minmax(360px, .82fr) minmax(560px, 1.18fr);
  gap:clamp(2rem, 4vw, 4.75rem);
  align-items:start;
}
.about-v8-left,
.about-v8-right,
.about-v8-section{
  min-width:0;
}
.about-v8-left{
  display:grid;
  gap:1.35rem;
}
.about-v8-portrait{
  position:relative;
  aspect-ratio:1/1;
  min-height:0;
  overflow:hidden;
  border:1px solid var(--line-strong);
  background:
    radial-gradient(ellipse at 50% 18%, rgba(251,252,119,.08), transparent 44%),
    linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.01)),
    var(--bg-2);
  box-shadow:0 30px 80px -56px rgba(0,0,0,.8);
}
.about-v8-portrait picture,
.about-v8-portrait__img{
  position:absolute;
  inset:0;
  display:block;
  width:100%;
  height:100%;
}
.about-v8-portrait__img{
  object-fit:cover;
  object-position:center top;
  transform:none;
  animation:none;
}
.about-v8-id-card,
.about-v8-right,
.about-v8-section{
  border:1px solid var(--line-strong);
  background:
    linear-gradient(135deg, rgba(255,255,255,.055), rgba(255,255,255,.014) 48%, rgba(251,252,119,.035)),
    rgba(18,20,27,.70);
  box-shadow:0 28px 80px -62px rgba(0,0,0,.9);
}
.about-v8-id-card{
  padding:clamp(1.25rem, 2vw, 1.8rem);
  border-left:3px solid var(--accent);
}
.about-v8-id-card h2{
  margin:.35rem 0 .25rem;
  font-family:var(--font-display);
  font-size:clamp(2.8rem, 4.1vw, 4.8rem);
  line-height:.92;
  text-transform:uppercase;
  color:var(--accent);
  letter-spacing:-.025em;
  text-shadow:0 7px 0 rgba(0,0,0,.30);
}
.about-v8-id-card p{
  max-width:58ch;
  margin:.65rem 0 0;
  color:var(--ink-soft);
  font-size:1rem;
  line-height:1.7;
}
.about-v8-id-card .about-v8-role{
  margin-top:.15rem;
  color:var(--ink);
  font:700 .88rem/1.5 var(--font-tech);
  text-transform:uppercase;
  letter-spacing:.2em;
}
.about-v8-id-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:1rem;
}
.about-v8-id-tags span{
  display:inline-flex;
  align-items:center;
  min-height:2.05rem;
  padding:.46rem .65rem;
  border:1px solid var(--accent-line);
  background:rgba(251,252,119,.045);
  color:var(--accent);
  font:700 .68rem/1 var(--font-tech);
  text-transform:uppercase;
  letter-spacing:.18em;
}
.about-v8-right{
  padding:clamp(1.7rem, 3vw, 3.15rem);
  border-left:3px solid var(--accent);
}
.about-v8-title{
  max-width:12.5em;
  margin:.55rem 0 1.15rem;
  color:var(--accent);
  font-family:var(--font-display);
  font-size:clamp(3.2rem, 5.4vw, 7rem);
  line-height:.91;
  text-transform:uppercase;
  letter-spacing:-.035em;
  text-shadow:0 7px 0 rgba(0,0,0,.32);
}
.about-v8-lead{
  max-width:68ch;
  margin:0;
  color:var(--ink);
  font-size:clamp(1.16rem, 1.7vw, 1.55rem);
  line-height:1.55;
  letter-spacing:-.02em;
}
.about-v8-body{
  max-width:78ch;
  margin:1.25rem 0 0;
  color:var(--ink-soft);
  font-size:1rem;
  line-height:1.78;
}
.about-v8-metrics{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:.75rem;
  margin:1.65rem 0 0;
}
.about-v8-metrics article{
  min-height:6.4rem;
  padding:1rem;
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,.03);
}
.about-v8-metrics strong{
  display:block;
  color:var(--accent);
  font:700 clamp(2rem, 3vw, 3.4rem)/.85 var(--font-display);
  letter-spacing:-.03em;
  text-transform:uppercase;
}
.about-v8-metrics span{
  display:block;
  margin-top:.55rem;
  color:var(--ink-soft);
  font:700 .74rem/1.35 var(--font-tech);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.about-v8-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  margin:1.55rem 0 0;
}
.about-v8-actions .btn{
  min-height:3.25rem;
}
.about-v8-tools-block{
  margin-top:1.85rem;
  padding-top:1.35rem;
  border-top:1px solid var(--line);
}
.about-v8-subhead{
  display:grid;
  grid-template-columns:minmax(170px, max-content) minmax(0, 1fr);
  gap:1rem;
  align-items:end;
  margin-bottom:1rem;
}
.about-v8-subhead p,
.about-v8-section-head p{
  margin:0;
  color:var(--ink-soft);
  line-height:1.65;
  max-width:62ch;
}
.about-v8-tools-list{
  display:flex;
  flex-wrap:wrap;
  gap:.65rem;
}
.about-v8-tools-list .about-tool-badge{
  min-height:2.65rem;
  padding:.48rem .72rem;
  border-color:var(--accent-line);
  background:rgba(251,252,119,.04);
}
.about-v8-tools-list .about-tool-badge__icon,
.about-v8-tools-list .about-tool-badge__fallback{
  width:1.65rem;
  height:1.65rem;
}
.about-v8-section{
  margin-top:2rem;
  padding:clamp(1.25rem, 2vw, 1.8rem);
}
.about-v8-section-head{
  display:grid;
  grid-template-columns:minmax(220px, max-content) minmax(0, 1fr);
  gap:1.2rem;
  align-items:end;
  margin-bottom:1rem;
}
.about-v8-skill-list{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:.75rem;
  list-style:none;
  margin:0;
  padding:0;
}
.about-v8-skill-list li{
  margin:0;
  min-height:6.25rem;
  padding:1rem;
  display:grid;
  gap:.35rem;
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,.025);
}
.about-v8-skill-list .skill-num{
  color:var(--accent);
  font:700 .78rem/1 var(--font-tech);
  letter-spacing:.18em;
}
.about-v8-skill-list .skill-name{
  color:var(--ink);
  font:700 1.2rem/1.1 var(--font-display);
  text-transform:uppercase;
  letter-spacing:.01em;
}
.about-v8-skill-list .skill-tag{
  color:var(--ink-mute);
  font:700 .76rem/1.35 var(--font-tech);
  text-transform:uppercase;
  letter-spacing:.12em;
}

@media (max-width:1180px){
  .about-v8-shell{grid-template-columns:1fr;gap:1.35rem}
  .about-v8-left{grid-template-columns:minmax(260px, 420px) minmax(0, 1fr);align-items:stretch}
  .about-v8-portrait{height:100%}
  .about-v8-title{max-width:13.5em}
  .about-v8-skill-list{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width:720px){
  body.page-about .about-section.about-v8{padding-top:calc(var(--header-h) + .85rem)}
  .about-v8-left{grid-template-columns:1fr}
  .about-v8-right{padding:1.15rem}
  .about-v8-title{font-size:clamp(2.6rem, 14vw, 4.4rem);line-height:.95;text-shadow:0 5px 0 rgba(0,0,0,.25)}
  .about-v8-lead{font-size:1.05rem;line-height:1.62}
  .about-v8-body{font-size:.96rem;line-height:1.7}
  .about-v8-metrics{grid-template-columns:1fr}
  .about-v8-subhead,.about-v8-section-head{grid-template-columns:1fr;gap:.45rem}
  .about-v8-skill-list{grid-template-columns:1fr}
  .about-v8-actions .btn{width:100%;justify-content:space-between}
}

/* ===================== ABOUT V9 — CLEAN TWO-COLUMN REDESIGN ===================== */
body.page-about .about-section.about-v9{
  max-width:min(1500px, 100%);
  padding:calc(var(--header-h) + 2.2rem) var(--gutter) 6rem;
}
.about-v9{
  --about-v9-card:linear-gradient(135deg, rgba(255,255,255,.045), rgba(255,255,255,.012));
  --about-v9-card-soft:linear-gradient(135deg, rgba(236,231,75,.08), rgba(255,255,255,.018));
  --about-v9-line:rgba(236,231,75,.22);
}
.about-v9-hero{
  display:grid;
  grid-template-columns:minmax(320px, 0.92fr) minmax(0, 1.45fr);
  gap:clamp(2.2rem, 4.8vw, 5rem);
  align-items:start;
}
.about-v9-visual{
  min-width:0;
}
.about-v9-portrait{
  position:relative;
  overflow:hidden;
  width:100%;
  min-height:clamp(440px, 62vh, 690px);
  aspect-ratio:4 / 5;
  border:1px solid var(--line);
  background:
    radial-gradient(circle at 45% 18%, rgba(236,231,75,.15), transparent 32%),
    linear-gradient(145deg, rgba(255,255,255,.04), rgba(255,255,255,.012)),
    var(--bg-2);
  box-shadow:0 24px 80px rgba(0,0,0,.34);
}
.about-v9-portrait picture,
.about-v9-portrait__img{
  position:absolute;
  inset:0;
  display:block;
  width:100%;
  height:100%;
}
.about-v9-portrait__img{
  object-fit:cover;
  object-position:center top;
  transform:scale(1.015);
  animation:none;
}
.about-v9-id-card{
  margin-top:1.1rem;
  padding:clamp(1.25rem, 2.1vw, 1.8rem);
  border:1px solid var(--line);
  border-left:4px solid var(--accent);
  background:var(--about-v9-card);
}
.about-v9-id-card h2{
  margin:.45rem 0 .25rem;
  font-family:var(--font-display);
  font-size:clamp(2.7rem, 4.2vw, 4.85rem);
  line-height:.94;
  letter-spacing:-.035em;
  text-transform:uppercase;
  color:var(--accent);
  text-shadow:0 4px 0 rgba(0,0,0,.24);
}
.about-v9-role{
  margin:0;
  font-family:var(--font-ui);
  font-size:.82rem;
  line-height:1.55;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink);
}
.about-v9-focus{
  margin:.65rem 0 0;
  max-width:42ch;
  font-size:.98rem;
  line-height:1.65;
  color:var(--ink-soft);
}
.about-v9-copy{
  min-width:0;
  padding:clamp(2rem, 4vw, 3.6rem);
  border:1px solid var(--line);
  background:
    radial-gradient(circle at 98% 2%, rgba(236,231,75,.10), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.045), rgba(255,255,255,.012));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035), 0 24px 80px rgba(0,0,0,.18);
}
.about-v9-title{
  max-width:14.5em;
  margin:.65rem 0 1.25rem;
  font-family:var(--font-display);
  font-size:clamp(2.65rem, 4.8vw, 5.6rem);
  line-height:.96;
  letter-spacing:-.035em;
  text-transform:uppercase;
  color:var(--accent);
  text-shadow:0 4px 0 rgba(0,0,0,.22);
}
.about-v9-lead{
  max-width:70ch;
  margin:0;
  font-size:clamp(1.15rem, 1.55vw, 1.65rem);
  line-height:1.62;
  letter-spacing:-.02em;
  color:var(--ink);
}
.about-v9-body{
  max-width:78ch;
  margin:1.35rem 0 0;
  font-size:clamp(.98rem, 1vw, 1.08rem);
  line-height:1.78;
  color:var(--ink-soft);
}
.about-v9-summary{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:.8rem;
  margin-top:1.75rem;
}
.about-v9-summary article{
  display:flex;
  align-items:center;
  gap:.85rem;
  min-height:82px;
  padding:.95rem 1rem;
  border:1px solid var(--line);
  background:rgba(0,0,0,.16);
}
.about-v9-summary strong{
  font-family:var(--font-display);
  font-size:clamp(2.2rem, 3.2vw, 3.3rem);
  line-height:.85;
  color:var(--accent);
}
.about-v9-summary span{
  font-family:var(--font-ui);
  font-size:.74rem;
  line-height:1.35;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.about-v9-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:1.6rem;
}
.about-v9-actions .btn{
  min-height:48px;
}
.about-v9-tools{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid var(--line);
}
.about-v9-mini-head{
  display:grid;
  grid-template-columns:auto minmax(0, 1fr);
  gap:1rem;
  align-items:end;
}
.about-v9-mini-head p,
.about-v9-section-head p{
  margin:0;
  max-width:58ch;
  color:var(--ink-mute);
  line-height:1.6;
}
.about-v9-tools-list{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:1rem;
}
.about-v9-tools-list .about-tool-badge{
  padding:.38rem .75rem .38rem .42rem;
  background:rgba(0,0,0,.18);
  border-color:rgba(236,231,75,.18);
}
.about-v9-tools-list .about-tool-badge__icon,
.about-v9-tools-list .about-tool-badge__fallback{
  width:20px;
  height:20px;
}
.about-v9-focus-section{
  margin-top:clamp(1.8rem, 4vw, 3rem);
  padding:clamp(1.5rem, 3vw, 2.3rem);
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
}
.about-v9-section-head{
  display:grid;
  grid-template-columns:auto minmax(0, 1fr);
  gap:1.25rem;
  align-items:end;
  margin-bottom:1.15rem;
}
.about-v9-skill-list{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:.75rem;
}
.about-v9-skill-list li{
  min-height:112px;
  padding:1rem;
  border:1px solid var(--line);
  background:rgba(0,0,0,.16);
}
.about-v9-skill-list .skill-num{
  color:var(--accent);
}
.about-v9-skill-list .skill-name{
  font-size:1rem;
}
.about-v9-skill-list .skill-tag{
  opacity:.75;
}

body.light .about-v9-portrait,
body.light .about-v9-copy,
body.light .about-v9-id-card,
body.light .about-v9-focus-section{
  background:linear-gradient(135deg, rgba(255,255,255,.82), rgba(255,255,255,.62));
}

@media (max-width:1180px){
  .about-v9-hero{grid-template-columns:minmax(280px, .9fr) minmax(0, 1.15fr);gap:2rem}
  .about-v9-summary{grid-template-columns:1fr 1fr 1fr}
  .about-v9-skill-list{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width:900px){
  body.page-about .about-section.about-v9{padding-top:calc(var(--header-h) + 1.15rem)}
  .about-v9-hero{grid-template-columns:1fr;gap:1.2rem}
  .about-v9-visual{display:grid;grid-template-columns:minmax(240px, 420px) minmax(0, 1fr);gap:1rem;align-items:stretch}
  .about-v9-portrait{min-height:auto;aspect-ratio:1/1}
  .about-v9-id-card{margin-top:0;display:flex;flex-direction:column;justify-content:center}
  .about-v9-title{font-size:clamp(2.35rem, 9vw, 4.1rem);line-height:1}
  .about-v9-copy{padding:1.35rem}
  .about-v9-mini-head,.about-v9-section-head{grid-template-columns:1fr;gap:.45rem}
}
@media (max-width:640px){
  .about-v9-visual{grid-template-columns:1fr}
  .about-v9-id-card{margin-top:0}
  .about-v9-summary{grid-template-columns:1fr;gap:.65rem}
  .about-v9-summary article{min-height:72px}
  .about-v9-actions .btn{width:100%;justify-content:space-between}
  .about-v9-skill-list{grid-template-columns:1fr}
  .about-v9-tools-list .about-tool-badge{font-size:.68rem}
}

/* =======================================================================
   ABOUT V9 SPACIOUS READABILITY PASS — May 2026
   Keeps the current About design, but opens the layout, shortens the visual
   weight of headings, improves text measure, and enlarges tools/focus cards.
   ======================================================================= */
body.page-about .about-section.about-v9{
  max-width:min(1680px, calc(100vw - (var(--gutter) * .65)));
  padding:calc(var(--header-h) + clamp(1.35rem, 2.6vw, 2.65rem)) var(--gutter) clamp(5rem, 7vw, 7.5rem);
}
body.page-about .about-v9-hero{
  grid-template-columns:minmax(340px, .78fr) minmax(680px, 1.62fr);
  gap:clamp(2.6rem, 5.2vw, 6.6rem);
  align-items:start;
}
body.page-about .about-v9-portrait{
  min-height:clamp(500px, 68vh, 760px);
  aspect-ratio:4 / 5.35;
}
body.page-about .about-v9-id-card{
  margin-top:1.35rem;
  padding:clamp(1.35rem, 2.2vw, 2rem);
}
body.page-about .about-v9-id-card h2{
  font-size:clamp(2.65rem, 3.75vw, 4.65rem);
  line-height:.96;
}
body.page-about .about-v9-role{
  max-width:44ch;
  font-size:clamp(.78rem, .82vw, .9rem);
  letter-spacing:.14em;
}
body.page-about .about-v9-focus{
  max-width:54ch;
  font-size:clamp(1rem, .95vw, 1.08rem);
  line-height:1.75;
}
body.page-about .about-v9-copy{
  padding:clamp(2.25rem, 4.1vw, 4.4rem);
  border-left:3px solid var(--accent);
}
body.page-about .about-v9-title{
  max-width:10.5em;
  margin:.62rem 0 clamp(1.4rem, 2.4vw, 2rem);
  font-size:clamp(2.55rem, 4.1vw, 5.1rem);
  line-height:.98;
  letter-spacing:-.028em;
}
body.page-about .about-v9-lead{
  max-width:68ch;
  font-size:clamp(1.14rem, 1.35vw, 1.42rem);
  line-height:1.68;
}
body.page-about .about-v9-body{
  max-width:74ch;
  margin-top:1.15rem;
  font-size:clamp(1rem, .98vw, 1.08rem);
  line-height:1.82;
}
body.page-about .about-v9-summary{
  gap:clamp(.9rem, 1.3vw, 1.25rem);
  margin-top:clamp(1.8rem, 2.6vw, 2.35rem);
}
body.page-about .about-v9-summary article{
  min-height:92px;
  padding:1.1rem 1.15rem;
}
body.page-about .about-v9-actions{
  gap:.9rem;
  margin-top:clamp(1.75rem, 2.5vw, 2.25rem);
}
body.page-about .about-v9-actions .btn{
  min-height:52px;
  padding-inline:1.15rem;
}
body.page-about .about-v9-tools{
  margin-top:clamp(2.15rem, 3vw, 2.75rem);
  padding-top:clamp(1.6rem, 2.3vw, 2rem);
}
body.page-about .about-v9-mini-head{
  grid-template-columns:minmax(190px, max-content) minmax(0, 1fr);
  gap:clamp(1rem, 2vw, 1.75rem);
  align-items:start;
}
body.page-about .about-v9-mini-head p,
body.page-about .about-v9-section-head p{
  max-width:64ch;
  font-size:1rem;
  line-height:1.7;
}
body.page-about .about-v9-tools-list{
  gap:.75rem;
  margin-top:1.25rem;
}
body.page-about .about-v9-tools-list .about-tool-badge{
  min-height:2.9rem;
  padding:.52rem .92rem .52rem .54rem;
  gap:.58rem;
  font-size:.78rem;
  letter-spacing:.14em;
  border-color:rgba(236,231,75,.26);
}
body.page-about .about-v9-tools-list .about-tool-badge__icon,
body.page-about .about-v9-tools-list .about-tool-badge__fallback{
  width:1.55rem;
  height:1.55rem;
}
body.page-about .about-v9-focus-section{
  margin-top:clamp(2.3rem, 4.6vw, 3.8rem);
  padding:clamp(1.8rem, 3vw, 2.65rem);
}
body.page-about .about-v9-section-head{
  grid-template-columns:minmax(230px, max-content) minmax(0, 1fr);
  gap:clamp(1rem, 2.2vw, 1.9rem);
  align-items:start;
  margin-bottom:clamp(1.25rem, 2.2vw, 1.8rem);
}
body.page-about .about-v9-skill-list{
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:clamp(.9rem, 1.35vw, 1.2rem);
}
body.page-about .about-v9-skill-list li{
  min-height:138px;
  padding:clamp(1.1rem, 1.6vw, 1.35rem);
  display:grid;
  grid-template-columns:1fr;
  align-content:start;
  gap:.62rem;
  border-color:rgba(236,231,75,.16);
}
body.page-about .about-v9-skill-list .skill-num{
  font-size:.8rem;
  letter-spacing:.24em;
}
body.page-about .about-v9-skill-list .skill-name{
  font-size:clamp(1.35rem, 1.55vw, 1.72rem);
  line-height:1.02;
  letter-spacing:.01em;
}
body.page-about .about-v9-skill-list .skill-tag{
  font-size:clamp(.72rem, .78vw, .82rem);
  line-height:1.45;
  letter-spacing:.16em;
}

@media (max-width:1280px){
  body.page-about .about-v9-hero{
    grid-template-columns:minmax(300px, .9fr) minmax(0, 1.18fr);
    gap:clamp(1.7rem, 3.5vw, 3rem);
  }
  body.page-about .about-v9-skill-list{grid-template-columns:repeat(2, minmax(0, 1fr));}
}
@media (max-width:960px){
  body.page-about .about-section.about-v9{max-width:100%;}
  body.page-about .about-v9-hero{grid-template-columns:1fr;gap:1.35rem;}
  body.page-about .about-v9-visual{display:grid;grid-template-columns:minmax(240px, 430px) minmax(0, 1fr);gap:1rem;align-items:stretch;}
  body.page-about .about-v9-portrait{min-height:auto;aspect-ratio:1 / 1;}
  body.page-about .about-v9-copy{padding:clamp(1.35rem, 5vw, 2.1rem);}
  body.page-about .about-v9-title{font-size:clamp(2.45rem, 9vw, 4.4rem);max-width:11em;}
  body.page-about .about-v9-mini-head,
  body.page-about .about-v9-section-head{grid-template-columns:1fr;gap:.65rem;}
}
@media (max-width:640px){
  body.page-about .about-v9-visual{grid-template-columns:1fr;}
  body.page-about .about-v9-title{font-size:clamp(2.25rem, 12.5vw, 3.75rem);}
  body.page-about .about-v9-lead{font-size:1.05rem;}
  body.page-about .about-v9-summary,
  body.page-about .about-v9-skill-list{grid-template-columns:1fr;}
  body.page-about .about-v9-tools-list .about-tool-badge{font-size:.72rem;min-height:2.7rem;}
}

/* =======================================================================
   ABOUT V10 — OPEN EDIT BASED ON PROVIDED REFERENCE
   Same structure, more whitespace, no boxed right column, wider readable layout.
   ======================================================================= */
body.page-about .about-section.about-v9{
  max-width:min(1580px, calc(100vw - clamp(2rem, 5vw, 5rem)));
  padding-top:calc(var(--header-h) + clamp(2.1rem, 4vw, 4rem));
  padding-bottom:clamp(5.5rem, 8vw, 8rem);
}

body.page-about .about-v9-hero{
  width:100%;
  display:grid;
  grid-template-columns:minmax(360px, 520px) minmax(0, 1fr);
  gap:clamp(4rem, 6.5vw, 7.2rem);
  align-items:start;
}

body.page-about .about-v9-visual{
  max-width:520px;
}

body.page-about .about-v9-portrait{
  min-height:0;
  aspect-ratio:1 / 1.08;
  border-color:rgba(236,231,75,.20);
  background:
    radial-gradient(circle at 50% 10%, rgba(236,231,75,.12), transparent 32%),
    linear-gradient(145deg, rgba(255,255,255,.035), rgba(255,255,255,.01)),
    var(--bg-2);
  box-shadow:0 30px 90px rgba(0,0,0,.36);
}

body.page-about .about-v9-portrait__img{
  object-position:center top;
  transform:scale(1.005);
}

body.page-about .about-v9-id-card{
  margin-top:1.35rem;
  padding:clamp(1.35rem, 2.1vw, 1.95rem);
  min-height:clamp(190px, 15vw, 245px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-color:rgba(236,231,75,.20);
  border-left-width:4px;
  background:linear-gradient(135deg, rgba(255,255,255,.045), rgba(255,255,255,.01));
  box-shadow:0 18px 70px rgba(0,0,0,.2);
}

body.page-about .about-v9-id-card h2{
  max-width:8.5em;
  margin:.5rem 0 .35rem;
  font-size:clamp(2.85rem, 4.05vw, 4.8rem);
  line-height:.92;
}

body.page-about .about-v9-role{
  font-size:clamp(.78rem, .84vw, .9rem);
  letter-spacing:.16em;
  color:var(--accent);
}

body.page-about .about-v9-focus{
  max-width:44ch;
  margin-top:clamp(.8rem, 1.2vw, 1rem);
  font-size:clamp(1rem, 1vw, 1.12rem);
  line-height:1.75;
}

body.page-about .about-v9-copy{
  padding:clamp(1.2rem, 2.5vw, 2.4rem) 0 0;
  border:0;
  border-left:0;
  background:transparent;
  box-shadow:none;
}

body.page-about .about-v9-title{
  max-width:9.8em;
  margin:.7rem 0 clamp(1.35rem, 2.2vw, 1.9rem);
  font-size:clamp(3.65rem, 5.15vw, 6.4rem);
  line-height:.92;
  letter-spacing:-.032em;
  color:var(--ink);
  text-shadow:0 5px 0 rgba(0,0,0,.26);
}

body.page-about .about-v9-title span{
  color:var(--accent);
}

body.page-about .about-v9-lead{
  max-width:64ch;
  font-size:clamp(1.18rem, 1.28vw, 1.46rem);
  line-height:1.68;
  letter-spacing:-.012em;
}

body.page-about .about-v9-body{
  max-width:70ch;
  margin-top:1.25rem;
  font-size:clamp(1rem, .95vw, 1.08rem);
  line-height:1.85;
}

body.page-about .about-v9-summary{
  max-width:680px;
  gap:clamp(.9rem, 1.2vw, 1.15rem);
  margin-top:clamp(1.85rem, 2.4vw, 2.35rem);
}

body.page-about .about-v9-summary article{
  position:relative;
  min-height:112px;
  padding:1.15rem 1.15rem 1.05rem;
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-areas:
    "icon number"
    "label label";
  align-items:end;
  column-gap:.85rem;
  row-gap:.45rem;
  border-color:rgba(236,231,75,.18);
  background:linear-gradient(145deg, rgba(0,0,0,.24), rgba(255,255,255,.018));
}

body.page-about .about-v9-summary-icon{
  grid-area:icon;
  width:2.35rem;
  height:2.35rem;
  display:grid;
  place-items:center;
  border:1px solid rgba(236,231,75,.55);
  border-radius:999px;
  color:var(--accent);
  font-size:1.1rem;
  line-height:1;
}

body.page-about .about-v9-summary strong{
  grid-area:number;
  font-size:clamp(2.35rem, 3vw, 3.55rem);
  line-height:.82;
}

body.page-about .about-v9-summary span:not(.about-v9-summary-icon){
  grid-area:label;
  font-size:.76rem;
  letter-spacing:.18em;
}

body.page-about .about-v9-actions{
  max-width:700px;
  gap:clamp(.8rem, 1.1vw, 1rem);
  margin-top:clamp(1.45rem, 2vw, 1.95rem);
}

body.page-about .about-v9-actions .btn{
  flex:1 1 170px;
  min-height:52px;
  justify-content:center;
}

body.page-about .about-v9-tools{
  max-width:790px;
  margin-top:clamp(2.1rem, 3vw, 2.8rem);
  padding-top:clamp(1.35rem, 2.2vw, 1.8rem);
  border-top-color:rgba(236,231,75,.15);
}

body.page-about .about-v9-mini-head{
  grid-template-columns:1fr;
  gap:.45rem;
}

body.page-about .about-v9-mini-head p,
body.page-about .about-v9-section-head p{
  max-width:70ch;
  color:var(--ink-soft);
}

body.page-about .about-v9-tools-list{
  gap:.78rem;
  margin-top:1.15rem;
}

body.page-about .about-v9-tools-list .about-tool-badge{
  min-height:3.05rem;
  padding:.58rem 1rem .58rem .62rem;
  gap:.62rem;
  font-size:.82rem;
  letter-spacing:.14em;
  border-color:rgba(236,231,75,.20);
  background:rgba(0,0,0,.18);
}

body.page-about .about-v9-tools-list .about-tool-badge__icon,
body.page-about .about-v9-tools-list .about-tool-badge__fallback{
  width:1.6rem;
  height:1.6rem;
}

body.page-about .about-v9-focus-section{
  margin-top:clamp(3rem, 5vw, 4.8rem);
  padding:clamp(1.8rem, 3vw, 2.6rem);
  border-color:rgba(236,231,75,.16);
  background:linear-gradient(135deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}

body.page-about .about-v9-section-head{
  grid-template-columns:minmax(230px, max-content) minmax(0, 1fr);
  align-items:start;
}

body.page-about .about-v9-skill-list{
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:clamp(1rem, 1.45vw, 1.3rem);
}

body.page-about .about-v9-skill-list li{
  min-height:150px;
  padding:clamp(1.2rem, 1.55vw, 1.45rem);
}

body.page-about .about-v9-skill-list .skill-name{
  font-size:clamp(1.35rem, 1.55vw, 1.75rem);
}

body.light .about-v9-copy{
  background:transparent;
}

body.light .about-v9-title{
  color:var(--ink);
  text-shadow:none;
}

@media (max-width:1280px){
  body.page-about .about-v9-hero{
    grid-template-columns:minmax(320px, 460px) minmax(0, 1fr);
    gap:clamp(2.4rem, 4vw, 3.6rem);
  }
  body.page-about .about-v9-title{font-size:clamp(3.1rem, 5.4vw, 5.4rem);}
  body.page-about .about-v9-skill-list{grid-template-columns:repeat(2, minmax(0, 1fr));}
}

@media (max-width:960px){
  body.page-about .about-section.about-v9{
    max-width:100%;
    padding-top:calc(var(--header-h) + 1.25rem);
  }
  body.page-about .about-v9-hero{
    grid-template-columns:1fr;
    gap:1.5rem;
  }
  body.page-about .about-v9-visual{
    max-width:none;
    display:grid;
    grid-template-columns:minmax(240px, 430px) minmax(0, 1fr);
    gap:1rem;
  }
  body.page-about .about-v9-copy{
    padding-top:.5rem;
  }
  body.page-about .about-v9-title{
    font-size:clamp(2.75rem, 10vw, 4.8rem);
  }
  body.page-about .about-v9-summary{
    max-width:none;
  }
  body.page-about .about-v9-section-head{
    grid-template-columns:1fr;
  }
}

@media (max-width:700px){
  body.page-about .about-v9-visual{
    grid-template-columns:1fr;
  }
  body.page-about .about-v9-id-card{
    min-height:auto;
  }
  body.page-about .about-v9-summary,
  body.page-about .about-v9-skill-list{
    grid-template-columns:1fr;
  }
  body.page-about .about-v9-actions .btn{
    flex-basis:100%;
    justify-content:space-between;
  }
  body.page-about .about-v9-tools-list .about-tool-badge{
    font-size:.74rem;
    min-height:2.8rem;
  }
}


/* =======================================================================
   ABOUT V11 — WIDER, LESS CRAMPED FINAL TUNING
   - Uses more horizontal space instead of keeping the section centered/narrow
   - Moves the portrait block further left and lets the text breathe on the right
   - Simplifies the main title and improves letter spacing/readability
   - Forces the desktop program badges into a clean two-row grid
   ======================================================================= */
body.page-about .about-section.about-v9{
  width:100%;
  max-width:none !important;
  margin-inline:0 !important;
  padding-left:clamp(1.25rem, 2.4vw, 3.25rem) !important;
  padding-right:clamp(1.25rem, 2.4vw, 3.25rem) !important;
  padding-top:calc(var(--header-h) + clamp(2rem, 3.2vw, 3.45rem)) !important;
}

body.page-about .about-v9-hero{
  width:min(100%, 1880px);
  margin-inline:auto;
  grid-template-columns:minmax(390px, 560px) minmax(0, 1fr) !important;
  gap:clamp(3.5rem, 5.4vw, 7.4rem) !important;
  align-items:start;
}

body.page-about .about-v9-visual{
  max-width:none !important;
  margin-left:calc(-1 * clamp(.35rem, 1.15vw, 1.55rem));
}

body.page-about .about-v9-copy{
  max-width:none !important;
  padding:clamp(1.2rem, 2.1vw, 2.6rem) 0 0 !important;
  margin-left:clamp(.4rem, 1.6vw, 2.4rem);
}

body.page-about .about-v9-portrait{
  width:100%;
  aspect-ratio:1 / 1.06 !important;
  border-color:rgba(236,231,75,.28) !important;
}

body.page-about .about-v9-id-card{
  width:100%;
  margin-top:clamp(1rem, 1.3vw, 1.35rem) !important;
}

body.page-about .eyebrow--ink,
body.page-about .about-v9-mini-head .eyebrow,
body.page-about .about-v9-section-head .eyebrow{
  color:var(--accent) !important;
  opacity:1 !important;
  letter-spacing:.20em !important;
  font-weight:800 !important;
}

body.page-about .about-v9-title{
  max-width:12em !important;
  margin:.65rem 0 clamp(1.25rem, 2vw, 1.85rem) !important;
  color:var(--ink) !important;
  font-size:clamp(3.15rem, 4.65vw, 5.75rem) !important;
  line-height:1.02 !important;
  letter-spacing:.018em !important;
  text-shadow:0 4px 0 rgba(0,0,0,.22) !important;
}

body.page-about .about-v9-lead{
  max-width:76ch !important;
  font-size:clamp(1.22rem, 1.34vw, 1.58rem) !important;
  line-height:1.72 !important;
  letter-spacing:.005em !important;
  font-weight:500 !important;
  color:rgba(248,246,239,.94) !important;
}

body.page-about .about-v9-body{
  max-width:82ch !important;
  margin-top:1.2rem !important;
  font-size:clamp(1.06rem, 1.04vw, 1.18rem) !important;
  line-height:1.86 !important;
  letter-spacing:.004em !important;
  font-weight:500 !important;
  color:rgba(234,228,218,.82) !important;
}

body.page-about .about-v9-focus,
body.page-about .about-v9-mini-head p,
body.page-about .about-v9-section-head p{
  font-weight:500 !important;
  color:rgba(234,228,218,.78) !important;
}

body.page-about .about-v9-summary,
body.page-about .about-v9-actions,
body.page-about .about-v9-tools{
  max-width:none !important;
}

body.page-about .about-v9-summary{
  width:min(100%, 860px);
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
}

body.page-about .about-v9-actions{
  width:min(100%, 860px);
}

body.page-about .about-v9-tools{
  width:min(100%, 1020px);
}

body.page-about .about-v9-tools-list{
  display:grid !important;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:.68rem !important;
  align-items:stretch;
}

body.page-about .about-v9-tools-list .about-tool-badge{
  width:100%;
  min-width:0;
  min-height:3rem !important;
  justify-content:flex-start;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  padding:.56rem .78rem .56rem .58rem !important;
  font-size:.78rem !important;
  line-height:1.1;
  letter-spacing:.095em !important;
  font-weight:800 !important;
  color:rgba(248,246,239,.86) !important;
  border-color:rgba(236,231,75,.28) !important;
}

body.page-about .about-v9-tools-list .about-tool-badge__icon,
body.page-about .about-v9-tools-list .about-tool-badge__fallback{
  width:1.55rem !important;
  height:1.55rem !important;
}

body.page-about .about-v9-focus-section{
  width:min(100%, 1880px);
  margin-inline:auto;
  padding-left:clamp(1.45rem, 2.2vw, 3rem) !important;
  padding-right:clamp(1.45rem, 2.2vw, 3rem) !important;
}

body.page-about .about-v9-skill-list li{
  min-height:142px !important;
}

body.page-about .about-v9-skill-list .skill-name{
  letter-spacing:.025em !important;
  color:var(--ink) !important;
}

body.page-about .about-v9-skill-list .skill-tag{
  color:rgba(234,228,218,.76) !important;
  font-weight:700 !important;
}

body.light.page-about .about-v9-title,
body.light.page-about .about-v9-lead{
  color:var(--ink) !important;
  text-shadow:none !important;
}

body.light.page-about .about-v9-body,
body.light.page-about .about-v9-focus,
body.light.page-about .about-v9-mini-head p,
body.light.page-about .about-v9-section-head p{
  color:rgba(23,24,28,.74) !important;
}

@media (max-width:1380px){
  body.page-about .about-v9-hero{
    grid-template-columns:minmax(340px, 500px) minmax(0, 1fr) !important;
    gap:clamp(2.4rem, 4.2vw, 4.5rem) !important;
  }
  body.page-about .about-v9-copy{margin-left:0;}
  body.page-about .about-v9-title{font-size:clamp(2.9rem, 5vw, 4.9rem) !important;}
  body.page-about .about-v9-tools-list{grid-template-columns:repeat(6, minmax(0, 1fr));}
}

@media (max-width:1120px){
  body.page-about .about-v9-hero{
    grid-template-columns:1fr !important;
  }
  body.page-about .about-v9-visual{
    margin-left:0;
    display:grid;
    grid-template-columns:minmax(260px, 440px) minmax(0, 1fr);
    gap:1rem;
  }
  body.page-about .about-v9-copy{
    margin-left:0;
  }
  body.page-about .about-v9-tools-list{grid-template-columns:repeat(4, minmax(0, 1fr));}
}

@media (max-width:760px){
  body.page-about .about-section.about-v9{
    padding-left:1rem !important;
    padding-right:1rem !important;
  }
  body.page-about .about-v9-visual{
    grid-template-columns:1fr;
  }
  body.page-about .about-v9-title{
    font-size:clamp(2.55rem, 12vw, 3.6rem) !important;
    letter-spacing:.01em !important;
  }
  body.page-about .about-v9-lead{font-size:1.08rem !important;}
  body.page-about .about-v9-body{font-size:1rem !important;}
  body.page-about .about-v9-summary,
  body.page-about .about-v9-skill-list{
    grid-template-columns:1fr !important;
  }
  body.page-about .about-v9-tools-list{grid-template-columns:repeat(2, minmax(0, 1fr));}
}

@media (max-width:460px){
  body.page-about .about-v9-tools-list{grid-template-columns:1fr;}
}

/* =======================================================================
   ABOUT V12 — IDENTITY LETTER SPACING + SOFT ATMOSPHERIC BACKGROUND
   - Opens up the Omar Khuffash identity wordmark so it no longer feels cramped
   - Adds a very light moving yellow atmosphere behind the page content
   ======================================================================= */
body.page-about{
  position:relative;
  background:
    radial-gradient(ellipse at 10% 36%, rgba(255, 211, 92, .060), transparent 36%),
    radial-gradient(ellipse at 88% 16%, rgba(251, 254, 57, .045), transparent 42%),
    linear-gradient(135deg, #0f1115 0%, #0b0d12 46%, #121319 100%) !important;
}

body.page-about::before{
  content:"";
  position:fixed;
  inset:-18vmax;
  z-index:0;
  pointer-events:none;
  opacity:.48;
  background:
    radial-gradient(circle at 18% 42%, rgba(255, 196, 80, .125), transparent 24%),
    radial-gradient(circle at 78% 18%, rgba(251, 254, 57, .095), transparent 27%),
    radial-gradient(ellipse at 58% 78%, rgba(255, 222, 116, .060), transparent 34%);
  filter:blur(10px);
  transform:translate3d(0,0,0) scale(1);
  animation:aboutAtmosphereDrift 24s ease-in-out infinite alternate;
}

body.page-about .about-section.about-v9,
body.page-about .site-footer,
body.page-about .float-contact-btn,
body.page-about .theme-toggle{
  position:relative;
  z-index:1;
}

body.page-about .about-v9-id-card{
  padding:clamp(1.55rem, 2.35vw, 2.15rem) !important;
}

body.page-about .about-v9-id-card h2{
  max-width:none !important;
  margin:.58rem 0 .45rem !important;
  font-size:clamp(2.28rem, 3.25vw, 4.05rem) !important;
  line-height:1.02 !important;
  letter-spacing:.052em !important;
  word-spacing:.10em !important;
  white-space:nowrap;
  color:var(--accent) !important;
  text-shadow:0 4px 0 rgba(0,0,0,.22), 0 0 28px rgba(251,254,57,.10) !important;
}

body.page-about .about-v9-role{
  letter-spacing:.19em !important;
}

@keyframes aboutAtmosphereDrift{
  0%{
    transform:translate3d(-1.5%, -1%, 0) scale(1);
  }
  50%{
    transform:translate3d(1.3%, 1.6%, 0) scale(1.035);
  }
  100%{
    transform:translate3d(2.2%, -1.1%, 0) scale(1.055);
  }
}

@media (max-width:760px){
  body.page-about .about-v9-id-card h2{
    font-size:clamp(2.12rem, 10vw, 3.2rem) !important;
    letter-spacing:.035em !important;
    white-space:normal;
  }
}

@media (prefers-reduced-motion:reduce){
  body.page-about::before{
    animation:none !important;
    transform:none !important;
  }
}

/* ============================================================================
   CONTACT PAGE HOTFIX — KEEP HERO TITLE FROM BEING CLIPPED
   Moves the Contact heading slightly lower and gives the display font breathing
   room so the top of the letters cannot hide under the fixed header.
   ============================================================================ */
.page-contact .contact-section {
  padding-top: calc(var(--header-h) + clamp(5.2rem, 7vw, 7.4rem));
}
.page-contact .contact-section > header {
  margin-top: clamp(0.65rem, 1.5vw, 1.25rem);
}
.page-contact .contact-section .title-xxl {
  line-height: 0.96;
  letter-spacing: 0.012em;
  padding-top: 0.12em;
  margin-top: 0.35rem !important;
  overflow: visible;
}
@media (max-width: 760px) {
  .page-contact .contact-section {
    padding-top: calc(var(--header-h) + 4.5rem);
  }
  .page-contact .contact-section .title-xxl {
    font-size: clamp(3.6rem, 18vw, 6.5rem);
  }
}
