/* =========================================================================
   PICHAMON · PORTFOLIO — Playful & Colorful refresh
   Tokens-driven so the Tweaks panel can repaint at runtime.
   ========================================================================= */

:root{
  /* ---- Tweakable tokens (set via JS) ---- */
  --bg:        #fdf6f1;     /* paper */
  --ink:       #1a0f1f;     /* near-black with violet tint */
  --muted:     #6b5566;
  --accent:    #d6336c;     /* primary accent — pink/magenta */
  --accent-2:  #f59f00;     /* secondary accent — warm amber */
  --accent-3:  #2f9e44;     /* tertiary — green */
  --accent-4:  #4263eb;     /* quaternary — blue */

  /* derived (recomputed in JS when accent changes) */
  --accent-soft: color-mix(in oklab, var(--accent) 18%, transparent);
  --accent-tint: color-mix(in oklab, var(--accent) 8%, var(--bg));

  /* type */
  --font-display: "Bricolage Grotesque", "DM Serif Display", Georgia, serif;
  --font-body:    "DM Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  /* shape */
  --r-lg: 28px;
  --r-md: 18px;
  --r-sm: 12px;

  /* shadow */
  --shadow:      0 24px 60px -20px rgba(70, 20, 50, 0.25), 0 4px 14px -6px rgba(70, 20, 50, 0.12);
  --shadow-soft: 0 14px 40px -16px rgba(70, 20, 50, 0.18);
  --border:      color-mix(in oklab, var(--ink) 12%, transparent);
}

*{box-sizing:border-box}
html,body{height:100%}
body,
body *{
  user-select:none !important;
  -webkit-user-select:none !important;
  -moz-user-select:none !important;
  -ms-user-select:none !important;
}
body{
  margin:0;
  font-family: var(--font-body);
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:inherit; text-decoration:none}

/* =====================  Background system  ===================== */
.bg-base{position:fixed; inset:0; z-index:-30; background:var(--bg);}

.bg-ink{
  position:fixed; inset:-15%; z-index:-29;
  background:
    radial-gradient(40% 40% at 22% 18%, color-mix(in oklab, var(--accent) 22%, transparent), transparent 65%),
    radial-gradient(36% 36% at 80% 25%, color-mix(in oklab, var(--accent-2) 20%, transparent), transparent 65%),
    radial-gradient(40% 40% at 70% 80%, color-mix(in oklab, var(--accent-4) 18%, transparent), transparent 65%),
    radial-gradient(30% 30% at 18% 78%, color-mix(in oklab, var(--accent-3) 18%, transparent), transparent 65%);
  filter: blur(40px) saturate(1.1);
  background-size: 140% 140%;
  animation: drift 22s ease-in-out infinite;
  will-change: background-position, transform;
}

@keyframes drift{
  0%   {background-position:  0%  0%, 100%   0%, 100% 100%,   0% 100%; transform: translate3d(0,0,0) }
  33%  {background-position: 12% -6%,  88%  10%,  92%  92%,   8%  88%; transform: translate3d(0,-8px,0) }
  66%  {background-position: -4% 10%, 100%  -4%, 100% 100%,  -2%  92%; transform: translate3d(0,4px,0) }
  100% {background-position:  0%  0%, 100%   0%, 100% 100%,   0% 100%; transform: translate3d(0,0,0) }
}

.bg-grid{
  position:fixed; inset:0; z-index:-28;
  opacity:0.5;
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in oklab, var(--ink) 14%, transparent) 1px, transparent 0);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 50%, #000 50%, transparent 100%);
}

/* Floating sticker shapes — bigger, more characterful */
.blob{
  position:fixed; z-index:-27;
  border-radius:999px;
  will-change: transform;
  animation: floaty 14s ease-in-out infinite;
  mix-blend-mode: multiply;
  opacity: 0.85;
}
.blob.squiggle{
  border-radius:0;
  background:transparent !important;
  animation: floaty 16s ease-in-out infinite;
}
.blob.star{
  background:transparent !important;
  border-radius:0;
}
.blob.ring{
  background:transparent !important;
  border:3px dashed currentColor;
  border-radius:999px;
}

@keyframes floaty{
  0%   {transform: translateY(0) rotate(0deg)}
  25%  {transform: translateY(-14px) rotate(5deg)}
  50%  {transform: translateY(0) rotate(-2deg)}
  75%  {transform: translateY(14px) rotate(-5deg)}
  100% {transform: translateY(0) rotate(0deg)}
}

