/* ---------- SELF-HOSTED FONTS (KVKK: no Google IP leak) --------------- */
@font-face{font-family:"Fraunces";src:url("/fonts/fraunces.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("/fonts/fraunces-italic.woff2") format("woff2");font-weight:100 900;font-style:italic;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("/fonts/hanken.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("/fonts/hanken-italic.woff2") format("woff2");font-weight:100 900;font-style:italic;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("/fonts/jetbrains-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("/fonts/jetbrains-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}

/* =========================================================================
   cerenpolat.com  —  atelier / gallery aesthetic
   Display: Fraunces · Body: Hanken Grotesk · Mono: JetBrains Mono
   ========================================================================= */

/* ---------- THEME TOKENS ------------------------------------------------ */
:root{
  /* default theme = DARK (anthracite + dark walnut) */
  --bg:#1a1816;
  --bg-2:#211e1b;
  --surface:#26221f;
  --surface-2:#2e2a26;
  --text:#ece7e0;
  --muted:#a59c91;
  --faint:#776e63;
  --accent:#c2415a;
  --accent-2:#e6a3b1;
  --accent-soft:rgba(194,65,90,.16);
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);
  --shadow:0 30px 80px -30px rgba(0,0,0,.7);
  --grain-opacity:.04;
  --paper:transparent;
  --r:18px;
  --ease:cubic-bezier(.22,1,.36,1);
  color-scheme:dark;
}
[data-theme="light"]{
  /* warm paper (quiet luxury) */
  --bg:#efeae1;
  --bg-2:#e7e0d4;
  --surface:#fbf8f2;
  --surface-2:#efe8dc;
  --text:#211d1a;
  --muted:#6b6459;
  --faint:#9a9286;
  --accent:#7a1f3d;
  --accent-2:#9a2e4e;
  --accent-soft:rgba(122,31,61,.10);
  --line:rgba(33,29,26,.12);
  --line-strong:rgba(33,29,26,.20);
  --shadow:0 30px 70px -34px rgba(60,45,35,.35);
  --grain-opacity:.05;
  color-scheme:light;
}

/* ---------- RESET ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:
    radial-gradient(46% 44% at 8% -4%, color-mix(in srgb,var(--accent) 22%,transparent), transparent 60%),
    radial-gradient(42% 40% at 104% 18%, color-mix(in srgb,var(--accent) 16%,transparent), transparent 60%),
    radial-gradient(60% 55% at 50% 120%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 62%),
    linear-gradient(165deg, var(--bg) 0%, var(--bg-2) 45%, var(--bg) 100%);
  background-attachment:fixed;
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  transition:color .5s var(--ease);
  min-height:100vh;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--accent);color:#fff}

/* grain + vignette atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:9990;pointer-events:none;
  opacity:var(--grain-opacity);mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body::after{
  content:"";position:fixed;inset:-15%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(40% 45% at 22% 26%, color-mix(in srgb,var(--accent) 16%,transparent), transparent 60%),
    radial-gradient(38% 42% at 80% 72%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 60%);
  animation:bgFloat 24s ease-in-out infinite alternate;
}
@keyframes bgFloat{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(2.5%,-3%,0) scale(1.05)}}

/* ---------- TYPOGRAPHY -------------------------------------------------- */
.display{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.02;letter-spacing:-.02em}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace}
.kicker{
  font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--accent-2);display:inline-block;
}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:600;letter-spacing:-.02em;line-height:1.05}

/* ---------- LAYOUT ------------------------------------------------------ */
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}
section{position:relative}
.sec-pad{padding:clamp(72px,11vh,150px) 0}
.eyebrow-block{margin-bottom:clamp(36px,6vw,64px)}
.eyebrow-block h2{font-size:clamp(2rem,5.5vw,4rem);margin-top:.4em}
.eyebrow-block .sub{color:var(--muted);max-width:60ch;margin-top:1rem;font-size:clamp(1rem,1.4vw,1.12rem)}

