/* =====================================================================
   MELLOBASS · front-end theme  ·  "year 2060"
   Colours/fonts come from CSS variables injected by index.php (editable
   in the admin). This file only references var(--x) so re-theming is live.
   ===================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#05010f; --surface:#0d0820; --primary:#b14bff; --secondary:#00e5ff;
  --accent:#ff2d95; --text:#eae6ff; --radius:20px;
  --muted:color-mix(in srgb,var(--text) 60%,transparent);
  --line:color-mix(in srgb,var(--text) 12%,transparent);
  --glass:color-mix(in srgb,var(--surface) 70%,transparent);
  --font-display:"Orbitron",sans-serif; --font-body:"Space Grotesk",system-ui,sans-serif;
  --maxw:1200px;
}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--text); font-family:var(--font-body);
  line-height:1.6; overflow-x:hidden; min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--primary);color:#fff}

/* ---------- animated background ---------- */
.bg-aurora,.bg-grid{position:fixed;inset:0;z-index:-2;pointer-events:none}
.bg-aurora{
  background:
    radial-gradient(40vmax 40vmax at 15% 10%, color-mix(in srgb,var(--primary) 45%,transparent), transparent 60%),
    radial-gradient(35vmax 35vmax at 85% 20%, color-mix(in srgb,var(--secondary) 38%,transparent), transparent 60%),
    radial-gradient(45vmax 45vmax at 50% 100%, color-mix(in srgb,var(--accent) 35%,transparent), transparent 60%);
  filter:blur(20px) saturate(140%); opacity:.55;
  animation:drift 24s ease-in-out infinite alternate;
}
.fx-aurora .bg-aurora{animation:drift 24s ease-in-out infinite alternate}
@keyframes drift{
  0%{transform:translate3d(-4%,-2%,0) scale(1.05)}
  50%{transform:translate3d(3%,4%,0) scale(1.15)}
  100%{transform:translate3d(2%,-3%,0) scale(1.08)}
}
.bg-grid{
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; opacity:.25;
  mask-image:radial-gradient(circle at 50% 30%, #000 30%, transparent 80%);
  z-index:-1;
}
/* film grain */
.fx-grain::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;
  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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media (prefers-reduced-motion:reduce){.bg-aurora{animation:none}}

/* ---------- shared ---------- */
.glass{
  background:var(--glass);
  border:1px solid var(--line);
  border-radius:var(--radius);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  box-shadow:0 20px 60px -30px rgba(0,0,0,.8), inset 0 1px 0 color-mix(in srgb,var(--text) 8%,transparent);
}
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,8rem) clamp(1.2rem,5vw,2rem)}
.section-head{margin-bottom:3rem}
.kicker{
  font-family:var(--font-display);font-size:.78rem;letter-spacing:.35em;
  color:var(--secondary);text-transform:uppercase;
}
.section-title{
  font-family:var(--font-display);font-weight:900;line-height:1;
  font-size:clamp(2rem,6vw,4.2rem);margin-top:.4rem;
  background:linear-gradient(120deg,var(--text),var(--primary) 60%,var(--secondary));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-lede{color:var(--muted);max-width:50ch;margin-top:1rem}
.empty{color:var(--muted);text-align:center;padding:3rem;border:1px dashed var(--line);border-radius:var(--radius)}

/* ---------- buttons ---------- */
.btn{
  --b:var(--primary);
  display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;
  font-family:var(--font-display);font-weight:600;font-size:.9rem;letter-spacing:.05em;
  padding:.8rem 1.5rem;border-radius:999px;border:1px solid transparent;
  transition:transform .2s,box-shadow .3s,background .3s;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:.5rem 1rem;font-size:.78rem}
.btn-lg{padding:1rem 2rem;font-size:1rem}
.btn-primary{
  background:linear-gradient(120deg,var(--primary),var(--accent));color:#fff;
  box-shadow:0 10px 40px -10px var(--primary);
}
.btn-primary:hover{box-shadow:0 14px 50px -8px var(--primary)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--secondary);box-shadow:0 0 0 1px var(--secondary),0 0 30px -10px var(--secondary)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(1.2rem,5vw,2.5rem);transition:padding .3s,background .3s;
}
.nav.scrolled{
  background:color-mix(in srgb,var(--bg) 75%,transparent);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding-top:.7rem;padding-bottom:.7rem;
}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:700;letter-spacing:.15em}
.brand-dot{width:.7rem;height:.7rem;border-radius:50%;background:var(--secondary);box-shadow:0 0 14px var(--secondary);animation:pulse 2s infinite}
.nav-links{display:flex;align-items:center;gap:1.8rem;font-size:.92rem}
.nav-links a{color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-links .btn{color:#fff}
.nav-toggle{display:none;background:none;border:0;color:var(--text);font-size:1.4rem;cursor:pointer}
.nav-backdrop{display:none}

/* ---------- hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding:6rem clamp(1.2rem,5vw,2.5rem) 4rem}
.hero-inner{max-width:var(--maxw);margin:0 auto;width:100%;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;color:var(--secondary);font-family:var(--font-display);font-size:.8rem;letter-spacing:.3em}
.pulse{width:.6rem;height:.6rem;border-radius:50%;background:var(--secondary);box-shadow:0 0 12px var(--secondary);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.hero-title{
  font-family:var(--font-display);font-weight:900;line-height:.92;margin:1rem 0;
  font-size:clamp(3rem,11vw,7.5rem);letter-spacing:-.02em;
  background:linear-gradient(120deg,#fff,var(--primary) 45%,var(--secondary));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{font-size:clamp(1rem,2.4vw,1.4rem);color:var(--muted);max-width:30ch}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin:2rem 0}

/* glitch — subtle chromatic flicker; clean title most of the time.
   NOTE: use background-image (not the `background` shorthand) so it does
   not reset background-clip:text back to border-box. */
.glitch{position:relative}
.glitch::before,.glitch::after{
  content:attr(data-text);position:absolute;inset:0;pointer-events:none;opacity:0;
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.glitch::before{background-image:linear-gradient(120deg,var(--accent),var(--accent));animation:glitchA 6s infinite}
.glitch::after{background-image:linear-gradient(120deg,var(--secondary),var(--secondary));animation:glitchB 6s infinite}
@keyframes glitchA{0%,93%,100%{opacity:0;transform:translate(0)}94%{opacity:.85;transform:translate(-2px,-1px)}97%{opacity:.6;transform:translate(2px,1px)}}
@keyframes glitchB{0%,92%,100%{opacity:0;transform:translate(0)}93%{opacity:.85;transform:translate(2px,1px)}96%{opacity:.6;transform:translate(-2px,-1px)}}
@media (prefers-reduced-motion:reduce){.glitch::before,.glitch::after{animation:none}}

/* hero orb */
.hero-visual{display:grid;place-items:center}
.orb{position:relative;width:min(420px,80vw);aspect-ratio:1}
.orb-img,.orb-placeholder{
  position:absolute;inset:8%;border-radius:50%;object-fit:cover;width:84%;height:84%;
  box-shadow:0 0 80px -10px var(--primary);border:1px solid var(--line);
}
.orb-placeholder{display:grid;place-items:center;text-align:center;color:var(--muted);background:var(--surface);font-size:.9rem;letter-spacing:.1em}
.orb-ring{position:absolute;inset:0;border-radius:50%;border:1px solid color-mix(in srgb,var(--secondary) 50%,transparent);animation:spin 18s linear infinite}
.orb-ring-2{inset:-7%;border-color:color-mix(in srgb,var(--primary) 50%,transparent);border-style:dashed;animation:spin 26s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}

.socials{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.5rem}
.social{
  width:2.6rem;height:2.6rem;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--line);font-family:var(--font-display);font-size:.72rem;font-weight:700;
  color:var(--muted);transition:.2s;
}
.social:hover{color:#fff;border-color:var(--secondary);box-shadow:0 0 20px -4px var(--secondary);transform:translateY(-3px)}

.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%)}
.scroll-hint span{display:block;width:1.4rem;height:2.3rem;border:2px solid var(--line);border-radius:999px;position:relative}
.scroll-hint span::after{content:"";position:absolute;top:.4rem;left:50%;transform:translateX(-50%);width:.3rem;height:.5rem;border-radius:2px;background:var(--secondary);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;top:.3rem}40%{opacity:1}100%{opacity:0;top:1.2rem}}

