/* ===========================================================
   PRIZMA — креативна рекламна агенція повного циклу
   Signature: spectral refraction / chromatic aberration (prism)
   Type: Syne (display) + Inter (body) · Palette: bone / ink / spectrum
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Inter:wght@400;500;600&display=swap');

/* ---------- Tokens ---------- */
:root{
  --paper:#efeadd;
  --paper-2:#e6e0d0;
  --ink:#0e0e12;
  --ink-2:#1a1a20;
  --muted:#56564f;
  --line:rgba(14,14,18,.14);
  --line-2:rgba(14,14,18,.08);

  --mag:#ff2d78;
  --vio:#6c4df5;
  --cyn:#1fd1d1;
  --amb:#ffb02e;

  --spectrum:linear-gradient(90deg,#ff2d78 0%,#ff7a3d 22%,#ffd23d 42%,#1fd1d1 64%,#6c4df5 86%,#b14dff 100%);
  --spectrum-soft:linear-gradient(90deg,rgba(255,45,120,.9),rgba(108,77,245,.9),rgba(31,209,209,.9));

  --font-d:'Syne',sans-serif;
  --font-b:'Inter',system-ui,sans-serif;

  --container:1320px;
  --gut:clamp(20px,5vw,48px);
  --radius:18px;

  --ease:cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font-b);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-d);font-weight:800;line-height:1.02;letter-spacing:-.03em}
