/* assets/css/style.css */
@import url('vars.css');

:root {
  --soft-edge: 24px;
  --hero-anim-duration: 4200ms;
  --hero-overlap: clamp(72px, 10vh, 120px);
  --header-bleed: 12px;
  --hero-full-bg:
    radial-gradient(circle at 12% 28%, rgba(227,55,155,0.35), transparent 42%),
    radial-gradient(circle at 82% 18%, rgba(123,63,255,0.35), transparent 40%),
    linear-gradient(135deg, #1a062a 0%, #2a0b3c 40%, #0b061a 100%);
}

* { box-sizing: border-box; }
html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
html,body {
  height: 100%;
  margin:0;
  font-family: Inter, "Poppins", system-ui, -apple-system;
  background: radial-gradient(circle at 10% 10%, rgba(255,255,255,0.02), transparent 8%), var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
}
body {
  position:relative;
  overflow-x:hidden;
}
img { max-width: 100%; height: auto; display: block; }
video,
iframe { max-width: 100%; height: auto; }
a { color:var(--neon-1); text-decoration:none; }
button,
input,
select,
textarea { font: inherit; }
.container { max-width:1200px; margin:0 auto; padding:2rem; }
main.container { padding-top:0; }
main { position:relative; z-index:1; }

/* Header */
.header {
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:0;
  position:relative;
  z-index:2;
  isolation:isolate;
}
.header > * { position:relative; z-index:1; }
.header.container {
  padding:0.75rem 1.5rem;
}
.logo { font-weight:700; letter-spacing:0.6px; font-size:1.2rem; display:flex; align-items:center; gap:.5rem; }
.logo:focus-visible {
  outline:2px solid var(--neon-1);
  outline-offset:4px;
  border-radius:12px;
}
.logo .mark {
  width:clamp(200px, 18vw, 260px);
  height:clamp(52px, 6vw, 72px);
  border-radius:12px;
  background: center/contain no-repeat url("../img/ESBA LOGO.svg?v=20260314");
  background-size:900% auto;
  box-shadow:0 6px 24px rgba(0,0,0,0.35);
  display:inline-block;
  flex:0 0 auto;
}

/* Top nav */
nav ul { list-style:none; display:flex; gap:1rem; margin:0; padding:0; align-items:center; flex-wrap:wrap; }
nav a{
  padding:.5rem .75rem;
  border-radius:12px;
  font-weight:500;
  transition:background .2s ease, box-shadow .2s ease, color .2s ease, transform .2s ease;
}
nav a:hover{
  background:linear-gradient(90deg,var(--neon-1),var(--neon-2));
  color:#fff;
  box-shadow:0 10px 40px var(--glow);
  transform:translateY(-1px);
}

/* Mobile nav toggle */
.nav-toggle {
  display:none;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.08);
  background:var(--card-bg);
  color:var(--text);
  cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,0.35);
}
.nav-toggle span {
  width:18px;
  height:2px;
  background:var(--text);
  display:block;
  position:relative;
}
.nav-toggle span::before,
.nav-toggle span::after {
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background:var(--text);
}
.nav-toggle span::before { top:-6px; }
.nav-toggle span::after { top:6px; }

/* Theme toggle */
.theme-switch { display:flex; gap:.6rem; align-items:center; background:var(--card-bg); padding:.4rem; border-radius:999px; box-shadow:0 4px 30px var(--glow); }
.theme-switch button { background:transparent; border:0; color:var(--text); padding:.5rem; border-radius:12px; cursor:pointer; }
.theme-switch button.is-active {
  color:#fff;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.18);
}
.theme-switch button.is-active[data-set-theme="purple-tech"] {
  box-shadow:0 0 16px rgba(139,92,246,0.6), 0 0 32px rgba(155,89,255,0.45);
}
.theme-switch button.is-active[data-set-theme="dark-neon"] {
  box-shadow:0 0 16px rgba(0,229,255,0.6), 0 0 32px rgba(255,45,149,0.4);
}

/* Header actions */
.header-actions { display:flex; align-items:center; gap:.6rem; }
.nav-logout {
  background:transparent;
  border:1px solid rgba(255,255,255,0.18);
  color:var(--text);
  padding:.5rem .9rem;
  border-radius:14px;
  cursor:pointer;
}

/* Shared hero */
.hero,
.site-hero {
  display:flex;
  gap:2rem;
  align-items:center;
  padding:calc(2rem + var(--hero-overlap)) 2rem 2rem;
  margin:calc(-1 * var(--hero-overlap)) 0 1.25rem;
  position:relative;
  overflow:hidden;
  border-radius:calc(var(--soft-edge) + 6px);
  border:1px solid rgba(255,255,255,0.08);
  background:var(--hero-full-bg);
  background-size:140% 140%;
  background-position:12% 12%;
  box-shadow:0 24px 60px rgba(0,0,0,0.5);
  transition:transform .35s ease, box-shadow .35s ease, background-position .9s ease;
}
.hero::before,
.site-hero::before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, rgba(255,255,255,0.07), transparent 58%);
  pointer-events:none;
}
.hero::after,
.site-hero::after {
  content:"";
  position:absolute;
  inset:-35% -10%;
  background:radial-gradient(circle, rgba(255,255,255,0.14), transparent 55%);
  opacity:0;
  transform:translateY(8%) scale(.98);
  transition:opacity .4s ease, transform .7s ease;
  pointer-events:none;
}
.hero:hover,
.site-hero:hover {
  transform:translateY(-6px);
  box-shadow:0 30px 90px rgba(0,0,0,0.6), 0 18px 40px var(--glow);
  background-position:85% 10%;
}
.hero:hover::after,
.site-hero:hover::after {
  opacity:1;
  transform:translateY(-6%) scale(1.02);
}

/* Static hero (no hover/magnetic animation) */
.hero,
.site-hero {
  transition:none;
}
.hero:hover,
.site-hero:hover {
  transform:none;
  box-shadow:0 24px 60px rgba(0,0,0,0.5);
  background-position:12% 12%;
}
.hero:hover::after,
.site-hero:hover::after {
  opacity:0;
  transform:none;
}
.hero:hover .hero-art,
.site-hero:hover .site-hero-art {
  transform:none;
  box-shadow:0 20px 60px rgba(0,0,0,0.58), inset 0 1px 0 rgba(255,255,255,0.07);
}

/* Remove hero tech card + triangle grid */
.hero-art,
.site-hero-art,
.hero-tile-grid,
.site-hero-grid,
.site-hero-scan,
.site-hero-node,
.site-hero-link {
  display:none !important;
}

