/* ============ NEON BLOOM TOKYO — Static CSS ============ */
@import url("https://fonts.googleapis.com/css2?family=Orbitron:wght@500;600;700;900&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&family=Zen+Kaku+Gothic+New:wght@400;700&display=swap");

:root {
  --bg: #0b0a14;
  --fg: #f4f2fb;
  --card: #15132a;
  --muted: #b3b0c8;
  --muted-2: #7c7894;
  --border: rgba(120, 100, 200, 0.25);
  --neon-pink: #ff2a92;
  --neon-magenta: #ff1ec1;
  --neon-cyan: #5ef0ff;
  --neon-blue: #4080ff;
  --neon-purple: #a855ff;
  --grad-holo: linear-gradient(120deg, #ff2a92, #a855ff, #5ef0ff, #4080ff);
  --grad-night: radial-gradient(ellipse at top, #1a1330 0%, #08071a 70%);
  --shadow-neon-pink: 0 0 20px rgba(255, 42, 146, 0.6), 0 0 40px rgba(255, 42, 146, 0.3);
  --shadow-neon-cyan: 0 0 20px rgba(94, 240, 255, 0.6), 0 0 40px rgba(94, 240, 255, 0.3);
  --font-display: "Orbitron", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
  --font-sans: "Inter", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--bg); color: var(--fg); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
body {
  min-height: 100vh;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(255, 42, 146, 0.18), transparent),
    radial-gradient(ellipse 60% 40% at 80% 110%, rgba(94, 240, 255, 0.14), transparent),
    var(--grad-night);
  background-attachment: fixed;
  overflow-x: hidden;
}
::selection { background: var(--neon-pink); color: #0b0a14; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font-family: inherit; color: inherit; }
h1, h2, h3, h4 { font-family: var(--font-display); letter-spacing: -0.02em; line-height: 1; }

/* ============ Layout ============ */
.container { max-width: 1400px; margin: 0 auto; padding: 0 1.5rem; }
@media (min-width: 1024px) { .container { padding: 0 2.5rem; } }

/* ============ Navigation ============ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  transition: all .5s ease;
}
.nav.scrolled { background: rgba(11, 10, 20, 0.7); backdrop-filter: blur(18px); border-bottom: 1px solid var(--border); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.5rem; max-width: 1400px; margin: 0 auto; }
@media (min-width: 1024px) { .nav-inner { padding: 1rem 2.5rem; } }

.brand { display: flex; align-items: center; gap: .65rem; }
.brand-mark { position: relative; width: 28px; height: 28px; }
.brand-mark::before, .brand-mark::after {
  content: ""; position: absolute; inset: 0; transform: rotate(45deg);
}
.brand-mark::before { border: 1px solid var(--neon-pink); animation: pulse-glow 3s ease-in-out infinite; }
.brand-mark::after { inset: 4px; background: linear-gradient(135deg, var(--neon-pink), var(--neon-cyan)); opacity: .85; }
.brand-name { font-family: var(--font-display); font-size: .85rem; font-weight: 700; letter-spacing: .25em; }
.brand-sub { font-family: var(--font-mono); font-size: .55rem; letter-spacing: .4em; color: var(--neon-cyan); }

.nav-links { display: none; gap: .25rem; align-items: center; }
@media (min-width: 1024px) { .nav-links { display: flex; } }
.nav-links a {
  position: relative; padding: .5rem 1rem; font-family: var(--font-mono); font-size: .72rem;
  text-transform: uppercase; letter-spacing: .2em; color: var(--muted); transition: color .3s;
}
.nav-links a:hover, .nav-links a.active { color: var(--neon-cyan); }
.nav-links a::after {
  content: ""; position: absolute; left: 1rem; right: 1rem; bottom: 4px; height: 1px;
  background: var(--neon-cyan); transform: scaleX(0); transition: transform .3s;
}
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); }

.nav-actions { display: flex; align-items: center; gap: .75rem; }
.nav-icon-btn {
  width: 36px; height: 36px; display: none; align-items: center; justify-content: center;
  border: 1px solid var(--border); background: transparent; cursor: pointer; color: var(--muted); transition: all .2s;
}
@media (min-width: 768px) { .nav-icon-btn { display: inline-flex; } }
.nav-icon-btn:hover { color: var(--neon-cyan); border-color: var(--neon-cyan); }
.cart-btn {
  display: inline-flex; align-items: center; gap: .5rem; height: 36px; padding: 0 .75rem;
  border: 1px solid var(--neon-pink); background: rgba(255,42,146,.1); color: var(--neon-pink);
  font-family: var(--font-mono); font-size: .7rem; letter-spacing: .2em; text-transform: uppercase;
  cursor: pointer; transition: all .2s;
}
.cart-btn:hover { background: var(--neon-pink); color: #0b0a14; }

.menu-toggle { background: transparent; border: 0; color: var(--fg); cursor: pointer; display: inline-flex; }
@media (min-width: 1024px) { .menu-toggle { display: none; } }
.svg-icon { width: 18px; height: 18px; stroke: currentColor; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; }

.mobile-menu {
  display: none; border-top: 1px solid var(--border); background: rgba(11,10,20,.96);
  backdrop-filter: blur(18px); padding: 1rem 1.5rem 1.5rem;
}
.mobile-menu.open { display: block; }
.mobile-menu a {
  display: block; padding: 1rem 0; border-bottom: 1px solid rgba(120,100,200,.15);
  font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; letter-spacing: .04em;
}
.mobile-menu a.active { color: var(--neon-pink); }

/* ============ Buttons ============ */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .875rem 1.75rem; font-family: var(--font-display); font-weight: 600; font-size: .8rem;
  letter-spacing: .18em; text-transform: uppercase; cursor: pointer;
  background: linear-gradient(135deg, rgba(255,42,146,.15), rgba(168,85,255,.15));
  border: 1px solid var(--neon-pink); color: var(--fg);
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
  transition: all .3s cubic-bezier(.4,0,.2,1);
}
.btn:hover { background: linear-gradient(135deg, var(--neon-pink), var(--neon-magenta)); box-shadow: var(--shadow-neon-pink); color: #0b0a14; transform: translateY(-2px); }
.btn-cyan { border-color: var(--neon-cyan); background: linear-gradient(135deg, rgba(94,240,255,.12), transparent); }
.btn-cyan:hover { background: linear-gradient(135deg, var(--neon-cyan), var(--neon-blue)); box-shadow: var(--shadow-neon-cyan); }
.btn-ghost { background: transparent; border-color: rgba(255,255,255,.2); color: var(--fg); }
.btn-ghost:hover { background: rgba(255,255,255,.05); border-color: var(--neon-cyan); color: var(--neon-cyan); box-shadow: 0 0 20px rgba(94,240,255,.3); }

/* ============ Cards ============ */
.card {
  position: relative;
  background: linear-gradient(180deg, rgba(21,19,42,.85), rgba(11,10,20,.85));
  border: 1px solid var(--border); backdrop-filter: blur(8px);
  overflow: hidden; transition: all .4s cubic-bezier(.4,0,.2,1);
}
.card::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 30%, rgba(255,42,146,.1) 50%, transparent 70%);
  opacity: 0; transition: opacity .4s; pointer-events: none;
}
.card:hover { border-color: var(--neon-pink); box-shadow: 0 8px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(255,42,146,.15); transform: translateY(-4px); }
.card:hover::before { opacity: 1; }

