/* ============================================================
   A&V PRIMETEHNIC — Security for all
   Aesthetic: "Vigilent" — dark security-grade, amber signal accent
   Mobile-first. Romanian only.
   ============================================================ */

:root{
  --bg:        #0A0E17;
  --bg-2:      #0C1119;
  --surface:   #121A28;
  --surface-2: #18222F;
  --line:      rgba(255,255,255,.08);
  --line-2:    rgba(255,255,255,.14);
  --ink:       #EAF0FA;
  --ink-mute:  #93A2BC;
  --ink-dim:   #6B7A93;

  --amber:     #FFB627;
  --amber-2:   #F59E0B;
  --amber-ink: #1A1203;
  --ok:        #34D399;

  --r:   14px;
  --r-lg:20px;
  --maxw:1180px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --shadow:   0 18px 50px -22px rgba(0,0,0,.85);
  --glow-amb: 0 0 0 1px rgba(255,182,39,.18), 0 14px 40px -16px rgba(255,182,39,.35);

  --f-disp: "Archivo", system-ui, sans-serif;
  --f-body: "Manrope", system-ui, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--f-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img,svg,iframe{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3{ font-family:var(--f-disp); font-weight:800; line-height:1.05; letter-spacing:-.02em; margin:0; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:20px; }

.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--amber); color:var(--amber-ink); padding:10px 16px;
  border-radius:0 0 10px 0; font-weight:700;
}
.skip-link:focus{ left:0; }

.dot{ width:7px; height:7px; border-radius:50%; display:inline-block; background:var(--ink-dim); }
.dot--ok{ background:var(--ok); box-shadow:0 0 0 0 rgba(52,211,153,.55); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(52,211,153,.5);} 70%{ box-shadow:0 0 0 7px rgba(52,211,153,0);} 100%{ box-shadow:0 0 0 0 rgba(52,211,153,0);} }

/* ---------- Buttons ---------- */
.btn{
  --pad:14px 22px;
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:var(--pad); border-radius:12px;
  font-family:var(--f-disp); font-weight:700; font-size:15px; letter-spacing:.01em;
  cursor:pointer; border:1px solid transparent; transition:transform .18s var(--ease), box-shadow .25s var(--ease), background .2s;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px) scale(.99); }
