/* ============================================================
   TRUE HEART TATTOO CO. — NEON TOKYO CYBERPUNK
   Palette: void black, electric cyan, hot magenta, acid yellow,
   deep purple, chrome. Orbitron × Share Tech Mono.
   ============================================================ */
:root {
  --void:       #050508;
  --void-soft:  #0D0D14;
  --void-mid:   #14141F;
  --panel:      #0A0A12;
  --panel-edge: #1E1E2E;

  --cyan:       #00F5FF;
  --cyan-dim:   #009AA3;
  --cyan-glow:  rgba(0, 245, 255, 0.18);
  --cyan-glow2: rgba(0, 245, 255, 0.06);

  --magenta:    #FF006E;
  --magenta-dim:#8C003C;
  --magenta-glow: rgba(255, 0, 110, 0.18);

  --yellow:     #FFE600;
  --yellow-dim: #B3A100;
  --yellow-glow: rgba(255, 230, 0, 0.15);

  --purple:     #6600CC;
  --purple-light:#9B5DE5;
  --chrome:     #C0C0D0;
  --chrome-dim: #6E6E88;

  --text-primary: #E8E8F0;
  --text-muted:   #7070A0;

  --font-display: 'Orbitron', sans-serif;
  --font-mono:    'Share Tech Mono', monospace;
  --font-body:    'Rajdhani', sans-serif;

  --ease: cubic-bezier(.22,1,.36,1);

  /* Neon glow system */
  --glow-cyan:    0 0 6px var(--cyan), 0 0 18px rgba(0,245,255,.4), 0 0 40px rgba(0,245,255,.15);
  --glow-magenta: 0 0 6px var(--magenta), 0 0 18px rgba(255,0,110,.4), 0 0 40px rgba(255,0,110,.15);
  --glow-yellow:  0 0 6px var(--yellow), 0 0 18px rgba(255,230,0,.4), 0 0 40px rgba(255,230,0,.15);

  /* Panel border system — chrome-edge tech panels */
  --border-cyan:    1px solid rgba(0,245,255,.35);
  --border-magenta: 1px solid rgba(255,0,110,.35);
  --border-chrome:  1px solid rgba(192,192,208,.15);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family: var(--font-body);
  background: var(--void);
  color: var(--text-primary);
  overflow-x: hidden;
  position: relative;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important;}
}

/* ---- Scanline overlay ---- */
body::before {
  content:'';
  position:fixed; inset:0; z-index:2; pointer-events:none;
  background: repeating-linear-gradient(
    to bottom,
    transparent,
    transparent 2px,
    rgba(0,0,0,.12) 2px,
    rgba(0,0,0,.12) 4px
  );
  mix-blend-mode: overlay;
}

/* ---- Static grain ---- */
.grain{
  position:fixed; inset:0; z-index:3; pointer-events:none;
  opacity:.04; mix-blend-mode:overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection{ background: var(--cyan); color: var(--void); }
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer; border:none;}
img{display:block; max-width:100%;}

::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--void);}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--cyan),var(--magenta)); border-radius:3px;}
:focus-visible{outline:2px solid var(--cyan); outline-offset:3px;}