/* ---------- LOADER ------------------------------------------------------ */
#loader{
  position:fixed;inset:0;z-index:10000;background:var(--bg);
  display:grid;place-items:center;transition:opacity .7s ease,visibility .7s;
}
#loader.done{opacity:0;visibility:hidden}
.loader-inner{display:grid;place-items:center;gap:22px}
.loader-inner img{width:84px;height:auto;animation:logoPulse 1.8s ease-in-out infinite}
.loader-bar{width:160px;height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.loader-bar span{display:block;height:100%;width:0;background:var(--accent);
  animation:loadFill 1.05s var(--ease) forwards}
#loader.done .loader-bar span{width:100%}
@keyframes logoPulse{0%,100%{opacity:.4;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}
@keyframes loadFill{0%{width:0}80%{width:88%}100%{width:100%}}

/* ---------- DECORATIVE CURSOR (additive, never hides native) ----------- */
.cursor-dot{
  position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--accent);
  border-radius:50%;pointer-events:none;z-index:9995;transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .3s;
  opacity:0;mix-blend-mode:difference;
}
.cursor-dot.show{opacity:.65}
.cursor-dot.hot{width:54px;height:54px;background:var(--accent-soft)}
@media (hover:none),(pointer:coarse){.cursor-dot{display:none}}

/* ---------- NAVBAR ------------------------------------------------------ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:9000;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(20px,5vw,64px);
  transition:background .4s var(--ease),border-color .4s,padding .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:color-mix(in srgb,var(--bg) 78%,transparent);
  backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--line);padding:10px clamp(20px,5vw,64px);
}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:"Fraunces",serif;font-weight:600;font-size:1.15rem}
.nav-logo img{width:30px;height:30px;object-fit:contain}
.nav-logo .sig{letter-spacing:-.01em}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-size:.86rem;padding:8px 13px;border-radius:999px;color:var(--muted);
  transition:color .25s,background .25s;position:relative;white-space:nowrap;
}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--text);background:var(--accent-soft)}
.nav-tools{display:flex;align-items:center;gap:8px}
.icon-btn{
  width:38px;height:38px;border-radius:999px;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--text);
  transition:border-color .25s,background .25s,transform .25s;background:var(--surface);
}
.icon-btn:hover{border-color:var(--accent);transform:translateY(-2px)}
.icon-btn svg{width:17px;height:17px}
.lang-btn{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.08em;
  width:auto;padding:0 13px;height:38px}
.burger{display:none}

/* mobile nav */
@media (max-width:1080px){
  .nav-links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:8px;
    background:color-mix(in srgb,var(--bg) 97%,transparent);backdrop-filter:blur(26px);
    opacity:0;visibility:hidden;transform:translateY(-8px);
    transition:opacity .35s var(--ease),transform .35s var(--ease),visibility .35s;z-index:8999;
  }
  .nav-links.open{opacity:1;visibility:visible;transform:none}
  .nav-links a{font-size:1.4rem;font-family:"Fraunces",serif;padding:10px 24px}
  .burger{display:grid;place-items:center}
}

/* ---------- BUTTONS ----------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:13px 24px;border-radius:999px;
  font-size:.92rem;font-weight:600;transition:transform .3s var(--ease),box-shadow .3s,background .3s;
  border:1px solid var(--line-strong);
}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px -12px var(--accent)}
.btn-ghost:hover{background:var(--surface);transform:translateY(-3px)}

/* ---------- HERO -------------------------------------------------------- */
.hero{min-height:100svh;display:grid;align-items:center;padding-top:90px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,5vw,72px);align-items:center}
.hero-title{font-size:clamp(2.8rem,8.5vw,6.6rem);margin:.35em 0 .5em}
.hero-title .line{display:block;overflow:hidden}
.hero-title .reveal{display:inline-block;transform:translateY(110%);animation:riseUp 1s var(--ease) forwards}
@keyframes riseUp{to{transform:translateY(0)}}
.hero-sub{color:var(--muted);max-width:46ch;font-size:clamp(1rem,1.5vw,1.18rem);
  opacity:0;animation:fadeUp .9s var(--ease) .7s forwards}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:2.2rem;
  opacity:0;animation:fadeUp .9s var(--ease) .9s forwards}
