/* ============================================
   ISHXN — CLEAN EDITION
   minimal x playful x indie builder
   ============================================ */
:root {
  --black: #0B090A; --black2: #111111; --black3: #1a1a1a; --black4: #222;
  --white: #FFF; --gray: #888; --gray-l: #bbb; --gray-d: #555;
  --violet: #7D39EB; --violet2: #6a2ed4;
  --violet-soft: rgba(125,57,235,.12); --violet-glow: rgba(125,57,235,.35);
  --lime: #C6FF33; --lime2: #b8f020;
  --lime-soft: rgba(198,255,51,.08); --lime-glow: rgba(198,255,51,.25);
  --red-hot: #FF3366; --matrix-green: #00FF41;
  --font: 'Space Grotesk', sans-serif;
  --mono: 'Space Mono', monospace;
  --display: 'Syne', sans-serif;

  --ease: cubic-bezier(.16,1,.3,1);
  --ease-out: cubic-bezier(.22,1,.36,1);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { background:var(--black); color:var(--white); font-family:var(--font); overflow-x:hidden; -webkit-font-smoothing:antialiased; }
::selection { background:var(--lime); color:var(--black); }
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
.container { max-width:1320px; margin:0 auto; padding:0 60px; }
@media(max-width:768px) { .container { padding:0 20px; } }

/* ====== GRAIN OVERLAY ====== */
body::after {
  content:''; position:fixed; inset:0; z-index:9990; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  background-repeat: repeat; background-size: 256px;
  opacity: var(--grain-opacity, 0.3);
}

/* ====== SCROLL PROGRESS ====== */
.scroll-progress { position:fixed; top:0; left:0; height:2px; z-index:9998; background:var(--lime); opacity:.7; width:0%; transition:width .1s linear; }

/* ====== LOADER ====== */
.loader {
  position:fixed; inset:0; z-index:10000; background:var(--black);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  transition: opacity .8s var(--ease), visibility .8s;
}
.loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.loader-typing { font-family:var(--mono); font-size:clamp(14px,2.5vw,20px); color:var(--gray); text-align:center; min-height:120px; display:flex; flex-direction:column; align-items:center; gap:8px; }
.loader-typing .strike { text-decoration:line-through; color:var(--gray-d); opacity:.6; }
.loader-typing .final { color:var(--lime); font-style:normal; }
.loader-name {
  font-family:var(--display); font-size:clamp(64px,15vw,180px); font-weight:800;
  text-transform:lowercase; letter-spacing:-6px; opacity:0;
  transform:scale(1.2); transition:all .6s var(--ease);
}
.loader-name.show { opacity:1; transform:scale(1); }
.loader-name .dot { color:var(--lime); }

/* ====== NAV ====== */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  padding:20px 60px; display:flex; justify-content:space-between; align-items:center;
  mix-blend-mode:difference;
}
.nav-logo { font-family:var(--display); font-weight:800; font-size:20px; letter-spacing:2px; text-transform:lowercase; }
.nav-logo .dot { color:var(--lime); }
.nav-3am-moon { display:none; margin-left:6px; font-size:14px; }
body.three-am .nav-3am-moon { display:inline; }
.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a {
  font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:2px;
  color:var(--white); opacity:.5; transition:opacity .3s; position:relative;
}
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:var(--lime); transition:width .3s var(--ease); }
.nav-links a:hover { opacity:1; }
.nav-links a:hover::after { width:100%; }
.nav-toggle {
  display:none; background:none; border:none; cursor:pointer;
  width:32px; height:24px; position:relative; z-index:201;
}
.nav-toggle span { display:block; width:100%; height:2px; background:var(--white); position:absolute; left:0; transition:all .3s var(--ease); }
.nav-toggle span:nth-child(1) { top:0; }
.nav-toggle span:nth-child(2) { top:50%; transform:translateY(-50%); }
.nav-toggle span:nth-child(3) { bottom:0; }
.nav-toggle.active span:nth-child(1) { top:50%; transform:translateY(-50%) rotate(45deg); }
.nav-toggle.active span:nth-child(2) { opacity:0; }
.nav-toggle.active span:nth-child(3) { bottom:50%; transform:translateY(50%) rotate(-45deg); }
@media(max-width:900px) {
  .nav { padding:14px 20px; }
  .nav-toggle { display:block; }
  .nav-links {
    position:fixed; inset:0; background:var(--black); flex-direction:column;
    justify-content:center; align-items:center; gap:32px; opacity:0; visibility:hidden;
    transition:opacity .4s var(--ease), visibility .4s; z-index:200;
  }
  .nav-links.open { opacity:1; visibility:visible; }
  .nav-links a { font-size:24px; font-family:var(--display); font-weight:700; opacity:1; letter-spacing:0; text-transform:uppercase; }
}

/* ====== HERO ====== */
.hero { min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding:160px 0 80px; position:relative; overflow:hidden; }
/* Floating ambient shapes */
.hero-ambient {
  position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none;
}
.hero-shape {
  position:absolute; border-radius:50%; opacity:0;
  animation:heroFloat 20s ease-in-out infinite;
}
.hero-shape:nth-child(1) { width:300px; height:300px; right:10%; top:20%; background:radial-gradient(circle,var(--violet-soft) 0%,transparent 70%); animation-delay:0s; }
.hero-shape:nth-child(2) { width:200px; height:200px; right:30%; bottom:20%; background:radial-gradient(circle,var(--lime-soft) 0%,transparent 70%); animation-delay:-7s; }
.hero-shape:nth-child(3) { width:150px; height:150px; right:5%; top:60%; background:radial-gradient(circle,rgba(255,255,255,.03) 0%,transparent 70%); animation-delay:-14s; }
@keyframes heroFloat {
  0%,100% { opacity:0; transform:translateY(40px) scale(.8); }
  20% { opacity:1; }
  80% { opacity:1; }
  50% { transform:translateY(-40px) scale(1.1); }
}
@media(max-width:768px) { .hero-shape:nth-child(1) { width:200px; height:200px; } .hero-shape:nth-child(2) { width:140px; height:140px; } }
.hero-content { position:relative; z-index:1; }
.hero-name {
  font-family:var(--display); font-size:clamp(72px,14vw,180px); font-weight:800;
  text-transform:lowercase; letter-spacing:-6px; line-height:.9; margin-bottom:24px;
}
.hero-name .dot { color:var(--lime); }
.hero-rotate {
  font-size:clamp(16px,2.2vw,24px); color:var(--gray-l); min-height:72px;
  line-height:1.5; max-width:600px; position:relative; overflow:hidden;
}
.hero-rotate-line { transition:all .4s var(--ease); }
.hero-scroll-hint {
  font-family:var(--mono); font-size:11px; color:var(--gray-d); letter-spacing:2px;
  text-transform:lowercase; margin-top:48px; opacity:0;
  animation: fu .8s var(--ease) 3s forwards;
}
@keyframes fu { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }

/* ====== TICKER ====== */
.ticker-wrap {
  overflow:hidden; border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06); padding:14px 0; background:var(--black);
}
.ticker-track { display:flex; gap:24px; animation:marquee 35s linear infinite; width:max-content; }
.ticker-item {
  font-family:var(--mono); font-size:12px; text-transform:lowercase; letter-spacing:2px;
  color:var(--gray-d); white-space:nowrap; display:flex; align-items:center; gap:24px;
}
.ticker-item .sep { color:var(--lime); font-size:10px; }
.ticker-item:nth-child(even) .sep { color:var(--violet); }
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }
.ticker-wrap:hover .ticker-track { animation-play-state:paused; }