/* Hero liquid ripple + aurora shimmer */
.hero.glass-lens,
.site-hero.glass-lens {
  --glass-blur: 12px;
  --ripple-x: 50%;
  --ripple-y: 50%;
  position:relative;
  isolation:isolate;
}
.glass-lens > :is(.hero-left, .hero-art, .site-hero-content, .site-hero-art) {
  position:relative;
  z-index:3;
}
.glass-lens .hero-glass-pane {
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:
    radial-gradient(circle at 16% 12%, rgba(255,255,255,0.18), transparent 45%),
    linear-gradient(140deg, rgba(255,255,255,0.16), rgba(255,255,255,0.04) 60%);
  backdrop-filter: blur(var(--glass-blur)) saturate(1.2);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(1.2);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.5),
    inset 0 -1px 0 rgba(255,255,255,0.1);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
  z-index:0;
}
.glass-lens.is-hovered .hero-glass-pane {
  opacity:0.55;
}
.glass-lens .hero-aurora {
  position:absolute;
  inset:-28%;
  background:
    radial-gradient(circle at 18% 22%, rgba(80, 220, 255, 0.28), transparent 45%),
    radial-gradient(circle at 72% 28%, rgba(140, 120, 255, 0.28), transparent 50%),
    radial-gradient(circle at 50% 70%, rgba(255, 120, 200, 0.22), transparent 52%),
    linear-gradient(120deg, rgba(255,255,255,0.06), transparent 60%);
  opacity:0;
  filter: blur(14px);
  mix-blend-mode:screen;
  transform:translate3d(-6%, 2%, 0) scale(1.05);
  animation:hero-aurora-drift 16s ease-in-out infinite alternate;
  animation-play-state:paused;
  pointer-events:none;
  z-index:1;
}
.glass-lens .hero-ripple {
  position:absolute;
  left:var(--ripple-x);
  top:var(--ripple-y);
  width:180px;
  height:180px;
  border-radius:50%;
  background:
    radial-gradient(circle, rgba(255,255,255,0.45) 0 10%, rgba(255,255,255,0.18) 22%, transparent 55%);
  opacity:0;
  mix-blend-mode:screen;
  transform:translate(-50%, -50%) scale(0.2);
  animation:none;
  pointer-events:none;
  z-index:2;
}
.glass-lens .hero-ripple.ripple-b {
  width:260px;
  height:260px;
  opacity:0;
}
.glass-lens.is-hovered .hero-aurora {
  opacity:0.35;
  animation-play-state:running;
}
.glass-lens.is-rippling .hero-ripple {
  animation:hero-ripple 3.2s ease-out infinite;
  animation-delay:0s;
  animation-fill-mode:both;
}
.glass-lens.is-rippling .hero-ripple.ripple-b {
  animation-duration:3.8s;
  animation-delay:.6s;
}

@keyframes hero-aurora-drift {
  0% { transform:translate3d(-6%, 2%, 0) scale(1.05); }
  50% { transform:translate3d(4%, -2%, 0) scale(1.08); }
  100% { transform:translate3d(8%, 4%, 0) scale(1.04); }
}
@keyframes hero-ripple {
  0% { transform:translate(-50%, -50%) scale(0.2); opacity:0; }
  35% { opacity:0.55; }
  100% { transform:translate(-50%, -50%) scale(1.7); opacity:0; }
}

/* Full-bleed hero (home) */
.hero-full {
  --hero-overlap: clamp(56px, 8vh, 96px);
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  padding:clamp(3.25rem, 6vh, 4.5rem) max(6vw, 2.5rem);
  padding-top:calc(clamp(3.25rem, 6vh, 4.5rem) + var(--hero-overlap));
  min-height:calc(100vh - 120px);
  min-height:calc(100dvh - 120px);
  border-radius:0;
  border:0;
  box-shadow:none;
}
.hero-full::before {
  background:
    radial-gradient(circle at 88% 70%, rgba(255,255,255,0.08), transparent 48%),
    linear-gradient(120deg, rgba(255,255,255,0.05), transparent 62%);
}
.hero-full::after {
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  right:6%;
  bottom:10%;
  border-radius:50%;
  border:1px dashed rgba(255,255,255,0.18);
  opacity:.7;
  pointer-events:none;
}
.hero-full .hero-title {
  font-size:clamp(2.6rem, 4.2vw, 4.1rem);
}
.hero-full .hero-sub {
  font-size:1.05rem;
  max-width:52ch;
}
.hero-full .hero-art {
  height:320px;
  width:clamp(260px, 34vw, 440px);
  background:radial-gradient(circle at 30% 25%, rgba(255,255,255,0.16), transparent 55%);
}
.hero-left,
.site-hero-content {
  flex:1;
  min-width:260px;
  position:relative;
  z-index:1;
}
.site-hero-kicker {
  margin:0 0 .55rem;
  letter-spacing:.11em;
  text-transform:uppercase;
  font-size:.75rem;
  color:var(--muted);
}
.hero-title,
.site-hero-title {
  font-size:2.2rem;
  margin:0 0 .75rem;
  text-shadow:0 6px 28px var(--glow);
}
.hero-sub,
.site-hero-sub {
  color:var(--muted);
  margin-bottom:1rem;
  max-width:60ch;
}
.cta {
  display:inline-block;
  padding:.72rem 1.15rem;
  border-radius:16px;
  background:linear-gradient(90deg,var(--neon-1),var(--neon-2));
  color:#fff;
  box-shadow:0 10px 40px var(--glow);
  transform:translateZ(0);
}

button,
input[type="submit"],
.cta,
.btn,
.service-btn,
.nav-logout,
.nav-toggle,
.theme-switch button {
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
button:hover,
button:focus-visible,
input[type="submit"]:hover,
input[type="submit"]:focus-visible,
.cta:hover,
.cta:focus-visible,
.btn:hover,
.btn:focus-visible,
.service-btn:hover,
.service-btn:focus-visible,
.nav-logout:hover,
.nav-logout:focus-visible,
.nav-toggle:hover,
.nav-toggle:focus-visible,
.theme-switch button:hover,
.theme-switch button:focus-visible {
  box-shadow:0 10px 30px var(--glow), 0 0 24px rgba(255,255,255,0.25);
  transform:translateY(-2px);
}

/* Hero tech art */
.hero-art,
.site-hero-art {
  width:420px;
  min-width:300px;
  height:250px;
  border-radius:calc(var(--soft-edge) + 2px);
  background:linear-gradient(145deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
  box-shadow:0 20px 60px rgba(0,0,0,0.58), inset 0 1px 0 rgba(255,255,255,0.07);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.12);
  z-index:1;
  transition:transform .5s ease, box-shadow .5s ease;
}
.hero:hover .hero-art,
.site-hero:hover .site-hero-art {
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 18px 50px rgba(0,0,0,0.35);
}
.hero-art .float-shape {
  position:absolute;
  width:220px;
  height:220px;
  background:radial-gradient(circle, rgba(255,255,255,0.08), transparent 40%);
  transform:translate(20px,-40px) rotate(25deg);
  filter: blur(14px);
}
.hero,
.site-hero {
  --hero-tile: rgba(254, 206, 0, 0.78);
  --hero-tile-glow: rgba(254, 206, 0, 0.35);
}
.hero-tile-grid {
  position:absolute;
  inset:0;
  margin:auto;
  height:clamp(160px, 70%, 300px);
  aspect-ratio:9 / 7;
  display:grid;
  grid-template-columns:repeat(9, minmax(0, 1fr));
  grid-template-rows:repeat(7, minmax(0, 1fr));
  gap:clamp(6px, 1vw, 12px);
  opacity:0.85;
  pointer-events:none;
  z-index:1;
  filter:drop-shadow(0 18px 34px rgba(0,0,0,0.45));
}
.hero-tile {
  width:100%;
  height:100%;
  border-radius:0;
  clip-path:polygon(50% 0%, 0% 100%, 100% 100%);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.32), rgba(255,255,255,0.04)),
    var(--hero-tile);
  border:1px solid rgba(255,255,255,0.22);
  box-shadow:0 8px 20px rgba(0,0,0,0.28), 0 0 18px var(--hero-tile-glow);
  transform:rotate(0deg);
  transition:transform .18s ease, box-shadow .18s ease;
  will-change:transform;
}
@media (max-width:900px) {
  .hero-tile-grid {
    height:clamp(140px, 60%, 240px);
    opacity:0.65;
  }
}
.site-hero-grid,
.site-hero-scan,
.site-hero-node,
.site-hero-link {
  position:absolute;
}
.site-hero-grid {
  inset:-40%;
  background-image:
    linear-gradient(rgba(255,255,255,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size:34px 34px;
  opacity:.35;
  z-index:0;
}
.site-hero-scan {
  left:0;
  right:0;
  top:-40%;
  height:42%;
  background:linear-gradient(to bottom, rgba(0,0,0,0), rgba(0,229,255,0.28), rgba(0,0,0,0));
  opacity:0;
  z-index:2;
}
.site-hero-node {
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--neon-1);
  box-shadow:0 0 0 7px rgba(155,89,255,0.12), 0 0 16px rgba(155,89,255,0.85);
  opacity:.55;
  z-index:3;
}
.site-hero-node.node-a { top:18%; left:18%; }
.site-hero-node.node-b { top:62%; left:28%; }
.site-hero-node.node-c { top:34%; right:25%; }
.site-hero-node.node-d { bottom:18%; right:18%; }
.site-hero-link {
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, transparent, var(--neon-1), transparent);
  opacity:.22;
  z-index:2;
}
.site-hero-link.link-a { top:29%; left:21%; width:56%; transform:rotate(18deg); }
.site-hero-link.link-b { top:52%; left:20%; width:55%; transform:rotate(-18deg); }
.site-hero-link.link-c { top:66%; left:30%; width:42%; transform:rotate(10deg); }
.site-hero-auth {
  width:calc(100% - 4rem);
  max-width:1200px;
  margin:0 auto 1.25rem;
}