/* ---- Circuit trace decorative corner ---- */
.panel-corner{
  position:relative;
}
.panel-corner::before,.panel-corner::after{
  content:''; position:absolute; width:16px; height:16px; pointer-events:none;
}
.panel-corner::before{
  top:0; left:0;
  border-top:2px solid var(--cyan);
  border-left:2px solid var(--cyan);
}
.panel-corner::after{
  bottom:0; right:0;
  border-bottom:2px solid var(--cyan);
  border-right:2px solid var(--cyan);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 5vw;
  transition:background .4s var(--ease), padding .4s var(--ease);
}
.nav.scrolled{
  background: rgba(5,5,8,.92);
  backdrop-filter:blur(16px);
  padding:12px 5vw;
  border-bottom: 1px solid rgba(0,245,255,.15);
  box-shadow: 0 0 30px rgba(0,245,255,.05);
}
.nav-logo{
  font-family: var(--font-display);
  font-size:clamp(1rem,2vw,1.4rem);
  letter-spacing:3px;
  color:var(--cyan);
  text-shadow: var(--glow-cyan);
  display:flex; align-items:center; gap:10px;
}
.logo-slash{
  display:inline-block;
  width:3px; height:22px;
  background:var(--magenta);
  box-shadow: var(--glow-magenta);
  border-radius:1px;
  margin:0 2px;
}
.nav-links{display:flex; gap:clamp(14px,2.5vw,32px); align-items:center;}
.nav-links a{
  font-family:var(--font-mono);
  font-size:.72rem; text-transform:uppercase; letter-spacing:2.5px;
  color:var(--chrome-dim);
  position:relative; padding:4px 0;
  transition:color .25s;
}
.nav-links a::before{
  content:'_'; position:absolute; right:-6px; opacity:0;
  color:var(--cyan); transition:opacity .2s;
}
.nav-links a:hover{color:var(--cyan); text-shadow:var(--glow-cyan);}
.nav-links a:hover::before{opacity:1;}
.nav-book-btn{
  background:transparent;
  color:var(--cyan);
  font-family:var(--font-mono);
  font-size:.7rem; text-transform:uppercase; letter-spacing:2px;
  padding:9px 24px;
  border:1px solid var(--cyan);
  box-shadow: 0 0 12px rgba(0,245,255,.2), inset 0 0 12px rgba(0,245,255,.05);
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  transition:all .25s;
  white-space:nowrap;
}
.nav-book-btn:hover{
  background:var(--cyan-glow);
  box-shadow:var(--glow-cyan);
  color:#fff;
}
.nav-toggle{display:none; background:none; font-size:1.6rem; color:var(--cyan);}

@media(max-width:860px){
  .nav-links{
    position:fixed; top:0; right:0; height:100vh; width:min(78vw,300px);
    background:rgba(5,5,8,.97); backdrop-filter:blur(20px);
    flex-direction:column; justify-content:center; gap:32px;
    transform:translateX(100%); transition:transform .45s var(--ease);
    border-left:var(--border-cyan);
  }
  .nav-links.open{transform:translateX(0);}
  .nav-toggle{display:block; z-index:101;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(102,0,204,.12) 0%, transparent 55%),
    radial-gradient(ellipse at 70% 40%, rgba(0,245,255,.07) 0%, transparent 50%),
    var(--void);
  padding:140px 5vw 80px;
}

/* Grid overlay */
.hero::after{
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(0,245,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,245,255,.04) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 20%, transparent 75%);
}

.hero-vignette{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(ellipse at 50% 40%, transparent 30%, rgba(5,5,8,.8) 100%);
}
.hero-layer{position:absolute; inset:0; will-change:transform; pointer-events:none;}
.hero-content{
  position:relative; z-index:5; text-align:center; max-width:900px;
}

/* Replace hero flash art with a glitch-styled frame */
.hero-flash-art{
  width:min(72vw,480px);
  margin:0 auto 24px;
  display:block;
  mix-blend-mode: screen;
  filter:
    drop-shadow(0 0 16px rgba(0,245,255,.6))
    drop-shadow(0 0 40px rgba(255,0,110,.25))
    brightness(1.1) contrast(1.05);
  animation: heroImgPulse 4s ease-in-out infinite;
}
@keyframes heroImgPulse{
  0%,100%{
    filter:drop-shadow(0 0 16px rgba(0,245,255,.6)) drop-shadow(0 0 40px rgba(255,0,110,.25)) brightness(1.1) contrast(1.05);
  }
  50%{
    filter:drop-shadow(0 0 28px rgba(0,245,255,.9)) drop-shadow(0 0 60px rgba(255,0,110,.4)) brightness(1.2) contrast(1.1);
  }
}

.hero-eyebrow{
  font-family:var(--font-mono);
  color:var(--cyan-dim);
  font-size:clamp(.7rem,1.2vw,.9rem);
  letter-spacing:5px; text-transform:uppercase;
  display:block; margin-bottom:16px;
}
.hero-eyebrow::before{content:'[ '; color:var(--magenta);}
.hero-eyebrow::after{content:' ]'; color:var(--magenta);}