/* ====== RIGHT NOW STRIP ====== */
.rightnow {
  border-bottom:1px solid rgba(255,255,255,.06); padding:10px 0;
  display:flex; align-items:center; gap:12px;
}
.rightnow-avatar {
  width:28px; height:28px; border-radius:50%; object-fit:cover;
  border:2px solid var(--lime); flex-shrink:0;
}
.rightnow-text { font-family:var(--mono); font-size:11px; color:var(--gray); letter-spacing:1px; text-transform:lowercase; }
.rightnow-text .hl { color:var(--lime); }

/* ====== QUIRKY ELEMENTS ====== */
/* Section headings get a subtle wobble on hover */
.sec-head { font-family:var(--display); font-size:clamp(36px,6vw,72px); font-weight:800; text-transform:uppercase; letter-spacing:-3px; line-height:1; transition:letter-spacing .4s var(--ease); }
.sec-head:hover { letter-spacing:-1px; }
.sec-head .dim { color:var(--gray-d); transition:color .4s; }
.sec-head:hover .dim { color:var(--gray); }
.sec-head .lime { color:var(--lime); }

/* Playful squiggle divider */
.squiggle { text-align:center; padding:48px 0; opacity:.15; font-size:24px; letter-spacing:12px; color:var(--gray-d); user-select:none; }

/* Floating dot — tiny decorative element */
.float-dot {
  display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--lime); opacity:.25;
  animation:dotBob 3s ease-in-out infinite;
}
.float-dot:nth-child(2) { animation-delay:-1s; background:var(--violet); }
.float-dot:nth-child(3) { animation-delay:-2s; }
@keyframes dotBob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* ====== ABOUT TIMELINE ====== */
.sec { padding:100px 0; }
.sec-sub { font-family:var(--mono); font-size:12px; color:var(--gray); letter-spacing:2px; text-transform:lowercase; margin-top:12px; max-width:500px; line-height:1.7; }
.timeline { margin-top:48px; }
.tl-year {
  border-top:2px solid rgba(255,255,255,.06); padding:24px 0; cursor:pointer;
  transition:all .3s var(--ease);
}
.tl-year:last-child { border-bottom:2px solid rgba(255,255,255,.06); }
.tl-year:hover { border-color:rgba(255,255,255,.15); }
.tl-year-head { display:flex; align-items:center; gap:24px; }
.tl-year-num {
  font-family:var(--display); font-size:clamp(36px,5vw,56px); font-weight:800;
  color:var(--gray-d); transition:color .3s var(--ease); min-width:120px;
}
.tl-year.active .tl-year-num { color:var(--lime); }
.tl-year-teaser { font-size:15px; color:var(--gray); line-height:1.6; }
.tl-year-body {
  max-height:0; overflow:hidden; transition:max-height .6s var(--ease), padding .4s;
  padding:0 0 0 144px;
}
.tl-year.active .tl-year-body { max-height:600px; padding:24px 0 24px 144px; }
@media(max-width:768px) { .tl-year-body, .tl-year.active .tl-year-body { padding-left:0; } .tl-year-num { min-width:80px; } }
.tl-year-detail { font-size:15px; color:var(--gray-l); line-height:1.8; max-width:560px; }
.tl-year-img { margin-top:16px; max-width:360px; height:240px; border:2px solid rgba(255,255,255,.06); overflow:hidden; }
.tl-year-img picture { display:block; width:100%; height:100%; }
.tl-year-img img { width:100%; height:100%; object-fit:cover; object-position:center center; display:block; }
.tl-year-plus { font-family:var(--mono); font-size:20px; color:var(--gray-d); margin-left:auto; transition:all .3s var(--ease); }
.tl-year.active .tl-year-plus { transform:rotate(45deg); color:var(--lime); }

/* ====== (poetry interstitial removed) ====== */

/* ====== SLOT MACHINE ====== */
.slot { padding:100px 0; text-align:center; }
.slot-machine {
  max-width:640px; margin:48px auto 0; border:3px solid rgba(255,255,255,.1);
  background:var(--black2); position:relative; overflow:hidden;
}
.slot-screen { padding:40px 32px; min-height:280px; position:relative; display:flex; flex-direction:column; justify-content:center; }
.slot-screen::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,.03) 2px, rgba(0,0,0,.03) 4px);
  opacity:0; transition:opacity .3s;
}
.slot-machine.spinning .slot-screen::after { opacity:1; }
.slot-emoji { font-size:48px; margin-bottom:16px; }
.slot-proj-name { font-family:var(--display); font-size:clamp(24px,4vw,36px); font-weight:800; text-transform:uppercase; letter-spacing:-2px; }
.slot-proj-type { font-family:var(--mono); font-size:11px; color:var(--gray); letter-spacing:2px; text-transform:uppercase; margin-top:8px; }
.slot-proj-tags { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-top:16px; }
.slot-proj-tag { font-family:var(--mono); font-size:10px; letter-spacing:1px; text-transform:uppercase; padding:5px 14px; border:1px solid; }
.slot-proj-tag.t-l { border-color:var(--lime); color:var(--lime); }
.slot-proj-tag.t-v { border-color:var(--violet); color:var(--violet); }
.slot-proj-tag.t-w { border-color:var(--gray-d); color:var(--gray-l); }
.slot-proj-desc { font-size:14px; color:var(--gray-l); line-height:1.7; margin-top:16px; max-width:480px; margin-left:auto; margin-right:auto; }
.slot-btn {
  display:block; width:100%; padding:20px; background:var(--lime); color:var(--black);
  font-family:var(--display); font-weight:800; font-size:16px; text-transform:uppercase;
  letter-spacing:3px; border:none; cursor:pointer; transition:all .2s var(--ease);
  border-top:3px solid rgba(0,0,0,.1);
}
.slot-btn:hover { background:var(--lime2); }
.slot-btn:active { transform:scale(.98); }
.slot-btn.bounce { animation:chunkBounce .4s var(--ease); }
@keyframes chunkBounce { 0% { transform:scale(1); } 30% { transform:scale(.96); } 60% { transform:scale(1.02); } 100% { transform:scale(1); } }
.slot-counter { font-family:var(--mono); font-size:11px; color:var(--gray-d); letter-spacing:1px; margin-top:16px; text-transform:lowercase; }
.slot-snark { font-family:var(--mono); font-size:11px; color:var(--lime); letter-spacing:1px; margin-top:8px; opacity:0; transition:opacity .4s; }
.slot-snark.show { opacity:1; }