.site-hero.is-animating .site-hero-grid {
  animation:hero-grid-drift var(--hero-anim-duration) linear 1;
}
.site-hero.is-animating .site-hero-scan {
  animation:hero-scan var(--hero-anim-duration) ease-in-out 1;
}
.site-hero.is-animating .site-hero-node {
  animation:hero-node-pulse 1s ease-in-out 4;
}
.site-hero.is-animating .site-hero-link {
  animation:hero-link-glow 1.1s ease-in-out 4;
}

@keyframes hero-grid-drift {
  0% { transform:translate3d(0,0,0); }
  50% { transform:translate3d(-18px, 12px, 0); }
  100% { transform:translate3d(0,0,0); }
}
@keyframes hero-scan {
  0% { transform:translateY(-120%); opacity:0; }
  18% { opacity:.9; }
  85% { opacity:.85; }
  100% { transform:translateY(180%); opacity:0; }
}
@keyframes hero-node-pulse {
  0%,100% { transform:scale(1); opacity:.55; }
  50% { transform:scale(1.7); opacity:1; }
}
@keyframes hero-link-glow {
  0%,100% { opacity:.2; }
  50% { opacity:.95; }
}

/* Grid & cards */
.grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); gap:1.25rem; margin-top:1.5rem; }
.card { background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent); border-radius:var(--soft-edge); padding:1.15rem; box-shadow:0 8px 42px rgba(0,0,0,0.5); border:1px solid rgba(255,255,255,0.03); transition:transform .2s ease, box-shadow .2s ease; }
.card:hover { transform:translateY(-6px); box-shadow:0 18px 80px rgba(0,0,0,0.6), 0 10px 30px var(--glow); }
.card.has-media {
  display:flex;
  flex-direction:column;
  gap:.85rem;
}
.card-media {
  width:100%;
  aspect-ratio:16 / 9;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(145deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.07);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card-media img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.card.has-media:hover .card-media {
  box-shadow:0 14px 38px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.08);
  transform:translateY(-2px);
}

/* small neon accent line on cards */
.card .accent { height:6px; width:80px; border-radius:999px; background:linear-gradient(90deg,var(--neon-1),var(--neon-2)); margin-bottom:.65rem; box-shadow:0 6px 26px var(--glow); }
.card.has-media .accent { margin-bottom:.25rem; }

/* About page */
.about-mission { margin-top:1.5rem; }
.about-mission-grid {
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  align-items:center;
}
.card-media iframe {
  width:100%;
  height:100%;
  border:0;
}
.about-video-caption {
  margin:.6rem 0 0;
}
.values-list {
  list-style:none;
  margin:.35rem 0 0;
  padding:0;
  display:grid;
  gap:.55rem;
}
.values-list li {
  position:relative;
  padding-left:1.1rem;
  color:var(--muted);
  line-height:1.55;
}
.values-list li::before {
  content:"";
  position:absolute;
  left:0;
  top:.55rem;
  width:8px;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--neon-1),var(--neon-2));
  box-shadow:0 0 12px var(--glow);
}
.values-list strong { color:var(--text); }

/* Footer */
footer {
  padding:2rem 0;
  color:var(--muted);
  border-top:1px solid rgba(255,255,255,0.08);
  margin-top:2rem;
}
.footer-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.footer-links {
  display:flex;
  gap:.9rem;
  flex-wrap:wrap;
}
footer a {
  color:var(--muted);
  font-weight:600;
}
footer a:hover,
footer a:focus-visible {
  color:var(--text);
  text-decoration:underline;
}

/* Forms (public pages) */
.container form label { display:block; margin:.75rem 0 .35rem; color:var(--muted); font-weight:500; }
.container form input,
.container form textarea {
  width:100%;
  padding:.7rem .85rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(10,10,20,0.7);
  color:var(--text);
}
.container form textarea { min-height:140px; resize:vertical; }
.muted { color:var(--muted); }

/* Contact page */
.contact {
  display:grid;
  gap:1.5rem;
}
.contact-location {
  margin-top:.25rem;
}
.contact-main {
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(260px, 0.9fr);
  gap:1.5rem;
  align-items:start;
}
.contact-side {
  display:grid;
  gap:1.5rem;
}
.contact-form {
  padding:1.4rem;
  display:grid;
  gap:.85rem;
}
.contact-form label {
  margin:0;
}
.contact-form input,
.contact-form textarea {
  margin-top:.35rem;
}
.contact-form .cta {
  justify-self:flex-start;
}
.contact-location {
  text-align:center;
  width:100%;
}
.contact-location .map-wrap {
  margin-left:auto;
  margin-right:auto;
  max-width:none;
}

.contact-follow {
  padding:1.4rem;
  display:grid;
  gap:1rem;
}
.follow-head h2 {
  margin:0 0 .35rem;
}
.follow-head p {
  margin:0;
}
.follow-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1rem;
}
.follow-link {
  position:relative;
  display:flex;
  align-items:center;
  gap:.85rem;
  padding:.85rem 1rem;
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,20,0.5);
  color:var(--text);
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  overflow:hidden;
}
.follow-link::after {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 20% 20%, rgba(255,255,255,0.12), transparent 55%);
  opacity:0;
  transition:opacity .2s ease;
  pointer-events:none;
}
.follow-link:hover,
.follow-link:focus-visible {
  transform:translateY(-3px);
}
.follow-link:focus-visible {
  outline:2px solid var(--neon-1);
  outline-offset:3px;
}
.follow-link:hover::after,
.follow-link:focus-visible::after {
  opacity:1;
}
.follow-icon {
  width:48px;
  height:48px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.14);
  flex:0 0 auto;
  transition:box-shadow .2s ease, border-color .2s ease;
}
.follow-icon svg {
  width:24px;
  height:24px;
  fill:currentColor;
}
.follow-link:hover .follow-icon,
.follow-link:focus-visible .follow-icon {
  border-color:currentColor;
  box-shadow:0 0 18px currentColor;
}
.follow-text {
  display:flex;
  flex-direction:column;
  gap:.15rem;
}
.follow-name {
  font-weight:600;
}
.follow-handle {
  font-size:.88rem;
  color:var(--muted);
}