.hero-kicker{opacity:0;animation:fadeUp .8s var(--ease) .15s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* animated per-letter blue word in title */
.word-blue{color:var(--accent);position:relative;white-space:nowrap}
.word-blue .ch{
  display:inline-block;
  background:linear-gradient(110deg,var(--accent) 0%,var(--accent-2) 30%,#f6d9e0 45%,var(--accent-2) 60%,var(--accent) 100%);
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:shimmer 3.4s linear infinite;
  animation-delay:calc(var(--i) * .09s);
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-100% 0}}
.word-blue:hover .ch{animation-duration:1.1s}

/* easel */
.easel-wrap{position:relative;display:grid;place-items:center;opacity:0;
  animation:fadeUp 1s var(--ease) .5s forwards}
.easel{position:relative;width:min(100%,440px)}
.easel-frame-img{width:100%;height:auto;filter:drop-shadow(0 40px 50px rgba(0,0,0,.5))}
.easel-canvas{
  position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:50%;aspect-ratio:3/4;overflow:hidden;background:transparent;
  filter:drop-shadow(0 14px 26px rgba(0,0,0,.45));border-radius:2px;
}
.easel-canvas img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:contain;
  opacity:0;transition:opacity 1.1s var(--ease)}
.easel-canvas img.on{opacity:1}
.easel-cap{text-align:center;margin-top:18px;color:var(--faint);font-size:.78rem}
.scrolldown{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  font-size:.68rem;letter-spacing:.3em;color:var(--faint);display:flex;flex-direction:column;
  align-items:center;gap:8px;text-transform:uppercase}
