@font-face{font-family:"PolySans";src:url("/fonts/PolySans Slim.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"PolySans";src:url("/fonts/PolySans Bulky.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

:root{
  --container-max: 1140px;
  --container-pad: 20px; /* header/container gutters */
  --bg:#0b0c0f; --panel:#121419; --muted:#a3adbc; --brand:#4f8cff; --brand-2:#7cc4ff; --text:#eef2f7;
  /* Brand accents */
  --brand-blue: rgba(0,10,255,1);
  --brand-orange: #ff7a00;
  --brand-blue-light: color-mix(in srgb, var(--brand-blue) 50%, white 50%);
  /* Aurora gradient stops (customizable) */
  --c1:#00064D; /* deep navy */
  --c2:#000AFF; /* brand blue */
  --c3:#4DB8FF; /* light cyan */
  --c4:#FF7A00; /* orange accent */
  --cta-gap: 48px; /* consistent CTA spacing */
  --tile-gap: 14px; /* portfolio tile gap */
  --heading-gap: 32px; /* consistent heading spacing */
  --subheading-top-gap: 0px; /* tighter subheading distance */
  --heading-sub-gap: 4px; /* h2 -> subheading reduced gap */
  --masonry-row: 4px; /* fine-grained masonry row */
  --subheading-gap: 4px; /* tighter subheading spacing under titles */
  --subheading-size: 18px;
  --radius:20px; --radius-sm:14px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --ring: 0 0 0 3px rgba(79,140,255,.35);
  --header-h:64px;
  --logo-h:36px;
}
/* Light theme overrides */
[data-theme="light"]{
  --bg:#f7f9fc; --panel:#ffffff; --text:#0b0c0f; --muted:#56627a;
  --brand:#2b6cff; --brand-2:#66b3ff;
}
/* Light theme visual fixes for contrast */
[data-theme="light"] .nav a{color:#0b0c0f}
[data-theme="light"] .nav a:hover{color:#000}
[data-theme="light"] .brand{color:#0b0c0f}
[data-theme="light"] .brand:hover{color:#000}
[data-theme="light"] .theme-toggle{border-color:rgba(0,0,0,.12);color:#0b0c0f}
[data-theme="light"] .mobile-nav{background:#ffffff;border-bottom-color:rgba(0,0,0,.06)}
[data-theme="light"] .mobile-nav__panel{background:#ffffff}
[data-theme="light"] .btn{border-color:rgba(0,0,0,.12)}
[data-theme="light"] .section.alt{background:#ffffff}
[data-theme="light"] .card,
[data-theme="light"] .service,
[data-theme="light"] .form{background:linear-gradient(180deg,#ffffff,#f5f7fb)}
[data-theme="light"] .card::before,
[data-theme="light"] .service::before,
[data-theme="light"] .form::before{background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.02))}
[data-theme="light"] .form input{background:#ffffff;color:#0b0c0f;border-color:rgba(0,0,0,.14)}
[data-theme="light"] .media{border-color:rgba(0,0,0,.08)}
[data-theme="light"] .media:hover{border-color:rgba(0,120,255,.4);box-shadow:0 12px 30px rgba(0,120,255,.15)}
[data-theme="light"] .hero-media{background:#f4f7fc}
[data-theme="light"] .site-footer{background:#f2f5fb;border-top-color:rgba(0,0,0,.06)}
[data-theme="light"] .footer-nav a{color:#56627a}
[data-theme="light"] .footer-nav a:hover{color:#0b0c0f}
*{box-sizing:border-box}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a, button, input, textarea { -webkit-tap-highlight-color: transparent; }
body{margin:0;background:radial-gradient(1200px 600px at 10% -10%, rgba(79,140,255,.15), transparent 60%), radial-gradient(900px 500px at 80% 0%, rgba(124,196,255,.12), transparent 55%), linear-gradient(180deg,#0b0c0f 0%,#0e1117 100%);color:var(--text);font-family:"PolySans",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial;line-height:1.7;letter-spacing:.005em}
[data-theme="light"] body{background:linear-gradient(180deg,#f7f9fc 0%,#eef3fb 100%)}
/* Focus visibility */
:focus-visible{outline:none;box-shadow:var(--ring)}
html{scroll-behavior:auto}

/* Stabilize bottom-of-page scrolling on mobile browsers */
html, body{ overscroll-behavior-y: contain; }
body.no-scroll{overflow:hidden;touch-action:none}
.site-footer{ scroll-margin-top: var(--header-h); }
#faq .faq-item summary{ scroll-margin-top: calc(var(--header-h) + 8px); }
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}
.mobile-only{display:none}
em{font-style:italic}

/* 3. Insert consistent typography scale after em */
.h1{font-size:clamp(38px,5.2vw,64px);line-height:1.1;font-weight:700;margin:0 0 12px}
.h2{font-size:clamp(28px,3.6vw,40px);line-height:1.15;font-weight:700;margin:0 0 10px}
.h3, h3{font-size:18px;line-height:1.2;font-weight:700;margin:8px 0}
.body-sm{font-size:14px;line-height:1.45}
.body-md{font-size:16px;line-height:1.5}

/* Header */
.site-header{position:sticky;top:0;z-index:90;background:rgba(11,12,15,.6);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid rgba(255,255,255,.06);transition:background .25s ease, box-shadow .25s ease, border-color .25s ease}
.site-header{isolation:isolate}
.site-header::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.35;background:linear-gradient(120deg, rgba(0,10,255,.35), rgba(77,184,255,.25));filter:blur(20px)}
.site-header.scrolled{background:rgba(11,12,15,.85);box-shadow:0 8px 30px rgba(0,0,0,.35);border-bottom-color:rgba(255,255,255,.09)}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:transparent;color:#dfe6f0;cursor:pointer;margin-left:12px}
.theme-toggle:hover{color:#fff;border-color:#90b9ff}
[data-theme="light"] .site-header{background:rgba(255,255,255,.95);border-bottom-color:rgba(0,0,0,.08)}
[data-theme="light"] .site-header.scrolled{background:rgba(255,255,255,1);box-shadow:0 8px 30px rgba(0,0,0,.12)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.site-header .header-inner{max-width:var(--container-max);margin:0 auto;padding-inline:var(--container-pad)}
.brand{font-weight:700;letter-spacing:.2px;color:#dfe6f0}
.brand:hover{color:#fff}
.brand-logo{height:var(--logo-h);width:auto;display:block}
.brand{margin-left:0}
[data-theme="light"] .brand-logo{filter:drop-shadow(0 1px 0 rgba(0,0,0,.25))}
.site-header .btn{font-weight:400}
.nav a{font-weight:400}
.nav a{margin-left:24px;color:#dfe6f0;position:relative}
.nav a:hover{color:#fff}
/* subtle underline accent on hover */
.nav a::after{content:"";position:absolute;left:0;bottom:-8px;width:0;height:2px;background:linear-gradient(90deg, rgba(0,10,255,1), rgba(0,120,255,1));transition:width .2s ease}
.nav a:hover::after{width:100%}
.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:24px}
[data-theme="light"] .nav-toggle{color:#0b0c0f}
.mobile-nav{
  position:fixed;
  inset:0;
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  padding:calc(var(--header-h) + 16px) 16px 24px;
  background:rgba(11,12,15,.88);
  backdrop-filter:blur(10px);
  z-index:120;
}
.mobile-nav[hidden]{display:none !important; pointer-events:none !important}
.mobile-nav__panel{
  width:min(320px, calc(100% - 32px));
  background:var(--panel);
  border-radius:20px;
  padding:28px 24px 32px;
  box-shadow:0 40px 80px rgba(0,0,0,.45);
  display:flex;
  flex-direction:column;
  gap:24px;
  max-height:calc(100vh - var(--header-h) - 48px);
  overflow:auto;
}
.mobile-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:20px}
.mobile-nav a{display:block;font-size:18px;font-weight:500;line-height:1.4;padding:0}
.mobile-nav li:last-child a{border-bottom:0}
.noscript-nav{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;padding:14px 20px;background:var(--panel);border-bottom:1px solid rgba(255,255,255,.08)}
.noscript-nav .btn{margin-left:8px}
[data-theme="light"] .noscript-nav{background:#ffffff;border-bottom-color:rgba(0,0,0,.08)}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 20px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
}

.btn-primary{background:linear-gradient(180deg, var(--brand-blue-light), var(--brand-blue));color:#fff;border:0;box-shadow:0 6px 20px rgba(0,10,255,.35)}
.btn-primary:hover{transform:translateY(-1px) scale(1.01);box-shadow:0 10px 26px rgba(0,10,255,.5)}
.btn-ghost{background:linear-gradient(180deg, var(--brand-blue-light), var(--brand-blue));color:#fff;border:0}
.btn-ghost:hover{transform:translateY(-1px) scale(1.01);box-shadow:0 10px 26px rgba(0,10,255,.5)}

/* Hero */
.hero{padding:96px 0 72px;min-height:calc(100vh - var(--header-h));display:flex;align-items:center;--heading-gap:18px}
.hero{position:relative;overflow:visible;isolation:isolate}
.hero::before {
  content: none !important;
}
@keyframes heroAurora{
  0%{ background-position:0% 40%,100% 60%,0% 100%,100% 0% }
  50%{ background-position:100% 60%,0% 40%,100% 0%,0% 100% }
  100%{ background-position:0% 40%,100% 60%,0% 100%,100% 0% }
}
.hero-inner{display:grid;gap:32px;grid-template-columns:1.1fr .9fr;align-items:center}
.hero.no-media .hero-inner{grid-template-columns:1fr}
.hero-copy h1{font-size:clamp(42px, 6vw, 84px);line-height:1.08;margin:0;letter-spacing:-.01em;padding-block:0;overflow:visible}
.hero-copy{ text-align:center }
.accent{display:inline-block; /* remove filter to avoid Chrome clipping */ overflow:visible}
.accent.line{display:block;margin-top:0}
/* iOS-safe background underline instead of blue rectangle */
.grad-i{display:inline-block; padding:0 .06em 0; line-height:1; overflow:visible}
.accent .grad-i{
  display:inline-block;
  position:relative;
  -webkit-tap-highlight-color:transparent;
  background:none !important;
}
.accent .grad-i em{
  display:inline-block;
  font-style:normal;
  line-height:1;
  transform:skewX(-9deg);
  background:linear-gradient(180deg, var(--brand-blue-light), var(--brand-blue));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
  padding:.14em 0 .16em;
}
/* Degradado elegante y uniforme para hero y logos-strip */
.hero,
.logos-strip {
  position: relative;
  z-index: 1;
  background: none !important;
}

.hero .container,
.logos-strip .container {
  position: relative;
  z-index: 1;
}


/* Fallback: navegadores sin background-clip:text muestran azul sólido */
@supports not ((-webkit-background-clip: text) or (background-clip: text)) {
  .grad-i em{
    background:none;
    -webkit-text-fill-color:initial;
    color:var(--brand-blue);
    transform:skewX(-10deg);
  }
}
/* ensure headings don't clip accented text */
.hero-copy h1, .section h2{overflow:visible}
.hero-copy{ display:flex; flex-direction:column; align-items:center; gap:8px }
.hero-copy .support{ color:var(--muted); max-width:70ch; margin:6px auto 18px; font-size:16px }
.hero-copy .sub{color:var(--muted);max-width:70ch;margin:0 0 6px;font-size:clamp(16px,2.1vw,18px);line-height:1.35}

.ctas{display:flex;gap:12px;margin:var(--cta-gap) 0 0;justify-content:center}
.proof{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;color:#c7d0de;font-size:14px;padding:0;margin:12px 0 0;list-style:none}
.hero-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#0a0d14}
.hero-video{width:100%;aspect-ratio:16/9;object-fit:cover;opacity:.95;border-radius:var(--radius)}

/* (Hero PRO styles removed) */

/* Sections */
.section{padding:96px 0;min-height:auto;display:flex;align-items:flex-start}
/* Prevent unexpected auto-recentering caused by viewport unit changes at bottom of page */
#faq.section, #contact.section, .site-footer, .hero { contain: layout paint style; }
/* Prevent scroll anchoring jumps on dynamic sections */
.media-grid, #faq, .site-footer, .logos-strip { overflow-anchor: none; }
/* Sections with expandable / long content should not be vertically centered */
#faq.section, #contact.section, .site-footer { min-height:auto; }
#faq.section, #contact.section { align-items:flex-start; }
/* Avoid unexpected auto-scrolling when expanding FAQ on some browsers */
#faq { scroll-behavior:auto; }
.section.alt{background:#0b0c0f}
.section-lead{color:var(--muted);margin-top:var(--subheading-top-gap);margin-bottom:22px;font-size:18px}
/* Headings */
.section h2{font-size:clamp(34px, 4.2vw, 56px);line-height:1.08;margin:0 0 var(--heading-gap);letter-spacing:-.005em}
.section h2::after{content:none}
/* Contact: bring the first line closer only here */
.contact-copy h2 + p{margin-top:var(--subheading-top-gap);color:var(--muted)}
/* Reduced gap for sections with explicit subheading */
#offer h2{margin-bottom:16px}
#offer .section-lead{margin:6px 0 40px !important}
#offer .grid-3{margin-top:32px !important}
#expertise h2{margin-bottom:16px}
#expertise .grid-3{margin-top:32px !important}
.section.why h2{margin-bottom:16px}
.section.why .grid-3{margin-top:32px !important;gap:24px}
.section.why .card{
  padding:16px;
  line-height:1.45;
}
.section.why .card p{
  margin:0;
  line-height:inherit;
}
.contact-copy h2{margin-bottom:var(--heading-sub-gap)}
.grid-3{display:grid;gap:24px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:36px}
.card,.service{position:relative;background:linear-gradient(180deg,#10131a,#0e1218);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
/* gradient border */
.card::before,.service::before{content:"";position:absolute;inset:0;padding:1px;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.card:hover,.service:hover{transform:translateY(-2px)}
.card h3,.service h3{margin-top:0}
.cta-center{text-align:center;margin-top:var(--cta-gap)}
.media-grid + .cta-center{margin-top:var(--cta-gap)}

/* Logos / Portfolio */
.logos-row{display:flex;gap:48px;justify-content:center;align-items:center;opacity:.85;margin-bottom:12px}
/* Logos strip styling */
.logos-strip{padding:12px 0;border-bottom:none;background:transparent;backdrop-filter:none}
/* Marquee-ready track (Feedback 04) */
.logos-strip{ overflow:hidden }
.logos-strip .logos-row{ position:relative }
.logos-strip .logos-track{
  display:flex; align-items:center; gap:96px;
  flex-wrap:nowrap;               /* prevent wrapping to keep loop seamless */
  min-width:max-content;          /* ensure track width fits its content */
  will-change:transform;
  animation:marquee-left 36s linear infinite;
}
.logos-strip .logos-track[aria-hidden="true"]{display:flex}
@keyframes marquee-left{ from{ transform:translate3d(0,0,0) } to{ transform:translate3d(-50%,0,0) } }
@media (prefers-reduced-motion: reduce){ .logos-strip .logos-track{ animation:none } }
[data-theme="light"] .logos-strip{border-bottom:none;background:transparent}
@keyframes logoFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:.95;transform:none}}
@keyframes logoFloat{0%{transform:translateY(0)}50%{transform:translateY(-3px)}100%{transform:translateY(0)}}
.logos-strip .logos-row img{height:56px;width:auto;filter:grayscale(100%) contrast(1.05);opacity:.95;transition:opacity .25s ease, filter .25s ease, transform .25s ease;animation:logoFadeIn .6s ease both}
.logos-strip .logos-row img:hover{filter:none;opacity:1;transform:translateY(-4px) scale(1.03)}
.logos-strip img{height:36px;width:auto;opacity:.9;filter:grayscale(1)}
[data-theme="light"] .logos-strip{border-bottom:none}
[data-theme="light"] .logos-strip img{filter:grayscale(1)}
[data-theme="light"] .logos-strip .logos-row img{opacity:1;filter:none}
/* subtle float staggering */
.logos-strip .logos-row img:nth-child(3n){animation-delay:.05s}
.logos-strip .logos-row img:nth-child(3n+1){animation-delay:.1s}
.logos-strip .logos-row img:nth-child(3n+2){animation-delay:.15s}
@media (max-width: 720px){
  .logos-strip .logos-row img{height:44px}
  .logos-strip .logos-track{ gap:40px }
}
.media-grid{margin-top:8px;margin-bottom:20px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;align-items:start;grid-auto-rows:var(--masonry-row)}
/* Fade overlay at bottom of grids (Feedback 06.x) */
.media-grid{ position:relative }
.media-grid::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:280px; pointer-events:none;
  background:linear-gradient(180deg, rgba(11,12,15,0) 0%, rgba(11,12,15,.45) 40%, rgba(11,12,15,.8) 70%, #0b0c0f 100%)
}
.media-grid{ gap:18px }
.media{display:block;position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.06);transform:translateZ(0);transition:transform .3s ease, border-color .25s ease;break-inside:avoid;margin:0;background:#0a0d14;box-shadow:none}
.media img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .4s ease}
.media video.folio{width:100%;height:100%;display:block;object-fit:cover;object-position:center;border-radius:10px;background:#000}

/* Native video controls styling (best-effort) */
.media video.folio::-webkit-media-controls-enclosure{border-radius:10px;overflow:hidden}
.media video.folio::-webkit-media-controls-panel{background:transparent}
video.folio:fullscreen::-webkit-media-controls-panel{background:rgba(0,0,0,.35)}
.media video.folio::-webkit-media-controls-play-button,
.media video.folio::-webkit-media-controls-mute-button,
.media video.folio::-webkit-media-controls-volume-slider,
.media video.folio::-webkit-media-controls-timeline,
.media video.folio::-webkit-media-controls-current-time-display,
.media video.folio::-webkit-media-controls-time-remaining-display{ color:#fff }
.media::after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(120% 60% at 15% 0%, rgba(0,10,255,.12), transparent 65%);opacity:0}
.media:hover{transform:translateY(-2px) scale(1.01);border-color:rgba(124,196,255,.28);box-shadow:none}
.media .folio{transition:transform .35s ease;will-change:transform;backface-visibility:hidden;border-radius:inherit}
.media:hover .folio{transform:scale(1.06)}
.media:hover::after{opacity:0}
/* placeholders: dar tamaño estable aunque sea SVG inline */
.media img.folio{object-fit:cover;border-radius:10px;height:100%}
/* Preview crop rules by orientation */
.media.square{ aspect-ratio: 1 / 1; }
.media.vertical{ aspect-ratio: 4 / 5; }
.media.horizontal{ aspect-ratio: 5 / 4; }

@supports not (aspect-ratio: 1 / 1) {
  .media::before{
    content: "";
    display: block;
    width: 100%;
  }
  .media.square::before{ padding-top: 100%; }
  .media.vertical::before{ padding-top: 125%; }
  .media.horizontal::before{ padding-top: 80%; }
  .media > img.folio,
  .media > video.folio{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
}

/* Contact */
.contact{display:grid;gap:32px;grid-template-columns:1fr 1fr;align-items:start}
.form{background:linear-gradient(180deg,#10131a,#0e1218);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:relative}
.form::before{content:"";position:absolute;inset:0;padding:1px;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.form label{display:block;margin-bottom:12px}
.form span{display:block;margin-bottom:6px;color:#cbd5e1;font-size:14px}
.form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#0b0e14;color:#e8edf6}
.form button{width:100%;margin-top:18px}
.form .cta-center{margin-top:28px}
.form .fine{font-size:13px;color:#93a1b5;margin:10px 0 0}
.form-title{margin:0 0 18px;font-size:20px;font-weight:600;color:#fff}

.contact-details{margin-top:40px;color:#cbd5e1;border-top:1px solid rgba(255,255,255,.22);padding-top:18px}
.contact-details h3{margin:0 0 8px;font-size:18px;font-weight:600}
.contact-details a{color:#fff;font-weight:500}
.contact-details a:hover{color:var(--brand-2)}

/* Bulleted list styling */
.bullets{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:4px}
.bullets li{position:relative;padding-left:22px;margin-bottom:0}
.bullets li::before{content:"✓";position:absolute;left:0;top:0;color:var(--brand)}

/* FAQ */
.faq-list{display:grid;gap:12px;margin-top:12px}
.faq-item{background:linear-gradient(180deg,#10131a,#0e1218);border-radius:var(--radius);box-shadow:var(--shadow);padding:0;border:1px solid rgba(255,255,255,.06)}
.faq-item[open]{border-color:rgba(124,196,255,.3)}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:16px 18px;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  font-weight:700;
  touch-action:pan-y;
  margin:0;
}

/* Admin dashboard refinements */
.admin .toolbar{gap:8px}
.admin .toolbar input[type="file"]{
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:6px 10px;
  background:rgba(0,0,0,.12);
  color:inherit;
}
[data-theme="light"] .admin .toolbar input[type="file"]{
  border-color:rgba(0,0,0,.12);
  background:rgba(0,0,0,.04);
  color:inherit;
}
.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
  text-transform:uppercase;
  background:rgba(255,255,255,.12);
  color:#fff;
}
.pill.hot{background:rgba(255,99,71,.18);color:#ff6b5a;border:1px solid rgba(255,99,71,.45)}
.pill.warm{background:rgba(255,196,0,.18);color:#ffc400;border:1px solid rgba(255,196,0,.4)}
.pill.cold{background:rgba(79,140,255,.18);color:#79a6ff;border:1px solid rgba(79,140,255,.45)}
[data-theme="light"] .pill{
  background:rgba(0,0,0,.08);
  color:#0b0c0f;
  border:1px solid rgba(0,0,0,.12);
}
[data-theme="light"] .pill.hot{background:rgba(255,107,90,.12);color:#c3321f;border-color:rgba(255,107,90,.32)}
[data-theme="light"] .pill.warm{background:rgba(255,196,0,.12);color:#a06300;border-color:rgba(255,196,0,.28)}
[data-theme="light"] .pill.cold{background:rgba(79,140,255,.12);color:#264cbf;border-color:rgba(79,140,255,.3)}

.ag-theme-quartz{
  --ag-background-color: rgba(12,13,18,0.92);
  --ag-foreground-color: #e5ecff;
  --ag-font-size: 13px;
  --ag-header-background-color: rgba(18,20,25,0.95);
  --ag-header-foreground-color: #d6ddf5;
  --ag-odd-row-background-color: rgba(255,255,255,0.02);
  --ag-row-hover-color: rgba(79,140,255,0.12);
  --ag-row-border-color: rgba(255,255,255,0.05);
  --ag-input-border-color: rgba(255,255,255,0.25);
  --ag-header-column-resize-handle-color: rgba(124,196,255,0.6);
  --ag-wrapper-border-radius: 12px;
  border-radius:12px;
  overflow:hidden;
}
.ag-theme-quartz .ag-header-cell-label{font-weight:600}
.ag-theme-quartz .ag-row.ag-row-odd{background:rgba(255,255,255,0.01)}
.ag-theme-quartz .ag-row.row-error{animation:rowErrorPulse 2s ease}
.ag-theme-quartz .ag-loading-overlay,
.ag-theme-quartz .ag-overlay-no-rows-center{color:#eef2ff;font-size:14px}
.ag-theme-quartz .link-cell{color:var(--brand-2);text-decoration:none;font-weight:600}
.ag-theme-quartz .link-cell:hover{text-decoration:underline}
[data-theme="light"] .ag-theme-quartz .link-cell{color:#2b6cff}
[data-theme="light"] .ag-theme-quartz .whatsapp-link{border-color:rgba(0,0,0,.14);background:rgba(79,140,255,.12);color:#1a3f9f}
[data-theme="light"] .ag-theme-quartz .whatsapp-link:hover{background:rgba(79,140,255,.22)}
[data-theme="light"] .ag-theme-quartz{
  --ag-background-color:#ffffff;
  --ag-foreground-color:#0b0c0f;
  --ag-header-background-color:#f4f6fb;
  --ag-header-foreground-color:#1c2434;
  --ag-odd-row-background-color:#f6f8fd;
  --ag-row-hover-color:rgba(79,140,255,0.1);
  --ag-row-border-color:rgba(0,0,0,0.05);
  --ag-input-border-color:rgba(0,0,0,0.16);
}
@keyframes rowErrorPulse{
  0%{box-shadow:inset 0 0 0 0 rgba(255,88,88,0.4)}
  50%{box-shadow:inset 0 0 0 6px rgba(255,88,88,0.12)}
  100%{box-shadow:inset 0 0 0 0 rgba(255,88,88,0)}
}
.ag-theme-quartz .grid-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
}
.ag-theme-quartz .grid-btn{
  --grid-btn-bg:#2563eb;
  --grid-btn-border:#3b82f6;
  --grid-btn-color:#f8fafc;
  --grid-btn-ring:rgba(124,196,255,.65);
  --grid-btn-ring-inner:rgba(17,24,39,.85);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  line-height:1;
  font-weight:600;
  border:1px solid var(--grid-btn-border);
  background:var(--grid-btn-bg);
  color:var(--grid-btn-color);
  cursor:pointer;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, filter .2s ease;
}
[data-theme="light"] .ag-theme-quartz .grid-btn{
  --grid-btn-bg:#1d4ed8;
  --grid-btn-border:#1e3a8a;
  --grid-btn-color:#ffffff;
  --grid-btn-ring:rgba(37,99,235,.55);
  --grid-btn-ring-inner:rgba(15,23,42,.4);
}
.ag-theme-quartz .grid-btn:hover:not([disabled]){
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,0,0,.25);
  filter:brightness(1.05);
}
.ag-theme-quartz .grid-btn:focus-visible:not([disabled]){
  outline:2px solid transparent;
  box-shadow:0 0 0 2px var(--grid-btn-ring-inner),0 0 0 5px var(--grid-btn-ring);
  transform:translateY(-1px);
}
[data-theme="light"] .ag-theme-quartz .grid-btn:focus-visible:not([disabled]){
  box-shadow:0 0 0 2px var(--grid-btn-ring-inner),0 0 0 5px var(--grid-btn-ring);
}
.ag-theme-quartz .grid-btn[data-variant="delete"]{
  --grid-btn-bg:#b91c1c;
  --grid-btn-border:#f87171;
  --grid-btn-ring:rgba(248,113,113,.55);
}
[data-theme="light"] .ag-theme-quartz .grid-btn[data-variant="delete"]{
  --grid-btn-border:#7f1d1d;
  --grid-btn-ring:rgba(185,28,28,.55);
}
.ag-theme-quartz .grid-btn[data-variant="restore"]{
  --grid-btn-bg:#047857;
  --grid-btn-border:#34d399;
  --grid-btn-ring:rgba(52,211,153,.5);
}
[data-theme="light"] .ag-theme-quartz .grid-btn[data-variant="restore"]{
  --grid-btn-border:#065f46;
  --grid-btn-ring:rgba(6,95,70,.45);
}
.ag-theme-quartz .grid-btn[data-variant="whatsapp"]{
  --grid-btn-bg:#128c7e;
  --grid-btn-border:#25d366;
  --grid-btn-ring:rgba(37,211,102,.45);
}
[data-theme="light"] .ag-theme-quartz .grid-btn[data-variant="whatsapp"]{
  --grid-btn-border:#0f766e;
  --grid-btn-ring:rgba(15,118,110,.5);
}
.ag-theme-quartz .grid-btn[data-variant="spam"]{
  --grid-btn-bg:#b45309;
  --grid-btn-border:#fbbf24;
  --grid-btn-ring:rgba(251,191,36,.45);
}
[data-theme="light"] .ag-theme-quartz .grid-btn[data-variant="spam"]{
  --grid-btn-border:#92400e;
  --grid-btn-ring:rgba(146,64,14,.5);
}
.ag-theme-quartz .grid-actions .grid-btn[disabled]{
  opacity:.55;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
  filter:saturate(.6);
}
.ag-theme-quartz.grid-locked{
  pointer-events:none;
  opacity:.6;
  filter:grayscale(.2);
  transition:opacity .2s ease;
}
.admin--locked #agGrid{cursor:not-allowed;}
.toast-action{
  margin-left:auto;
  border:0;
  border-radius:999px;
  background:rgba(79,140,255,.3);
  color:#fff;
  padding:4px 12px;
  cursor:pointer;
  font-weight:600;
  font-size:12px;
  transition:background .2s ease;
}
.toast-action:hover{background:rgba(79,140,255,.45)}
.toast-action:focus-visible{outline:none;box-shadow:var(--ring)}
[data-theme="light"] #toast{background:#1f2a44;color:#f9fbff;border-color:rgba(43,108,255,.35)}
[data-theme="light"] .toast-action{background:#2b6cff;color:#fff}
[data-theme="light"] .admin .toolbar label span{color:#0b0c0f}
[data-theme="light"] .admin .toolbar label input[type="checkbox"]{accent-color:#2b6cff}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:focus-visible{outline:none;box-shadow:var(--ring);border-radius:12px}
.faq-item summary::after{
  content:"+";
  font-weight:700;
  margin-left:12px;
  transition:transform .2s ease;
}
.faq-item[open] summary::after{content:"–"}
.faq-item .answer{padding:0 18px 16px;color:#c7d0de;overflow:hidden}

/* --- Admin grid visibility fixes --- */
.admin .ag-theme-quartz .ag-center-cols-clipper,
.admin .ag-theme-quartz .ag-center-cols-viewport,
.admin .ag-theme-quartz .ag-pinned-right-cols-container,
.admin .ag-theme-quartz .ag-pinned-left-cols-container { overflow: visible !important; }

.admin .ag-theme-quartz .ag-cell,
.admin .ag-theme-quartz .ag-cell-wrapper { overflow: visible !important; }

.admin .ag-theme-quartz .ag-body-horizontal-scroll-viewport,
.admin .ag-theme-quartz .ag-body-horizontal-scroll { overflow-x: auto !important; }

.admin .action-chip{ display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; font-size:12px; line-height:1; border:1px solid rgba(255,255,255,.18); }
.admin .action-chip--whatsapp{ background:#1f5131; color:#d6ffe3; border-color:#2b7a46; }
.admin .action-chip--delete{ background:#5d1f1f; color:#ffe1e1; border-color:#8a2b2b; }
.faq-item .answer[hidden]{display:none}
@media (prefers-reduced-motion: reduce){
  .faq-item summary::after{transition:none}
}

[data-theme="light"] .faq-item{background:#ffffff;border-color:rgba(0,0,0,.08)}
[data-theme="light"] .faq-item[open]{border-color:rgba(0,120,255,.3)}
[data-theme="light"] .faq-item .answer{color:#333e52}

/* Footer */
.site-footer{padding:28px 0;border-top:1px solid rgba(255,255,255,.06);background:#0b0c10}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.footer-nav a{margin-left:16px;color:#cbd5e1}
.footer-nav a:hover{color:#fff}
.footer-contact{color:#cbd5e1;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.footer-contact a{color:#cbd5e1}
.footer-contact a:hover{color:#fff}

/* Footer contact — enhanced appearance */
/* Footer contact — enhanced appearance */
.footer-contact{ gap:16px; font-size:15px; color:#cfd6e3 }
.footer-contact a{ font-weight:400; }
.footer-contact a:hover{ color:var(--brand-2) }
/* Simple icons before email/phone (no extra assets) */
.footer-contact a[href^="mailto"]::before{ content:"✉ "; opacity:.85; margin-right:4px }
.footer-contact a[href^="tel"]::before{ content:"📞 "; opacity:.85; margin-right:4px }
@media (max-width:720px){
  .footer-contact{ width:100%; justify-content:center; gap:10px; font-size:14px }
}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .6s ease, transform .6s ease}
.reveal.reveal-in{opacity:1;transform:none}

/* Lightbox (expand mode) */
.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.92);z-index:1000;padding:16px;opacity:0;visibility:hidden;transition:opacity .2s ease}
.lightbox.open{opacity:1;visibility:visible}
.lightbox-content{position:relative;max-width:min(1400px,96vw);width:100%;max-height:92vh}
.lightbox video,.lightbox img{display:block;max-width:100%;max-height:92vh;margin:0 auto;border-radius:12px;background:#000;object-fit:contain}
.lightbox-close{position:absolute;top:12px;right:12px;width:48px;height:48px;border-radius:999px;border:0;background:rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;pointer-events:auto}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:999px;border:0;background:rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}
.lightbox-prev{left:12px}
.lightbox-next{right:12px}
body.lightbox-open{overflow:hidden}

/* Responsive */
@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr;gap:22px}
  .section{padding:72px 0;min-height:auto;align-items:flex-start}
  .grid-3{grid-template-columns:1fr 1fr}
  .contact{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .nav{display:none}
  .nav-toggle{display:block}
  .grid-3{grid-template-columns:1fr}
  .hero{padding-top:72px;min-height:auto}
  /* Reduce hero gradient start band on small screens */
  .hero::before{
    -webkit-mask-image: linear-gradient(to top, #000 160px, transparent 160px);
    mask-image: linear-gradient(to top, #000 160px, transparent 160px);
  }
  .section{padding:64px 0;min-height:auto;align-items:flex-start}
  .media-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;grid-auto-rows:var(--masonry-row)}
  /* Hide footer navigation menu */
  .site-footer nav,
  .site-footer .footer-menu{
    display:none !important;
  }
}

/* 4. Add compact Step 2 block styles at end of form styles */
.form .step2{ background:transparent; padding:12px 0 0; border-radius:0; text-align:left }
.form .step2 h3{ font-size:18px; line-height:1.2; margin:8px 0 6px }
.form .step2 p{ font-size:14px; line-height:1.35; margin:6px 0 10px; color:var(--muted); max-width:520px }
.form .step2 .btn{ margin-top:8px }

/* Contact form - Step 2 (book call) */
.form .step2{
  background:transparent;
  padding:18px 0 0;
  margin-top:18px;                 /* more space between form and step 2 */
  border-top:1px solid rgba(255,255,255,.10); /* subtle divider line */
  border-radius:0;
  text-align:left;
}
[data-theme="light"] .form .step2{ border-top-color:rgba(0,0,0,.08) }

.form .step2 h3{
  font-size:18px;
  line-height:1.2;
  margin:10px 0 6px;               /* slight breathing room */
}
.form .step2 p{
  font-size:14px;
  line-height:1.35;
  margin:6px 0 12px;
  color:var(--muted);
  max-width:620px;                  /* allow wider line on desktop */
}
.form .step2 .btn{ margin-top:10px }

/* Adjust the status message above for better spacing */
.form #formStatus{
  margin:8px 0 2px;                 /* keeps the divider closer visually */
}
[data-theme="light"] .badge{background:rgba(43,108,255,.12);color:#1a3f9f;border-color:rgba(43,108,255,.18)}
.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(124,196,255,.35);
  background:rgba(79,140,255,.16);
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:#dbe7ff;
}
.badge--env{font-size:11px;padding:2px 10px}
.badge[data-env="emulator"]{background:rgba(255,196,0,.18);color:#ffbf3b;border-color:rgba(255,196,0,.28)}
[data-theme="light"] .badge[data-env="emulator"]{background:rgba(255,196,0,.16);color:#a06300;border-color:rgba(255,196,0,.24)}

/* --- Admin grid visibility fixes --- */
.admin .ag-theme-quartz .ag-center-cols-clipper,
.admin .ag-theme-quartz .ag-center-cols-viewport,
.admin .ag-theme-quartz .ag-pinned-right-cols-container,
.admin .ag-theme-quartz .ag-pinned-left-cols-container { overflow: visible !important; }

/* Let cell contents render fully (e.g., action buttons) */
.admin .ag-theme-quartz .ag-cell,
.admin .ag-theme-quartz .ag-cell-wrapper { overflow: visible !important; }

/* Ensure the grid can scroll horizontally if needed */
.admin .ag-theme-quartz .ag-body-horizontal-scroll-viewport,
.admin .ag-theme-quartz .ag-body-horizontal-scroll { overflow-x: auto !important; }

/* Better contrast for action chips */
.admin .action-chip{ display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; font-size:12px; line-height:1; border:1px solid rgba(255,255,255,.18); }
.admin .action-chip--whatsapp{ background:#1f5131; color:#d6ffe3; border-color:#2b7a46; }
.admin .action-chip--delete{ background:#5d1f1f; color:#ffe1e1; border-color:#8a2b2b; }