.hero-title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,8vw,6rem);
  font-weight:900; line-height:1; letter-spacing:-1px;
  color:var(--text-primary);
  margin-bottom:20px;
  position:relative;
}
/* Glitch effect on the title */
.hero-title::before,.hero-title::after{
  content:attr(data-text);
  position:absolute; top:0; left:0; right:0;
  animation:glitch 6s infinite;
  clip-path:polygon(0 0,100% 0,100% 35%,0 35%);
}
.hero-title::before{
  color:var(--cyan); left:2px;
  animation:glitchA 6s infinite;
}
.hero-title::after{
  color:var(--magenta); left:-2px;
  clip-path:polygon(0 65%,100% 65%,100% 100%,0 100%);
  animation:glitchB 6s infinite;
}
@keyframes glitchA{
  0%,95%,100%{opacity:0;transform:translate(0);}
  96%{opacity:.8;transform:translate(-3px,1px);}
  97%{opacity:0;}
  98%{opacity:.6;transform:translate(3px,-1px);}
  99%{opacity:0;}
}
@keyframes glitchB{
  0%,94%,100%{opacity:0;transform:translate(0);}
  95%{opacity:.7;transform:translate(3px,2px);}
  96%{opacity:0;}
  97%{opacity:.5;transform:translate(-3px,-1px);}
  98%{opacity:0;}
}

.hero-sub{
  font-family:var(--font-mono);
  font-size:clamp(.8rem,1.4vw,1rem);
  color:var(--text-muted);
  max-width:560px; margin:0 auto 36px;
  line-height:1.7;
}

.hero-ctas{display:flex; gap:16px; justify-content:center; flex-wrap:wrap;}

.btn-primary{
  font-family:var(--font-mono);
  font-size:.78rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--void);
  background:var(--cyan);
  padding:14px 34px;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
  box-shadow:var(--glow-cyan);
  transition:all .25s;
  font-weight:700;
}
.btn-primary:hover{
  background:#fff;
  box-shadow:0 0 20px rgba(0,245,255,.8),0 0 60px rgba(0,245,255,.3);
  transform:translateY(-2px);
}
.btn-ghost{
  font-family:var(--font-mono);
  font-size:.78rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--magenta);
  padding:13px 34px;
  border:1px solid var(--magenta);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
  box-shadow:0 0 12px rgba(255,0,110,.15), inset 0 0 12px rgba(255,0,110,.05);
  transition:all .25s;
}
.btn-ghost:hover{
  background:rgba(255,0,110,.1);
  box-shadow:var(--glow-magenta);
  transform:translateY(-2px);
}

.scroll-cue{
  position:absolute; bottom:40px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:.62rem; letter-spacing:3px;
  color:var(--chrome-dim); text-transform:uppercase;
}
.pin{
  width:1px; height:50px;
  background:linear-gradient(to bottom, var(--cyan), transparent);
  animation:pinDrop 2s ease-in-out infinite;
  box-shadow:0 0 6px var(--cyan);
}
@keyframes pinDrop{0%{height:0;opacity:0;}50%{height:50px;opacity:1;}100%{height:50px;opacity:0;}}

/* ============================================================
   SECTION SHARED
   ============================================================ */
.section-pad{padding:100px 5vw;}

.section-head{text-align:center; margin-bottom:60px;}

.section-eyebrow{
  font-family:var(--font-mono);
  font-size:.7rem; letter-spacing:5px; text-transform:uppercase;
  color:var(--cyan);
  display:flex; align-items:center; justify-content:center; gap:12px;
  margin-bottom:16px;
}
.section-eyebrow::before,.section-eyebrow::after{
  content:''; width:40px; height:1px;
  background:linear-gradient(to right, transparent, var(--cyan));
}
.section-eyebrow::after{transform:rotate(180deg);}

.section-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,4vw,3.2rem);
  color:var(--text-primary);
  letter-spacing:1px; line-height:1.1;
  margin-bottom:16px;
}
.section-title span{color:var(--cyan); text-shadow:var(--glow-cyan);}

.section-desc{
  font-family:var(--font-mono);
  font-size:.85rem; color:var(--text-muted);
  max-width:520px; margin:0 auto; line-height:1.7;
}

/* Reveal animation */
.reveal{opacity:0; transform:translateY(30px); transition:opacity .7s var(--ease), transform .7s var(--ease);}
.reveal.in{opacity:1; transform:translateY(0);}

/* ============================================================
   ABOUT
   ============================================================ */
.about{background:var(--void-soft);}

.about-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center;
  max-width:1100px; margin:0 auto;
}
.about-visual{position:relative;}
.about-frame{
  position:relative;
  border:var(--border-cyan);
  box-shadow:0 0 30px rgba(0,245,255,.08), inset 0 0 30px rgba(0,245,255,.04);
}
.about-frame::before,.about-frame::after{
  content:''; position:absolute; width:20px; height:20px; pointer-events:none; z-index:2;
}
.about-frame::before{
  top:-2px; left:-2px;
  border-top:2px solid var(--cyan); border-left:2px solid var(--cyan);
  box-shadow: -1px -1px 8px var(--cyan);
}
.about-frame::after{
  bottom:-2px; right:-2px;
  border-bottom:2px solid var(--cyan); border-right:2px solid var(--cyan);
  box-shadow:1px 1px 8px var(--cyan);
}
.about-frame img{
  width:100%; display:block;
  filter:brightness(.85) contrast(1.1) saturate(0.6) hue-rotate(200deg);
}