.scrolldown .l{width:1px;height:36px;background:linear-gradient(var(--accent),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .easel{width:min(78vw,360px)}
  .hero{padding-top:120px}
}

/* ---------- MARQUEE ----------------------------------------------------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:20px clamp(16px,5vw,48px);background:var(--bg-2);
}
.marquee-track{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px clamp(18px,3vw,40px)}
.marquee span{font-family:"Fraunces",serif;font-size:clamp(.95rem,2.2vw,1.7rem);
  color:var(--faint);font-style:italic;display:inline-flex;align-items:center;gap:clamp(18px,3vw,40px)}
.marquee span::after{content:"✦";color:var(--accent);font-style:normal;font-size:.6em}
.marquee span:last-child::after{content:""}
@keyframes marq{to{transform:translateX(-50%)}}

/* scrolling artwork strip */
.artstrip{overflow:hidden;padding:14px 0;background:var(--bg)}
.artstrip-track{display:flex;gap:18px;width:max-content;animation:marq 48s linear infinite}
.artstrip:hover .artstrip-track{animation-play-state:paused}
.artstrip .media{height:clamp(150px,20vw,220px);width:auto;flex:0 0 auto;aspect-ratio:auto}
.artstrip .media img{height:100%;width:auto;object-fit:cover}

/* ---------- MEDIA + WATERMARK ------------------------------------------ */
.media{
  position:relative;overflow:hidden;border-radius:12px;background:var(--surface-2);
  border:1px solid var(--line);cursor:pointer;
}
.media img,.media video{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .8s var(--ease),filter .5s;
  -webkit-user-drag:none;user-select:none;
}
.media:hover img,.media:hover video{transform:scale(1.06)}
/* watermark is now burned in via Cloudinary (survives raw URL) */
.media .cap{
  position:absolute;inset:auto 0 0 0;padding:16px 14px 12px;z-index:2;
  background:linear-gradient(transparent,rgba(0,0,0,.78));
  transform:translateY(101%);transition:transform .4s var(--ease);color:#fff;
}
.media:hover .cap{transform:translateY(0)}
.media .cap b{font-family:"Fraunces",serif;font-weight:600;font-size:1rem;display:block}
.media .cap small{color:rgba(255,255,255,.7);font-size:.74rem;font-family:"JetBrains Mono",monospace}
.media .zoom{position:absolute;top:12px;left:12px;width:34px;height:34px;border-radius:999px;
  background:rgba(0,0,0,.45);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:3;
  opacity:0;transform:scale(.7);transition:.3s var(--ease)}
.media:hover .zoom{opacity:1;transform:scale(1)}
.media .zoom svg{width:15px;height:15px;stroke:#fff}

/* ---------- GALLERY GRIDS ---------------------------------------------- */
.masonry{columns:5;column-gap:12px}
.masonry .media{break-inside:avoid;margin-bottom:12px;display:block;height:auto}
.masonry .media img{height:auto;width:100%}
@media(max-width:1200px){.masonry{columns:4}}
@media(max-width:900px){.masonry{columns:3}}
@media(max-width:600px){.masonry{columns:2;column-gap:10px}.masonry .media{margin-bottom:10px}}

/* tiling galleries — dense mosaic, natural aspect ratio, never cropped */
.grid-2,.grid-3,.grid-4{column-gap:12px}
.grid-2{columns:3}.grid-3{columns:4}.grid-4{columns:5}
.grid-2 .media,.grid-3 .media,.grid-4 .media{break-inside:avoid;margin-bottom:12px;display:block;height:auto;aspect-ratio:auto}
.grid-2 .media img,.grid-3 .media img,.grid-4 .media img{width:100%;height:auto;display:block;object-fit:contain}
@media(max-width:1200px){.grid-4{columns:4}.grid-3{columns:3}}
@media(max-width:760px){.grid-2{columns:2}.grid-3{columns:2}.grid-4{columns:3}}
@media(max-width:480px){.grid-2,.grid-3,.grid-4{columns:2;column-gap:10px}}

.subhead{display:flex;align-items:baseline;gap:14px;margin:48px 0 22px;flex-wrap:wrap}
.subhead h3{font-size:clamp(1.4rem,3vw,2.1rem)}
.subhead .meta{color:var(--faint);font-family:"JetBrains Mono",monospace;font-size:.78rem}

/* ---------- REVEAL ON SCROLL ------------------------------------------- */
.reveal-up{opacity:0;transform:perspective(1000px) translateY(38px) rotateX(7deg);transform-origin:center top;
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-up.in{opacity:1;transform:perspective(1000px) translateY(0) rotateX(0)}
/* 3D interactive cards */
.card,.webcard,.codecard,.skill-card{transform-style:preserve-3d;will-change:transform;
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease)}
.card .num,.card h3,.card p,.card .go,.webcard .body,.codecard h4,.codecard p,.skill-card h4,.skill-card p{transform:translateZ(28px)}

/* ---------- HOME CARDS -------------------------------------------------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.cards{grid-template-columns:1fr}}
.card{
  position:relative;border:1px solid var(--line);border-radius:var(--r);padding:30px;
  background:var(--surface);overflow:hidden;transition:transform .4s var(--ease),border-color .4s;
  min-height:220px;display:flex;flex-direction:column;justify-content:space-between;
}
.card:hover{transform:translateY(-6px);border-color:var(--accent)}
.card::before{content:"";position:absolute;inset:0;background:
  radial-gradient(120% 120% at 100% 0%,var(--accent-soft),transparent 60%);opacity:0;transition:.4s}
.card:hover::before{opacity:1}
.card .num{font-family:"JetBrains Mono",monospace;color:var(--accent);font-size:.8rem;position:relative}
.card h3{font-size:1.5rem;margin:14px 0 8px;position:relative}
.card p{color:var(--muted);font-size:.92rem;position:relative}
.card .go{display:inline-flex;align-items:center;gap:8px;margin-top:18px;color:var(--accent-2);
  font-size:.85rem;font-weight:600;position:relative}
.card:hover .go .arr{transform:translateX(5px)}
.card .arr{transition:transform .3s var(--ease)}

/* ---------- ABOUT ------------------------------------------------------- */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,70px);align-items:start}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}}
.about-portrait{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  aspect-ratio:4/5;background:var(--surface-2)}
.about-portrait img{width:100%;height:100%;object-fit:cover}