/* Optional accent: noise texture for paper feel */
body::after{
  content:""; position:fixed; inset:0; z-index:-26; pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:0.6;
  mix-blend-mode: multiply;
}

@media (prefers-reduced-motion: reduce){
  .bg-ink, .blob, .card, .slide-up, .fade-in, .loader-title span{animation:none !important}
}

/* =====================  Layout / typography  ===================== */
.wrap{max-width:1180px; margin:0 auto; padding:40px 24px 80px;}
.fade-in{animation: fadeInUp .55s cubic-bezier(.16,1,.3,1) both;}
@keyframes fadeInUp{from{opacity:0; transform: translateY(14px)}to{opacity:1; transform: translateY(0)}}

.center{text-align:center}
.kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--font-mono);
  font-size:12px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--muted);
  padding:6px 14px;
  border-radius:999px;
  background:color-mix(in oklab, var(--ink) 5%, transparent);
  border:1px solid var(--border);
}
.kicker .dot{width:6px; height:6px; border-radius:999px; background:var(--accent); animation: pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.h1{
  margin:18px 0 0;
  font-family: var(--font-display);
  font-weight:700;
  letter-spacing:-0.035em;
  line-height:0.95;
  font-size:clamp(48px, 9vw, 120px);
}
.h1 .accent{color:var(--accent); font-style:italic; font-weight:600}
.h1 .underline-marker{
  position:relative; display:inline-block; padding: 0 0.05em;
}
.h1 .underline-marker::after{
  content:""; position:absolute; left:-2%; right:-2%; bottom:0.04em; height:0.32em;
  background: var(--accent-soft);
  z-index:-1;
  border-radius:6px;
  transform: skew(-3deg);
}

.p{
  margin:22px auto 0;
  max-width:640px;
  color:var(--muted);
  line-height:1.6;
  font-size:17px;
  text-wrap: pretty;
}

.h2{
  margin:0;
  font-family: var(--font-display);
  font-weight:600;
  letter-spacing:-0.02em;
  font-size:32px;
}
.section-label{
  font-family: var(--font-mono);
  font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted);
  margin-bottom:6px;
}

/* =====================  Hero scroll cue  ===================== */
.scroll-down{position:absolute; bottom:32px; left:50%; transform:translateX(-50%); opacity:.55; display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--ink)}
.scroll-down .label{font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase}
.mouse{width:22px; height:34px; border:2px solid currentColor; border-radius:12px; position:relative;}
.wheel{width:3px; height:6px; background:currentColor; border-radius:3px; position:absolute; top:6px; left:50%; transform:translateX(-50%); animation:scrollWheel 1.6s infinite;}
@keyframes scrollWheel{
  0%{top:6px; opacity:1}
  70%{top:18px; opacity:0}
  100%{top:6px; opacity:0}
}

/* =====================  Social pills  ===================== */
.social-row{margin-top:32px; display:flex; justify-content:center; flex-wrap:wrap; gap:10px;}
.social-pill{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:500;
  padding:10px 16px;
  border-radius:999px;
  background:color-mix(in oklab, var(--ink) 4%, var(--bg));
  border:1px solid var(--border);
  color:var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.social-pill:hover{
  transform: translateY(-2px);
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.social-pill svg{width:14px; height:14px; fill:currentColor;}

/* =====================  About strip  ===================== */
.about-strip{
  margin-top:64px;
  display:grid;
  grid-template-columns: 1fr;
  gap:28px;
  padding:32px;
  background: color-mix(in oklab, var(--accent) 6%, var(--bg));
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-soft);
  position:relative;
  overflow:hidden;
}
.about-strip::before{
  content:"";
  position:absolute; right:-40px; top:-40px;
  width:160px; height:160px; border-radius:999px;
  background: var(--accent);
  opacity:.16;
}
@media (min-width: 760px){
  .about-strip{grid-template-columns: 1fr 1.4fr; align-items:center; padding:42px 48px}
}
.about-strip .label{
  font-family: var(--font-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent);
}
.about-strip h3{
  font-family: var(--font-display); font-weight:600; letter-spacing:-0.02em;
  margin:8px 0 0; font-size:28px; line-height:1.15;
}
.about-strip p{margin:14px 0 0; color:var(--muted); line-height:1.6; max-width:52ch}
.about-meta{display:flex; gap:18px; flex-wrap:wrap; margin-top:18px}
.about-meta .item{display:flex; flex-direction:column; gap:2px}
.about-meta .k{font-family:var(--font-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted)}
.about-meta .v{font-weight:600; font-size:14px}

/* =====================  Section header  ===================== */
.section-head{
  margin-top:80px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:14px;
}
.section-head .left{display:flex; flex-direction:column; gap:6px}
.see-all{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink);
  padding:8px 14px; border-radius:999px;
  border:1px solid var(--border);
  transition: all .2s ease;
}
.see-all:hover{background:var(--ink); color:var(--bg); border-color:var(--ink)}