.follow-link.is-facebook { color:#9cc4ff; }
.follow-link.is-facebook:hover {
  border-color:rgba(24,119,242,0.6);
  box-shadow:0 12px 30px rgba(24,119,242,0.25), 0 0 18px rgba(24,119,242,0.55);
}
.follow-link.is-linkedin { color:#9ac7ff; }
.follow-link.is-linkedin:hover {
  border-color:rgba(10,102,194,0.6);
  box-shadow:0 12px 30px rgba(10,102,194,0.25), 0 0 18px rgba(10,102,194,0.55);
}
.follow-link.is-whatsapp { color:#9af5c0; }
.follow-link.is-whatsapp:hover {
  border-color:rgba(37,211,102,0.6);
  box-shadow:0 12px 30px rgba(37,211,102,0.25), 0 0 18px rgba(37,211,102,0.55);
}
.follow-link.is-youtube { color:#ffd2d2; }
.follow-link.is-youtube:hover {
  border-color:rgba(255,0,0,0.6);
  box-shadow:0 12px 30px rgba(255,0,0,0.25), 0 0 18px rgba(255,0,0,0.55);
}

/* Robotic cursor snake */
.cursor-snake {
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
  opacity:0;
  transition:opacity .2s ease;
}
.cursor-snake.is-active {
  opacity:1;
}
.cursor-snake-seg {
  position:absolute;
  border-radius:6px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.7), transparent 45%),
    linear-gradient(140deg, var(--snake-color-1), var(--snake-color-2));
  box-shadow:0 0 14px var(--snake-glow), 0 0 26px rgba(0,0,0,0.12);
  mix-blend-mode:screen;
  transform:translate3d(-999px, -999px, 0);
  will-change:transform;
  animation:snake-hue 6s linear infinite;
}

@keyframes snake-hue {
  0% { filter:hue-rotate(0deg) brightness(1.05); }
  50% { filter:hue-rotate(80deg) brightness(1.2); }
  100% { filter:hue-rotate(160deg) brightness(1.05); }
}

.hero-left,
.site-hero-content {
  position:relative;
  z-index:1;
}
.map-wrap {
  margin-top:.9rem;
  position:relative;
  width:100%;
  padding-top:56.25%;
  border-radius:calc(var(--soft-edge) - 4px);
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
}
.map-wrap iframe {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

/* Products search */
.product-search-wrap {
  margin-top:.75rem;
  margin-bottom:1rem;
  padding:1rem;
  border-radius:var(--soft-edge);
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
}
.product-controls {
  display:flex;
  gap:1.5rem;
  align-items:flex-end;
  flex-wrap:wrap;
}
.product-search {
  flex:1;
  min-width:240px;
}
.product-search-label {
  display:block;
  margin-bottom:.45rem;
  color:var(--muted);
  font-weight:600;
}
.product-search-input {
  width:100%;
  padding:.72rem .9rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,20,0.78);
  color:var(--text);
  outline:none;
}
.product-search-input:focus {
  border-color:var(--neon-1);
  box-shadow:0 0 0 3px rgba(155,89,255,0.12);
}
.product-search-count {
  margin:.55rem 0 0;
  color:var(--muted);
  font-size:.95rem;
}
.product-filters {
  min-width:200px;
}
.product-filter-select {
  width:100%;
  padding:.72rem .9rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,20,0.78);
  color:var(--text);
  outline:none;
}
.product-filter-select:focus {
  border-color:var(--neon-1);
  box-shadow:0 0 0 3px rgba(155,89,255,0.12);
}

/* Trending app + product cards */
.trending-block {
  margin-top:1.1rem;
  padding:1.1rem;
  border-radius:calc(var(--soft-edge) - 6px);
  border:1px solid rgba(255,255,255,0.1);
  background:linear-gradient(150deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
  display:grid;
  gap:1rem;
}
.trending-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.trending-kicker {
  margin:0 0 .35rem;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.trending-title {
  margin:0 0 .35rem;
  font-size:1.35rem;
}
.trending-sub {
  margin:0;
  color:var(--muted);
  max-width:60ch;
}
.trending-badge {
  padding:.35rem .75rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.2);
  background:rgba(255,255,255,0.06);
  font-weight:600;
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--neon-1);
}
.trending-card-slot {
  display:grid;
}
.app-card {
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.app-card[data-details] {
  cursor:pointer;
}
.app-card:focus-visible {
  outline:2px solid var(--neon-1);
  outline-offset:4px;
}
.app-card-main {
  display:flex;
  gap:1rem;
  align-items:flex-start;
}
.app-icon {
  width:64px;
  height:64px;
  border-radius:18px;
  overflow:hidden;
  background:linear-gradient(140deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
  border:1px solid rgba(255,255,255,0.14);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.2);
  flex:0 0 auto;
}
.app-icon img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.app-card-kicker {
  margin:0 0 .3rem;
  font-size:.7rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}
.app-card-title {
  margin:0 0 .35rem;
  font-size:1.2rem;
}
.app-card-tags {
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
  margin-top:.6rem;
}
.app-chip {
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.2rem .55rem;
  border-radius:999px;
  font-size:.72rem;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.04);
  color:var(--text);
}
.app-card-actions {
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  align-items:center;
}
.app-card-link {
  font-weight:600;
  color:var(--neon-1);
}
.app-card-topline {
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  margin-bottom:.35rem;
}
.app-status {
  padding:.2rem .55rem;
  border-radius:999px;
  font-size:.7rem;
  border:1px solid rgba(255,255,255,0.2);
  background:rgba(255,255,255,0.06);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.app-status.is-hot {
  color:#fff;
  border-color:rgba(255,255,255,0.3);
  background:linear-gradient(120deg, rgba(255,89,196,0.8), rgba(121,78,255,0.8));
  box-shadow:0 10px 26px rgba(121,78,255,0.25);
}
.app-card.is-trending {
  border:1px solid rgba(255,255,255,0.14);
  background:linear-gradient(140deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
}
.app-card.is-trending .app-icon {
  width:72px;
  height:72px;
  border-radius:20px;
}
.app-card.is-trending .app-card-title {
  font-size:1.35rem;
}
.app-card.is-grid .app-icon {
  width:56px;
  height:56px;
  border-radius:16px;
}
.app-card.is-compact .app-card-main {
  align-items:center;
}
.app-card.is-empty {
  align-items:center;
  text-align:center;
}

/* Product gallery + related apps */
.product-gallery-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.8rem;
}
.product-gallery-title {
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.product-gallery-hint {
  font-size:.85rem;
  color:var(--muted);
}
.related-apps {
  padding:1.4rem;
  display:grid;
  gap:1rem;
}
.related-apps-head h3 {
  margin:0;
}
.related-apps-head p {
  margin:.35rem 0 0;
}
.related-apps-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1rem;
}
.related-empty {
  padding:1.1rem;
  border-radius:16px;
  border:1px dashed rgba(255,255,255,0.12);
  color:var(--muted);
  text-align:center;
}

/* Product detail */
.product-detail {
  display:grid;
  gap:1.5rem;
}
.product-detail-hero {
  padding:1.4rem;
}
.product-detail-grid {
  display:grid;
  grid-template-columns:minmax(260px, 1fr) minmax(0, 1.1fr);
  gap:1.5rem;
  align-items:start;
}
.product-media {
  display:grid;
  gap:.75rem;
}
.product-cover {
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  aspect-ratio:16 / 10;
  display:flex;
  align-items:center;
  justify-content:center;
}
.product-cover img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:none;
}
.product-cover-placeholder {
  color:var(--muted);
  font-weight:600;
  padding:1rem;
  text-align:center;
}
.product-gallery {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(90px, 1fr));
  gap:.6rem;
}
.product-thumb {
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  overflow:hidden;
  padding:0;
  background:rgba(10,10,20,0.55);
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.product-thumb img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  aspect-ratio:1 / 1;
}
.product-thumb:hover {
  transform:translateY(-2px);
  border-color:var(--neon-1);
  box-shadow:0 10px 26px var(--glow);
}
.product-thumb.is-active {
  border-color:var(--neon-1);
  box-shadow:0 0 0 2px rgba(155,89,255,0.2);
}
.product-info h1,
.product-info h2 {
  margin-top:.1rem;
}
.product-price {
  font-weight:600;
  margin:.4rem 0 0;
}
.product-actions {
  margin-top:1rem;
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
}
.product-comments {
  padding:1.4rem;
}