::selection{background:var(--vio);color:#fff}

/* ---------- Helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--font-b);font-weight:600;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--ink);display:inline-block}
.eyebrow.spec::before{background:var(--spectrum)}
.lead{font-size:clamp(18px,2.3vw,22px);line-height:1.55;color:var(--ink-2);max-width:62ch}
.muted{color:var(--muted)}
.spectrum-text{
  background:var(--spectrum);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.skip-link{
  position:absolute;left:16px;top:-60px;background:var(--ink);color:#fff;padding:12px 18px;
  border-radius:10px;z-index:1000;transition:top .2s var(--ease);
}
.skip-link:focus{top:16px}

/* visible-by-default reveal: animate transform only */
.reveal{opacity:1;transform:translateY(26px);transition:transform .8s var(--ease),opacity .8s var(--ease)}
.reveal.in{transform:translateY(0)}
.reveal[data-d="1"]{transition-delay:.06s}
.reveal[data-d="2"]{transition-delay:.12s}
.reveal[data-d="3"]{transition-delay:.18s}
.reveal[data-d="4"]{transition-delay:.24s}
.reveal[data-d="5"]{transition-delay:.3s}

/* ---------- Buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:16px 26px;border-radius:100px;font-weight:600;font-size:15px;
  letter-spacing:.01em;transition:transform .35s var(--ease),background .35s,color .35s;
  min-height:48px;
}
.btn svg{width:16px;height:16px;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{transform:translateY(-3px)}
.btn-primary::after{
  content:"";position:absolute;inset:0;border-radius:100px;background:var(--spectrum);
  opacity:0;transition:opacity .35s;z-index:-1;
}
.btn-primary:hover::after{opacity:1}
.btn-primary:hover{color:#fff}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-3px)}
.btn:focus-visible{outline:3px solid var(--vio);outline-offset:3px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(239,234,221,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.site-header.scrolled{border-bottom-color:var(--line);background:rgba(239,234,221,.95)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.brand{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-d);font-weight:800;font-size:22px;letter-spacing:-.02em}
.brand .glyph{
  width:26px;height:26px;flex:none;position:relative;
}
.brand .glyph svg{width:100%;height:100%;display:block}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  position:relative;padding:9px 14px;border-radius:100px;font-size:15px;font-weight:500;
  color:var(--ink-2);transition:color .25s,background .25s;
}
.nav-links a:hover{background:rgba(14,14,18,.06)}
.nav-links a.active{color:var(--ink);font-weight:600}
.nav-links a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:3px;height:2px;background:var(--spectrum);border-radius:2px;
}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;width:44px;height:44px;border-radius:12px;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:2px;background:var(--ink);position:relative;transition:transform .3s,opacity .3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--ink);transition:transform .3s}
.burger span::before{top:-7px}.burger span::after{top:7px}
.burger.open span{background:transparent}
.burger.open span::before{transform:translateY(7px) rotate(45deg)}
.burger.open span::after{transform:translateY(-7px) rotate(-45deg)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--paper);padding:clamp(64px,9vw,110px) 0 36px;margin-top:clamp(80px,12vw,150px)}
.footer-spectrum{height:5px;background:var(--spectrum)}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:48px}
.footer-brand .brand{color:var(--paper);font-size:30px}
.footer-brand p{color:rgba(239,234,221,.6);max-width:34ch;margin-top:18px;font-size:15px}
.footer-col h4{font-family:var(--font-b);font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(239,234,221,.45);margin-bottom:18px}
.footer-col a,.footer-col p{display:block;color:rgba(239,234,221,.82);font-size:15px;padding:7px 0;transition:color .2s,transform .25s var(--ease)}
.footer-col a:hover{color:#fff;transform:translateX(5px)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-top:clamp(48px,7vw,80px);padding-top:28px;border-top:1px solid rgba(239,234,221,.14);color:rgba(239,234,221,.5);font-size:13px}
.footer-bottom a:hover{color:#fff}
.footer-bottom .socials{display:flex;gap:10px}
.footer-bottom .socials a{width:40px;height:40px;border:1px solid rgba(239,234,221,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .25s,color .25s}
.footer-bottom .socials a:hover{background:var(--paper);color:var(--ink)}
.footer-bottom .socials svg{width:17px;height:17px}

/* ===========================================================
   HERO
   =========================================================== */
.hero{position:relative;padding:clamp(56px,9vw,110px) 0 clamp(48px,7vw,80px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,52px)}
.hero-tag{margin-bottom:26px}
.hero h1{
  font-size:clamp(3rem,13.5vw,12rem);line-height:.9;letter-spacing:-.045em;
  text-transform:uppercase;
}
/* chromatic aberration signature */
.chroma{position:relative;display:inline-block}
.chroma::before,.chroma::after{
  content:attr(data-text);position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;
}
.chroma::before{color:var(--mag);transform:translateX(-.018em);animation:abr 7s ease-in-out infinite}
.chroma::after{color:var(--cyn);transform:translateX(.018em);animation:abr 7s ease-in-out infinite reverse}
@keyframes abr{0%,100%{transform:translateX(-.018em)}50%{transform:translateX(.028em)}}
.hero-sub{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(24px,4vw,60px);align-items:end;margin-top:clamp(24px,3vw,36px)}
.hero-sub .lead{margin:0}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-meta{display:flex;flex-direction:column;gap:14px;font-size:14px;color:var(--muted)}
.hero-meta b{font-family:var(--font-d);font-size:clamp(2rem,4vw,3rem);color:var(--ink);font-weight:800;line-height:1;display:block}
.hero-beam{height:6px;border-radius:6px;background:var(--spectrum);margin-top:clamp(36px,5vw,64px);transform-origin:left;}

/* scrolling marquee */
.marquee{overflow:hidden;border-block:1px solid var(--line);padding:18px 0;white-space:nowrap;margin-top:clamp(36px,5vw,60px)}
.marquee-track{display:inline-flex;gap:40px;animation:scroll-x 32s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:var(--font-d);font-weight:700;font-size:clamp(1.4rem,3vw,2.2rem);text-transform:uppercase;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:40px;color:var(--ink)}
.marquee span::after{content:"✳";color:var(--vio);font-size:.7em}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ===========================================================
   SECTION SHELL
   =========================================================== */
.section{padding:clamp(64px,10vw,128px) 0}
.section-head{display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,60px);align-items:end;margin-bottom:clamp(40px,6vw,72px)}
.section-head .idx{font-family:var(--font-d);font-weight:700;font-size:14px;color:var(--vio)}
.section-head h2{font-size:clamp(2.2rem,6.5vw,5rem);letter-spacing:-.04em}
.section-head .sh-right{align-self:end;max-width:46ch}
@media(max-width:760px){.section-head{grid-template-columns:1fr;gap:18px}}

/* ---------- Services list (editorial rows) ---------- */
.svc-list{border-top:1px solid var(--line)}
.svc-row{
  display:grid;grid-template-columns:64px minmax(0,1.4fr) minmax(0,1.6fr) auto;gap:24px;
  align-items:center;padding:clamp(24px,3.5vw,40px) 0;border-bottom:1px solid var(--line);
  position:relative;transition:padding .4s var(--ease);
}
.svc-row .num{font-family:var(--font-d);font-weight:700;font-size:14px;color:var(--muted)}
.svc-row h3{font-size:clamp(1.6rem,4vw,2.6rem);letter-spacing:-.03em;min-width:0;transition:transform .4s var(--ease)}
.svc-row p{color:var(--muted);font-size:15px;min-width:0}
.svc-row .arr{width:46px;height:46px;border:1.5px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .35s,border-color .35s,transform .35s}
.svc-row .arr svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.svc-row:hover{background:linear-gradient(90deg,rgba(108,77,245,.05),transparent)}
.svc-row:hover h3{transform:translateX(10px)}
.svc-row:hover .arr{background:var(--ink);border-color:var(--ink);color:var(--paper);transform:rotate(-45deg)}
@media(max-width:760px){
  .svc-row{grid-template-columns:auto 1fr auto;gap:14px}
  .svc-row p{grid-column:1/-1}
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(20px,3vw,40px)}
.stat .n{font-family:var(--font-d);font-weight:800;font-size:clamp(2.6rem,6vw,4.6rem);line-height:1;letter-spacing:-.04em}
.stat .l{display:block;margin-top:12px;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.stat:nth-child(1) .n{color:var(--mag)}
.stat:nth-child(2) .n{color:var(--vio)}
.stat:nth-child(3) .n{color:var(--cyn)}
.stat:nth-child(4) .n{color:var(--amb)}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:32px 20px}}