/* =====================  Awards (slider)  ===================== */
.awards-nav{display:flex; gap:8px}
.awards-arrow{
  width:38px; height:38px; border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--ink) 4%, var(--bg));
  color:var(--ink);
  font-size:16px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
.awards-arrow:hover{
  background: var(--accent); color:#fff; border-color: var(--accent);
  transform: translateY(-2px);
}

.awards-slider{
  margin-top:24px;
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 14px 4px 26px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.awards-slider::-webkit-scrollbar{height:6px}
.awards-slider::-webkit-scrollbar-track{background:transparent}
.awards-slider::-webkit-scrollbar-thumb{background:var(--border); border-radius:10px}

.award-card{
  position:relative;
  flex: 0 0 320px;
  scroll-snap-align: start;
  display:flex; align-items:flex-start; gap:14px;
  padding:20px 22px;
  background:#fff;
  border:1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-soft);
  text-decoration:none; color:inherit;
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s ease, border-color .25s ease;
  overflow:hidden;
}
@media (min-width:700px){.award-card{flex: 0 0 360px}}

.award-card[data-accent="pink"]  { --accent: var(--c-pink); }
.award-card[data-accent="blue"]  { --accent: var(--c-blue); }
.award-card[data-accent="green"] { --accent: var(--c-green); }
.award-card[data-accent="amber"] { --accent: var(--c-amber); }

.award-card::before{
  content:""; position:absolute; left:0; top:0; bottom:0;
  width:4px; background:var(--accent);
}

.awards-slider .award-card:nth-child(3n+1){ transform: rotate(-1deg); }
.awards-slider .award-card:nth-child(3n+2){ transform: rotate(0.7deg); }
.awards-slider .award-card:nth-child(3n+3){ transform: rotate(-0.4deg); }

.award-card:hover,
a.award-card:hover{
  transform: translateY(-8px) rotate(0deg);
  border-color: var(--accent);
  box-shadow: 0 32px 70px -22px rgba(70, 20, 50, 0.32), 0 6px 18px -8px rgba(70, 20, 50, 0.18);
}
.award-icon{
  flex:none;
  width:42px; height:42px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
  background: color-mix(in oklab, var(--accent) 14%, transparent);
  border-radius: 12px;
}
.award-body{flex:1; min-width:0}
.award-title{
  font-family: var(--font-display);
  font-weight:600; letter-spacing:-0.01em;
  font-size:15px; line-height:1.25;
}
.award-sub{
  margin-top:3px;
  font-family: var(--font-mono);
  font-size:11px; letter-spacing:0.06em; text-transform:uppercase;
  color: var(--accent);
  font-weight:500;
}
.award-desc{
  margin-top:8px;
  color: var(--muted);
  font-size:13px; line-height:1.5;
}
.award-link{
  display:none;
}

/* =====================  Cards  ===================== */
.grid{
  display:grid; grid-template-columns:1fr; gap:24px;
  margin-top:24px;
}
@media (min-width:700px){.grid{grid-template-columns:repeat(2,1fr); gap:28px}}
@media (min-width:1024px){.grid{grid-template-columns:repeat(3,1fr); gap:28px}}

.card{
  position:relative;
  height:420px;
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  background:#fff;
  box-shadow: var(--shadow);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s ease;
  will-change: transform;
}
.card:hover{
  transform: translateY(-8px) rotate(-0.4deg);
  box-shadow: 0 32px 70px -22px rgba(70, 20, 50, 0.32), 0 6px 18px -8px rgba(70, 20, 50, 0.18);
}

/* image-forward layout: image dominant on top, text panel at bottom */
.cardImg{
  position:relative; height:240px; flex:none;
  overflow:hidden;
  background: var(--accent-tint);
}
.cardImg img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; user-select:none; -webkit-user-drag:none;
  transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.card:hover .cardImg img{transform: scale(1.06)}

.cardImg .yearChip{
  position:absolute; top:14px; left:14px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em;
  padding:5px 10px; border-radius:999px;
  background:rgba(255,255,255,0.92);
  color:var(--ink);
  backdrop-filter: blur(6px);
}
.cardImg .arrow{
  position:absolute; top:14px; right:14px;
  width:36px; height:36px; border-radius:999px;
  background:var(--ink); color:#fff;
  display:flex; align-items:center; justify-content:center;
  transform: rotate(-45deg);
  transition: transform .3s ease, background .3s ease;
}
.card:hover .cardImg .arrow{transform: rotate(0deg); background: var(--accent)}