.brackets { position: relative; }
.brackets::before, .brackets::after {
  content: ""; position: absolute; width: 14px; height: 14px; border: 1px solid var(--neon-cyan); pointer-events: none; z-index: 2;
}
.brackets::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.brackets::after { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }

.label-mono { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; color: var(--neon-cyan); }
.text-pink { color: var(--neon-pink); text-shadow: 0 0 12px rgba(255,42,146,.7); }
.text-cyan { color: var(--neon-cyan); text-shadow: 0 0 12px rgba(94,240,255,.7); }
.text-glow {
  background: var(--grad-holo); background-size: 200% 200%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: holo-shift 8s ease infinite;
}

.scanline { background-image: repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(255,255,255,.02) 3px, rgba(255,255,255,.02) 4px); }
.cyber-grid {
  background-image:
    linear-gradient(rgba(94,240,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(94,240,255,.07) 1px, transparent 1px);
  background-size: 50px 50px; animation: grid-drift 20s linear infinite;
}

/* ============ Hero ============ */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11,10,20,1), rgba(11,10,20,.6) 50%, rgba(11,10,20,.4));
}
.hero-bg::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(to right, rgba(11,10,20,.8), transparent, rgba(11,10,20,.5));
}
.hero-content { position: relative; z-index: 2; padding: 8rem 0 6rem; width: 100%; }
.hero-grid { display: grid; gap: 3rem; }
@media (min-width: 1024px) { .hero-grid { grid-template-columns: 8fr 4fr; align-items: end; } }