/* ---------- Feature split (about teaser) ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.split .media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3}
.split .media img{width:100%;height:100%;object-fit:cover}
.split .media .badge{position:absolute;left:18px;bottom:18px;background:var(--paper);padding:12px 18px;border-radius:100px;font-weight:600;font-size:13px;display:flex;align-items:center;gap:8px}
.split .media .badge::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--spectrum)}
.split h2{font-size:clamp(2rem,5vw,3.6rem);margin-bottom:22px}
.split p+p{margin-top:16px}
.split .mini{display:flex;gap:32px;margin-top:30px;flex-wrap:wrap}
.split .mini div b{font-family:var(--font-d);font-size:1.6rem;display:block}
.split .mini div span{font-size:13px;color:var(--muted)}
@media(max-width:840px){.split{grid-template-columns:1fr}}

/* ---------- Work grid ---------- */
.work-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:clamp(18px,2.5vw,28px)}
.work-card{
  position:relative;border-radius:var(--radius);overflow:hidden;background:var(--paper-2);
  display:block;min-width:0;
}
.work-card .ph{position:relative;overflow:hidden;aspect-ratio:16/11}
.work-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.work-card:hover .ph img{transform:scale(1.06)}
.work-card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(14,14,18,.55));opacity:0;transition:opacity .4s}
.work-card:hover .ph::after{opacity:1}
.work-meta{padding:20px 22px;display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.work-meta h3{font-size:1.35rem;letter-spacing:-.02em;min-width:0}
.work-meta .cat{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.work-meta .yr{font-family:var(--font-d);font-weight:700;color:var(--vio);font-size:14px;flex:none}
.work-card.big{grid-column:span 7}
.work-card.med{grid-column:span 5}
.work-card.third{grid-column:span 4}
.tag-spectrum{display:inline-block;padding:5px 12px;border-radius:100px;font-size:12px;font-weight:600;background:var(--ink);color:var(--paper)}
@media(max-width:900px){
  .work-card.big,.work-card.med,.work-card.third{grid-column:span 6}
}
@media(max-width:600px){
  .work-card.big,.work-card.med,.work-card.third{grid-column:span 12}
}

/* ---------- Process / steps ---------- */
.process{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(18px,2.5vw,28px);counter-reset:step}
.step{padding:30px 26px;border-radius:var(--radius);background:var(--paper-2);min-width:0;position:relative;overflow:hidden}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--font-d);font-weight:800;font-size:clamp(2.4rem,5vw,3.4rem);color:var(--ink);opacity:.1;display:block;line-height:1}
.step h3{font-size:1.3rem;margin:16px 0 10px;letter-spacing:-.02em}
.step p{font-size:14.5px;color:var(--muted)}
.step .bar{position:absolute;left:0;top:0;height:4px;width:100%;background:var(--spectrum);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.step:hover .bar{transform:scaleX(1)}
@media(max-width:900px){.process{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.process{grid-template-columns:1fr}}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2.5vw,26px)}
.quote{padding:32px 28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);min-width:0;display:flex;flex-direction:column;gap:20px}
.quote .mark{font-family:var(--font-d);font-size:3rem;line-height:.6;color:var(--vio)}
.quote p{font-size:16.5px;color:var(--ink-2)}
.quote .who{display:flex;align-items:center;gap:14px;margin-top:auto}
.quote .who .av{width:46px;height:46px;border-radius:50%;background:var(--spectrum);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:800;color:#fff;flex:none}
.quote .who b{display:block;font-size:15px}
.quote .who span{font-size:13px;color:var(--muted)}
@media(max-width:900px){.quotes{grid-template-columns:1fr;max-width:560px}}

/* ---------- Logos strip ---------- */
.clients{display:flex;flex-wrap:wrap;gap:14px 28px;align-items:center}
.clients .c{font-family:var(--font-d);font-weight:700;font-size:clamp(1.1rem,2.4vw,1.6rem);color:var(--ink);opacity:.5;letter-spacing:-.02em;transition:opacity .3s}
.clients .c:hover{opacity:1}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--ink);color:var(--paper);border-radius:clamp(20px,3vw,32px);padding:clamp(44px,7vw,96px) clamp(28px,5vw,72px);overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:var(--spectrum);opacity:.16;mix-blend-mode:screen}
.cta-band h2{font-size:clamp(2.2rem,7vw,5.2rem);letter-spacing:-.04em;position:relative;max-width:16ch}
.cta-band p{color:rgba(239,234,221,.75);margin:22px 0 32px;max-width:50ch;position:relative}
.cta-band .btn-primary{background:var(--paper);color:var(--ink);position:relative}
.cta-band .btn-primary::after{background:var(--spectrum)}
.cta-band .btn-primary:hover{color:#fff}

/* ===========================================================
   PAGE HEADER (interior)
   =========================================================== */
.page-hero{padding:clamp(48px,7vw,90px) 0 clamp(32px,4vw,52px)}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:22px;display:flex;gap:8px;align-items:center}
.crumbs a:hover{color:var(--ink)}
.crumbs span{opacity:.5}
.page-hero h1{font-size:clamp(2.6rem,9vw,6.4rem);letter-spacing:-.04em;text-transform:uppercase;line-height:.94}
.page-hero .lead{margin-top:24px}