.cardBody{
  flex:1;
  padding:20px 22px;
  display:flex; flex-direction:column;
  background:#fff;
  border-top:1px solid var(--border);
}
.cardTitle{
  margin:0;
  font-family: var(--font-display);
  font-weight:600; letter-spacing:-0.015em;
  font-size:22px; line-height:1.15;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.cardTagline{
  margin:6px 0 0;
  color:var(--muted);
  line-height:1.5;
  font-size:13.5px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.pillWrap{margin-top:auto; padding-top:14px; display:flex; flex-wrap:wrap; gap:6px;}
.pill{
  display:inline-flex; align-items:center;
  font-family:var(--font-mono);
  font-size:10px; letter-spacing:0.06em; text-transform:uppercase;
  padding:5px 9px; border-radius:6px;
  background: color-mix(in oklab, var(--accent) 10%, transparent);
  color: color-mix(in oklab, var(--accent) 80%, var(--ink));
  border:1px solid color-mix(in oklab, var(--accent) 22%, transparent);
}

/* Accent variants per-card (cycle automatically via :nth-child) */
.card[data-accent="green"]  { --accent: var(--c-green); }
.card[data-accent="pink"]   { --accent: var(--c-pink); }
.card[data-accent="blue"]   { --accent: var(--c-blue); }
.card[data-accent="amber"]  { --accent: var(--c-amber); }

/* card style variants — set via data-card-style on body */
body[data-card-style="clean"] .card:hover{ transform: translateY(-6px); }
body[data-card-style="sticker"] .card:nth-child(3n+1){ transform: rotate(-1deg); }
body[data-card-style="sticker"] .card:nth-child(3n+2){ transform: rotate(0.6deg); }
body[data-card-style="sticker"] .card:nth-child(3n+3){ transform: rotate(-0.4deg); }
body[data-card-style="sticker"] .card:hover{ transform: translateY(-8px) rotate(0deg) !important; }

/* List style: vertical, with index numbers */
body[data-card-style="list"] .grid{ grid-template-columns: 1fr; gap:0; }
body[data-card-style="list"] .card{
  height:auto; flex-direction:row; align-items:stretch;
  border-radius:0; border-left:none; border-right:none;
  border-top:1px solid var(--border); border-bottom:none;
  box-shadow:none; background:transparent;
}
body[data-card-style="list"] .card:last-child{ border-bottom:1px solid var(--border); }
body[data-card-style="list"] .card:hover{ transform:none; background:color-mix(in oklab, var(--accent) 4%, transparent); }
body[data-card-style="list"] .card .cardImg{
  width:140px; height:96px; flex:none; align-self:center; margin:18px 22px 18px 0; border-radius:var(--r-md);
}
body[data-card-style="list"] .card .cardImg .yearChip,
body[data-card-style="list"] .card .cardImg .arrow{display:none}
body[data-card-style="list"] .card .cardBody{
  border-top:none; padding:22px 0; flex-direction:row; align-items:center; gap:24px; background:transparent;
}
body[data-card-style="list"] .card::before{
  content: attr(data-index);
  align-self:center; padding:0 22px;
  font-family:var(--font-display); font-size:38px; font-weight:600;
  color: var(--accent); width:80px;
}
body[data-card-style="list"] .cardTitle{flex:1; font-size:24px}
body[data-card-style="list"] .cardTagline{flex:1.4; font-size:14px; -webkit-line-clamp:2}
body[data-card-style="list"] .pillWrap{padding-top:0; flex:none; max-width:200px; justify-content:flex-end}

/* =====================  Detail page hero  ===================== */
.heroBox{
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-soft);
  padding:32px;
  background: color-mix(in oklab, var(--accent) 8%, var(--bg));
  position:relative;
  overflow:hidden;
}
.heroBox::after{
  content:""; position:absolute; right:-60px; bottom:-60px;
  width:220px; height:220px; border-radius:999px;
  background: var(--accent); opacity:.12;
}
.crumbs{display:flex; flex-wrap:wrap; gap:10px; align-items:center; color:var(--muted); font-size:13px; font-family:var(--font-mono); letter-spacing:0.04em}
.crumbs a{color:var(--ink); font-weight:500}
.home-crumb{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px; border-radius:999px;
  background: color-mix(in oklab, var(--ink) 4%, transparent);
  border:1px solid var(--border);
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
.home-crumb:hover{background: var(--accent); color:#fff; border-color: var(--accent); transform: translateY(-2px)}
.home-crumb svg{width:13px; height:13px}
.crumbs .sep{opacity:.45}
.heroTitle{
  margin:14px 0 0;
  font-family: var(--font-display);
  font-weight:600; letter-spacing:-0.025em;
  font-size:clamp(34px, 5vw, 56px); line-height:1.05;
}
.heroTag{margin:10px 0 0; color:var(--muted); max-width:760px; line-height:1.55; font-size:16px}
.tagRow{margin-top:18px; display:flex; flex-wrap:wrap; gap:8px}
.tag{
  font-family:var(--font-mono);
  font-size:11px; letter-spacing:0.08em; text-transform:uppercase;
  padding:6px 11px; border-radius:6px;
  background: rgba(255,255,255,0.7);
  border:1px solid var(--border);
  color: var(--ink);
}

/* =====================  Board / Panels  ===================== */
.board{column-count:1; column-gap:24px; margin-top:24px;}
@media (min-width:1024px){.board{column-count:2;}}

.panel{
  break-inside:avoid;
  margin:0 0 24px;
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  background:#fff;
  box-shadow: var(--shadow-soft);
  padding:24px;
}
.panel h2{
  margin:0;
  font-family: var(--font-display);
  font-size:22px; font-weight:600; letter-spacing:-0.015em;
}
.panel .stack{margin-top:14px;}
.panel .block + .block{margin-top:16px}
.panel p{margin:0; color:var(--ink); opacity:.82; line-height:1.7; font-size:15px}

.media{width:100%; border-radius: var(--r-md); border:1px solid var(--border); overflow:hidden; background:var(--bg);}
.media.ratio{aspect-ratio: 16 / 10; position:relative;}
.media.ratio img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; user-select:none; -webkit-user-drag:none;}

video{width:100%; border-radius: var(--r-md); border:1px solid var(--border);}

/* Gallery */
.gallery-scroll {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 14px;
  -webkit-overflow-scrolling: touch;
}
.gallery-item {
  flex: 0 0 85%;
  scroll-snap-align: center;
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--border);
  position: relative;
  aspect-ratio: 16/9;
  background: var(--accent-tint);
}
.gallery-item img {position:absolute; inset:0; width:100%; height:100%; object-fit:cover;}
.gallery-scroll::-webkit-scrollbar { height: 6px; }
.gallery-scroll::-webkit-scrollbar-track { background: transparent; }
.gallery-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 10px; }