.btn--sm{ --pad:10px 16px; font-size:14px; border-radius:10px; }
.btn--amber{ background:linear-gradient(180deg,var(--amber),var(--amber-2)); color:var(--amber-ink); box-shadow:var(--glow-amb); }
.btn--amber:hover{ transform:translateY(-2px); box-shadow:0 0 0 1px rgba(255,182,39,.3), 0 20px 46px -16px rgba(255,182,39,.55); }
.btn--ghost{ background:rgba(255,255,255,.03); color:var(--ink); border-color:var(--line-2); }
.btn--ghost:hover{ background:rgba(255,255,255,.07); border-color:var(--amber); color:#fff; transform:translateY(-2px); }

/* ---------- Utility bar ---------- */
.utilbar{ background:#070A11; border-bottom:1px solid var(--line); font-size:12.5px; }
.utilbar__in{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding-block:8px; }
.utilbar__lic{ font-family:var(--f-mono); color:var(--ink-mute); display:inline-flex; align-items:center; gap:8px; letter-spacing:.01em; }
.utilbar__contact{ display:flex; gap:8px; align-items:center; font-family:var(--f-mono); color:var(--ink); }
.utilbar__contact a:hover{ color:var(--amber); }
.utilbar .sep{ color:var(--ink-dim); }
.u-short{ display:none; }
@media (max-width:620px){
  .u-full{ display:none; }
  .u-short{ display:inline; }
  .utilbar__contact{ display:none; }
}

/* ---------- Header ---------- */
.site-head{ position:sticky; top:0; z-index:160; background:rgba(10,14,23,.78); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
.site-head__in{ display:flex; align-items:center; gap:20px; padding-block:12px; }
.brand{ display:inline-flex; align-items:center; gap:11px; margin-right:auto; position:relative; z-index:151; }
.brand__mark{ color:var(--amber); width:auto; height:36px; flex:none; }
img.brand__mark{ object-fit:contain; }
.brand__txt{ display:flex; flex-direction:column; line-height:1.05; }
.brand__txt strong{ font-family:var(--f-disp); font-weight:800; font-size:17px; letter-spacing:-.01em; }
.brand__txt em{ font-family:var(--f-mono); font-style:normal; font-size:10.5px; color:var(--amber); letter-spacing:.14em; text-transform:uppercase; }

.nav{ display:flex; gap:4px; }
.nav__foot{ display:none; }
.nav a{ padding:9px 14px; border-radius:9px; color:var(--ink-mute); font-weight:600; font-size:15px; transition:color .18s, background .18s; }
.nav a:hover{ color:var(--ink); background:rgba(255,255,255,.05); }

.head-cta{ flex:none; }
.burger{ display:none; position:relative; z-index:151; flex-direction:column; gap:5px; width:44px; height:44px; align-items:center; justify-content:center; background:transparent; border:1px solid var(--line-2); border-radius:11px; cursor:pointer; }
.burger span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s var(--ease), opacity .2s; }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width:860px){
  .head-cta{ display:none; }
  .burger{ display:flex; }
  /* backdrop-filter pe header ar ancora meniul fixed în bara de header (containing block).
     Pe mobil îl scoatem → meniul fixed se raportează corect la viewport. */
  .site-head{ backdrop-filter:none; -webkit-backdrop-filter:none; background:#0A0E17; }
  .nav{
    position:fixed; top:0; left:0; right:0; bottom:0; width:100vw; height:100vh; height:100dvh; z-index:150;
    flex-direction:column; align-items:center; justify-content:center; gap:6px;
    padding:80px 24px 40px;
    background:#0A0E17;
    transform:translateX(100%); transition:transform .35s var(--ease);
    overflow-y:auto;
  }
  .nav.open{ transform:translateX(0); }
  .nav > a{ width:100%; text-align:center; font-family:var(--f-disp); font-weight:700; font-size:24px; padding:14px 24px; color:var(--ink); }
  .nav > a:hover, .nav > a:active{ color:var(--amber); background:transparent; }
  .nav__foot{ display:flex; flex-direction:column; align-items:center; gap:10px; position:absolute; left:0; right:0; bottom:30px; padding:24px 24px 0; }
  .nav .nav__tel{ display:inline-flex; align-items:center; gap:8px; font-family:var(--f-disp); font-weight:800; font-size:20px; color:var(--amber); padding:0; width:auto; }
  .nav .nav__tel::before{ content:"📞"; font-size:15px; }
  .nav__copy{ font-family:var(--f-mono); font-size:11px; line-height:1.6; letter-spacing:.04em; color:var(--ink-dim); text-align:center; }
}

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; padding-block:clamp(48px,9vw,104px); background:radial-gradient(120% 90% at 80% -10%, #10203a 0%, var(--bg) 55%); }
.hero__grid{ position:absolute; inset:0; background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px); background-size:46px 46px; -webkit-mask-image:radial-gradient(120% 80% at 70% 0%,#000 0%,transparent 70%); mask-image:radial-gradient(120% 80% at 70% 0%,#000 0%,transparent 70%); opacity:.5; }
.hero__glow{ position:absolute; width:560px; height:560px; right:-80px; top:-120px; background:radial-gradient(circle, rgba(255,182,39,.16), transparent 62%); filter:blur(8px); pointer-events:none; }
.hero__in{ position:relative; display:grid; grid-template-columns:1.15fr .85fr; gap:40px; align-items:center; }

.eyebrow{ font-family:var(--f-mono); text-transform:uppercase; letter-spacing:.16em; font-size:12px; color:var(--ink-mute); display:inline-flex; align-items:center; gap:9px; margin:0 0 18px; }
.hero__title{ font-size:clamp(40px,7.2vw,74px); font-weight:900; }
.hero__title span{ color:var(--ink-mute); }
.hero__title .acc{ color:var(--amber); }
.hero__lead{ color:var(--ink-mute); font-size:clamp(16px,2.2vw,19px); max-width:54ch; margin:20px 0 28px; }
.hero__cta{ display:flex; gap:13px; flex-wrap:wrap; }
.hero__trust{ list-style:none; display:flex; flex-wrap:wrap; gap:10px 28px; margin:34px 0 0; padding:24px 0 0; border-top:1px solid var(--line); }
.hero__trust li{ font-size:13.5px; color:var(--ink-mute); }
.hero__trust strong{ display:block; font-family:var(--f-disp); color:var(--ink); font-size:20px; }
@media (max-width:820px){
  .hero__trust{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px 8px; text-align:center; }
  .hero__trust strong{ font-size:17px; }
  .hero__trust li{ font-size:12px; }
}
@media (max-width:360px){ .hero__trust strong{ font-size:15px; } }

/* radar */
.hero__radar{ display:flex; flex-direction:column; align-items:center; gap:16px; }
.radar{ position:relative; width:min(340px,72vw); aspect-ratio:1; border-radius:50%; background:radial-gradient(circle at 50% 50%, rgba(52,211,153,.06), rgba(10,14,23,.2) 70%); border:1px solid var(--line-2); box-shadow:inset 0 0 60px rgba(0,0,0,.6), var(--shadow); }
.radar__ring{ position:absolute; inset:0; margin:auto; border:1px solid rgba(52,211,153,.16); border-radius:50%; }
.radar__ring.r1{ width:33%; height:33%; }
.radar__ring.r2{ width:62%; height:62%; }
.radar__ring.r3{ width:90%; height:90%; }
.radar__cross{ position:absolute; background:rgba(52,211,153,.12); }
.radar__cross--x{ left:5%; right:5%; top:50%; height:1px; }
.radar__cross--y{ top:5%; bottom:5%; left:50%; width:1px; }
.radar__sweep{ position:absolute; inset:0; border-radius:50%; background:conic-gradient(from 0deg, rgba(52,211,153,.45), rgba(52,211,153,.04) 50deg, transparent 120deg); -webkit-mask:radial-gradient(circle, transparent 0, #000 0); animation:sweep 4s linear infinite; }
@keyframes sweep{ to{ transform:rotate(360deg); } }
.radar__core{ position:absolute; inset:0; margin:auto; width:8px; height:8px; border-radius:50%; background:var(--ok); box-shadow:0 0 12px var(--ok); }
.radar__blip{ position:absolute; width:8px; height:8px; border-radius:50%; background:var(--amber); box-shadow:0 0 10px var(--amber); opacity:0; animation:blip 4s linear infinite; }
.radar__blip.b1{ top:28%; left:64%; animation-delay:.6s; }
.radar__blip.b2{ top:62%; left:38%; animation-delay:2.1s; }
.radar__blip.b3{ top:46%; left:73%; animation-delay:3.2s; }
@keyframes blip{ 0%,100%{ opacity:0; transform:scale(.6);} 6%{ opacity:1; transform:scale(1);} 40%{ opacity:.15;} }
.radar__label{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:.12em; color:var(--ink-mute); margin:0; }

@media (prefers-reduced-motion:reduce){ .radar__sweep,.radar__blip,.dot--ok{ animation:none; } .radar__blip{ opacity:.9; } }

@media (max-width:820px){
  .hero__in{ grid-template-columns:1fr; gap:36px; }
  .hero__radar{ order:-1; }
  .hero__cta{ justify-content:center; }
  .hero__cta .btn{ flex:1 1 auto; min-width:150px; max-width:240px; }
}

/* ---------- Trust strip ---------- */
.strip{ border-block:1px solid var(--line); background:var(--bg-2); }
.strip__in{ display:grid; grid-template-columns:repeat(4,1fr); }
.strip__item{ display:flex; gap:13px; align-items:flex-start; padding:24px 22px; }
.strip__item + .strip__item{ border-left:1px solid var(--line); }
.strip__item svg{ width:26px; height:26px; flex:none; color:var(--amber); margin-top:2px; }
.strip__item strong{ display:block; font-family:var(--f-disp); font-size:15px; }
.strip__item span{ font-size:13px; color:var(--ink-mute); line-height:1.45; }
@media (max-width:820px){
  .strip__in{ grid-template-columns:1fr 1fr; }
  .strip__item:nth-child(3){ border-left:0; }
  .strip__item:nth-child(n+3){ border-top:1px solid var(--line); }
}
@media (max-width:480px){
  .strip__in{ grid-template-columns:1fr; }
  .strip__item + .strip__item{ border-left:0; border-top:1px solid var(--line); }
}

/* ---------- Section shell ---------- */
.section{ padding-block:clamp(56px,9vw,108px); scroll-margin-top:78px; }
#top{ scroll-margin-top:0; }
.section--alt{ background:var(--bg-2); border-block:1px solid var(--line); }
.sec-head{ max-width:680px; margin-bottom:clamp(34px,5vw,56px); }
.sec-head__idx{ font-family:var(--f-mono); font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--amber); margin:0 0 14px; }
.sec-head__title{ font-size:clamp(30px,5vw,46px); }
.sec-head__sub{ color:var(--ink-mute); font-size:clamp(15px,2vw,17.5px); margin:16px 0 0; }

/* ---------- Servicii ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.svc{ position:relative; padding:28px 24px 26px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:border-color .25s, transform .25s var(--ease), background .25s; }
.svc::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:linear-gradient(90deg,var(--amber),var(--amber-2)); transition:width .35s var(--ease); }
.svc:hover{ transform:translateY(-4px); border-color:var(--line-2); background:var(--surface-2); }
.svc:hover::before{ width:100%; }
.svc__n{ font-family:var(--f-mono); font-size:13px; color:var(--ink-dim); }
.svc h3{ font-size:20px; margin:14px 0 10px; }
.svc p{ color:var(--ink-mute); font-size:14.5px; margin:0; }
.svc--wide{ grid-column:span 1; }
@media (max-width:880px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .svc-grid{ grid-template-columns:1fr; } }

/* ---------- Produse ---------- */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.prod{ display:flex; flex-direction:column; gap:12px; padding:26px 22px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); transition:transform .25s var(--ease), border-color .25s, box-shadow .25s; }
.prod:hover{ transform:translateY(-4px); border-color:rgba(255,182,39,.4); box-shadow:var(--glow-amb); }
.prod__ico{ width:50px; height:50px; display:grid; place-items:center; border-radius:13px; background:radial-gradient(circle at 30% 25%, rgba(255,182,39,.18), rgba(255,182,39,.04)); border:1px solid rgba(255,182,39,.22); color:var(--amber); }
.prod__ico svg{ width:26px; height:26px; }
.prod h3{ font-size:17px; }
.prod p{ color:var(--ink-mute); font-size:14px; margin:0; }
@media (max-width:980px){ .prod-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .prod-grid{ grid-template-columns:1fr; } }
.prod-note{ text-align:center; margin:34px 0 0; color:var(--ink-mute); }
.prod-note a{ color:var(--amber); font-weight:700; border-bottom:1px solid rgba(255,182,39,.4); }

/* ---------- Product filter chips ---------- */
.prod-filter{ display:flex; flex-wrap:wrap; gap:9px; margin-bottom:26px; }
.chip{ font-family:var(--f-body); font-weight:600; font-size:13.5px; color:var(--ink-mute); background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:9px 16px; cursor:pointer; transition:color .18s, background .18s, border-color .18s; }
.chip:hover{ color:var(--ink); border-color:var(--line-2); }
.chip.is-active{ color:var(--amber-ink); background:linear-gradient(180deg,var(--amber),var(--amber-2)); border-color:transparent; }
@media (max-width:560px){
  .prod-filter{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:8px; }
  .chip{ text-align:center; padding:11px 10px; font-size:13px; }
}

/* ---------- Product cards (real catalog) ---------- */
.pc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.pc{ display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:transform .25s var(--ease), border-color .25s, box-shadow .25s; }
.pc:hover{ transform:translateY(-4px); border-color:rgba(255,182,39,.35); box-shadow:var(--glow-amb); }
.pc__media{ position:relative; aspect-ratio:1; background:#fff; display:grid; place-items:center; }
.pc__media img{ width:100%; height:100%; object-fit:contain; padding:14px; }
.pc__badge{ position:absolute; top:10px; left:10px; z-index:2; font-family:var(--f-mono); font-size:10.5px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--amber-ink); background:var(--amber); padding:4px 9px; border-radius:6px; }
.pc__body{ display:flex; flex-direction:column; gap:8px; padding:16px 16px 18px; flex:1; }
.pc__cat{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-dim); }
.pc__name{ font-size:14.5px; line-height:1.3; font-weight:700; font-family:var(--f-body); letter-spacing:-.005em; flex:1; }
.pc__foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:6px; padding-top:12px; border-top:1px solid var(--line); }
.pc__price{ font-family:var(--f-disp); font-weight:800; font-size:17px; color:var(--amber); white-space:nowrap; }
.pc__cta{ font-size:12.5px; font-weight:700; color:var(--ink-mute); border:1px solid var(--line-2); border-radius:8px; padding:7px 11px; transition:color .18s, border-color .18s, background .18s; white-space:nowrap; }
.pc__cta:hover{ color:var(--amber-ink); background:var(--amber); border-color:transparent; }
.pc.is-hidden{ display:none; }
.pc-note{ margin:14px 0 0; font-size:13px; color:var(--ink-dim); }
@media (max-width:980px){ .pc-grid{ grid-template-columns:1fr 1fr 1fr; } }
@media (max-width:720px){ .pc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:380px){ .pc-grid{ grid-template-columns:1fr 1fr; gap:12px; } .pc__name{ font-size:13.5px; } }

/* ---------- Oferta speciala ---------- */
.offer{ position:relative; display:grid; grid-template-columns:1.6fr .9fr; gap:0; border:1px solid rgba(255,182,39,.28); border-radius:var(--r-lg); overflow:hidden; background:linear-gradient(180deg,var(--surface),var(--bg-2)); box-shadow:var(--shadow); }
.offer__glow{ position:absolute; right:-120px; top:-120px; width:380px; height:380px; background:radial-gradient(circle,rgba(255,182,39,.18),transparent 65%); pointer-events:none; }
.offer__body{ position:relative; padding:clamp(28px,4vw,44px); }
.offer__tag{ font-family:var(--f-mono); font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--amber); margin:0 0 12px; }
.offer__title{ font-size:clamp(24px,3.6vw,36px); }
.offer__title span{ color:var(--amber); }
.offer__desc{ color:var(--ink-mute); font-size:15px; margin:16px 0 18px; max-width:60ch; }
.offer__list{ list-style:none; padding:0; margin:0 0 26px; display:grid; gap:9px; }
.offer__list li{ position:relative; padding-left:26px; font-size:14.5px; color:var(--ink); }
.offer__list li::before{ content:""; position:absolute; left:0; top:7px; width:14px; height:8px; border-left:2px solid var(--amber); border-bottom:2px solid var(--amber); transform:rotate(-45deg); }
.offer__price{ position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; padding:32px 20px; background:radial-gradient(circle at 50% 0%, rgba(255,182,39,.12), transparent 70%); border-left:1px solid rgba(255,182,39,.2); text-align:center; }
.offer__from{ font-family:var(--f-mono); font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); }
.offer__amount{ font-family:var(--f-disp); font-weight:900; font-size:clamp(54px,9vw,76px); line-height:1; color:#fff; }
.offer__amount small{ font-size:.32em; color:var(--amber); margin-left:6px; font-weight:700; }
.offer__vat{ font-size:12.5px; color:var(--ink-mute); }
@media (max-width:760px){ .offer{ grid-template-columns:1fr; } .offer__price{ border-left:none; border-top:1px solid rgba(255,182,39,.2); } .offer__body .btn{ display:flex; width:fit-content; margin-inline:auto; } }

/* ---------- Despre ---------- */
.despre{ display:grid; grid-template-columns:1.3fr .7fr; gap:44px; align-items:start; }
.despre__copy p{ color:var(--ink-mute); margin:0 0 16px; }
.despre__copy .sec-head__title{ margin-bottom:18px; }
.despre__legal{ font-size:14px; padding:18px 20px; border-left:3px solid var(--amber); background:var(--surface); border-radius:0 12px 12px 0; }
.despre__legal strong{ color:var(--ink); }
.despre__cards{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fact{ padding:22px 20px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); }
.fact__k{ display:block; font-family:var(--f-mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:8px; }
.fact__v{ font-family:var(--f-disp); font-weight:800; font-size:22px; color:var(--amber); }
@media (max-width:860px){ .despre{ grid-template-columns:1fr; gap:30px; } }
@media (max-width:420px){ .despre__cards{ grid-template-columns:1fr; } }

/* ---------- Nota persoane juridice ---------- */
.note-band{ background:linear-gradient(90deg, rgba(255,182,39,.07), transparent); border-block:1px solid var(--line); }
.note-band__in{ display:flex; gap:16px; align-items:flex-start; padding-block:26px; }
.note-band svg{ color:var(--amber); flex:none; margin-top:2px; }
.note-band p{ margin:0; color:var(--ink-mute); font-size:14.5px; }
.note-band strong{ color:var(--ink); }

/* ---------- Contact ---------- */
.contact{ display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:stretch; }
.contact__cards{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cc{ display:flex; flex-direction:column; gap:5px; padding:22px 20px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); transition:border-color .22s, transform .22s var(--ease), background .22s; }
a.cc:hover{ transform:translateY(-3px); border-color:rgba(255,182,39,.4); background:var(--surface-2); }
.cc__k{ font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); }
.cc__v{ font-family:var(--f-disp); font-weight:800; font-size:19px; color:var(--ink); }
a.cc:hover .cc__v{ color:var(--amber); }
.cc__sub{ font-size:13px; color:var(--ink-mute); }
.cc--static{ background:var(--bg-2); }
.cc--wide{ grid-column:1 / -1; flex-direction:row; flex-wrap:wrap; gap:18px 56px; }
.cc__part{ display:flex; flex-direction:column; gap:5px; }
.cc__v--sm{ font-size:16px; }
@media (max-width:440px){ .cc--wide{ flex-direction:column; gap:18px; } }
.cc--wa .cc__k{ color:#25D366; }
a.cc--wa:hover{ border-color:rgba(37,211,102,.5); }
a.cc--wa:hover .cc__v{ color:#25D366; }
.contact__map{ position:relative; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; min-height:300px; margin-top:24px; }
.contact__map iframe{ width:100%; height:100%; min-height:340px; border:0; filter:grayscale(.4) contrast(1.05) brightness(.92); }
@media (max-width:860px){ .contact{ grid-template-columns:1fr; } }
@media (max-width:440px){ .contact__cards{ grid-template-columns:1fr; } }

/* ---------- Contact form ---------- */
.contact__form{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(22px,3.5vw,32px); }
.contact__form-lead{ margin:0 0 20px; color:var(--ink-mute); font-size:15px; }
.field{ margin-bottom:16px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field label{ display:block; font-size:13px; font-weight:600; color:var(--ink-mute); margin-bottom:7px; }
.field label span{ color:var(--amber); }
.field input, .field textarea{ width:100%; font-family:var(--f-body); font-size:16px; color:var(--ink); background:var(--bg-2); border:1px solid var(--line-2); border-radius:11px; padding:13px 15px; transition:border-color .18s, box-shadow .18s; -webkit-appearance:none; appearance:none; }
.field input::placeholder, .field textarea::placeholder{ color:var(--ink-dim); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--amber); box-shadow:0 0 0 3px rgba(255,182,39,.16); }
.field textarea{ resize:vertical; min-height:104px; line-height:1.5; }
.contact__form .btn{ width:100%; margin-top:4px; }
.contact__form-note{ margin:14px 0 0; font-size:12.5px; color:var(--ink-dim); text-align:center; }
.contact__form-note a{ color:var(--ink-mute); border-bottom:1px solid var(--line-2); }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-status{ margin:14px 0 0; padding:0; font-size:14px; font-weight:600; text-align:center; }
.form-status.ok{ color:#34D399; }
.form-status.err{ color:#ff6b6b; }
.form-status:empty{ display:none; }
@media (max-width:480px){ .field-row{ grid-template-columns:1fr; gap:0; } }

/* ---------- Footer credit ---------- */
.foot__credit{ font-family:var(--f-mono); font-size:12.5px; letter-spacing:.02em; }
.foot__credit a{ color:var(--amber); }
.foot__credit a:hover{ text-decoration:underline; }
.foot__credit svg{ display:inline-block; width:14px; height:14px; vertical-align:-2px; }
.ic-heart{ color:#ff5d6c; }
.ic-coffee{ color:#e7dcc6; }

/* ---------- Footer ---------- */
.foot{ background:#070A11; border-top:1px solid var(--line); padding-block:48px 0; }
.foot__in{ display:grid; grid-template-columns:1.4fr 1fr 1.2fr; gap:36px; padding-bottom:36px; }
.foot__brand{ display:flex; flex-direction:column; gap:14px; align-items:flex-start; }
.foot__logo{ width:auto; height:124px; max-width:100%; object-fit:contain; }
.foot__brand p{ color:var(--ink-mute); font-size:13px; margin:0; }
.foot__nav{ display:flex; flex-direction:column; gap:10px; }
.foot__nav a{ color:var(--ink-mute); font-size:14.5px; width:fit-content; }
.foot__nav a:hover{ color:var(--amber); }
.foot__legal{ display:flex; flex-direction:column; gap:9px; }
.foot__legal a{ color:var(--ink-mute); font-size:13.5px; width:fit-content; }
.foot__legal a:hover{ color:var(--ink); }
.foot__anpc{ display:flex; gap:14px; margin-top:6px; }
.foot__anpc a{ font-family:var(--f-mono); font-size:12px; color:var(--amber); }
.foot__bottom{ display:flex; justify-content:space-between; gap:10px; flex-wrap:wrap; padding-block:20px; border-top:1px solid var(--line); font-size:13px; color:var(--ink-dim); }
.foot__bottom p{ margin:0; }
.foot__bottom p:last-child{ font-family:var(--f-mono); letter-spacing:.08em; }
@media (max-width:760px){ .foot__in{ grid-template-columns:1fr; gap:28px; } }

/* ---------- WhatsApp button (hero) ---------- */
.btn--wa{ background:#25D366; color:#062b16; }
.btn--wa:hover{ background:#22c45e; transform:translateY(-2px); box-shadow:0 18px 40px -16px rgba(37,211,102,.6); }
.btn--wa svg{ flex:none; }

/* ---------- Floating action buttons ---------- */
.fab-stack{ position:fixed; right:16px; bottom:16px; z-index:80; display:flex; flex-direction:column; gap:12px; }
.fab{ position:relative; width:56px; height:56px; border-radius:50%; display:grid; place-items:center; box-shadow:var(--shadow); transition:transform .2s var(--ease); }
.fab:active{ transform:scale(.94); }
.fab svg{ width:28px; height:28px; }
.fab--wa{ background:#25D366; color:#fff; box-shadow:0 12px 30px -8px rgba(37,211,102,.55); }
.fab--wa::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25D366; animation:ring 2.4s ease-out infinite; }
.fab--call{ background:linear-gradient(180deg,var(--amber),var(--amber-2)); color:var(--amber-ink); display:none; }
.fab--top{ background:var(--surface-2); color:var(--ink); border:1px solid var(--line-2); }
.fab--top:hover{ border-color:var(--amber); color:var(--amber); }
.fab.is-hidden{ opacity:0; visibility:hidden; transform:scale(.7); pointer-events:none; transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s; }
@keyframes ring{ 0%{ transform:scale(1); opacity:.6;} 100%{ transform:scale(1.55); opacity:0;} }
@media (max-width:860px){
  .fab--call{ display:grid; }
  .fab-stack{ bottom:14px; right:14px; }
}
@media (prefers-reduced-motion:reduce){ .fab--wa::after{ animation:none; } }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } }

/* focus states */
a:focus-visible,.btn:focus-visible,button:focus-visible{ outline:2px solid var(--amber); outline-offset:3px; border-radius:8px; }

/* ---------- Map consent placeholder ---------- */
.map-consent{ position:absolute; inset:0; display:flex; flex-direction:column; gap:12px; align-items:center; justify-content:center; text-align:center; padding:24px; background:linear-gradient(180deg,var(--surface),var(--bg-2)); }
.map-consent svg{ width:34px; height:34px; color:var(--ink-dim); }
.map-consent p{ margin:0; font-size:13.5px; color:var(--ink-mute); max-width:36ch; }
.map-consent button{ margin-top:4px; font:inherit; }

/* ---------- Cookie bar ---------- */
.cookiebar{ position:fixed; left:50%; bottom:18px; transform:translateX(-50%) translateY(140%); z-index:120; width:min(960px, calc(100% - 28px)); display:grid; grid-template-columns:1fr auto; gap:18px 24px; align-items:center; padding:20px 22px; background:rgba(15,21,33,.96); backdrop-filter:blur(14px); border:1px solid var(--line-2); border-radius:var(--r-lg); box-shadow:var(--shadow); transition:transform .45s var(--ease); }
.cookiebar.show{ transform:translateX(-50%) translateY(0); }
.cookiebar__txt{ font-size:13.5px; color:var(--ink-mute); line-height:1.55; }
.cookiebar__txt strong{ color:var(--ink); font-family:var(--f-disp); display:block; margin-bottom:3px; font-size:15px; }
.cookiebar__txt a{ color:var(--amber); border-bottom:1px solid rgba(255,182,39,.4); }
.cookiebar__btns{ display:flex; gap:10px; flex-wrap:wrap; }
@media (max-width:640px){
  .cookiebar{ grid-template-columns:1fr; gap:14px; bottom:0; left:0; transform:translateY(140%); width:100%; border-radius:16px 16px 0 0; border-left:0; border-right:0; border-bottom:0; }
  .cookiebar.show{ transform:translateY(0); }
  .cookiebar__btns .btn{ flex:1; }
}

/* ---------- Legal pages ---------- */
.legal-head{ position:sticky; top:0; z-index:50; background:rgba(10,14,23,.85); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.legal-head__in{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:14px; }
.legal-back{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:14.5px; color:var(--ink-mute); }
.legal-back:hover{ color:var(--amber); }
.legal-back svg{ width:18px; height:18px; }
.legal-wrap{ max-width:820px; margin-inline:auto; padding:clamp(40px,7vw,80px) 20px; }
.legal-wrap h1{ font-size:clamp(30px,5vw,44px); margin-bottom:10px; }
.legal-kicker{ font-family:var(--f-mono); font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--amber); margin:0 0 16px; }
.legal-updated{ font-size:13px; color:var(--ink-dim); margin:0 0 30px; padding-bottom:24px; border-bottom:1px solid var(--line); }
.legal-body h2{ font-size:clamp(20px,3vw,26px); margin:38px 0 12px; }
.legal-body h3{ font-size:17px; margin:24px 0 8px; font-family:var(--f-disp); }
.legal-body p, .legal-body li{ color:var(--ink-mute); font-size:15.5px; line-height:1.7; }
.legal-body p{ margin:0 0 14px; }
.legal-body ul{ margin:0 0 16px; padding-left:22px; }
.legal-body li{ margin-bottom:7px; }
.legal-body a{ color:var(--amber); border-bottom:1px solid rgba(255,182,39,.35); }
.legal-body strong{ color:var(--ink); }
.legal-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:22px 24px; margin:0 0 26px; }
.legal-card p{ margin:0 0 6px; font-size:14.5px; }
.legal-card p:last-child{ margin:0; }
.legal-foot{ border-top:1px solid var(--line); background:#070A11; }
.legal-foot__in{ display:flex; flex-wrap:wrap; gap:10px 22px; justify-content:space-between; align-items:center; padding-block:22px; font-size:13px; color:var(--ink-dim); }
.legal-foot__in a{ color:var(--ink-mute); }
.legal-foot__in a:hover{ color:var(--amber); }
.legal-foot__links{ display:flex; flex-wrap:wrap; gap:8px 18px; }