.about-body p{margin-bottom:1.1rem;color:var(--muted);font-size:1.05rem}
.about-body p:first-child{color:var(--text);font-size:1.18rem}
.stats{display:flex;gap:34px;margin:30px 0;flex-wrap:wrap}
.stat .n{font-family:"Fraunces",serif;font-size:2.6rem;color:var(--accent);line-height:1}
.stat .l{color:var(--faint);font-size:.8rem;font-family:"JetBrains Mono",monospace;margin-top:4px}
.skill-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:14px}
@media(max-width:560px){.skill-grid{grid-template-columns:1fr}}
.skill-card{border:1px solid var(--line);border-radius:14px;padding:18px;background:var(--surface)}
.skill-card h4{font-family:"JetBrains Mono",monospace;font-size:.78rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-2);margin-bottom:8px}
.skill-card p{font-size:.92rem;color:var(--muted)}
.langs{list-style:none;display:grid;gap:10px;margin-top:8px}
.langs li{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:.95rem}
.langs li::before{content:"▹";color:var(--accent)}

/* tools wall */
.tools{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.tool{
  display:flex;align-items:center;gap:9px;padding:9px 15px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);transition:.3s var(--ease);
}
.tool:hover{border-color:var(--accent);transform:translateY(-3px)}
.tool img{width:22px;height:22px;object-fit:contain}
.tool span{font-size:.82rem;color:var(--muted)}

/* ---------- WEB CARDS --------------------------------------------------- */
.webgrid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:820px){.webgrid{grid-template-columns:1fr}}
.webcard{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);
  transition:transform .4s var(--ease),border-color .4s}
.webcard:hover{transform:translateY(-6px);border-color:var(--accent)}
.webcard .shot{overflow:hidden;position:relative;background:var(--surface-2)}
.webcard .shot img{width:100%;height:auto;display:block;object-fit:contain;transition:transform .8s var(--ease)}
.webcard:hover .shot img{transform:scale(1.03)}
.webcard .body{padding:22px}
.webcard h3{font-size:1.4rem}
.webcard .stack{font-family:"JetBrains Mono",monospace;font-size:.72rem;color:var(--accent-2);margin:6px 0 12px}
.webcard p{color:var(--muted);font-size:.92rem;margin-bottom:16px}

/* ---------- MARINE ------------------------------------------------------ */
.marine-hero{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:21/9;border:1px solid var(--line);margin-bottom:50px}
.marine-hero img{width:100%;height:100%;object-fit:cover}

.marine-hero .ov{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(0,0,0,.7));
  display:flex;align-items:flex-end;padding:28px}
.marine-hero .ov b{font-family:"Fraunces",serif;font-size:clamp(1.2rem,3vw,2rem);color:#fff}
.codegrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.codegrid{grid-template-columns:1fr}}
.codecard{border:1px solid var(--line);border-radius:14px;padding:24px;background:var(--surface);
  position:relative;overflow:hidden;transition:border-color .3s}
.codecard:hover{border-color:var(--accent)}
.codecard .tag{font-family:"JetBrains Mono",monospace;font-size:.7rem;color:var(--accent);letter-spacing:.1em}
.codecard h4{font-size:1.25rem;margin:10px 0}
.codecard p{color:var(--muted);font-size:.92rem}
.codecard .deco{position:absolute;top:-20px;right:-10px;font-family:"JetBrains Mono",monospace;
  font-size:7rem;color:var(--line);font-weight:700;pointer-events:none}
.projtable{display:grid;gap:10px}
.projrow{display:grid;grid-template-columns:auto 1fr auto auto;gap:16px;align-items:center;
  padding:16px 20px;border:1px solid var(--line);border-radius:12px;background:var(--surface);
  transition:border-color .3s,transform .3s}