/* Cyberpunk floating badges instead of SVG flowers */
.floating-badge{
  position:absolute;
  font-family:var(--font-mono);
  font-size:.6rem; letter-spacing:2px;
  padding:6px 12px;
  background:var(--void);
  border:1px solid var(--magenta);
  color:var(--magenta);
  box-shadow:var(--glow-magenta);
  animation:floatBadge 4s ease-in-out infinite;
}
.floating-badge:nth-child(2){
  top:-14px; left:-18px;
  animation-delay:0s;
}
.floating-badge:nth-child(3){
  bottom:-14px; right:-18px;
  border-color:var(--yellow); color:var(--yellow);
  box-shadow:var(--glow-yellow);
  animation-delay:2s;
}
@keyframes floatBadge{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}

.about-text p{
  font-size:1rem; line-height:1.8; color:var(--text-muted);
  margin-bottom:18px;
}
.about-text p b{ color:var(--cyan); font-weight:600; }

.about-stats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:36px;
}
.stat{
  text-align:center; padding:20px 12px;
  border:var(--border-chrome);
  background:var(--panel);
  position:relative;
}
.stat::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--cyan), transparent);
}
.stat-num{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,3vw,2.4rem);
  color:var(--cyan); text-shadow:var(--glow-cyan);
  line-height:1;
}
.stat-label{
  font-family:var(--font-mono);
  font-size:.6rem; text-transform:uppercase; letter-spacing:2px;
  color:var(--chrome-dim); margin-top:8px;
}

@media(max-width:768px){
  .about-grid{grid-template-columns:1fr; gap:40px;}
  .about-stats{grid-template-columns:repeat(3,1fr);}
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:var(--void);}

.gallery-filter{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
  margin-bottom:48px;
}
.filter-btn{
  font-family:var(--font-mono);
  font-size:.68rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--chrome-dim);
  padding:8px 20px;
  border:var(--border-chrome);
  background:transparent;
  transition:all .25s;
  clip-path:polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}
.filter-btn:hover,.filter-btn.active{
  color:var(--cyan); border-color:rgba(0,245,255,.5);
  background:var(--cyan-glow2);
  box-shadow:0 0 12px rgba(0,245,255,.15);
}

.flash-wall{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:2px;
  max-width:1200px; margin:0 auto;
}

.flash-card{
  perspective:800px; cursor:pointer;
  --ry:0deg; --rx:0deg;
  aspect-ratio:1;
}
.flash-card-inner{
  position:relative; width:100%; height:100%;
  transform-style:preserve-3d;
  transition:transform .6s var(--ease);
  transform:rotateX(var(--rx)) rotateY(var(--ry));
}
.flash-card:hover .flash-card-inner:not(.flipped .flash-card-inner){
  /* tilt handled by JS */
}
.flash-card.flipped .flash-card-inner{ transform:rotateY(180deg); }

.flash-face{
  position:absolute; inset:0; backface-visibility:hidden;
  overflow:hidden;
}
.flash-face-front img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s var(--ease), filter .4s;
  filter:brightness(.75) contrast(1.1) saturate(0.5) hue-rotate(200deg);
}
.flash-card:hover .flash-face-front img{
  transform:scale(1.05);
  filter:brightness(.9) contrast(1.1) saturate(0.7) hue-rotate(195deg);
}

/* Cyan line scan on hover */
.flash-face-front::after{
  content:''; position:absolute; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  top:-2px; box-shadow:var(--glow-cyan);
  opacity:0; transition:opacity .3s;
  animation:scanDown 1.5s linear infinite;
}
.flash-card:hover .flash-face-front::after{opacity:1;}
@keyframes scanDown{0%{top:-2px;}100%{top:101%;}}

.flash-tag{
  position:absolute; bottom:0; left:0; right:0;
  font-family:var(--font-mono); font-size:.65rem; letter-spacing:1.5px;
  color:var(--cyan);
  background:linear-gradient(to top, rgba(5,5,8,.9), transparent);
  padding:20px 12px 10px;
  text-transform:uppercase;
}