/* Blog page */
.blog-main {
  display:flex;
  flex-direction:column;
  gap:1.4rem;
}
.blog-hero {
  margin-top:.25rem;
}
.blog-hero .site-hero-content {
  max-width:60ch;
}
.blog-hero-actions {
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  margin-top:1rem;
}
.blog-secondary-btn {
  display:inline-block;
  padding:.68rem 1.05rem;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.2);
  color:var(--text);
  background:rgba(255,255,255,0.02);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.blog-secondary-btn:hover {
  transform:translateY(-1px);
  border-color:var(--neon-1);
  box-shadow:0 10px 32px var(--glow);
}
.blog-hero-note {
  margin-top:.75rem;
  max-width:52ch;
}
.blog-controls {
  padding:1.25rem;
  border-radius:calc(var(--soft-edge) + 4px);
}
.blog-controls-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  flex-wrap:wrap;
}
.blog-controls-actions {
  display:flex;
  gap:1rem;
  align-items:flex-end;
  flex-wrap:wrap;
}
.blog-search {
  min-width:240px;
  flex:1;
  max-width:360px;
}
.blog-search label {
  display:block;
  margin-bottom:.35rem;
  color:var(--muted);
  font-weight:600;
}
.blog-search input {
  width:100%;
  padding:.7rem .9rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,20,0.72);
  color:var(--text);
  outline:none;
}
.blog-search input:focus {
  border-color:var(--neon-1);
  box-shadow:0 0 0 3px rgba(155,89,255,0.12);
}
.blog-count {
  margin:.45rem 0 0;
}
.blog-filters {
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
}
.blog-filter label {
  display:block;
  margin-bottom:.35rem;
  color:var(--muted);
  font-weight:600;
}
.blog-filter select {
  min-width:160px;
  padding:.65rem .8rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,20,0.72);
  color:var(--text);
}
.blog-filter select:focus {
  border-color:var(--neon-1);
  box-shadow:0 0 0 3px rgba(155,89,255,0.12);
}
.blog-featured-wrap {
  padding:0 .15rem;
}
.blog-featured-wrap h2 {
  margin:.1rem 0 .6rem;
}
.blog-featured {
  display:grid;
  gap:1rem;
}
.blog-featured-card {
  display:grid;
  grid-template-columns:minmax(240px, 1fr) minmax(0, 1.25fr);
  gap:1.2rem;
  padding:1.35rem;
  border-radius:calc(var(--soft-edge) + 6px);
}
.blog-featured-media {
  aspect-ratio:16 / 10;
  width:100%;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(255,255,255,0.09), rgba(255,255,255,0.01));
}
.blog-featured-body h3 {
  margin:.1rem 0 .45rem;
  font-size:1.5rem;
}
.blog-featured-actions {
  display:flex;
  align-items:center;
  gap:.8rem;
  flex-wrap:wrap;
  margin-top:.9rem;
}
.blog-kicker {
  margin:0 0 .35rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-size:.7rem;
  color:var(--muted);
}
.blog-tag-row {
  display:flex;
  align-items:center;
  gap:.6rem;
  flex-wrap:wrap;
}
.blog-tag {
  display:inline-flex;
  align-items:center;
  padding:.2rem .6rem;
  border-radius:999px;
  font-size:.72rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
}
.blog-tag-secondary {
  background:rgba(255,255,255,0.02);
  border-style:dashed;
}
.blog-read-time {
  color:var(--muted);
  font-size:.9rem;
}
.blog-actions {
  margin-top:1rem;
}
.blog-btn {
  display:inline-block;
  padding:.68rem 1.1rem;
  border-radius:16px;
  background:linear-gradient(90deg,var(--neon-1),var(--neon-2));
  color:#fff;
  box-shadow:0 10px 40px var(--glow);
  border:0;
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease;
}
.blog-btn:hover {
  transform:translateY(-1px);
  box-shadow:0 14px 44px var(--glow);
}
.blog-btn.secondary {
  background:rgba(255,255,255,0.08);
  color:var(--text);
  border:1px solid rgba(255,255,255,0.15);
  box-shadow:none;
}
.blog-btn.secondary:hover {
  box-shadow:0 10px 28px rgba(0,0,0,0.25);
}
.blog-feed-wrap {
  margin-top:0;
  padding:1.1rem;
  border-radius:calc(var(--soft-edge) + 4px);
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
}
.blog-feed-wrap h2 {
  margin:.15rem 0 .2rem;
}
.blog-feed {
  display:grid;
  grid-template-columns:repeat(2, minmax(320px, 1fr));
  gap:1.15rem;
  margin-top:.8rem;
  align-items:stretch;
}
.blog-pagination {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.75rem;
  margin-top:1.2rem;
}
.blog-page-btn {
  padding:.55rem .95rem;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.05);
  color:var(--text);
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.blog-page-btn:hover {
  transform:translateY(-1px);
  border-color:var(--neon-1);
  box-shadow:0 10px 30px var(--glow);
}
.blog-page-btn:disabled {
  opacity:.45;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}