/* ====== GALLERY FILM STRIP ====== */
.gallery-filters {
  display:flex; gap:8px; flex-wrap:wrap; margin-top:24px; margin-bottom:24px;
}
.gallery-filter-btn {
  font-family:var(--mono); font-size:10px; letter-spacing:1px; text-transform:uppercase;
  padding:8px 18px; border:1px solid rgba(255,255,255,.1); background:none; color:var(--gray);
  cursor:pointer; transition:all .3s var(--ease);
}
.gallery-filter-btn.active, .gallery-filter-btn:hover { border-color:var(--lime); color:var(--lime); }
.gallery-filter-btn.active { box-shadow:0 0 12px rgba(198,255,51,.15); }
.gf-short { display:none; }
@media(max-width:768px) { .gf-full { display:none; } .gf-short { display:inline; } }
/* ====== BENTO GALLERY ====== */
.bento-gallery {
  display:grid; grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:200px; gap:4px; margin-top:8px;
}
.bento-cell {
  position:relative; overflow:hidden; border-radius:3px;
  background:var(--black3); cursor:pointer;
  opacity:0; transform:translateY(20px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.bento-cell.vis { opacity:1; transform:translateY(0); }
.bento-cell img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.bento-cell:hover img { transform:scale(1.04); }
.bento-cell-cap {
  position:absolute; bottom:0; left:0; right:0; padding:10px 14px;
  background:linear-gradient(to top, rgba(0,0,0,.75), transparent);
  font-family:var(--mono); font-size:10px; color:var(--gray-l);
  letter-spacing:1px; text-transform:uppercase;
  opacity:0; transform:translateY(4px); transition:all .3s var(--ease);
}
.bento-cell:hover .bento-cell-cap { opacity:1; transform:translateY(0); }
.bento-hero { grid-column:span 2; grid-row:span 2; }
.bento-wide { grid-column:span 2; }
.bento-tall { grid-row:span 2; }
.bento-gallery.filtering .bento-cell {
  opacity:0 !important; transform:scale(.96) !important;
  transition:opacity .2s, transform .2s !important;
}
/* Gallery lightbox */
.lightbox {
  position:fixed; inset:0; z-index:10001;
  background:rgba(11,9,10,.92);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s;
}
.lightbox.active { opacity:1; visibility:visible; }
.lightbox-img {
  max-width:88vw; max-height:82vh; object-fit:contain;
  transition:opacity .35s var(--ease), transform .5s var(--ease);
  user-select:none; -webkit-user-drag:none;
}
.lightbox.active .lightbox-img { animation:lbZoomIn .5s var(--ease) both; }
@keyframes lbZoomIn { from { transform:scale(.92); opacity:0; } to { transform:scale(1); opacity:1; } }
.lightbox-img.switching { opacity:0; transform:scale(.97); }
.lightbox-close {
  position:absolute; top:20px; right:28px;
  background:none; border:none; color:var(--gray);
  font-size:32px; line-height:1; cursor:pointer; z-index:2;
  transition:color .3s, transform .3s;
}
.lightbox-close:hover { color:var(--lime); transform:scale(1.15); }
.lightbox-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  color:var(--gray-l); font-size:20px; padding:16px 14px;
  cursor:pointer; transition:all .3s var(--ease); z-index:2;
}
.lightbox-nav:hover { background:rgba(255,255,255,.08); border-color:var(--lime); color:var(--lime); box-shadow:0 0 20px rgba(198,255,51,.1); }
.lightbox-prev { left:20px; }
.lightbox-next { right:20px; }
.lightbox-caption {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  font-family:var(--mono); font-size:11px; color:var(--gray);
  letter-spacing:2px; text-transform:uppercase;
  opacity:0; transition:opacity .4s .2s;
}
.lightbox.active .lightbox-caption { opacity:1; }
.lightbox-counter {
  position:absolute; top:24px; left:28px;
  font-family:var(--mono); font-size:11px; color:var(--gray-d);
  letter-spacing:2px;
}
@media(max-width:768px) {
  .lightbox-nav { padding:12px 10px; font-size:16px; }
  .lightbox-prev { left:8px; }
  .lightbox-next { right:8px; }
  .lightbox-img { max-width:94vw; max-height:75vh; }
  .lightbox-close { top:12px; right:16px; font-size:28px; }
}
/* ====== WRITING WALL ====== */
.writing-wall { display:flex; flex-wrap:wrap; gap:16px; margin-top:48px; justify-content:center; }
.wcard {
  background:var(--black2); border:1px solid rgba(255,255,255,.06);
  padding:28px 22px; width:calc(33.33% - 12px); min-width:260px; max-width:360px;
  position:relative; overflow:hidden; cursor:pointer;
  transition:all .4s var(--ease); transform:rotate(var(--rot, 0deg));
}
.wcard:hover { transform:rotate(0deg) translateY(-6px) scale(1.02); z-index:5; border-color:rgba(255,255,255,.15); }
.wcard::before {
  content:''; position:absolute; top:0; left:0; width:100%; height:3px;
  transform:scaleX(0); transition:transform .4s var(--ease); transform-origin:left;
}
.wcard:hover::before { transform:scaleX(1); }
.wcard.poetry::before { background:var(--violet); }
.wcard.essay::before { background:var(--lime); }
.wcard.letter::before { background:var(--white); }
.wcard.manifesto::before { background:var(--red-hot); }
.wcard.thought::before { background:#FF9933; }
.wcard.story::before { background:#33BBFF; }
.wcard-cover { margin:-28px -22px 16px; height:160px; overflow:hidden; }
.wcard-cover img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.wcard:hover .wcard-cover img { transform:scale(1.05); }
.wcard-type { font-family:var(--mono); font-size:10px; letter-spacing:2px; text-transform:uppercase; margin-bottom:14px; }
.wcard.poetry .wcard-type { color:var(--violet); }
.wcard.essay .wcard-type { color:var(--lime); }
.wcard.letter .wcard-type { color:var(--gray-l); }
.wcard.manifesto .wcard-type { color:var(--red-hot); }
.wcard.thought .wcard-type { color:#FF9933; }
.wcard.story .wcard-type { color:#33BBFF; }
.wcard.wcard-hidden { display:none; }
.writing-wall.expanded .wcard.wcard-hidden { display:block; }
.wwall-viewall {
  display:block; width:100%; max-width:400px; margin:32px auto 0; padding:16px 32px;
  background:none; border:2px solid rgba(255,255,255,.1); color:var(--gray-l);
  font-family:var(--display); font-weight:700; font-size:14px; text-transform:uppercase;
  letter-spacing:2px; cursor:pointer; transition:all .3s var(--ease);
}
.wwall-viewall:hover { border-color:var(--lime); color:var(--lime); transform:translateY(-2px); }
.wwall-viewall.hidden { display:none; }
.wwall-filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:24px; }
.wwall-filter-btn {
  padding:8px 20px; background:none; border:1.5px solid rgba(255,255,255,.12); color:var(--gray);
  font-family:var(--display); font-weight:700; font-size:11px; text-transform:uppercase; letter-spacing:2px;
  cursor:pointer; transition:all .3s var(--ease); border-radius:0;
}
.wwall-filter-btn:hover { border-color:var(--lime); color:var(--lime); }
.wwall-filter-btn.active { border-color:var(--lime); color:var(--lime); background:rgba(163,255,0,.06); }
.wcard-title { font-size:18px; font-weight:700; margin-bottom:10px; line-height:1.3; }
.wcard-excerpt { font-size:13px; color:var(--gray); line-height:1.7; display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical; overflow:hidden; }
.wcard-date { font-size:11px; color:var(--gray-d); margin-top:14px; }
/* Writing modal */
.wmodal { position:fixed; inset:0; z-index:10001; background:rgba(11,9,10,.96); display:none; overflow-y:auto; }
.wmodal.active { display:flex; align-items:center; justify-content:center; }
.wmodal-inner { max-width:600px; padding:60px 40px; text-align:left; }
.wmodal-type { font-family:var(--mono); font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--violet); margin-bottom:16px; }
.wmodal-title { font-family:var(--display); font-size:clamp(28px,5vw,42px); font-weight:800; text-transform:uppercase; letter-spacing:-2px; margin-bottom:24px; }
.wmodal-body { font-size:16px; color:var(--gray-l); line-height:2; white-space:pre-wrap; }
.wmodal-close { position:fixed; top:24px; right:32px; font-family:var(--mono); font-size:12px; color:var(--gray-d); cursor:pointer; letter-spacing:2px; text-transform:uppercase; z-index:10002; transition:color .3s; }
.wmodal-close:hover { color:var(--lime); }
.wmodal-date { font-family:var(--mono); font-size:11px; color:var(--gray-d); margin-top:32px; letter-spacing:2px; }
.wmodal-share { margin-top:24px; }
.wmodal-share-btn {
  background:none; border:1px solid rgba(255,255,255,.12); color:var(--gray);
  font-family:var(--mono); font-size:11px; letter-spacing:1px; text-transform:uppercase;
  padding:8px 16px; cursor:pointer; transition:all .3s var(--ease);
}
.wmodal-share-btn:hover { border-color:var(--lime); color:var(--lime); }
@media(max-width:768px) { .wcard { width:100%; min-width:0; } }

/* ====== BLOG CARDS (homepage) ====== */
.blog-cards { margin-top:48px; }
.blog-card {
  padding:28px 0; border-bottom:1px solid rgba(255,255,255,.06);
  cursor:pointer; transition:all .3s var(--ease);
}
.blog-card.has-cover {
  display:flex; gap:24px; align-items:center;
}
.blog-card:first-child { border-top:1px solid rgba(255,255,255,.06); }
.blog-card:hover { padding-left:16px; }
.blog-card-cover {
  width:100px; height:100px; flex-shrink:0;
  overflow:hidden; border-radius:4px;
}
.blog-card-cover img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s var(--ease);
}
.blog-card:hover .blog-card-cover img { transform:scale(1.08); }
.blog-card-body { flex:1; min-width:0; }
.blog-card-title {
  font-family:var(--display); font-size:20px; font-weight:700;
  letter-spacing:-0.5px; margin-bottom:6px; transition:color .3s;
}
.blog-card:hover .blog-card-title { color:var(--lime); }
.blog-card-excerpt {
  font-size:14px; color:var(--gray); line-height:1.7; margin-bottom:8px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.blog-card-date { font-family:var(--mono); font-size:11px; color:var(--gray-d); letter-spacing:1px; }
@media(max-width:768px) {
  .blog-card { padding:24px 0; }
  .blog-card-cover { width:80px; height:80px; }
  .blog-card-title { font-size:17px; }
}

/* ====== NEWSLETTER CTA STRIP ====== */
.nl-strip {
  margin:64px 0; padding:56px 32px; background:var(--lime); color:var(--black);
  text-align:center; position:relative; overflow:hidden;
}
.nl-strip::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 100%, rgba(0,0,0,.06) 0%, transparent 60%);
  pointer-events:none;
}
.nl-strip-label {
  font-family:var(--mono); font-size:11px; letter-spacing:4px; text-transform:uppercase;
  color:rgba(11,9,10,.5); margin-bottom:16px; position:relative;
}
.nl-strip-title {
  font-family:var(--display); font-size:clamp(24px,4vw,36px);
  font-weight:800; letter-spacing:-1.5px; margin-bottom:12px; position:relative;
  color:var(--black);
}
.nl-strip-sub {
  font-size:14px; color:rgba(11,9,10,.7); margin-bottom:28px; line-height:1.7; position:relative;
  max-width:480px; margin-left:auto; margin-right:auto;
}
.nl-strip a {
  display:inline-block; padding:16px 40px; background:var(--black);
  color:var(--lime); font-family:var(--mono); font-size:12px;
  font-weight:700; letter-spacing:3px; text-transform:uppercase;
  text-decoration:none; position:relative;
  transition:all .3s var(--ease);
}
.nl-strip a:hover {
  background:var(--black2); transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(0,0,0,.3);
}

/* ====== (testimonials removed) ====== */

/* ====== DAPPASOL HERO ====== */
.dappasol-hero {
  position:relative; min-height:70vh; display:flex; align-items:center; justify-content:center;
  overflow:hidden; margin:80px 0;
  border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(255,255,255,.06);
}
.dappasol-hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(198,255,51,.12) 0%, transparent 70%),
    radial-gradient(ellipse 40% 50% at 20% 80%, rgba(125,57,235,.15) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 80% 20%, rgba(198,255,51,.06) 0%, transparent 60%);
  animation:dappaGlow 6s ease-in-out infinite alternate;
}
@keyframes dappaGlow {
  0% { opacity:.6; filter:blur(0px); }
  100% { opacity:1; filter:blur(40px); }
}
.dappasol-hero-content {
  position:relative; z-index:1; text-align:center; padding:60px 20px;
}
.dappasol-hero-label {
  font-family:var(--mono); font-size:11px; letter-spacing:4px; text-transform:uppercase;
  color:var(--lime); margin-bottom:24px; opacity:.8;
}
.dappasol-hero-link {
  display:inline-flex; align-items:baseline; gap:16px; text-decoration:none; color:var(--white);
  transition:all .4s var(--ease);
}
.dappasol-hero-link:hover { color:var(--lime); }
.dappasol-hero-link:hover .dappasol-hero-arrow { transform:translate(6px, -6px); color:var(--lime); }
.dappasol-hero-name {
  font-family:var(--display); font-size:clamp(48px, 12vw, 140px); font-weight:800;
  text-transform:uppercase; letter-spacing:-4px; line-height:1;
}
.dappasol-hero-arrow {
  font-size:clamp(24px, 4vw, 48px); color:var(--gray-d); transition:all .4s var(--ease);
}
.dappasol-hero-tagline {
  font-family:var(--font); font-size:clamp(16px, 2.5vw, 22px); color:var(--gray);
  margin-top:20px; letter-spacing:-0.5px;
}
.dappasol-hero-stats {
  display:flex; justify-content:center; gap:48px; margin-top:40px;
}
.dappasol-hero-stat {
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.dappasol-hero-stat-num {
  font-family:var(--display); font-size:clamp(28px, 4vw, 42px); font-weight:800; color:var(--white);
}
.dappasol-hero-stat-label {
  font-family:var(--mono); font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--gray-d);
}
.dappasol-hero-cta {
  display:inline-block; margin-top:48px; padding:18px 40px;
  background:var(--lime); color:var(--black);
  font-family:var(--display); font-weight:800; font-size:14px;
  text-transform:uppercase; letter-spacing:3px; text-decoration:none;
  transition:all .3s var(--ease);
}
.dappasol-hero-cta:hover {
  box-shadow:0 0 40px var(--lime-glow), 0 0 80px rgba(198,255,51,.15);
  transform:translateY(-3px);
}
@media(max-width:768px) {
  .dappasol-hero { min-height:auto; margin:48px 0; overflow:visible; }
  .dappasol-hero-content { padding:48px 20px; }
  .dappasol-hero-name { letter-spacing:-2px; }
  .dappasol-hero-tagline { font-size:15px; }
  .dappasol-hero-stats { gap:20px; flex-wrap:wrap; }
  .dappasol-hero-stat-num { font-size:24px; }
  .dappasol-hero-cta { margin-top:36px; padding:16px 32px; font-size:12px; }
}
.footer-dappasol {
  display:inline-flex; align-items:center; gap:8px;
  margin-bottom:20px; padding:12px 28px;
  border:2px solid var(--lime); color:var(--lime);
  font-family:var(--display); font-weight:800; font-size:14px;
  text-transform:uppercase; letter-spacing:2px;
  transition:all .3s var(--ease); text-decoration:none;
}
.footer-dappasol:hover {
  background:var(--lime); color:var(--black);
  box-shadow:0 0 32px var(--lime-glow);
}
.footer-dappasol .arrow { transition:transform .3s var(--ease); }
.footer-dappasol:hover .arrow { transform:translateX(4px); }