.flash-pin{
  position:absolute; top:10px; right:10px; width:8px; height:8px;
  background:var(--magenta); border-radius:50%;
  box-shadow:var(--glow-magenta);
  animation:pinBlink 3s ease-in-out infinite;
}
@keyframes pinBlink{0%,100%{opacity:1;}50%{opacity:.3;}}

.flash-face-back{
  transform:rotateY(180deg);
  background:var(--panel);
  border:var(--border-cyan);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; padding:24px;
  box-shadow:inset 0 0 40px rgba(0,245,255,.05);
}
.back-cap{
  font-family:var(--font-display);
  font-size:.85rem; color:var(--text-primary);
  text-align:center; letter-spacing:1px;
}
.back-cat{
  font-family:var(--font-mono);
  font-size:.65rem; color:var(--cyan); letter-spacing:3px; text-transform:uppercase;
}
.back-zoom{
  background:transparent; color:var(--magenta);
  border:1px solid var(--magenta); padding:8px 20px;
  font-family:var(--font-mono); font-size:.68rem; letter-spacing:2px; text-transform:uppercase;
  box-shadow:var(--glow-magenta);
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
  transition:all .25s;
}
.back-zoom:hover{background:rgba(255,0,110,.15); color:#fff;}
.back-hint{font-family:var(--font-mono); font-size:.58rem; color:var(--chrome-dim); letter-spacing:1px;}

.flash-empty{
  grid-column:1/-1; text-align:center;
  font-family:var(--font-mono); color:var(--chrome-dim);
  padding:60px; letter-spacing:2px;
}

/* ============================================================
   BOOKING
   ============================================================ */
.booking{background:var(--void-soft);}

.booking-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
  max-width:1100px; margin:0 auto;
}

.panel{
  background:var(--panel);
  border:var(--border-chrome);
  padding:32px;
  position:relative;
}
.panel::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
}

.cal-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:20px;
}
.cal-head h3{
  font-family:var(--font-display);
  font-size:1rem; color:var(--cyan); letter-spacing:2px;
  text-shadow:var(--glow-cyan);
}
.cal-nav{display:flex; gap:8px;}
.cal-nav button{
  background:transparent; color:var(--chrome-dim);
  border:var(--border-chrome); width:32px; height:32px;
  font-size:1.2rem; transition:all .2s;
}
.cal-nav button:hover{border-color:rgba(0,245,255,.4); color:var(--cyan);}

.cal-dow{
  display:grid; grid-template-columns:repeat(7,1fr);
  margin-bottom:8px;
}
.cal-dow span{
  font-family:var(--font-mono);
  font-size:.6rem; text-align:center; color:var(--chrome-dim);
  letter-spacing:1px; text-transform:uppercase; padding:6px 0;
}
.cal-grid{display:grid; grid-template-columns:repeat(7,1fr); gap:3px;}
.cal-day{
  font-family:var(--font-mono);
  font-size:.75rem; text-align:center;
  padding:8px 4px; border-radius:2px;
  aspect-ratio:1;
  display:flex; align-items:center; justify-content:center;
}
.cal-day.pad{opacity:0;}
.cal-day.full{color:var(--chrome-dim); opacity:.35;}
.cal-day.avail{
  color:var(--cyan); cursor:pointer;
  border:1px solid rgba(0,245,255,.2);
  transition:all .2s;
}
.cal-day.avail:hover{
  background:var(--cyan-glow); border-color:var(--cyan);
  box-shadow:0 0 8px rgba(0,245,255,.2);
}
.cal-day.today{border-color:rgba(0,245,255,.5) !important;}
.cal-day.selected{
  background:var(--cyan) !important;
  color:var(--void) !important; font-weight:700;
  box-shadow:var(--glow-cyan);
}
.cal-legend{
  display:flex; gap:20px; margin-top:14px;
  font-family:var(--font-mono); font-size:.6rem; color:var(--chrome-dim);
  letter-spacing:1px; text-transform:uppercase;
}
.dot{
  display:inline-block; width:8px; height:8px;
  border-radius:50%; margin-right:5px;
}
.dot.avail{background:var(--cyan); box-shadow:0 0 6px var(--cyan);}
.dot.selected{background:var(--cyan); box-shadow:0 0 10px var(--cyan);}