.blog-page-info {
  font-weight:600;
}
.blog-post {
  border-radius:calc(var(--soft-edge) + 2px);
  overflow:hidden;
  padding:0;
  border:1px solid rgba(255,255,255,0.07);
  background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
  display:flex;
  flex-direction:column;
  height:100%;
}
.blog-card-clickable {
  cursor:pointer;
}
.blog-card-clickable:focus-visible {
  outline:2px solid var(--neon-1);
  outline-offset:4px;
}
.blog-post-media-wrap {
  aspect-ratio:16 / 10;
  width:100%;
  background:linear-gradient(180deg, rgba(255,255,255,0.09), rgba(255,255,255,0.01));
}
.blog-media {
  width:100%;
  height:100%;
  object-fit:cover;
  border:0;
  margin:0;
}
.blog-media-placeholder {
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  letter-spacing:.3px;
  font-weight:600;
}
.blog-post-body {
  padding:1rem 1rem .75rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
  flex:1;
}
.blog-post h3 {
  margin:.05rem 0 .4rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.blog-meta {
  font-size:.9rem;
  margin:0 0 .6rem;
  color:var(--muted);
}
.blog-excerpt {
  margin:.15rem 0 0;
  line-height:1.55;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.blog-post-actions {
  display:flex;
  align-items:center;
  gap:.6rem;
  margin-top:auto;
  flex-wrap:wrap;
  padding-top:.7rem;
}
.blog-card-link {
  font-weight:600;
  color:var(--neon-1);
}
.blog-read-more {
  margin-top:.55rem;
}
.blog-read-more summary {
  cursor:pointer;
  color:var(--neon-1);
  font-weight:600;
}
.blog-read-more p {
  margin:.45rem 0 0;
  color:var(--muted);
  line-height:1.55;
}
.blog-full-content {
  margin:.5rem 0 0;
  color:var(--muted);
  line-height:1.6;
}
.blog-full-content p {
  margin:0 0 .8rem;
}
.blog-full-content h2,
.blog-full-content h3 {
  margin:.5rem 0 .65rem;
  color:var(--text);
}
.blog-full-content ul,
.blog-full-content ol {
  margin:.3rem 0 .8rem 1.15rem;
}
.blog-full-content blockquote {
  margin:.3rem 0 .8rem;
  padding-left:.75rem;
  border-left:3px solid var(--neon-1);
}
.blog-video-link {
  margin:.6rem 0 0;
}
.blog-video-link a {
  font-weight:600;
}
.blog-comments {
  margin:0 1rem 1rem;
  padding:.85rem;
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
}
.blog-comments h4 {
  margin:.1rem 0 .65rem;
}
.comment-form textarea {
  width:100%;
  min-height:90px;
  margin:0 0 .5rem;
}
.comment-list {
  display:grid;
  gap:.65rem;
  margin-top:.75rem;
}
.comment-item {
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.06);
  padding:.7rem .8rem;
  background:rgba(255,255,255,0.03);
}
.comment-item small {
  margin-left:.5rem;
  color:var(--muted);
}
.comment-item p {
  margin:.35rem 0 0;
}
.blog-form input,
.blog-form textarea,
.comment-form textarea {
  border-radius:14px;
}
.blog-detail-main {
  display:grid;
  gap:1.2rem;
}
.blog-detail-hero .site-hero-title {
  font-size:2rem;
}
.blog-detail-hero .site-hero-sub {
  max-width:70ch;
}
.blog-detail-main > * {
  width:100%;
}
.blog-detail-card {
  max-width:920px;
  margin:0 auto;
}
.blog-detail-hero,
.blog-back-link {
  max-width:1100px;
  margin-left:auto;
  margin-right:auto;
}
.blog-back-link {
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  color:var(--neon-1);
  font-weight:600;
}
.blog-detail-card {
  border-radius:calc(var(--soft-edge) + 6px);
  padding:1.5rem;
}
.blog-detail-header {
  margin-bottom:1rem;
}
.blog-detail-title {
  margin:.2rem 0 .6rem;
  font-size:2rem;
}
.blog-detail-meta {
  color:var(--muted);
  margin:0;
}
.blog-detail-media {
  margin:1rem 0;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(255,255,255,0.09), rgba(255,255,255,0.01));
  height:clamp(220px, 38vw, 420px);
}
.blog-detail-media-img,
.blog-detail-media-video {
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.blog-detail-media-placeholder {
  padding:2.5rem 1rem;
  text-align:center;
  color:var(--muted);
  font-weight:600;
}
.blog-detail-content {
  line-height:1.7;
}
.blog-detail-content img {
  max-width:100%;
  height:auto;
  display:block;
  margin:1rem 0;
}
.blog-detail-content p {
  margin:0 0 1rem;
}
.blog-detail-content h2,
.blog-detail-content h3 {
  margin:.5rem 0 .75rem;
}
.blog-detail-content ul,
.blog-detail-content ol {
  margin:.3rem 0 .9rem 1.2rem;
}
.blog-detail-content blockquote {
  margin:.4rem 0 1rem;
  padding-left:.8rem;
  border-left:3px solid var(--neon-1);
  color:var(--muted);
}
.blog-detail-tags {
  margin-bottom:1rem;
}
.blog-detail-card .blog-comments {
  margin:1.25rem 0 0;
}
.blog-editor-main {
  display:grid;
  gap:1rem;
}
.blog-editor-card {
  border-radius:calc(var(--soft-edge) + 6px);
}
.blog-editor-head {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.blog-editor-head h1 {
  margin:.1rem 0 .35rem;
}
.blog-editor-form {
  margin-top:.85rem;
}
.editor-shell {
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.1);
  background:rgba(10,10,20,0.45);
  overflow:hidden;
}
.image-crop-modal {
  position:fixed;
  inset:0;
  background:rgba(5,6,10,0.78);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
  z-index:999;
}
.image-crop-modal[hidden] {
  display:none;
}
.image-crop-card {
  width:min(920px, 96vw);
  max-height:92vh;
  display:flex;
  flex-direction:column;
  gap:1rem;
  padding:1rem;
  border-radius:20px;
  background:linear-gradient(160deg, rgba(16,16,24,0.96), rgba(10,10,18,0.95));
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:0 24px 80px rgba(0,0,0,0.55);
}
.image-crop-head {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
}
.image-crop-head h3 {
  margin:0;
}
.image-crop-close {
  background:transparent;
  border:1px solid rgba(255,255,255,0.15);
  color:var(--text);
  padding:.45rem .8rem;
  border-radius:12px;
  cursor:pointer;
}
.image-crop-stage {
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:.8rem;
  border-radius:16px;
  background:rgba(0,0,0,0.35);
  overflow:auto;
}
.image-crop-media {
  position:relative;
  display:inline-block;
}
.image-crop-media img {
  max-width:100%;
  max-height:60vh;
  display:block;
  user-select:none;
}
.image-crop-rect {
  position:absolute;
  border:2px solid var(--neon-1);
  box-shadow:0 0 0 9999px rgba(0,0,0,0.35);
  cursor:move;
  touch-action:none;
}
.image-crop-handle {
  position:absolute;
  width:14px;
  height:14px;
  background:var(--neon-1);
  border-radius:999px;
  box-shadow:0 0 0 4px rgba(155,89,255,0.2);
}
.image-crop-handle[data-handle="nw"] { top:-7px; left:-7px; cursor:nwse-resize; }
.image-crop-handle[data-handle="ne"] { top:-7px; right:-7px; cursor:nesw-resize; }
.image-crop-handle[data-handle="sw"] { bottom:-7px; left:-7px; cursor:nesw-resize; }
.image-crop-handle[data-handle="se"] { bottom:-7px; right:-7px; cursor:nwse-resize; }
.image-crop-controls {
  display:flex;
  align-items:center;
  gap:.8rem;
  flex-wrap:wrap;
}
.image-crop-controls label {
  color:var(--muted);
  font-weight:600;
}
.image-crop-controls select {
  padding:.45rem .7rem;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.15);
  background:rgba(10,10,20,0.7);
  color:var(--text);
}
.image-crop-actions {
  display:flex;
  justify-content:flex-end;
  gap:.6rem;
  flex-wrap:wrap;
}
.editor-image-tools {
  display:grid;
  gap:.75rem;
  margin-top:.85rem;
  padding:.9rem;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.1);
  background:rgba(10,10,20,0.35);
}
.editor-image-field label {
  display:block;
  margin-bottom:.35rem;
  color:var(--muted);
  font-weight:600;
}
.editor-image-field input,
.editor-image-field select {
  width:100%;
  padding:.6rem .8rem;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,20,0.7);
  color:var(--text);
}
.editor-image-actions {
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
}
.editor-canvas img.blog-inline-image {
  max-width:100%;
  height:auto;
  display:block;
  margin:1rem 0;
}
.editor-canvas img.img-selected {
  outline:2px solid var(--neon-1);
  outline-offset:4px;
}
.inline-image-resizer {
  position:fixed;
  border:2px solid var(--neon-1);
  border-radius:10px;
  pointer-events:none;
  z-index:1000;
}
.inline-image-resizer.is-hidden {
  display:none;
}
.inline-image-resizer .resize-handle {
  position:absolute;
  width:14px;
  height:14px;
  background:var(--neon-1);
  border-radius:999px;
  box-shadow:0 0 0 4px rgba(155,89,255,0.2);
  pointer-events:auto;
}
.inline-image-resizer .resize-handle.nw { top:-7px; left:-7px; cursor:nwse-resize; }
.inline-image-resizer .resize-handle.ne { top:-7px; right:-7px; cursor:nesw-resize; }
.inline-image-resizer .resize-handle.sw { bottom:-7px; left:-7px; cursor:nesw-resize; }
.inline-image-resizer .resize-handle.se { bottom:-7px; right:-7px; cursor:nwse-resize; }
.blog-inline-image.img-square { border-radius:0; }
.blog-inline-image.img-soft { border-radius:14px; }
.blog-inline-image.img-round { border-radius:24px; }
.blog-inline-image.img-pill { border-radius:999px; }
.blog-inline-image.img-circle {
  border-radius:999px;
  aspect-ratio:1 / 1;
  object-fit:cover;
  width:min(320px, 80vw);
  margin-left:auto;
  margin-right:auto;
}
.blog-inline-image.img-crop-16x9 {
  aspect-ratio:16 / 9;
  object-fit:cover;
  width:100%;
}
.blog-inline-image.img-crop-4x3 {
  aspect-ratio:4 / 3;
  object-fit:cover;
  width:100%;
}
.blog-inline-image.img-crop-1x1 {
  aspect-ratio:1 / 1;
  object-fit:cover;
  width:100%;
}
.editor-toolbar {
  display:flex;
  gap:.45rem;
  flex-wrap:wrap;
  padding:.7rem;
  border-bottom:1px solid rgba(255,255,255,0.1);
  background:rgba(255,255,255,0.03);
}
.editor-tool {
  min-width:40px;
  padding:.45rem .65rem;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.2);
  background:rgba(255,255,255,0.03);
  color:var(--text);
  cursor:pointer;
}
.editor-tool:hover {
  border-color:var(--neon-1);
  box-shadow:0 0 0 2px rgba(155,89,255,0.12);
}
.editor-canvas {
  min-height:320px;
  padding:1rem;
  line-height:1.65;
  outline:none;
}
.editor-canvas:empty::before {
  content:attr(data-placeholder);
  color:var(--muted);
}
.editor-canvas p,
.editor-canvas h2,
.editor-canvas blockquote {
  margin:0 0 .8rem;
}
.editor-canvas blockquote {
  border-left:3px solid var(--neon-1);
  padding-left:.8rem;
  color:var(--muted);
}
@media (min-width:1080px) {
  .blog-featured-card {
    align-items:center;
  }
}
@media (max-width:700px) {
  .blog-feed {
    grid-template-columns:1fr;
  }
  .blog-feed-wrap {
    padding:1rem;
  }
  .blog-featured-card {
    grid-template-columns:1fr;
  }
  .blog-controls-actions {
    width:100%;
  }
  .blog-search,
  .blog-filters,
  .blog-filter select {
    width:100%;
    max-width:none;
  }
  .editor-toolbar {
    gap:.35rem;
  }
  .blog-detail-card {
    padding:1.1rem;
  }
  .blog-detail-media {
    height:clamp(180px, 52vw, 280px);
  }
  .footer-inner {
    justify-content:center;
    text-align:center;
  }
  .footer-links {
    justify-content:center;
  }
  .product-detail-grid {
    grid-template-columns:1fr;
  }
  .product-cover {
    aspect-ratio:4 / 3;
  }
}