.projrow:hover{border-color:var(--accent);transform:translateX(5px)}
.projrow .code{font-family:"JetBrains Mono",monospace;color:var(--accent-2);font-size:.85rem}
.projrow .nm{font-family:"Fraunces",serif;font-size:1.15rem}
.projrow .sp{color:var(--muted);font-size:.85rem}
.badge{font-family:"JetBrains Mono",monospace;font-size:.66rem;padding:4px 10px;border-radius:999px;
  border:1px solid var(--line-strong);white-space:nowrap}
.badge.build{color:var(--accent-2);border-color:var(--accent)}
.badge.service{color:var(--muted)}
@media(max-width:640px){.projrow{grid-template-columns:auto 1fr;row-gap:6px}.projrow .sp,.projrow .badge{grid-column:2}}

/* ---------- CONTACT ----------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.field{margin-bottom:18px}
.field label{display:block;font-family:"JetBrains Mono",monospace;font-size:.74rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.field input,.field textarea{
  width:100%;padding:14px 16px;border-radius:12px;border:1px solid var(--line);
  background:var(--surface);color:var(--text);font-family:inherit;font-size:1rem;
  transition:border-color .3s,background .3s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:var(--surface-2)}
.field textarea{resize:vertical;min-height:130px}
.form-ok{padding:14px 18px;border:1px solid var(--accent);border-radius:12px;
  background:var(--accent-soft);color:var(--text);margin-bottom:18px;display:none}
.form-ok.show{display:block}
.contact-side .mailto{font-family:"Fraunces",serif;font-size:clamp(1.3rem,3vw,1.9rem);
  color:var(--accent);word-break:break-all;display:inline-block;margin-top:6px}
.social{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.social a{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);font-size:.85rem;color:var(--muted);
  transition:.3s var(--ease)}
.social a:hover{border-color:var(--accent);color:var(--text);transform:translateY(-3px)}
.singulart-badge{display:inline-flex;align-items:center;gap:8px;background:#0b08c8;
  padding:8px 14px;border-radius:20px;text-decoration:none;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.singulart-badge:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(11,8,200,.5)}
.singulart-badge span{font-size:13px;font-weight:500;color:#c8c6ff}

/* ---------- FOOTER ------------------------------------------------------ */
.footer{border-top:1px solid var(--line);padding:56px 0 40px;background:var(--bg-2);margin-top:40px}
.footer-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.footer .sig-img{height:46px;width:auto;opacity:.85;margin-bottom:14px}
.footer .made{font-family:"Fraunces",serif;font-style:italic;font-size:1.1rem}
.footer .made .heart{color:var(--accent)}
.footer-cols{display:flex;gap:50px;flex-wrap:wrap}
.footer-cols h5{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.footer-cols a{display:block;color:var(--muted);font-size:.88rem;padding:4px 0;transition:color .25s}
.footer-cols a:hover{color:var(--accent-2)}
.footer-bottom{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--faint);font-size:.8rem}
.footer-bottom a{color:var(--faint)}
.footer-bottom a:hover{color:var(--accent-2)}

/* ---------- LIGHTBOX ---------------------------------------------------- */
.lightbox{position:fixed;inset:0;z-index:9800;background:rgba(0,0,0,.94);
  display:grid;place-items:center;opacity:0;visibility:hidden;transition:.4s ease;padding:24px}
.lightbox.open{opacity:1;visibility:visible}
.lightbox-stage{position:relative;max-width:92vw;max-height:88vh;display:grid;place-items:center}
.lightbox-stage img,.lightbox-stage video{max-width:92vw;max-height:84vh;border-radius:8px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);object-fit:contain}

.lb-cap{position:absolute;bottom:-34px;left:0;right:0;text-align:center;color:#bbb;font-size:.85rem;
  font-family:"JetBrains Mono",monospace}
.lb-btn{position:fixed;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:999px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);display:grid;place-items:center;color:#fff;
  border:1px solid rgba(255,255,255,.15);transition:.3s;z-index:9810}
.lb-btn:hover{background:var(--accent)}
.lb-prev{left:18px}.lb-next{right:18px}
.lb-close{position:fixed;top:18px;right:18px;width:46px;height:46px;border-radius:999px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);display:grid;place-items:center;color:#fff;
  border:1px solid rgba(255,255,255,.15);z-index:9810;transition:.3s}