.slots{display:grid; grid-template-columns:repeat(2,1fr); gap:8px; margin-top:8px;}
.slot-btn{
  font-family:var(--font-mono);
  font-size:.72rem; letter-spacing:1.5px;
  padding:10px; background:transparent;
  border:var(--border-chrome); color:var(--chrome-dim);
  transition:all .2s;
}
.slot-btn:hover{border-color:rgba(0,245,255,.4); color:var(--cyan);}
.slot-btn.selected{
  background:rgba(0,245,255,.1); border-color:var(--cyan);
  color:var(--cyan); box-shadow:0 0 10px rgba(0,245,255,.15);
}

/* Form */
.selected-summary{
  display:none; padding:12px 16px; margin-bottom:20px;
  background:rgba(0,245,255,.05);
  border:var(--border-cyan);
  font-family:var(--font-mono); font-size:.78rem; color:var(--cyan);
}
.selected-summary.show{display:block;}
.selected-summary b{color:#fff;}

.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.form-group{margin-bottom:16px; display:flex; flex-direction:column; gap:6px;}
.form-group label{
  font-family:var(--font-mono);
  font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--chrome-dim);
}
.form-group input,
.form-group select,
.form-group textarea{
  background:var(--void);
  border:var(--border-chrome);
  color:var(--text-primary);
  padding:10px 14px;
  font-family:var(--font-mono); font-size:.85rem;
  transition:border-color .2s, box-shadow .2s;
  outline:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:rgba(0,245,255,.5);
  box-shadow:0 0 12px rgba(0,245,255,.1);
}
.form-group input::placeholder,
.form-group textarea::placeholder{ color:var(--chrome-dim); }
.form-group select{
  -webkit-appearance:none; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2300F5FF'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
}
.form-group select option{background:var(--void);}
.form-group textarea{resize:vertical; min-height:90px;}

.submit-btn{
  width:100%; padding:14px;
  background:var(--magenta); color:#fff;
  font-family:var(--font-mono); font-size:.78rem;
  letter-spacing:3px; text-transform:uppercase;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
  box-shadow:var(--glow-magenta);
  transition:all .25s;
}
.submit-btn:hover{
  background:#ff3388;
  box-shadow:0 0 20px rgba(255,0,110,.7),0 0 60px rgba(255,0,110,.2);
  transform:translateY(-1px);
}
.submit-btn:disabled{opacity:.5; cursor:not-allowed;}

.form-msg{
  font-family:var(--font-mono); font-size:.75rem;
  margin-top:12px; display:none; padding:10px;
  letter-spacing:1px;
}
.form-msg.show{display:block;}
.form-msg.error{color:var(--magenta); border:1px solid var(--magenta-dim); background:rgba(255,0,110,.05);}
.form-msg.success{color:var(--cyan); border:var(--border-cyan); background:rgba(0,245,255,.05);}

@media(max-width:768px){
  .booking-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
}

/* ============================================================
   STUDIO STRIP
   ============================================================ */
.studio-strip{
  position:relative; overflow:hidden;
  background:var(--void);
}
.studio-strip img{
  width:100%; max-height:480px; object-fit:cover; object-position:center 30%; display:block;
  filter:brightness(.6) contrast(1.15) saturate(0.4) hue-rotate(200deg);
}
.studio-strip-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(0,245,255,.08), transparent 30%, transparent 70%, rgba(255,0,110,.06));
  pointer-events:none;
}
.studio-strip-label{
  position:absolute; top:50%; left:5vw; transform:translateY(-50%);
  font-family:var(--font-display);
  font-size:clamp(1.2rem,3vw,2.4rem);
  color:var(--cyan); text-shadow:var(--glow-cyan);
  letter-spacing:4px;
  text-transform:uppercase;
}

/* ============================================================
   SOCIAL
   ============================================================ */