/* ====== RECOMMENDS SLOT MACHINES ====== */
.recs-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:48px; }
.rec-slot {
  background:var(--black2); border:2px solid rgba(255,255,255,.06);
  overflow:hidden; position:relative; transition:border-color .3s var(--ease);
}
.rec-slot:hover { border-color:rgba(255,255,255,.12); }
.rec-slot-cat {
  font-family:var(--display); font-size:11px; font-weight:800; letter-spacing:4px; text-transform:uppercase;
  color:var(--black); background:var(--lime); padding:8px 20px; display:inline-block;
}
.rec-slot-screen {
  padding:20px 20px 16px; min-height:160px; position:relative;
  display:flex; flex-direction:column; justify-content:center;
  transition:background .4s var(--ease);
}
.rec-slot-screen::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,.03) 2px, rgba(0,0,0,.03) 4px);
  opacity:0; transition:opacity .3s;
}
.rec-slot.spinning .rec-slot-screen::after { opacity:1; }
.rec-slot-title {
  font-family:var(--display); font-size:clamp(18px,2.5vw,26px); font-weight:800;
  text-transform:uppercase; letter-spacing:-1px; line-height:1.1; margin-bottom:8px;
  transition:opacity .3s var(--ease), transform .3s var(--ease);
}
.rec-slot-take {
  font-size:13px; color:var(--gray); line-height:1.6; font-style:italic;
  transition:opacity .3s var(--ease);
}
.rec-slot-meta {
  font-family:var(--mono); font-size:10px; color:var(--gray-d); letter-spacing:1px;
  text-transform:uppercase; margin-top:10px;
  transition:opacity .3s var(--ease);
}
.rec-slot-btn {
  display:block; width:100%; padding:12px; background:var(--lime); color:var(--black);
  font-family:var(--display); font-weight:800; font-size:12px; text-transform:uppercase;
  letter-spacing:3px; border:none; cursor:pointer; transition:all .2s var(--ease);
  border-top:2px solid rgba(0,0,0,.08);
}
.rec-slot-btn:hover { background:var(--lime2); }
.rec-slot-btn:active { transform:scale(.98); }
.rec-slot-btn.bounce { animation:chunkBounce .4s var(--ease); }
.rec-shuffle-all {
  display:block; width:100%; padding:18px; margin-top:16px;
  background:var(--violet); color:var(--white);
  font-family:var(--display); font-weight:800; font-size:14px; text-transform:uppercase;
  letter-spacing:3px; border:none; cursor:pointer; transition:all .3s var(--ease);
}
.rec-shuffle-all:hover { background:var(--violet2); transform:translateY(-2px); box-shadow:0 12px 32px var(--violet-glow); }
.rec-shuffle-all:active { transform:scale(.98); }
.rec-counter { font-family:var(--mono); font-size:11px; color:var(--gray-d); letter-spacing:1px; margin-top:16px; text-transform:lowercase; text-align:center; }
.rec-snark { font-family:var(--mono); font-size:11px; color:var(--violet); letter-spacing:1px; margin-top:8px; text-align:center; opacity:0; transition:opacity .4s; }
.rec-snark.show { opacity:1; }
@media(max-width:768px) {
  .recs-grid { grid-template-columns:1fr; }
  .rec-slot-title { font-size:clamp(16px,5vw,22px); }
}