.eyebrow-row { display: flex; align-items: center; gap: .75rem; }
.eyebrow-row .line { display: inline-block; width: 40px; height: 1px; background: var(--neon-cyan); }
.jp-label { margin-top: .75rem; font-family: var(--font-mono); font-size: .85rem; letter-spacing: .4em; color: var(--neon-pink); }

.hero h1 {
  margin-top: 1.5rem; font-size: clamp(2.5rem, 8vw, 6.5rem); font-weight: 700;
  line-height: .9; letter-spacing: -0.025em;
}
.hero h1 span { display: block; }
.hero p.lead { margin-top: 2rem; max-width: 560px; color: var(--muted); font-size: 1.05rem; line-height: 1.6; }
.cta-row { margin-top: 2.5rem; display: flex; flex-wrap: wrap; gap: 1rem; }
.hero-meta { margin-top: 3rem; display: flex; flex-wrap: wrap; gap: .75rem 2rem; font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .2em; color: var(--muted); }
.hero-meta span { display: inline-flex; align-items: center; gap: .5rem; }
.dot-cyan { width: 6px; height: 6px; border-radius: 50%; background: var(--neon-cyan); box-shadow: 0 0 8px var(--neon-cyan); }
.dot-cyan.pulse { animation: pulse-dot 1.5s ease-in-out infinite; }

.status-card { display: none; padding: 1.5rem; border: 1px solid rgba(94,240,255,.4); background: linear-gradient(180deg, rgba(21,19,42,.85), rgba(11,10,20,.85)); position: relative; }
.status-card::before, .status-card::after { content: ""; position: absolute; width: 14px; height: 14px; border: 1px solid var(--neon-cyan); }
.status-card::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.status-card::after { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }
@media (min-width: 1024px) { .status-card { display: block; } }
.status-stats { margin-top: 1.5rem; display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; text-align: center; }
.stat-num { font-family: var(--font-display); font-size: 2rem; font-weight: 700; }
.stat-num.pink { color: var(--neon-pink); }
.stat-num.cyan { color: var(--neon-cyan); }
.stat-label { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .2em; color: var(--muted); }

.marquee {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 3;
  border-top: 1px solid var(--border); background: rgba(11,10,20,.6); backdrop-filter: blur(8px); overflow: hidden;
}
.marquee-track { display: flex; white-space: nowrap; padding: .75rem 0; font-family: var(--font-mono); font-size: .75rem; letter-spacing: .3em; color: var(--muted); animation: marquee 30s linear infinite; }
.marquee-set { display: flex; gap: 2rem; padding: 0 2rem; flex-shrink: 0; }
.marquee-set span { display: inline-flex; align-items: center; gap: .5rem; }
.marquee-set .dot { color: var(--neon-pink); }

/* ============ Sections ============ */
.section { position: relative; padding: 6rem 0; }
@media (min-width: 1024px) { .section { padding: 8rem 0; } }
.section-alt { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: rgba(11,10,20,.4); }
.section-head { display: flex; flex-wrap: wrap; align-items: end; justify-content: space-between; gap: 1.5rem; }
.section-head h2 { margin-top: 1rem; max-width: 720px; font-size: clamp(2rem, 5vw, 4rem); font-weight: 700; line-height: 1.05; }