/* Services page */
.service-intro {
  max-width:80ch;
}
.service-card h3 {
  margin:.15rem 0 .45rem;
}
.service-card p {
  margin:.2rem 0 1rem;
  color:var(--muted);
}
.service-form-card {
  margin-top:1.5rem;
}
.service-form {
  margin-top:.5rem;
}
.service-form label {
  display:block;
  margin:.75rem 0 .35rem;
  color:var(--muted);
  font-weight:500;
}
.service-form input,
.service-form textarea,
.service-form select {
  width:100%;
  padding:.72rem .88rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.09);
  background:rgba(10,10,20,0.72);
  color:var(--text);
}
.service-form textarea {
  min-height:130px;
  resize:vertical;
}
.service-form-actions {
  margin-top:1rem;
}
.service-btn {
  display:inline-block;
  padding:.68rem 1.1rem;
  border-radius:16px;
  background:linear-gradient(90deg,var(--neon-1),var(--neon-2));
  color:#fff;
  box-shadow:0 10px 40px var(--glow);
  border:0;
  cursor:pointer;
}

/* Projects */
.project-intro {
  max-width:80ch;
  margin-top:.25rem;
}
.project-grid {
  align-items:stretch;
}
.project-card h3 {
  margin:.2rem 0 .55rem;
}
.project-card p {
  margin:.35rem 0;
  color:var(--muted);
  line-height:1.55;
}
.project-link-wrap a {
  color:var(--neon-1);
  font-weight:600;
  word-break:break-word;
}
.project-tags {
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  margin-top:.8rem;
}
.project-tags span {
  display:inline-block;
  padding:.28rem .6rem;
  border-radius:999px;
  font-size:.82rem;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.03);
  color:var(--text);
}

/* Projects showcase slider */
.projects-showcase-wrap {
  display:grid;
  gap:1rem;
}
.projects-showcase-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.projects-showcase-head h2 {
  margin:0;
}
.projects-showcase {
  position:relative;
  border-radius:calc(var(--soft-edge) + 6px);
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(160deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
  padding:1.1rem 0;
  overflow:hidden;
}
.projects-showcase::before,
.projects-showcase::after {
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:90px;
  pointer-events:none;
  z-index:2;
}
.projects-showcase::before {
  left:0;
  background:linear-gradient(90deg, rgba(11,15,26,0.96), transparent);
}
.projects-showcase::after {
  right:0;
  background:linear-gradient(270deg, rgba(11,15,26,0.96), transparent);
}
.projects-track {
  --marquee-distance: 1200px;
  --marquee-duration: 36s;
  display:flex;
  align-items:stretch;
  gap:1.25rem;
  width:max-content;
  padding:0 2.2rem;
  animation:projects-marquee var(--marquee-duration) linear infinite;
}
.projects-track.is-static {
  animation:none;
  width:100%;
  justify-content:center;
}
.projects-showcase:hover .projects-track,
.projects-showcase:focus-within .projects-track {
  animation-play-state:paused;
}
@keyframes projects-marquee {
  to { transform:translateX(calc(-1 * var(--marquee-distance))); }
}
.project-slide {
  position:relative;
  flex:0 0 clamp(240px, 28vw, 380px);
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.12);
  background:linear-gradient(160deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
  box-shadow:0 18px 40px rgba(0,0,0,0.45);
  text-decoration:none;
  color:var(--text);
  display:flex;
  flex-direction:column;
  transform:translateZ(0);
  transition:transform .3s ease, box-shadow .3s ease;
}
.project-slide:hover {
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 26px 60px rgba(0,0,0,0.55), 0 18px 40px var(--glow);
}
.project-slide:focus-visible {
  outline:2px solid var(--neon-1);
  outline-offset:4px;
}
.project-media {
  width:100%;
  aspect-ratio:16 / 10;
  background:rgba(8,12,20,0.35);
  display:flex;
  align-items:center;
  justify-content:center;
}
.project-media img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.project-overlay {
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding:1rem 1rem 1.1rem;
  background:linear-gradient(180deg, rgba(0,0,0,0.05), rgba(2,6,14,0.82));
  opacity:0;
  transform:translateY(10px);
  transition:opacity .25s ease, transform .25s ease;
}
.project-slide:hover .project-overlay,
.project-slide:focus-visible .project-overlay,
.project-slide:focus-within .project-overlay {
  opacity:1;
  transform:translateY(0);
}
.project-overlay h3 {
  margin:0 0 .4rem;
  font-size:1.15rem;
}
.project-overlay p {
  margin:0 0 .7rem;
  color:var(--muted);
  font-size:.95rem;
  line-height:1.5;
}
.project-tag-row {
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
  margin-bottom:.6rem;
}
.project-tag {
  padding:.2rem .55rem;
  border-radius:999px;
  font-size:.72rem;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.04);
  letter-spacing:.03em;
  text-transform:uppercase;
}
.project-cta {
  font-weight:600;
  color:var(--neon-1);
}
.project-slide-placeholder {
  align-items:center;
  justify-content:center;
  min-height:220px;
  font-weight:600;
  color:var(--muted);
}