/* ====== CONTACT CONVERSATION ====== */
.contact { padding:100px 0; }
.contact-step { display:none; }
.contact-step.active { display:block; }
.contact-choices { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:32px; }
.contact-choice {
  padding:28px 24px; border:2px solid rgba(255,255,255,.08); background:var(--black2);
  cursor:pointer; transition:all .3s var(--ease); text-align:left;
}
.contact-choice:hover { border-color:var(--lime); transform:translateY(-3px); }
.contact-choice-label { font-family:var(--display); font-size:18px; font-weight:700; text-transform:uppercase; margin-bottom:4px; }
.contact-choice-sub { font-size:12px; color:var(--gray); }
@media(max-width:600px) { .contact-choices { grid-template-columns:1fr; } }
.contact-form { margin-top:32px; }
.contact-form label { font-family:var(--mono); font-size:10px; color:var(--gray-d); text-transform:uppercase; letter-spacing:1px; display:block; margin-bottom:6px; }
.contact-form input, .contact-form textarea {
  width:100%; background:var(--black2); border:1px solid rgba(255,255,255,.08);
  padding:14px 16px; color:var(--white); font-family:var(--font); font-size:14px;
  outline:none; transition:border .3s; resize:vertical;
}
.contact-form input:focus, .contact-form textarea:focus { border-color:var(--violet); }
.contact-form textarea { min-height:120px; }
.contact-form .form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.contact-form .form-field { margin-bottom:12px; }
.contact-submit {
  width:100%; padding:18px; background:var(--lime); color:var(--black);
  font-family:var(--display); font-weight:800; font-size:15px; text-transform:uppercase;
  letter-spacing:3px; border:none; cursor:pointer; transition:all .3s var(--ease); margin-top:8px;
}
.contact-submit:hover { background:var(--lime2); transform:translateY(-2px); box-shadow:0 12px 32px var(--lime-glow); }
.contact-back { font-family:var(--mono); font-size:11px; color:var(--gray-d); cursor:pointer; letter-spacing:1px; text-transform:uppercase; margin-top:16px; display:inline-block; transition:color .3s; }
.contact-back:hover { color:var(--lime); }
.contact-poem-flash { min-height:50vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:40px; }
.contact-poem-flash p { font-size:clamp(16px,3vw,24px); color:var(--gray-l); line-height:1.8; max-width:500px; font-style:italic; }

/* ====== FOOTER ====== */
.footer { padding:60px 0 40px; text-align:center; border-top:1px solid rgba(255,255,255,.06); }
.footer-poem { font-size:15px; color:var(--gray); font-style:italic; line-height:1.7; margin-bottom:24px; }
.footer-links { display:flex; gap:24px; justify-content:center; margin-bottom:20px; }
.footer-links a { font-family:var(--mono); font-size:11px; color:var(--gray-d); letter-spacing:1px; text-transform:uppercase; transition:color .3s; }
.footer-links a:hover { color:var(--lime); }
.footer-visitor { font-family:var(--mono); font-size:11px; color:var(--gray-d); letter-spacing:1px; margin-bottom:8px; }
.footer-credit { font-family:var(--mono); font-size:10px; color:rgba(255,255,255,.15); letter-spacing:1px; }