.grid-cards { margin-top: 3rem; display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .grid-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .grid-cards { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px) { .grid-cards { grid-template-columns: repeat(4, 1fr); } }

/* Collection card */
.col-card .img-wrap { position: relative; aspect-ratio: 4 / 5; overflow: hidden; }
.col-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.col-card:hover .img-wrap img { transform: scale(1.1); }
.col-card .img-wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, var(--bg), rgba(11,10,20,.3) 60%, transparent); }
.tag-pill {
  position: absolute; left: .75rem; top: .75rem; z-index: 2;
  border: 1px solid var(--neon-cyan); background: rgba(11,10,20,.8); backdrop-filter: blur(4px);
  padding: 2px 8px; font-family: var(--font-mono); font-size: .6rem; text-transform: uppercase;
  letter-spacing: .2em; color: var(--neon-cyan);
}
.tag-pill.pink { border-color: var(--neon-pink); color: var(--neon-pink); }
.col-num { position: absolute; right: .75rem; top: .75rem; z-index: 2; font-family: var(--font-mono); font-size: .6rem; letter-spacing: .3em; color: rgba(94,240,255,.7); }
.col-card .body { padding: 1.25rem; }
.col-card h3 { margin-top: .25rem; font-size: 1.25rem; font-weight: 700; letter-spacing: .02em; }
.col-card .price-row { display: flex; align-items: start; justify-content: space-between; gap: .75rem; }
.price { text-align: right; }
.price .currency { font-family: var(--font-mono); font-size: .6rem; text-transform: uppercase; letter-spacing: .2em; color: var(--muted); }
.price .amount { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; }
.col-desc { margin-top: .75rem; font-size: .9rem; color: var(--muted); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.add-cart {
  margin-top: 1.25rem; width: 100%; padding: .75rem 1rem; display: flex; align-items: center; justify-content: space-between;
  background: rgba(21,19,42,.5); border: 1px solid var(--border); color: var(--fg); cursor: pointer;
  font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .2em;
  transition: all .2s;
}
.add-cart:hover { border-color: var(--neon-pink); background: rgba(255,42,146,.1); color: var(--neon-pink); }

/* Occasions */
.occasions-grid { margin-top: 3rem; display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .occasions-grid { grid-template-columns: repeat(3, 1fr); } }
.occ-card { position: relative; aspect-ratio: 3 / 4; overflow: hidden; }
.occ-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .7s; z-index: 0; }
.occ-card:hover img { transform: scale(1.1); }
.occ-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, var(--bg), rgba(11,10,20,.6) 40%, transparent); z-index: 1; }
.occ-card .inner { position: relative; z-index: 2; height: 100%; padding: 1.5rem; display: flex; flex-direction: column; justify-content: space-between; }
.occ-code { font-family: var(--font-mono); font-size: .65rem; letter-spacing: .3em; color: var(--neon-cyan); }
.occ-card h3 { margin-top: .5rem; font-size: 1.875rem; font-weight: 700; line-height: 1.05; }
.occ-link { margin-top: 1rem; display: inline-flex; align-items: center; gap: .5rem; font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .2em; color: var(--neon-pink); }

/* Delivery */
.delivery-grid { display: grid; gap: 3rem; }
@media (min-width: 1024px) { .delivery-grid { grid-template-columns: 1fr 1fr; align-items: center; } }
.cities-mini { margin-top: 2rem; display: grid; gap: .75rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 640px) { .cities-mini { grid-template-columns: repeat(3, 1fr); } }
.city-mini { display: flex; align-items: center; gap: .5rem; padding: .75rem 1rem; background: rgba(21,19,42,.5); border: 1px solid var(--border); }
.city-mini .label { font-family: var(--font-mono); font-size: .75rem; letter-spacing: .15em; }
.delivery-img { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.delivery-img img { width: 100%; height: 100%; object-fit: cover; }
.delivery-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top right, var(--bg), transparent); }
.tracker { position: absolute; inset: auto 0 0 0; padding: 1.25rem; border-top: 1px solid var(--border); background: rgba(11,10,20,.85); backdrop-filter: blur(6px); }
.tracker-row { display: flex; align-items: center; justify-content: space-between; font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .2em; }
.tracker-bar { margin-top: .75rem; height: 4px; background: var(--card); overflow: hidden; }
.tracker-fill { height: 100%; width: 68%; background: linear-gradient(90deg, var(--neon-pink), var(--neon-cyan)); }