/* ---------- vision ---------- */
.vision-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:1.5rem}
.vision-text{padding:2.2rem;font-size:1.1rem;line-height:1.8}
.vision-stats{display:grid;gap:1.5rem}
.stat{padding:1.6rem;text-align:center}
.stat-num{display:block;font-family:var(--font-display);font-weight:900;font-size:2.4rem;background:linear-gradient(120deg,var(--secondary),var(--primary));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{color:var(--muted);font-size:.85rem;letter-spacing:.05em}

/* ---------- music ---------- */
.track-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.track{overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.track:hover{transform:translateY(-6px);box-shadow:0 30px 70px -30px var(--primary)}
.track-cover{position:relative;aspect-ratio:1;overflow:hidden;background:var(--surface)}
.track-cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.track:hover .track-cover img{transform:scale(1.06)}
.track-cover-fallback{display:grid;place-items:center;height:100%;font-size:3rem;color:var(--muted)}
.play-btn{
  position:absolute;right:1rem;bottom:1rem;width:3.4rem;height:3.4rem;border-radius:50%;border:0;cursor:pointer;
  background:linear-gradient(120deg,var(--primary),var(--accent));color:#fff;font-size:1.1rem;
  box-shadow:0 10px 30px -6px var(--primary);transition:transform .2s;display:grid;place-items:center;
}
.play-btn:hover{transform:scale(1.1)}
.play-btn.playing{animation:pulse 1.4s infinite}
.track-body{padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.track-title{font-family:var(--font-display);font-size:1.15rem}
.track-sub{color:var(--secondary);font-size:.85rem}
.track-desc{color:var(--muted);font-size:.9rem}
.embed{margin:.5rem 0;border-radius:14px;overflow:hidden}
.embed iframe{width:100%;height:152px;border:0;display:block}
.embed iframe[src*="youtube"]{aspect-ratio:16/9;height:auto}
.track-meta{margin-top:auto;display:flex;align-items:center;gap:1rem;padding-top:.8rem;border-top:1px solid var(--line);font-size:.9rem}
.track-buy{margin-left:auto;color:var(--secondary)}

.like{background:none;border:0;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font:inherit;transition:color .2s}
.like .heart{transition:transform .2s}
.like:hover{color:var(--accent)}
.like.liked{color:var(--accent)}
.like.liked .heart{animation:pop .4s}
@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.5)}100%{transform:scale(1)}}
.plays{color:var(--muted)}