/* ====== TERMINAL ====== */
.term-hint {
  position:fixed; bottom:20px; right:20px; z-index:50;
  font-family:var(--mono); font-size:10px; color:var(--gray-d);
  background:var(--black2); border:1px solid rgba(255,255,255,.06);
  padding:6px 12px; cursor:pointer; opacity:.3; transition:opacity .3s;
  text-transform:uppercase; letter-spacing:1px;
}
.term-hint:hover { opacity:1; border-color:var(--lime); color:var(--lime); }
.term-hint kbd { font-size:10px; background:var(--black); padding:2px 5px; border:1px solid rgba(255,255,255,.1); margin-left:4px; }
.term-ov { position:fixed; inset:0; background:rgba(0,0,0,.92); backdrop-filter:blur(12px); z-index:10003; display:none; justify-content:center; align-items:center; }
.term-ov.active { display:flex; }
.tbox {
  background:var(--black); border:1px solid var(--violet);
  width:min(640px,90vw); max-height:420px; overflow-y:auto;
  padding:20px; font-family:var(--mono); font-size:13px;
  box-shadow:0 0 80px var(--violet-glow);
}
.tbox .th { display:flex; gap:6px; padding-bottom:14px; border-bottom:1px solid rgba(255,255,255,.06); margin-bottom:14px; }
.tc { width:10px; height:10px; border-radius:50%; }
.tc1 { background:#ff5f57; } .tc2 { background:#febc2e; } .tc3 { background:#28c840; }
.tbox .tline { margin-bottom:3px; line-height:1.6; }
.tbox .pr { color:var(--violet); }
.tbox .out { color:var(--gray); }
.tbox .il { display:flex; align-items:center; gap:8px; }
.tbox input { background:none; border:none; color:#fff; font-family:var(--mono); font-size:13px; outline:none; flex:1; caret-color:var(--lime); }

/* ====== KONAMI DOSSIER ====== */
.konami-overlay {
  position:fixed; inset:0; z-index:10001; background:var(--black);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:all .5s var(--ease); padding:40px;
  overflow-y:auto;
}
.konami-overlay.active { opacity:1; visibility:visible; }
.konami-overlay::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(255,255,255,.02) 2px, rgba(255,255,255,.02) 4px);
  animation:scanlines 8s linear infinite;
}
@keyframes scanlines { from { background-position:0 0; } to { background-position:0 100%; } }
.konami-stamp {
  font-family:var(--display); font-size:clamp(24px,5vw,48px); font-weight:800;
  text-transform:uppercase; letter-spacing:3px; color:var(--red-hot);
  border:4px solid var(--red-hot); padding:12px 32px; margin-bottom:32px;
  transform:rotate(-3deg); position:relative; z-index:1;
}
.konami-file { list-style:none; max-width:560px; position:relative; z-index:1; }
.konami-file-head { font-family:var(--mono); font-size:12px; color:var(--lime); letter-spacing:2px; text-transform:uppercase; margin-bottom:16px; }
.konami-file li {
  font-family:var(--mono); font-size:13px; color:var(--gray-l); padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  opacity:0; transform:translateY(16px); animation:fu .5s var(--ease) forwards;
}
.konami-file li:nth-child(1) { animation-delay:.1s; } .konami-file li:nth-child(2) { animation-delay:.2s; }
.konami-file li:nth-child(3) { animation-delay:.3s; } .konami-file li:nth-child(4) { animation-delay:.4s; }
.konami-file li:nth-child(5) { animation-delay:.5s; } .konami-file li:nth-child(6) { animation-delay:.6s; }
.konami-file li:nth-child(7) { animation-delay:.7s; } .konami-file li:nth-child(8) { animation-delay:.8s; }
.konami-file li:nth-child(9) { animation-delay:.9s; }
.konami-threat { font-family:var(--display); font-size:16px; font-weight:700; color:var(--lime); text-transform:uppercase; letter-spacing:2px; margin-top:24px; position:relative; z-index:1; }
.konami-close { margin-top:32px; font-family:var(--mono); font-size:11px; color:var(--gray-d); text-transform:uppercase; letter-spacing:2px; cursor:pointer; transition:color .3s; position:relative; z-index:1; }
.konami-close:hover { color:var(--lime); }

/* ====== MATRIX CANVAS ====== */
.matrix-canvas { position:fixed; inset:0; z-index:10002; pointer-events:none; opacity:0; transition:opacity .5s; }
.matrix-canvas.active { opacity:1; pointer-events:auto; }

/* ====== CLICK RIPPLE ====== */
.click-ripple {
  position:fixed; border-radius:50%; pointer-events:none; z-index:9997;
  border:2px solid var(--lime); animation:rippleOut .6s var(--ease) forwards;
}
@keyframes rippleOut { from { width:0; height:0; opacity:1; } to { width:120px; height:120px; opacity:0; } }

/* ====== FLOATING EMOJI (click counter) ====== */
.float-emoji {
  position:fixed; pointer-events:none; z-index:9996; font-size:20px;
  animation:floatUp 1.5s var(--ease) forwards;
}
@keyframes floatUp { from { opacity:1; transform:translateY(0) scale(1); } to { opacity:0; transform:translateY(-120px) scale(.5); } }


/* ====== TOAST ====== */
.toast {
  position:fixed; bottom:80px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--black2); border:1px solid rgba(255,255,255,.1);
  padding:14px 24px; font-family:var(--mono); font-size:12px; color:var(--gray-l);
  letter-spacing:1px; z-index:9998; opacity:0; transition:all .4s var(--ease);
  white-space:nowrap; max-width:90vw;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast .lime { color:var(--lime); }

/* ====== CONFETTI ====== */
.confetti-piece {
  position:fixed; pointer-events:none; z-index:9999; width:8px; height:8px;
  animation:confettiFall 1.5s var(--ease) forwards;
}
@keyframes confettiFall {
  0% { opacity:1; transform:translateY(0) rotate(0deg) scale(1); }
  100% { opacity:0; transform:translateY(400px) rotate(720deg) scale(0); }
}

/* ====== CUSTOM CURSOR ====== */
.cursor-dot {
  position:fixed; top:0; left:0; width:8px; height:8px;
  background:var(--lime); border-radius:50%; pointer-events:none;
  z-index:10003; transform:translate(-50%,-50%);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s;
  mix-blend-mode:difference;
}
.cursor-ring {
  position:fixed; top:0; left:0; width:40px; height:40px;
  border:1.5px solid rgba(198,255,51,.35); border-radius:50%;
  pointer-events:none; z-index:10003; transform:translate(-50%,-50%);
  transition:width .3s var(--ease), height .3s var(--ease), border-color .3s;
}
.cursor-hover .cursor-dot { width:12px; height:12px; }
.cursor-hover .cursor-ring { width:60px; height:60px; border-color:rgba(198,255,51,.5); }
@media(max-width:768px),(hover:none) { .cursor-dot, .cursor-ring { display:none !important; } }
@media(hover:hover) { body { cursor:none; } a, button, [role="button"], input, textarea, select { cursor:none; } }

/* ====== SKIP LINK ====== */
.skip-link { position:absolute; top:-100%; left:16px; background:var(--lime); color:var(--black); padding:8px 16px; z-index:10001; font-family:var(--mono); font-size:12px; }
.skip-link:focus { top:16px; }