/* Journal */
.journal-grid { margin-top: 3rem; display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .journal-grid { grid-template-columns: repeat(3, 1fr); } }
.journal-card { overflow: hidden; }
.journal-card .img-wrap { position: relative; aspect-ratio: 16/11; overflow: hidden; }
.journal-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.journal-card:hover .img-wrap img { transform: scale(1.05); }
.journal-card .img-wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(11,10,20,.8), transparent); }
.journal-card .body { padding: 1.25rem; }
.journal-meta { display: flex; align-items: center; gap: .75rem; font-family: var(--font-mono); font-size: .65rem; letter-spacing: .2em; color: var(--muted); }
.journal-card h3 { margin-top: .5rem; font-size: 1.25rem; line-height: 1.2; transition: color .3s; }
.journal-card:hover h3 { color: var(--neon-cyan); }
.journal-feature { grid-column: span 1 / span 1; }
@media (min-width: 768px) { .journal-feature { grid-column: span 2 / span 2; grid-row: span 2 / span 2; } .journal-feature .img-wrap { aspect-ratio: 16/10; } .journal-feature h3 { font-size: 2rem; } }

/* Testimonials */
.testimonials-grid { margin-top: 3rem; display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .testimonials-grid { grid-template-columns: repeat(3, 1fr); } }
.test-card { padding: 1.75rem; }
.test-stars { display: flex; gap: 4px; color: var(--neon-cyan); }
.test-stars svg { width: 14px; height: 14px; fill: currentColor; }
.test-text { margin-top: 1rem; font-size: .9rem; line-height: 1.6; }
.test-foot { margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--border); display: flex; align-items: center; gap: .75rem; }
.avatar { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--neon-pink), var(--neon-purple)); font-family: var(--font-display); font-weight: 700; color: #0b0a14; }
.test-name { font-family: var(--font-display); font-size: .9rem; font-weight: 700; }
.test-role { font-family: var(--font-mono); font-size: .65rem; letter-spacing: .2em; color: var(--muted); }

/* CTA */
.cta-block { position: relative; overflow: hidden; padding: 3rem 1.5rem; text-align: center; }
@media (min-width: 768px) { .cta-block { padding: 5rem 2rem; } }
.cta-block::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,42,146,.18), transparent, rgba(94,240,255,.18)); }
.cta-block > * { position: relative; }
.cta-block h2 { margin-top: 1rem; font-size: clamp(2rem, 5vw, 3.5rem); }
.cta-block .lead { margin: 1.5rem auto 0; max-width: 540px; color: var(--muted); }
.cta-block .cta-row { justify-content: center; margin-top: 2.5rem; }