.lb-close:hover{background:var(--accent);transform:rotate(90deg)}
.lb-btn svg,.lb-close svg{width:20px;height:20px;stroke:#fff}
@media(max-width:700px){.lb-btn{width:42px;height:42px}.lb-prev{left:8px}.lb-next{right:8px}}

/* ---------- COOKIE BANNER ---------------------------------------------- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:9700;max-width:560px;margin:0 auto;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:16px;padding:20px 22px;
  box-shadow:var(--shadow);transform:translateY(160%);transition:transform .6s var(--ease)}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:.86rem;color:var(--muted);margin-bottom:14px}
.cookie p a{color:var(--accent-2);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions .btn{padding:9px 18px;font-size:.84rem}

/* ---------- PAGE HEADER (inner pages) ---------------------------------- */
.page-head{padding:140px 0 30px}
.page-head h1{font-size:clamp(2.4rem,7vw,5rem);margin-top:.3em}

/* ---------- LEGAL ------------------------------------------------------- */
.legal{max-width:780px}
.legal h2{font-size:1.4rem;margin:34px 0 12px}
.legal p,.legal li{color:var(--muted);margin-bottom:12px;font-size:.98rem}
.legal ul{padding-left:22px}
.legal .updated{font-family:"JetBrains Mono",monospace;font-size:.78rem;color:var(--faint)}

/* protect toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(140%);
  background:var(--surface);border:1px solid var(--accent);padding:12px 22px;border-radius:999px;
  font-size:.85rem;z-index:9999;transition:transform .4s var(--ease);box-shadow:var(--shadow)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* utilities */
.center{text-align:center}
.mt-l{margin-top:48px}
img{-webkit-user-drag:none}

/* ---------- ORIGINS (about) -------------------------------------------- */
.origins{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;padding-top:8px;border-top:1px solid var(--line)}
.origins .kicker{color:var(--accent-2)}
.origins-line{font-family:"Fraunces",serif;font-size:clamp(1.3rem,3.4vw,2.2rem);line-height:1.2;
  font-style:italic;color:var(--text);max-width:24ch}

/* ---------- HERO (centered, generous whitespace) ---------------------- */
.hero-center{min-height:100vh;display:grid;place-items:center;text-align:center;padding:140px 0 90px}
.hero-center .wrap{display:flex;flex-direction:column;align-items:center;gap:26px;max-width:980px}
.hero-center .hero-title{font-size:clamp(2.8rem,9vw,6.6rem)}
.hero-center .hero-sub{max-width:54ch;font-size:1.15rem;color:var(--muted)}
.hero-center .hero-actions{margin-top:6px}

/* ---------- FOYER (v17 sliding easels) -------------------------------- */
.foyer-section{padding:3.5rem 0 4.5rem;position:relative;overflow:hidden}
.foyer-header{text-align:center;margin-bottom:1.5rem;padding:0 3rem}
.foyer-label{font-size:.72rem;letter-spacing:.3em;color:var(--accent-2);text-transform:uppercase;margin-bottom:.5rem;display:block;font-family:"JetBrains Mono",monospace}
.foyer-title{font-family:"Fraunces",serif;font-size:clamp(2rem,5vw,3.4rem);font-weight:600;letter-spacing:-.02em;color:var(--text)}
.foyer-marquee-container{overflow:hidden;padding:2.4rem 0;cursor:grab}
.foyer-marquee-container:active{cursor:grabbing}
.foyer-marquee{display:flex;gap:2rem;will-change:transform}
.easel-item{flex-shrink:0;position:relative;width:600px;cursor:pointer;transition:transform .4s var(--ease)}
.easel-item:hover{transform:translateY(-15px) scale(1.05);z-index:10}
.easel-frame{position:relative;z-index:1;width:100%}
.easel-image{width:100%;height:auto;display:block;filter:drop-shadow(0 20px 40px rgba(0,0,0,.28));pointer-events:none}
.artwork-container{position:absolute;top:36%;left:17%;width:66%;height:34%;overflow:hidden;border-radius:2px;
  box-shadow:inset 0 0 15px rgba(0,0,0,.15),0 4px 15px rgba(0,0,0,.25);background:var(--surface-2);z-index:10}
.artwork-container img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);pointer-events:none}
.easel-item:hover .artwork-container img{transform:scale(1.08)}
.artwork-info{position:absolute;top:23%;left:50%;transform:translateX(-50%) translateY(-10px);text-align:center;width:90%;
  opacity:0;transition:all .4s ease;pointer-events:none;z-index:11}