/* ====== ANIMATIONS ====== */
.rv { opacity:0; transform:translateY(30px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.rv.vis { opacity:1; transform:translateY(0); }
.rv-d1 { transition-delay:.1s; } .rv-d2 { transition-delay:.2s; } .rv-d3 { transition-delay:.3s; }

/* ====== 3AM MODE ====== */
body.three-am { --lime: #D4FF66; --grain-opacity: 0.4; }

/* ====== REDUCED MOTION ====== */
@media(prefers-reduced-motion:reduce) {
  *, *::before, *::after { animation-duration:0.01ms!important; animation-iteration-count:1!important; transition-duration:0.01ms!important; scroll-behavior:auto!important; }
}

/* ====== RESPONSIVE ====== */
@media(max-width:900px) {
  .hero { padding:120px 0 60px; }
  .hero-name { letter-spacing:-3px; }
  .contact-choices { grid-template-columns:1fr; }
  .contact-form .form-row { grid-template-columns:1fr; }
}
@media(max-width:600px) {
  .sec { padding:60px 0; }
  .slot-machine { margin-top:32px; }
  .slot-screen { padding:28px 20px; }
}

/* ============================================
   MOBILE APP EXPERIENCE
   ============================================ */
@media(max-width:768px) {
  /* GLOBAL MOBILE FEEL — lock down overflow */
  html {
    overflow-x:hidden; width:100%; max-width:100vw;
  }
  body {
    overscroll-behavior: none;
    -webkit-overflow-scrolling: touch;
    overflow-x:hidden; width:100%; max-width:100vw;
    position:relative;
  }
  body::after { display:none; /* grain kills perf on mobile — compositing layer on every frame */ }
  .container { padding:0 16px; }

  /* ACTIVE STATES — tactile press feel */
  a:active, button:active, .tl-year:active, .contact-choice:active,
  .wcard:active, .rec-slot:active, .gallery-filter-btn:active {
    transform:scale(0.97) !important;
    transition:transform .1s !important;
  }

  /* HIDE HAMBURGER NAV (replaced by bottom tab bar) */
  .nav-toggle { display:none !important; }
  .nav-links { display:none !important; }
  .nav { padding:10px 16px; }

  /* BOTTOM TAB BAR */
  .mob-tabs {
    position:fixed; bottom:0; left:0; right:0; z-index:9998;
    height:64px;
    padding-bottom:env(safe-area-inset-bottom, 0px);
    background:rgba(11,9,10,.92);
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    display:flex; justify-content:space-around; align-items:center;
    border-top:1px solid rgba(255,255,255,.06);
    box-shadow:0 -4px 24px rgba(0,0,0,.4);
    transition:transform .3s var(--ease);
  }
  /* tab bar is always visible — no hiding */
  .mob-tab {
    display:flex; flex-direction:column; align-items:center; gap:2px;
    background:none; border:none; cursor:pointer; padding:6px 0;
    -webkit-tap-highlight-color:transparent; position:relative;
    flex:1; min-width:0;
  }
  .mob-tab-icon {
    width:22px; height:22px; transition:transform .2s var(--ease);
    display:flex; align-items:center; justify-content:center;
  }
  .mob-tab-icon svg { width:20px; height:20px; stroke:var(--gray-d); stroke-width:1.5; fill:none; stroke-linecap:round; stroke-linejoin:round; transition:stroke .2s; }
  .mob-tab.active .mob-tab-icon svg { stroke:var(--lime); }
  .mob-tab-label {
    font-family:var(--mono); font-size:9px; letter-spacing:1px;
    text-transform:uppercase; color:var(--gray-d); transition:color .2s;
  }
  .mob-tab.active .mob-tab-label { color:var(--lime); }
  .mob-tab.active .mob-tab-icon { transform:scale(1.15); }
  .mob-tab::after {
    content:''; position:absolute; top:-1px; left:50%; transform:translateX(-50%);
    width:0; height:2px; background:var(--lime);
    transition:width .3s var(--ease);
  }
  .mob-tab.active::after { width:28px; }

  /* SAFE AREA PADDING for content above tab bar */
  .footer { padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px)) !important; }

  /* TOAST above tab bar */
  .toast { bottom:calc(80px + env(safe-area-inset-bottom, 0px)) !important; }

  /* TERMINAL HINT — hide the hint bubble (terminal accessed via tab bar) */
  .term-hint { display:none !important; }
  /* Terminal overlay mobile adjustments */
  .term-ov { z-index:10003 !important; }
  .tbox { width:95vw !important; max-height:55vh; font-size:12px; margin-bottom:calc(64px + env(safe-area-inset-bottom, 0px)); }
  .tbox input { font-size:16px; /* prevent iOS zoom */ }

  /* CLICK RIPPLE — disable on mobile */
  .click-ripple { display:none; }

  /* HERO — App splash */
  .hero {
    min-height:100dvh; min-height:-webkit-fill-available;
    padding:80px 0 40px; justify-content:center; text-align:center;
    overflow:hidden;
  }
  .hero-name {
    font-size:clamp(48px,14vw,80px); letter-spacing:-3px;
    line-height:.9; word-break:break-word; overflow-wrap:break-word;
  }
  .hero-rotate {
    font-size:clamp(14px,3.8vw,18px); margin:0 auto;
    max-width:90%; min-height:54px; line-height:1.5;
    word-break:break-word; overflow-wrap:break-word;
    padding:0 4px;
  }
  .hero-scroll-hint {
    display:none;
  }
  .mob-scroll-hint {
    position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
    display:flex; flex-direction:column; align-items:center; gap:6px;
    animation:mobHintFade 3s var(--ease) 2s forwards;
  }
  .mob-scroll-chevron {
    font-size:20px; color:var(--gray-d);
    animation:mobBounce 1.5s var(--ease) infinite;
  }
  .mob-scroll-label {
    font-family:var(--mono); font-size:9px; color:var(--gray-d);
    letter-spacing:2px; text-transform:uppercase;
  }
  @keyframes mobBounce {
    0%,100% { transform:translateY(0); opacity:.4; }
    50% { transform:translateY(8px); opacity:1; }
  }
  @keyframes mobHintFade {
    to { opacity:0; visibility:hidden; }
  }

  /* TICKER — edge to edge */
  .ticker-wrap { margin:0 -16px; overflow:hidden; }
  .ticker-item { font-size:11px; letter-spacing:1px; }

  /* RIGHT NOW — Swipeable pills */
  .rightnow {
    overflow-x:auto; overflow-y:hidden; gap:0;
    scrollbar-width:none; -ms-overflow-style:none;
    scroll-snap-type:x mandatory; padding:12px 0;
    -webkit-overflow-scrolling:touch; flex-wrap:nowrap;
  }
  .rightnow::-webkit-scrollbar { display:none; }
  .rightnow-avatar { display:none; }
  .mob-rn-card {
    flex:0 0 auto; scroll-snap-align:start;
    font-family:var(--mono); font-size:11px; color:var(--gray-l);
    letter-spacing:1px; text-transform:lowercase;
    padding:8px 16px; margin-right:8px;
    border:1px solid rgba(255,255,255,.08); border-radius:20px;
    white-space:nowrap; background:var(--black2);
  }
  .mob-rn-card .hl { color:var(--lime); }

  /* TIMELINE — Horizontal swipe cards */
  .timeline {
    display:flex; overflow-x:auto; overflow-y:hidden;
    scroll-snap-type:x mandatory; gap:12px;
    scrollbar-width:none; -ms-overflow-style:none;
    -webkit-overflow-scrolling:touch;
    padding:8px 0 16px; margin:32px -16px 0; padding-left:16px; padding-right:16px;
  }
  .timeline::-webkit-scrollbar { display:none; }
  .tl-year {
    flex:0 0 calc(85vw - 16px); scroll-snap-align:center;
    border:2px solid rgba(255,255,255,.08) !important;
    border-radius:0; padding:0 !important;
    background:var(--black2); position:relative; overflow:hidden;
  }
  .tl-year:last-child { border-bottom:2px solid rgba(255,255,255,.08) !important; }
  .tl-year-head {
    flex-direction:column; align-items:flex-start;
    padding:20px; gap:8px;
  }
  .tl-year-num { min-width:auto !important; font-size:clamp(36px,10vw,48px); }
  .tl-year-teaser { font-size:14px; line-height:1.6; }
  .tl-year-plus { display:none; }
  .tl-year-body {
    max-height:none !important; padding:0 20px 20px !important;
    overflow:visible;
  }
  .tl-year-detail { font-size:13px; line-height:1.7; max-width:none; }
  .tl-year-img { max-width:100%; margin-top:12px; }
  .tl-year-img img { border-radius:0; }
  /* Timeline dots */
  .mob-tl-dots {
    display:flex; justify-content:center; gap:6px;
    margin-top:12px; padding:8px 0;
  }
  .mob-tl-dot {
    width:6px; height:6px; border-radius:50%;
    background:var(--gray-d); transition:all .3s var(--ease);
  }
  .mob-tl-dot.active { background:var(--lime); width:18px; border-radius:3px; }

  /* POETRY INTERSTITIALS — dramatic full screen */
  .poetry-break { min-height:100dvh; min-height:-webkit-fill-available; padding:60px 20px; }
  .poetry-break-text .pline { font-size:clamp(16px,5vw,28px); line-height:2; }
  .poetry-break-typing { font-size:clamp(15px,4.5vw,24px); line-height:2; }

  /* SLOT MACHINE — full width, swipeable */
  .slot-machine { border-width:2px; margin-top:24px !important; overflow:hidden; }
  .slot-screen { padding:32px 20px !important; min-height:240px; }
  .slot-emoji { font-size:40px; }
  .slot-proj-name { font-size:clamp(18px,5.5vw,26px); word-break:break-word; }
  .slot-btn { padding:18px; font-size:14px; min-height:56px; }
  .slot-machine.mob-swiping .slot-screen {
    transition:transform .05s linear, opacity .1s;
  }
  .slot-machine.mob-swipe-out .slot-screen {
    transform:translateX(-120%); opacity:0;
    transition:transform .3s var(--ease), opacity .2s;
  }
  .slot-machine.mob-swipe-in .slot-screen {
    animation:mobSlideIn .3s var(--ease);
  }
  @keyframes mobSlideIn {
    from { transform:translateX(100%); opacity:0; }
    to { transform:translateX(0); opacity:1; }
  }

  /* DAPPASOL STRIP — tap friendly */
  .dappasol-strip { padding:40px 20px; }
  .dappasol-strip a { gap:16px; }
  .dappasol-strip-name { font-size:clamp(22px,6vw,32px); }

  /* GALLERY — responsive bento */
  .bento-gallery {
    grid-template-columns:repeat(2, 1fr);
    grid-auto-rows:150px; gap:3px; margin:0 -16px;
  }
  .bento-hero { grid-column:span 2; grid-row:span 2; }
  .bento-wide { grid-column:span 2; }
  .bento-tall { grid-row:span 2; }
  .bento-cell-cap {
    opacity:1 !important; transform:none !important;
    font-size:9px; padding:8px 12px;
  }
  .gallery-filters {
    overflow-x:auto; flex-wrap:nowrap; scrollbar-width:none;
    -ms-overflow-style:none; gap:6px; padding-bottom:8px;
    -webkit-overflow-scrolling:touch; margin:16px 0;
  }
  .gallery-filters::-webkit-scrollbar { display:none; }
  .gallery-filter-btn { white-space:nowrap; flex-shrink:0; padding:8px 14px; font-size:9px; }

  /* WRITING WALL — full width clean cards */
  .writing-wall { gap:12px; }
  .wcard {
    transform:none !important; border-radius:0; width:100%;
    padding:24px 20px; border-width:1px;
    border-left:3px solid transparent;
  }
  .wcard.poetry { border-left-color:var(--violet); }
  .wcard.essay { border-left-color:var(--lime); }
  .wcard.letter { border-left-color:var(--gray); }
  .wcard.manifesto { border-left-color:var(--red-hot); }
  .wcard.thought { border-left-color:#FF9933; }
  .wcard.story { border-left-color:#33BBFF; }
    .wcard:hover { transform:none !important; }
  .wcard::before { display:none; }
  .wcard-title { font-size:16px; }

  .wcard-excerpt { font-size:12px; -webkit-line-clamp:3; }
  .wwall-viewall { max-width:100%; padding:14px 24px; font-size:12px; letter-spacing:1.5px; margin-top:24px; min-height:52px; }
  .wwall-filters { gap:8px; margin-bottom:20px; }
  .wwall-filter-btn { padding:8px 14px; font-size:10px; letter-spacing:1.5px; min-height:40px; }

  /* RECOMMENDS — thumb-friendly */
  .recs-grid { gap:12px; margin-top:32px; }
  .rec-slot { border-width:1px; }
  .rec-slot-screen { padding:20px 16px 14px; min-height:140px; }
  .rec-slot-title { font-size:clamp(16px,5vw,22px) !important; }
  .rec-slot-take { font-size:12px; }
  .rec-slot-btn { padding:14px; min-height:52px; font-size:11px; }
  .rec-shuffle-all { padding:16px; font-size:13px; min-height:52px; }

  /* CONTACT — full-screen steps */
  .contact { padding:60px 0 40px; }
  .contact-choice {
    padding:20px; border-width:1px;
    min-height:64px; display:flex; flex-direction:column; justify-content:center;
  }
  .contact-choice-label { font-size:15px; }
  .contact-form input, .contact-form textarea {
    padding:14px; font-size:16px; /* 16px prevents iOS zoom */
    min-height:48px;
  }
  .contact-submit { padding:16px; min-height:56px; font-size:14px; }

  /* FOOTER — compact */
  .footer { padding:40px 0 20px; }
  .footer-dappasol {
    display:flex; width:100%; justify-content:center;
    padding:14px 20px; font-size:13px;
  }
  .footer-links { gap:16px; flex-wrap:wrap; }
  .footer-links a {
    font-size:12px; padding:8px 4px;
    min-width:44px; min-height:44px;
    display:flex; align-items:center; justify-content:center;
  }

  /* LIGHTBOX mobile */
  .lightbox-close { top:16px; right:16px; font-size:16px; padding:12px; }

  /* WRITING MODAL mobile */
  .wmodal-inner { padding:40px 20px; }
  .wmodal-close { top:16px; right:16px; padding:8px; }
  .wmodal-title { font-size:clamp(24px,7vw,36px); }

  /* SEC HEADS — mobile sizing */
  .sec-head {
    font-size:clamp(28px,9vw,48px); letter-spacing:-1.5px;
    word-break:break-word; overflow-wrap:break-word;
    max-width:100%;
  }
  .sec-sub { font-size:11px; line-height:1.7; margin-top:8px; max-width:100%; }

  /* KONAMI — mobile adjustments */
  .konami-overlay { padding:20px 16px; }
  .konami-stamp { font-size:clamp(16px,4.5vw,32px); padding:8px 16px; }
  .konami-file { padding:0 8px; }
  .konami-file li { font-size:11px; padding:8px 0; word-break:break-word; }
  .konami-file-head { font-size:10px; word-break:break-word; }
  .konami-threat { font-size:13px; word-break:break-word; }

  /* LOADER — mobile */
  .loader-typing { font-size:clamp(12px,3vw,16px); padding:0 16px; min-height:100px; }
  .loader-name { font-size:clamp(48px,14vw,100px); letter-spacing:-3px; }

  /* POETRY — overflow */
  .poetry-break-text { max-width:100%; padding:0; }
  .poetry-break-typing { max-width:100%; word-break:break-word; }

  /* DappaSol strip overflow */
  .dappasol-strip { overflow:hidden; }
  .dappasol-strip-sub { font-size:10px; }

  /* Footer poem overflow */
  .footer-poem { font-size:13px; padding:0 8px; word-break:break-word; }
  .footer-credit { font-size:9px; }
  .footer-visitor { font-size:10px; }

  /* RIGHT NOW overflow */
  .rightnow { margin:0 -16px; padding:12px 16px; }

  /* Slot tags overflow */
  .slot-proj-tags { gap:4px; }
  .slot-proj-tag { font-size:8px; padding:4px 8px; }
  .slot-proj-desc { font-size:12px; }
  .slot-proj-type { font-size:10px; }
}