/* ============ Footer ============ */
.footer { position: relative; margin-top: 8rem; border-top: 1px solid var(--border); }
.footer-grid { padding: 5rem 0 0; display: grid; gap: 3rem; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: 4fr 3fr 2fr 3fr; } }
.footer p { margin-top: 1.5rem; max-width: 380px; color: var(--muted); font-size: .9rem; line-height: 1.6; }
.socials { margin-top: 1.5rem; display: flex; gap: .75rem; }
.social { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--border); color: var(--muted); transition: all .2s; }
.social:hover { color: var(--neon-pink); border-color: var(--neon-pink); }
.foot-list { margin-top: 1rem; list-style: none; padding: 0; display: grid; gap: .5rem; font-size: .9rem; }
.foot-list.cols-2 { grid-template-columns: 1fr 1fr; }
.foot-list a { color: var(--muted); }
.foot-list a:hover { color: var(--fg); }
.foot-list .city span { color: var(--muted); }
.foot-list .city::before { content: "/"; color: var(--neon-pink); margin-right: .5rem; }
.subscribe { margin-top: 1rem; display: flex; }
.subscribe input { flex: 1; background: var(--card); border: 1px solid var(--border); padding: .65rem .75rem; font-family: var(--font-mono); font-size: .75rem; color: var(--fg); }
.subscribe input:focus { outline: none; border-color: var(--neon-pink); }
.subscribe button { border: 1px solid var(--neon-pink); border-left: 0; background: rgba(255,42,146,.1); color: var(--neon-pink); padding: 0 1rem; cursor: pointer; }
.subscribe button:hover { background: var(--neon-pink); color: #0b0a14; }
.foot-info { margin-top: 1.5rem; display: grid; gap: .5rem; font-size: .75rem; color: var(--muted); }
.foot-info span { display: inline-flex; align-items: center; gap: .5rem; }
.foot-info .ic { color: var(--neon-cyan); }
.foot-bottom { margin-top: 4rem; padding: 1.5rem 0; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: .75rem; font-family: var(--font-mono); font-size: .7rem; letter-spacing: .15em; color: var(--muted); }
@media (min-width: 768px) { .foot-bottom { flex-direction: row; align-items: center; justify-content: space-between; } }

/* ============ Page Hero ============ */
.page-hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--border); padding: 6rem 0 5rem; }
@media (min-width: 1024px) { .page-hero { padding: 8rem 0 6rem; } }
.page-hero h1 { margin-top: 1.5rem; max-width: 1000px; font-size: clamp(2.5rem, 6vw, 5rem); font-weight: 700; line-height: .95; letter-spacing: -.02em; }
.page-hero .lead { margin-top: 1.5rem; max-width: 640px; color: var(--muted); font-size: 1.05rem; line-height: 1.6; }

/* ============ Forms ============ */
.field label { font-family: var(--font-mono); font-size: .65rem; letter-spacing: .3em; color: var(--neon-cyan); }
.field input, .field textarea {
  margin-top: .5rem; width: 100%; background: rgba(11,10,20,.6); border: 1px solid var(--border);
  padding: .75rem; font-family: var(--font-mono); font-size: .8rem; color: var(--fg);
}
.field input:focus, .field textarea:focus { outline: none; border-color: var(--neon-pink); }
.contact-grid { display: grid; gap: 2.5rem; }
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 7fr 5fr; } }
.contact-form { padding: 2rem; display: grid; gap: 1.25rem; }
.field-row { display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .field-row { grid-template-columns: 1fr 1fr; } }

/* ============ Effects ============ */
.rain { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1; }
.drop { position: absolute; top: 0; width: 1px; background: linear-gradient(to bottom, transparent, var(--neon-cyan), transparent); animation: rain-fall linear infinite; }
.petals { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 2; }
.petal { position: absolute; top: 0; border-radius: 50%; filter: blur(1px); animation: float-petal linear infinite; }

/* ============ Animations ============ */
@keyframes pulse-glow { 0%,100%{box-shadow:0 0 12px rgba(255,42,146,.5);} 50%{box-shadow:0 0 24px rgba(255,42,146,.9), 0 0 36px rgba(94,240,255,.4);} }
@keyframes pulse-dot { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .5; transform: scale(1.3); } }
@keyframes rain-fall { 0%{transform:translateY(-120%);} 100%{transform:translateY(120vh);} }
@keyframes float-petal { 0%{transform:translate(0,-10vh) rotate(0);opacity:0;} 10%{opacity:.7;} 100%{transform:translate(40px,110vh) rotate(360deg);opacity:0;} }
@keyframes holo-shift { 0%,100%{background-position:0% 50%;} 50%{background-position:100% 50%;} }
@keyframes grid-drift { 0%{background-position:0 0;} 100%{background-position:50px 50px;} }
@keyframes marquee { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }
@keyframes fade-up { 0%{opacity:0;transform:translateY(30px);} 100%{opacity:1;transform:translateY(0);} }

[data-reveal] { opacity: 0; transform: translateY(30px); transition: opacity .8s ease, transform .8s ease; }
[data-reveal].visible { opacity: 1; transform: translateY(0); }