/* ---------- About: values ---------- */
.values{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2.5vw,26px)}
.value{padding:30px 26px;border:1px solid var(--line);border-radius:var(--radius);min-width:0;background:var(--paper)}
.value .ic{width:48px;height:48px;border-radius:14px;background:var(--ink);display:flex;align-items:center;justify-content:center;color:var(--paper);margin-bottom:20px}
.value .ic svg{width:22px;height:22px}
.value h3{font-size:1.35rem;margin-bottom:10px;letter-spacing:-.02em}
.value p{font-size:14.5px;color:var(--muted)}
@media(max-width:820px){.values{grid-template-columns:1fr;max-width:540px}}

/* ---------- Timeline ---------- */
.timeline{border-top:1px solid var(--line)}
.tl-row{display:grid;grid-template-columns:minmax(0,160px) minmax(0,1fr);gap:clamp(20px,4vw,56px);padding:clamp(24px,3vw,38px) 0;border-bottom:1px solid var(--line);align-items:baseline}
.tl-row .yr{font-family:var(--font-d);font-weight:800;font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--vio)}
.tl-row h3{font-size:1.4rem;margin-bottom:8px;letter-spacing:-.02em}
.tl-row p{color:var(--muted);font-size:15px;max-width:60ch}
@media(max-width:640px){.tl-row{grid-template-columns:1fr;gap:6px}}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(18px,2.5vw,26px)}
.member{min-width:0}
.member .ph{border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;background:var(--paper-2)}
.member .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);transition:filter .5s,transform .8s var(--ease)}
.member:hover .ph img{filter:grayscale(0);transform:scale(1.04)}
.member h3{font-size:1.25rem;margin-top:18px;letter-spacing:-.02em}
.member span{font-size:14px;color:var(--muted)}
@media(max-width:820px){.team{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* ---------- Services page detail cards ---------- */
.svc-detail{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(18px,3vw,28px)}
.svc-card{padding:clamp(28px,3.5vw,44px);border-radius:var(--radius);background:var(--paper-2);min-width:0;position:relative;overflow:hidden}
.svc-card .tagn{font-family:var(--font-d);font-weight:700;color:var(--vio);font-size:14px}
.svc-card h3{font-size:clamp(1.5rem,3vw,2.1rem);margin:14px 0 14px;letter-spacing:-.03em}
.svc-card p{color:var(--ink-2);font-size:15.5px;margin-bottom:22px}
.svc-card ul{display:flex;flex-wrap:wrap;gap:9px}
.svc-card ul li{font-size:13px;padding:7px 13px;border:1px solid var(--line);border-radius:100px;color:var(--muted)}
.svc-card .glow{position:absolute;right:-60px;top:-60px;width:180px;height:180px;border-radius:50%;background:var(--spectrum);filter:blur(50px);opacity:.18}
@media(max-width:760px){.svc-detail{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{max-width:880px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:26px 0;text-align:left}
.faq-q h3{font-size:clamp(1.15rem,2.6vw,1.5rem);letter-spacing:-.02em;min-width:0}
.faq-q .pm{flex:none;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--line);position:relative;transition:background .3s,border-color .3s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--ink);transition:transform .35s var(--ease),background .3s}
.faq-q .pm::before{left:50%;top:11px;bottom:11px;width:2px;transform:translateX(-50%)}
.faq-q .pm::after{top:50%;left:11px;right:11px;height:2px;transform:translateY(-50%)}
.faq-item.open .faq-q .pm{background:var(--ink);border-color:var(--ink)}
.faq-item.open .faq-q .pm::before{transform:translateX(-50%) scaleY(0);background:#fff}
.faq-item.open .faq-q .pm::after{background:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a-inner{padding:0 0 28px;color:var(--muted);font-size:16px;max-width:70ch}
.faq-item.open .faq-q h3{color:var(--vio)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:start}
.contact-info .ci{padding:22px 0;border-bottom:1px solid var(--line)}
.contact-info .ci .l{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.contact-info .ci a,.contact-info .ci p{font-family:var(--font-d);font-weight:700;font-size:clamp(1.2rem,2.6vw,1.7rem);letter-spacing:-.02em;word-break:break-word}
.contact-info .ci a:hover{color:var(--vio)}
.form{display:grid;gap:20px;background:var(--paper-2);padding:clamp(26px,4vw,44px);border-radius:var(--radius)}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:13px;font-weight:600;letter-spacing:.04em}
.field input,.field textarea,.field select{
  font:inherit;font-size:16px;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--paper);color:var(--ink);transition:border-color .25s,box-shadow .25s;width:100%;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--vio);box-shadow:0 0 0 4px rgba(108,77,245,.14)}
.field .err{font-size:13px;color:#c01f4a;display:none;align-items:center;gap:6px}
.field.invalid input,.field.invalid textarea{border-color:#c01f4a}
.field.invalid .err{display:flex}
.form-note{font-size:13px;color:var(--muted)}
.form-note a{text-decoration:underline}
.form-success{display:none;padding:18px 20px;border-radius:12px;background:rgba(31,209,209,.16);border:1px solid var(--cyn);color:#0d6b6b;font-weight:600;align-items:center;gap:10px}
.form-success.show{display:flex}
.map-wrap{margin-top:clamp(40px,6vw,72px);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/7;min-height:300px}
.map-wrap iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.3) contrast(1.05)}
@media(max-width:840px){.contact-grid{grid-template-columns:1fr}.map-wrap{aspect-ratio:4/3}}

/* ---------- Legal / privacy ---------- */
.legal{max-width:820px}
.legal h2{font-size:clamp(1.5rem,3.5vw,2rem);margin:44px 0 16px;letter-spacing:-.03em}
.legal h2:first-child{margin-top:0}
.legal p,.legal li{color:var(--ink-2);font-size:16.5px;line-height:1.7;margin-bottom:14px}
.legal ul{padding-left:24px;list-style:disc}
.legal li{margin-bottom:8px}
.legal a{color:var(--vio);text-decoration:underline}
.legal .updated{font-size:14px;color:var(--muted);margin-bottom:40px}

/* ---------- Cookie banner ---------- */
.cookie{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:560px;margin-inline:auto;
  background:var(--ink);color:var(--paper);border-radius:16px;padding:20px 22px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  box-shadow:0 20px 50px rgba(0,0,0,.3);transform:translateY(160%);transition:transform .6s var(--ease);
}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:14px;color:rgba(239,234,221,.82);flex:1;min-width:200px}
.cookie p a{text-decoration:underline;color:#fff}
.cookie .ck-actions{display:flex;gap:10px}
.cookie button{padding:11px 20px;border-radius:100px;font-weight:600;font-size:14px}
.cookie .accept{background:var(--paper);color:var(--ink)}
.cookie .accept:hover{background:#fff}
.cookie .decline{border:1px solid rgba(239,234,221,.3);color:var(--paper)}
.cookie .decline:hover{background:rgba(239,234,221,.12)}

/* ===========================================================
   RESPONSIVE — header / footer
   =========================================================== */
@media(max-width:980px){
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:880px){
  .burger{display:flex}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:var(--paper);flex-direction:column;align-items:stretch;
    gap:0;padding:16px var(--gut) 30px;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .5s var(--ease);box-shadow:0 24px 40px rgba(0,0,0,.08);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:16px 4px;border-bottom:1px solid var(--line-2);border-radius:0;font-size:18px}
  .nav-links a.active::after{display:none}
  .nav-cta .btn{display:none}
  .hero-sub{grid-template-columns:1fr}
}
@media(max-width:560px){
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{transform:none}
  .chroma::before,.chroma::after{display:none}
}