/* Responsive */
@media (max-width:1100px) {
  .hero-full {
    padding:4rem max(4vw, 2rem);
  }
  .hero-full .hero-art {
    width:clamp(220px, 40vw, 360px);
    height:280px;
  }
  .blog-feed {
    grid-template-columns:repeat(2, minmax(260px, 1fr));
  }
}
@media (max-width:900px) {
  .container { padding:1.5rem; }
  main.container { padding-top:0; }
  .header { flex-wrap:wrap; align-items:center; }
  .logo { order:1; }
  .nav-toggle { order:2; margin-left:auto; }
  .header-actions { order:3; width:100%; justify-content:flex-start; flex-wrap:wrap; }
  nav { order:4; width:100%; }
  .nav-toggle { display:inline-flex; }
  nav ul {
    display:none;
    flex-direction:column;
    gap:.4rem;
    padding:1rem;
    border-radius:calc(var(--soft-edge) - 6px);
    background:var(--surface);
    width:100%;
  }
  nav ul.show { display:flex; }
  nav a { display:block; width:100%; }
  .hero,
  .site-hero { flex-direction:column; text-align:center; gap:1.35rem; }
  .hero-full { padding:3.25rem 1.5rem; min-height:auto; }
  .hero-art,
  .site-hero-art { width:100%; min-width:0; height:230px; margin-top:.35rem; }
  .site-hero-auth { width:calc(100% - 3rem); }
  .projects-showcase {
    overflow-x:auto;
  }
  .projects-showcase::before,
  .projects-showcase::after {
    display:none;
  }
  .projects-track {
    animation:none;
    padding:0 1rem 1rem;
  }
  .project-slide {
    flex:0 0 clamp(220px, 70vw, 300px);
  }
  .project-overlay {
    opacity:1;
    transform:none;
    background:linear-gradient(180deg, rgba(0,0,0,0.25), rgba(2,6,14,0.88));
  }
  .trending-head {
    align-items:flex-start;
  }
  .app-card-main {
    flex-direction:column;
    align-items:flex-start;
  }
  .app-card.is-compact .app-card-main {
    flex-direction:row;
  }
  .contact-main {
    grid-template-columns:1fr;
  }
}
@media (max-width:600px) {
  .container { padding:1.25rem; }
  main.container { padding-top:0; }
  .logo .mark {
    width:clamp(160px, 55vw, 220px);
    height:clamp(44px, 12vw, 60px);
  }
  .hero-title,
  .site-hero-title { font-size:1.8rem; }
  .cta { width:100%; text-align:center; }
  .site-hero { padding:1.35rem; }
  .hero-full { padding:2.5rem 1.25rem; }
  .site-hero-auth { width:calc(100% - 2.5rem); }
  .product-controls,
  .product-filters {
    width:100%;
  }
  input,
  textarea,
  select {
    font-size:16px;
  }
  .blog-featured-card {
    padding:1.05rem;
  }
  .blog-detail-title {
    font-size:1.6rem;
  }
}
@media (max-width:480px) {
  .container { padding:1rem; }
  .hero-title,
  .site-hero-title { font-size:1.6rem; }
  .hero-sub,
  .site-hero-sub { font-size:.95rem; }
  .header-actions { gap:.5rem; }
  .theme-switch { width:100%; justify-content:center; }
  .nav-logout { width:100%; }
  .blog-detail-card {
    padding:1rem;
  }
}
@supports not (aspect-ratio: 1 / 1) {
  .card-media,
  .product-cover,
  .product-thumb img,
  .blog-post-media-wrap,
  .blog-featured-media,
  .blog-detail-media {
    height:auto;
  }
  .blog-media,
  .blog-detail-media-img,
  .blog-detail-media-video,
  .card-media img,
  .product-cover img {
    height:auto;
  }
}
@media (prefers-reduced-motion: reduce) {
  .site-hero *,
  .hero * {
    animation:none !important;
    transition:none !important;
  }
  .projects-track {
    animation:none !important;
  }
  .project-slide,
  .project-overlay {
    transition:none !important;
  }
  .glass-lens .hero-aurora,
  .glass-lens .hero-ripple {
    animation:none !important;
    opacity:0;
  }
  .glass-lens.is-hovered .hero-aurora,
  .glass-lens.is-hovered .hero-ripple {
    opacity:0.2;
  }
}

/* Header hero cover */
.header::before {
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:100vw;
  bottom:calc(-1 * var(--header-bleed));
  background:var(--hero-full-bg);
  background-size:140% 140%;
  background-position:12% 12%;
  z-index:0;
  pointer-events:none;
}
/* LOGIN BUTTON STYLE */
.login-button button {
  padding: 8px 16px;
  border: none;
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
  font-weight: 600;
  transition: 0.3s ease;
}

/* Purple Theme */
html[data-theme="purple-tech"] .login-button button {
  background: #6a00ff;
  color: white;
}
html[data-theme="purple-tech"] .login-button button:hover {
  background: #5500cc;
}

/* Neon Theme */
html[data-theme="dark-neon"] .login-button button {
  background: #00eaff;
  color: #000;
  box-shadow: 0 0 8px #00eaff;
}
html[data-theme="dark-neon"] .login-button button:hover {
  background: #00bcd4;
}
/* ---------- Login Page Styles ---------- */

.login-wrapper {
  width: 100%;
  min-height: calc(100vh - 2rem);
  min-height: calc(100dvh - 2rem);
  background: #0c1b2b; /* dark theme */
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.25rem;
}

.login-box {
  background: #102339;
  padding: clamp(24px, 4vw, 40px);
  border-radius: 20px;
  width: min(100%, 360px);
  text-align: center;
  color: #fff;
  box-shadow: 0px 0px 25px rgba(0, 0, 0, 0.4);
}

.login-box h1,
.login-box h2 {
  margin-bottom: 10px;
  font-size: 26px;
}

.subtitle {
  color: #aaaaaa;
  font-size: 14px;
  margin-bottom: 25px;
}

.input {
  width: 100%;
  padding: 14px;
  margin: 10px 0;
  border-radius: 14px;
  border: none;
  outline: none;
  font-size: 15px;
}

.btn {
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  font-size: 16px;
  margin-top: 10px;
  transition: 0.2s;
}

.primary-btn {
  background: #1a73e8;
  color: white;
}

.primary-btn:hover {
  background: #1666cc;
}

.divider {
  margin: 15px 0;
  color: #aaa;
  position: relative;
}

.divider span {
  position: relative;
  z-index: 2;
  background: #102339;
  padding: 0 10px;
}

.divider::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background: #444;
  z-index: 1;
}

.google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  color: #333;
  gap: 10px;
}

.google-btn:hover {
  background: #eaeaea;
}

.google-icon {
  width: 20px;
}

.register-text {
  margin-top: 15px;
  font-size: 14px;
}

.register-text a {
  color: #1a73e8;
  text-decoration: none;
}