.easel-item:hover .artwork-info{opacity:1;transform:translateX(-50%) translateY(0)}
.artwork-title{font-family:"Fraunces",serif;font-size:1.15rem;font-weight:600;color:var(--text);
  text-shadow:0 1px 3px var(--bg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.artwork-medium{font-size:.86rem;color:var(--muted);font-style:italic}
.artwork-plaque{position:absolute;top:73%;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#D4AF37 0%,#F5E7A3 30%,#D4AF37 50%,#B8962E 100%);
  padding:.2rem .6rem;border-radius:2px;box-shadow:0 2px 6px rgba(0,0,0,.3);opacity:0;transition:all .4s ease .1s;z-index:11}
.easel-item:hover .artwork-plaque{opacity:1}
.plaque-text{font-family:"JetBrains Mono",monospace;font-size:.74rem;color:#2D2926;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
@media(max-width:760px){
  .easel-item{width:82vw}
  .foyer-header{padding:0 1.5rem}
  .hero-center{padding:120px 0 70px}
}


/* ---------- ACCESSIBILITY ------------------------------------------- */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal-up{opacity:1!important;transform:none!important}
  .cursor-dot{display:none!important}
}

/* ---------- HERO with full-screen blurred photo --------------------- */
.hero-photo{position:relative;min-height:100vh;display:grid;place-items:center;text-align:center;overflow:hidden;padding:120px 0 90px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:blur(3px) saturate(.85) brightness(.78) contrast(1.04);transform:scale(1.05)}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg, color-mix(in srgb,var(--bg) 32%,transparent), color-mix(in srgb,var(--bg) 62%,transparent) 70%, color-mix(in srgb,var(--bg) 80%,transparent)),
  radial-gradient(80% 78% at 50% 40%, transparent 30%, var(--bg) 100%)}
.hero-photo .wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:24px;max-width:1000px}
.hero-manifesto{font-family:"Fraunces",serif;font-weight:500;line-height:1.45;max-width:40ch;
  font-size:clamp(1rem,1.9vw,1.45rem);color:var(--muted);text-wrap:balance}
.hero-manifesto em{display:block;font-style:normal;font-weight:600;letter-spacing:-.02em;line-height:1.02;
  font-size:clamp(3rem,9vw,6.5rem);margin-bottom:.28em;
  background:linear-gradient(100deg,var(--accent) 0%,var(--accent-2) 28%,#f6d9e0 46%,var(--accent-2) 64%,var(--accent) 100%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;animation:heroShine 7s linear infinite}
@keyframes heroShine{0%{background-position:0% center}100%{background-position:220% center}}

/* ---------- BACK TO TOP --------------------------------------------- */
.to-top{position:fixed;right:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:9000;
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;border:none;
  background:var(--accent);color:#fff;box-shadow:0 12px 30px -10px var(--accent);
  opacity:0;visibility:hidden;transform:translateY(12px);
  transition:opacity .35s var(--ease),transform .35s var(--ease),visibility .35s}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{transform:translateY(-3px)}
.to-top svg{width:20px;height:20px;transform:rotate(-90deg)}

/* ---------- FOYER: no selection while panning ----------------------- */
.foyer-marquee-container,.foyer-marquee,.easel-item,.easel-item *{
  user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-touch-callout:none}
.artwork-container img,.easel-image{-webkit-user-drag:none;-khtml-user-drag:none;user-drag:none;pointer-events:none}