/* ---------- gallery ---------- */
.gallery{columns:3 260px;column-gap:1.2rem}
.shot{position:relative;margin-bottom:1.2rem;break-inside:avoid;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.shot img{width:100%;transition:transform .5s}
.shot:hover img{transform:scale(1.05)}
.shot figcaption{position:absolute;inset:auto 0 0 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(transparent,rgba(0,0,0,.8));font-size:.85rem;opacity:0;transform:translateY(10px);transition:.3s}
.shot:hover figcaption{opacity:1;transform:none}
.like-mini{color:#fff}

/* ---------- services ---------- */
.services{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}
.service{padding:2rem;display:flex;flex-direction:column;gap:.8rem;transition:transform .3s,box-shadow .3s}
.service:hover{transform:translateY(-6px);box-shadow:0 30px 70px -30px var(--secondary)}
.service-icon{font-size:2.4rem;filter:drop-shadow(0 0 16px var(--secondary))}
.service-title{font-family:var(--font-display);font-size:1.2rem}
.service-desc{color:var(--muted);font-size:.95rem;flex:1}
.service-foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:.5rem}
.service-price{font-family:var(--font-display);color:var(--secondary)}

/* ---------- contact ---------- */
.contact{max-width:680px;margin:0 auto;padding:2.2rem;display:grid;gap:1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact input,.contact textarea{
  width:100%;background:color-mix(in srgb,var(--bg) 60%,transparent);border:1px solid var(--line);
  border-radius:14px;padding:.9rem 1.1rem;color:var(--text);font:inherit;transition:border .2s,box-shadow .2s;
}
.contact input:focus,.contact textarea:focus{outline:0;border-color:var(--secondary);box-shadow:0 0 0 3px color-mix(in srgb,var(--secondary) 25%,transparent)}
.contact textarea{resize:vertical}
.hp{position:absolute;left:-9999px}

/* ---------- join / members ---------- */
.join{display:grid;grid-template-columns:1.1fr 1fr;gap:2.5rem;align-items:center;padding:clamp(1.6rem,4vw,2.8rem)}
.join .kicker{color:var(--secondary)}
.join .section-title{font-size:clamp(1.6rem,4.5vw,2.8rem)}
.join .section-lede{margin-top:.8rem}
.join-form{display:grid;gap:1rem}
.join-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.join-form input{width:100%;background:color-mix(in srgb,var(--bg) 60%,transparent);border:1px solid var(--line);border-radius:14px;padding:.9rem 1.1rem;color:var(--text);font:inherit;transition:border .2s,box-shadow .2s}
.join-form input:focus{outline:0;border-color:var(--secondary);box-shadow:0 0 0 3px color-mix(in srgb,var(--secondary) 25%,transparent)}
.join-form .btn{width:100%;justify-content:center}
@media(max-width:780px){.join{grid-template-columns:1fr;gap:1.5rem}.join-row{grid-template-columns:1fr}}

/* ---------- blog / pages ---------- */
.page-wrap{max-width:var(--maxw);margin:0 auto;padding:clamp(6rem,12vw,9rem) clamp(1.2rem,5vw,2rem) 4rem}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.post-card{overflow:hidden;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-6px);box-shadow:0 30px 70px -30px var(--primary)}
.post-card-link{display:flex;flex-direction:column;height:100%}
.post-cover{aspect-ratio:16/10;overflow:hidden;background:var(--surface)}
.post-cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.post-card:hover .post-cover img{transform:scale(1.06)}
.post-cover-fallback{display:grid;place-items:center;font-family:var(--font-display);font-size:3rem;font-weight:900;color:color-mix(in srgb,var(--primary) 60%,transparent)}
.post-card-body{padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.post-date{color:var(--secondary);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.post-card-title{font-family:var(--font-display);font-size:1.2rem;line-height:1.25}
.post-card-excerpt{color:var(--muted);font-size:.92rem;flex:1}
.post-readmore{color:var(--secondary);font-weight:600;font-size:.9rem;margin-top:.3rem}
.pager{display:flex;gap:.5rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap}
.pager-link{width:2.6rem;height:2.6rem;display:grid;place-items:center;border-radius:12px;border:1px solid var(--line);color:var(--muted)}
.pager-link.active,.pager-link:hover{color:#fff;border-color:var(--secondary);box-shadow:0 0 20px -8px var(--secondary)}

/* article */
.article{max-width:780px;margin:0 auto}
.article-title{font-size:clamp(1.8rem,5vw,3.2rem)}
.article-cover{border-radius:var(--radius);overflow:hidden;margin:1.5rem 0;border:1px solid var(--line)}
.article-cover img{width:100%;display:block}
.article-body{padding:clamp(1.4rem,4vw,2.4rem);font-size:1.08rem;line-height:1.85}
.article-body>*+*{margin-top:1.1rem}
.article-body h2{font-family:var(--font-display);font-size:1.6rem;margin-top:2rem}
.article-body h3{font-family:var(--font-display);font-size:1.25rem;margin-top:1.6rem}
.article-body a{color:var(--secondary);text-decoration:underline;text-underline-offset:3px}
.article-body img{max-width:100%;border-radius:14px;margin:1.2rem 0}
.article-body ul,.article-body ol{padding-left:1.4rem}
.article-body li{margin:.3rem 0}
.article-body blockquote{border-left:3px solid var(--primary);padding-left:1.2rem;color:var(--muted);font-style:italic}
.article-body code{background:color-mix(in srgb,var(--text) 10%,transparent);padding:.1rem .4rem;border-radius:6px;font-size:.9em}

/* share buttons */
.share{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.share-label{color:var(--muted);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin-right:.3rem}
.share-btn{font-family:var(--font-body);font-size:.82rem;font-weight:600;cursor:pointer;padding:.5rem 1rem;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--text);transition:.2s}
.share-btn:hover{border-color:var(--secondary);color:#fff;box-shadow:0 0 20px -8px var(--secondary);transform:translateY(-2px)}

/* ---------- chatbot ---------- */
.chat-fab{position:fixed;right:1.2rem;bottom:1.2rem;z-index:120;width:3.6rem;height:3.6rem;border-radius:50%;border:0;cursor:pointer;font-size:1.5rem;background:linear-gradient(120deg,var(--primary),var(--accent));color:#fff;box-shadow:0 12px 36px -8px var(--primary);transition:transform .2s,opacity .2s}
.chat-fab:hover{transform:scale(1.08)}
.chat-fab.hidden{opacity:0;pointer-events:none;transform:scale(.6)}
.chat-panel{position:fixed;right:1.2rem;bottom:1.2rem;z-index:121;width:min(370px,calc(100vw - 2rem));height:min(520px,calc(100vh - 2rem));display:flex;flex-direction:column;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb,var(--surface) 97%,transparent);backdrop-filter:blur(20px);box-shadow:0 30px 80px -20px #000;transform:translateY(20px) scale(.98);opacity:0;pointer-events:none;transition:.28s cubic-bezier(.2,.8,.2,1)}
.chat-panel.open{transform:none;opacity:1;pointer-events:auto}
.chat-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem;background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 32%,transparent),color-mix(in srgb,var(--secondary) 22%,transparent));border-bottom:1px solid var(--line);font-family:var(--font-display);font-size:.95rem;letter-spacing:.04em}
.chat-head-btns{display:flex;align-items:center;gap:.3rem}
.chat-head button{background:none;border:0;color:var(--text);cursor:pointer;font-size:1rem;opacity:.75;padding:.2rem .35rem;border-radius:8px}
.chat-head button:hover{opacity:1;background:color-mix(in srgb,var(--text) 10%,transparent)}
.chat-log{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.7rem;overscroll-behavior:contain}
.msg{max-width:86%;padding:.7rem 1rem;border-radius:16px;font-size:.92rem;line-height:1.55;white-space:pre-wrap;word-wrap:break-word;animation:msgin .25s ease}
@keyframes msgin{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msg.bot{align-self:flex-start;background:color-mix(in srgb,var(--text) 9%,transparent);border:1px solid var(--line);border-bottom-left-radius:5px}
.msg.user{align-self:flex-end;background:linear-gradient(120deg,var(--primary),var(--accent));color:#fff;border-bottom-right-radius:5px}
.msg .caret{display:inline-block;width:.5ch;background:var(--secondary);margin-left:1px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.chat-input{display:flex;gap:.5rem;padding:.8rem;border-top:1px solid var(--line)}
.chat-input input{flex:1;min-width:0;background:color-mix(in srgb,var(--bg) 60%,transparent);border:1px solid var(--line);border-radius:999px;padding:.7rem 1rem;color:var(--text);font:inherit}
.chat-input input:focus{outline:0;border-color:var(--secondary);box-shadow:0 0 0 3px color-mix(in srgb,var(--secondary) 22%,transparent)}
.chat-input button{width:2.7rem;height:2.7rem;border-radius:50%;border:0;cursor:pointer;background:linear-gradient(120deg,var(--primary),var(--accent));color:#fff;font-size:1rem;flex:none}
@media(max-width:520px){.chat-panel{right:.5rem;bottom:.5rem;width:calc(100vw - 1rem);height:calc(100vh - 5rem)}.chat-fab{right:.9rem;bottom:.9rem}}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:2rem;padding:clamp(3rem,7vw,5rem) clamp(1.2rem,5vw,2.5rem) 2rem}
.footer-main{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;align-items:start}
.footer-brand{font-family:var(--font-display);font-weight:900;font-size:1.6rem;letter-spacing:.2em;background:linear-gradient(120deg,var(--primary),var(--secondary));-webkit-background-clip:text;background-clip:text;color:transparent}
.footer-tagline{color:var(--muted);margin:.6rem 0 1.2rem;max-width:38ch}
.footer-brand-col .socials{margin-top:0}
.footer-links{display:flex;flex-direction:column;gap:.6rem}
.footer-links h4{font-family:var(--font-display);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--secondary);margin-bottom:.4rem}
.footer-links a{color:var(--muted);transition:color .2s;width:fit-content}
.footer-links a:hover{color:var(--text)}
.footer-bottom{max-width:var(--maxw);margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-fine{color:var(--muted);font-size:.85rem}
/* development credit badge (matches the requested look) */
.credit-badge{display:inline-flex;align-items:center;gap:.55rem;padding:.5rem 1rem;border-radius:10px;background:#0a0a0a;border:1px solid #2a2a2a;color:#ffb000;font-family:var(--font-display),ui-monospace,monospace;font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;transition:.25s;box-shadow:inset 0 0 0 1px rgba(255,176,0,.06)}
.credit-badge:hover{border-color:#ffb000;box-shadow:0 0 24px -8px #ffb000,inset 0 0 0 1px rgba(255,176,0,.2);color:#ffc83d}
.credit-dot{width:.5rem;height:.5rem;border-radius:50%;background:#ffb000;box-shadow:0 0 10px #ffb000;animation:pulse 2s infinite}

/* ---------- flash ---------- */
.flash{position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:200;padding:.9rem 1.4rem;border-radius:999px;font-size:.9rem;backdrop-filter:blur(10px);animation:flashin .4s}
.flash-ok{background:color-mix(in srgb,var(--secondary) 25%,var(--surface));border:1px solid var(--secondary)}
.flash-err{background:color-mix(in srgb,var(--accent) 25%,var(--surface));border:1px solid var(--accent)}
@keyframes flashin{from{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%,0)}}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- scrollbar ---------- */
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--primary),var(--secondary));border-radius:10px}

/* ---------- responsive ---------- */
/* large tablet / small laptop */
@media (max-width:1024px){
  .footer-main{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand-col{grid-column:1 / -1}
  .track-grid,.services,.post-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
}
/* nav collapses to a drawer (more menu items now, so a bit earlier) */
@media (max-width:980px){
  /* Keep the top bar readable + fixed. IMPORTANT: no backdrop-filter here —
     a filtered ancestor becomes the containing block for the position:fixed
     drawer, which would trap it inside the bar's height. */
  .nav, .nav.scrolled{background:color-mix(in srgb,var(--bg) 93%,transparent);backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:1px solid var(--line)}
  .brand{position:relative;z-index:3}
  .nav-links{
    position:fixed;top:0;right:0;bottom:0;width:min(86vw,350px);
    flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;
    background:color-mix(in srgb,var(--surface) 97%,transparent);backdrop-filter:blur(24px);
    border-left:1px solid var(--line);box-shadow:-30px 0 70px -20px #000;
    transform:translateX(105%);transition:transform .35s cubic-bezier(.2,.8,.2,1);
    padding:5.5rem 1.5rem 2rem;overflow-y:auto;font-size:1.12rem;z-index:1;
    overscroll-behavior:contain;
  }
  .nav-links.open{transform:none}
  .nav-links a{width:100%;padding:.95rem .5rem;border-bottom:1px solid var(--line);color:var(--text)}
  .nav-links a:hover{color:var(--secondary)}
  .nav-links .btn{margin-top:1rem;width:100%;justify-content:center;border-bottom:0}
  .nav-toggle{display:grid;place-items:center;width:2.6rem;height:2.6rem;font-size:1.5rem;z-index:3}
  .nav-backdrop{display:block;position:fixed;inset:0;z-index:50;background:rgba(2,1,8,.62);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s}
  .nav-backdrop.open{opacity:1;pointer-events:auto}
  body.menu-open{overflow:hidden}
}
/* portrait tablet / large phone */
@media (max-width:860px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-copy{order:2}.hero-visual{order:1}
  .hero-cta,.socials,.eyebrow{justify-content:center}
  .vision-grid{grid-template-columns:1fr}
}
/* phone */
@media (max-width:680px){
  .footer-main{grid-template-columns:1fr;gap:1.6rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .gallery{columns:2 150px}
}
@media (max-width:520px){
  .field-row{grid-template-columns:1fr}
  .track-meta{flex-wrap:wrap;gap:.6rem}
  .credit-badge{font-size:.62rem;letter-spacing:.1em;padding:.45rem .8rem}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;justify-content:center}
}