.social{
  background:var(--void-soft);
  padding:80px 5vw;
}
.social-inner{max-width:700px; margin:0 auto; text-align:center;}
.social-title{
  font-family:var(--font-display);
  font-size:clamp(1.2rem,2.5vw,1.8rem);
  color:var(--text-primary); letter-spacing:3px; margin-bottom:40px;
}
.social-links{
  display:flex; gap:24px; flex-wrap:wrap; justify-content:center;
}
.social-link{
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:.75rem; letter-spacing:2px;
  color:var(--chrome-dim); text-transform:uppercase;
  padding:12px 24px;
  border:var(--border-chrome);
  background:var(--panel);
  transition:all .25s;
}
.social-link svg{width:18px; height:18px; flex-shrink:0;}
.social-link:hover{
  color:var(--cyan); border-color:rgba(0,245,255,.4);
  box-shadow:0 0 14px rgba(0,245,255,.12);
}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  background:var(--void);
  border-top:1px solid rgba(0,245,255,.08);
  padding:40px 5vw;
  text-align:center;
}
.footer-logo{
  font-family:var(--font-display);
  font-size:clamp(.9rem,1.5vw,1.2rem);
  color:var(--cyan); letter-spacing:4px; margin-bottom:12px;
  text-shadow:var(--glow-cyan);
}
.footer-addr{
  font-family:var(--font-mono);
  font-size:.7rem; color:var(--chrome-dim); letter-spacing:1.5px;
  line-height:1.7;
}
.footer-admin{
  margin-top:12px;
  font-family:var(--font-mono); font-size:.65rem; color:var(--chrome-dim);
}
.footer-admin a{color:var(--magenta); border-bottom:1px solid var(--magenta-dim);}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(5,5,8,.96);
  display:none; align-items:center; justify-content:center;
  flex-direction:column; gap:16px;
  padding:40px;
}
.lightbox.open{display:flex;}
.lightbox-close{
  position:absolute; top:24px; right:24px;
  background:transparent; color:var(--cyan);
  font-size:1.6rem; border:var(--border-cyan);
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--glow-cyan);
  transition:all .2s;
}
.lightbox-close:hover{background:rgba(0,245,255,.1);}
.lightbox-img{
  max-width:90vw; max-height:80vh; object-fit:contain;
  border:var(--border-cyan); box-shadow:var(--glow-cyan);
  filter:brightness(.9) contrast(1.1) saturate(0.6) hue-rotate(200deg);
}
.lightbox-cap{
  font-family:var(--font-mono); font-size:.8rem;
  color:var(--chrome-dim); letter-spacing:2px;
}

/* ============================================================
   LOGIN MODAL
   ============================================================ */
.modal-overlay{
  position:fixed; inset:0; z-index:150;
  background:rgba(5,5,8,.9); backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center;
}
.modal-overlay.open{display:flex;}
.modal{
  background:var(--panel);
  border:var(--border-cyan);
  box-shadow:var(--glow-cyan);
  padding:40px; max-width:400px; width:90%;
  position:relative;
}
.modal::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
}
.modal h3{
  font-family:var(--font-display);
  font-size:1.2rem; color:var(--cyan); letter-spacing:2px; margin-bottom:8px;
}
.modal .sub{
  font-family:var(--font-mono); font-size:.75rem;
  color:var(--chrome-dim); margin-bottom:28px;
}
.modal-close{
  position:absolute; top:16px; right:16px;
  background:transparent; color:var(--chrome-dim);
  font-size:1rem; border:none; transition:color .2s;
}
.modal-close:hover{color:var(--cyan);}

/* ============================================================
   ADMIN VIEW
   ============================================================ */
.admin-view{
  display:none; padding:60px 5vw;
  background:var(--void); min-height:100vh;
}
.admin-view.show{display:block;}
.admin-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:32px; padding-bottom:24px;
  border-bottom:1px solid rgba(0,245,255,.12);
}
.admin-head h2{
  font-family:var(--font-display);
  font-size:1.4rem; color:var(--cyan); letter-spacing:2px;
}
.logout-btn{
  background:transparent; color:var(--magenta);
  border:1px solid var(--magenta); padding:8px 20px;
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:2px;
  transition:all .2s;
}
.logout-btn:hover{background:rgba(255,0,110,.1);}
.admin-tabs{display:flex; gap:4px; margin-bottom:32px;}
.admin-tab{
  background:transparent; color:var(--chrome-dim);
  border:var(--border-chrome); padding:10px 20px;
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:2px;
  text-transform:uppercase; transition:all .2s;
}
.admin-tab.active,.admin-tab:hover{
  border-color:rgba(0,245,255,.4); color:var(--cyan);
  background:rgba(0,245,255,.05);
}
.admin-pane{display:none;}
.admin-pane.show{display:block;}

/* Upload zone */
.upload-zone{
  border:2px dashed rgba(0,245,255,.25);
  padding:60px; text-align:center; cursor:pointer;
  background:var(--panel); transition:all .3s;
  position:relative;
}
.upload-zone:hover,.upload-zone.drag{
  border-color:var(--cyan); background:rgba(0,245,255,.04);
  box-shadow:0 0 20px rgba(0,245,255,.1);
}
.upload-icon{font-size:2.5rem; margin-bottom:16px; color:var(--cyan);}
.upload-zone h4{font-family:var(--font-display); font-size:1rem; color:var(--text-primary); margin-bottom:8px;}
.upload-zone p{font-family:var(--font-mono); font-size:.75rem; color:var(--chrome-dim);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}