ul{margin:0; padding-left:18px; color:var(--ink); opacity:.82; font-size:15px; line-height:1.65}
li+li{margin-top:6px}

.footer{
  margin-top:80px; text-align:center;
  color:var(--muted); font-size:13px;
  padding-top:32px; border-top:1px solid var(--border);
}
.footer .marks{display:flex; justify-content:center; gap:14px; margin-bottom:14px}
.footer .marks span{font-family:var(--font-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase}

.noselect{user-select:none}

/* Slide-up entrance */
.slide-up{animation: slideUp .8s cubic-bezier(0.16, 1, 0.3, 1) both;}
@keyframes slideUp{
  from{opacity:0; transform:translateY(36px)}
  to{opacity:1; transform:translateY(0)}
}

/* =====================  Loader  ===================== */
.loader-wrap{
  position:fixed; inset:0; z-index:9999;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  transition: transform 1.1s cubic-bezier(0.87, 0, 0.13, 1);
  will-change: transform;
}
.loader-wrap.is-hidden{transform: translateY(-100%);}
.loader-title{
  font-family: var(--font-display);
  color:var(--ink);
  font-size:clamp(38px, 7vw, 84px);
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1;
  text-align:center;
  overflow:hidden;
  display:flex; align-items:baseline; gap:0.2em;
}
.loader-title .word{display:inline-block; overflow:hidden}
.loader-title .word span{
  display:inline-block;
  transform:translateY(110%);
  animation: revealText 1.1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.loader-title .word:nth-child(1) span{animation-delay:0.1s}
.loader-title .word:nth-child(2) span{animation-delay:0.25s; color:var(--accent); font-style:italic}
.loader-title .word:nth-child(3) span{animation-delay:0.4s}
@keyframes revealText{ to{transform:translateY(0)} }

/* tweaks panel host overrides — make sure our floating panel sits above */
[data-tweaks-host]{z-index: 10000}