/* Crop stage */
.crop-stage{display:none;}
.crop-stage.show{display:block;}
.crop-wrap{display:flex; justify-content:center; margin-top:24px;}
#cropCanvas{
  border:var(--border-cyan);
  box-shadow:var(--glow-cyan);
  max-width:100%; height:auto;
}
.crop-controls{max-width:500px; margin:20px auto 0; display:flex; flex-direction:column; gap:14px;}
.crop-controls .row{
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:.72rem; color:var(--chrome-dim); letter-spacing:1.5px;
}
.crop-controls input[type=range]{
  flex:1; accent-color:var(--cyan);
}
.crop-meta{display:grid; grid-template-columns:1fr auto; gap:10px;}
.crop-actions{display:flex; gap:12px;}
.crop-cancel,.crop-save{
  flex:1; padding:10px; font-family:var(--font-mono);
  font-size:.72rem; letter-spacing:2px; text-transform:uppercase; transition:all .2s;
}
.crop-cancel{background:transparent; color:var(--chrome-dim); border:var(--border-chrome);}
.crop-cancel:hover{color:var(--magenta); border-color:rgba(255,0,110,.4);}
.crop-save{background:var(--cyan); color:var(--void); border:none; font-weight:700;}
.crop-save:hover{background:#fff; box-shadow:var(--glow-cyan);}

.admin-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px;
}
.admin-card{
  position:relative; background:var(--panel);
  border:var(--border-chrome);
}
.admin-card img{width:100%;aspect-ratio:1;object-fit:cover;filter:saturate(.5) hue-rotate(200deg);}
.admin-card .cap{
  font-family:var(--font-mono); font-size:.62rem;
  padding:8px; color:var(--chrome-dim); letter-spacing:1px;
}
.admin-card .del{
  position:absolute; top:6px; right:6px;
  background:rgba(5,5,8,.8); color:var(--magenta);
  border:1px solid var(--magenta); width:24px; height:24px;
  font-size:.75rem; display:flex; align-items:center; justify-content:center;
  transition:all .2s;
}
.admin-card .del:hover{background:rgba(255,0,110,.2);}

/* Requests */
.req-list{display:flex; flex-direction:column; gap:12px;}
.req-card{
  background:var(--panel); border:var(--border-chrome);
  padding:20px; display:flex; align-items:flex-start;
  justify-content:space-between; gap:16px;
}
.req-card::before{
  content:''; display:block; width:3px; flex-shrink:0;
  background:var(--cyan); align-self:stretch;
  box-shadow:0 0 6px var(--cyan);
}
.req-info b{color:var(--text-primary);}
.req-info .meta{font-family:var(--font-mono);font-size:.68rem;color:var(--chrome-dim);margin-top:4px;letter-spacing:.5px;}
.req-info .note{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);margin-top:8px;font-style:italic;}
.req-status{
  font-family:var(--font-mono); font-size:.65rem; letter-spacing:1.5px; text-transform:uppercase;
  padding:8px 16px; white-space:nowrap;
  background:transparent; border:var(--border-chrome); color:var(--chrome-dim);
  transition:all .2s;
}
.req-status.new{border-color:rgba(0,245,255,.4);color:var(--cyan);}
.req-status.confirmed{border-color:rgba(255,230,0,.3);color:var(--yellow);}
.req-empty{
  font-family:var(--font-mono); color:var(--chrome-dim);
  text-align:center; padding:40px; letter-spacing:2px;
}

/* ============================================================
   TOAST
   ============================================================ */
.toast{
  position:fixed; bottom:30px; right:30px; z-index:500;
  background:var(--panel); border:var(--border-cyan);
  color:var(--cyan); box-shadow:var(--glow-cyan);
  font-family:var(--font-mono); font-size:.75rem; letter-spacing:2px;
  padding:14px 24px; opacity:0; transform:translateY(10px);
  transition:all .35s var(--ease); pointer-events:none;
}
.toast.show{opacity:1; transform:translateY(0);}

/* ============================================================
   NEON GRID SECTION DIVIDER
   ============================================================ */
.neon-divider{
  height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),var(--magenta),var(--cyan),transparent);
  box-shadow:0 0 10px rgba(0,245,255,.3);
  opacity:.4;
}
