/* BoardDay MICE — emotional, photo-heavy, event-industry vibe */
:root{
  --bg:#fbf7f2;        /* warm cream */
  --bg-2:#ffffff;
  --surface:#ffffff;
  --surface-2:#f3ede4;
  --line:rgba(20,16,12,.08);
  --line-strong:rgba(20,16,12,.14);
  --text:#14100c;
  --muted:#6b6258;
  --muted-soft:#a09684;
  --brand:#e15140;        /* coral */
  --brand-2:#c33c2b;
  --brand-soft:#fde7e2;
  --brand-glow:rgba(225,81,64,.2);
  --accent:#0c1a26;       /* deep navy */
  --gold:#c9a352;
  --r-xs:8px; --r-sm:12px; --r-md:18px; --r-lg:24px; --r-xl:32px;
  --container:1280px;
  --shadow-1:0 1px 2px rgba(20,16,12,.06),0 10px 30px rgba(20,16,12,.06);
  --shadow-2:0 18px 60px rgba(225,81,64,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:0;color:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
section{padding:96px 0;position:relative}
section.compact{padding:64px 0}
section.dark{background:var(--accent);color:#fff}
section.dark .lead, section.dark .muted{color:rgba(255,255,255,.7)}

h1,h2,h3,h4{font-weight:800;letter-spacing:-.025em;line-height:1.05}
h1{font-size:clamp(34px,4.5vw,64px)}
h2{font-size:clamp(30px,4vw,52px);margin-bottom:14px;line-height:1.08}
h3{font-size:clamp(20px,2vw,26px);font-weight:700;line-height:1.2}
.serif{font-family:'Playfair Display','Georgia',serif;font-weight:700;font-style:italic;letter-spacing:-.01em}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--muted);max-width:720px;line-height:1.6}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:var(--brand-soft);color:var(--brand-2);
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  max-width:100%;line-height:1.3;
  flex-wrap:wrap;
}
.eyebrow > *{min-width:0;flex:0 1 auto}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand)}
.eyebrow.dark{background:rgba(255,255,255,.1);color:#fff}
.eyebrow.dark::before{background:var(--gold)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 28px;border-radius:999px;font-weight:600;font-size:15px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;cursor:pointer;
}
.btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-2)}
.btn-primary:hover{background:var(--brand-2);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line-strong);color:var(--text);background:rgba(255,255,255,.6)}
.btn-ghost:hover{background:#fff;border-color:var(--text)}
.btn-light{background:#fff;color:var(--accent)}
.btn-light:hover{background:#f8f8f8;transform:translateY(-2px)}
.btn-dark{background:var(--accent);color:#fff}
.btn svg{width:16px;height:16px}

/* Header */
.hdr{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  background:rgba(251,247,242,.82);
  border-bottom:1px solid var(--line);
  transition:box-shadow .2s;
}
.hdr.scrolled{box-shadow:0 4px 24px rgba(20,16,12,.06);background:rgba(251,247,242,.95)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.hdr-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hdr-logo img{height:24px;width:auto;filter:invert(1) sepia(0)}
.hdr-logo .tag{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;border-left:1px solid var(--line-strong);padding-left:12px;margin-left:4px;white-space:nowrap}
.hdr-nav{display:flex;gap:28px;align-items:center}
.hdr-nav a{font-size:14px;color:var(--text);font-weight:500;transition:color .15s}
.hdr-nav a:hover{color:var(--brand)}
.hdr-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hdr-tel{font-weight:600;font-size:14px;white-space:nowrap}
.hdr-tel-mobile{display:none;width:44px;height:44px;border-radius:50%;background:var(--brand-soft);color:var(--brand);align-items:center;justify-content:center}
.hdr-burger{
  display:none;width:44px;height:44px;border-radius:12px;
  background:transparent;border:1px solid var(--line-strong);
  align-items:center;justify-content:center;
  cursor:pointer;
  position:relative;z-index:51;
  -webkit-tap-highlight-color:rgba(225,81,64,.15);
  touch-action:manipulation;
}
.hdr-burger svg{width:22px;height:22px}
.hdr-burger .b-close{display:none}
.hdr.menu-open .hdr-burger .b-open{display:none}
.hdr.menu-open .hdr-burger .b-close{display:block}

.mobile-menu{
  position:fixed;top:74px;left:0;right:0;bottom:0;z-index:49;
  background:var(--bg);
  padding:24px;
  display:none;flex-direction:column;gap:6px;
  overflow-y:auto;
  animation:slideIn .25s ease;
}
.mobile-menu.show{display:flex}
.mobile-menu a{
  font-size:18px;font-weight:600;color:var(--text);
  padding:16px 18px;border-radius:14px;
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid transparent;
  transition:background .15s, border-color .15s;
}
.mobile-menu a:hover{background:var(--surface-2);border-color:var(--line)}
.mobile-menu a svg{width:18px;height:18px;color:var(--muted)}
.mobile-menu .mob-contact{margin-top:14px;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.mobile-menu .mob-contact a{font-size:15px;font-weight:500;padding:14px 18px;background:var(--surface-2);justify-content:flex-start;gap:12px;color:var(--text)}
.mobile-menu .mob-contact a.btn{justify-content:center}
@keyframes slideIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}

/* Header breakpoints */
@media(max-width:1140px){.hdr-logo .tag{display:none}.hdr-nav{gap:22px}}
@media(max-width:980px){.hdr-nav{display:none}.hdr-tel{display:none}.hdr-burger{display:inline-flex}.hdr-cta .btn-primary{display:none}.hdr-tel-mobile{display:inline-flex}}
@media(max-width:420px){.hdr-inner{gap:8px}}
@media(max-width:380px){.hdr-inner{gap:6px}.hdr-tel-mobile{width:40px;height:40px}.hdr-burger{width:40px;height:40px}}

/* Hero */
.hero{
  padding:80px 0 100px;
  position:relative;overflow:hidden;
}
.hero h1, .hero .lead, .hero .eyebrow{max-width:100%;overflow-wrap:break-word;word-wrap:break-word}
.hero h1{box-sizing:border-box;width:100%}
.hero-bg-decor{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(40% 60% at 10% 0%,rgba(225,81,64,.10),transparent 60%),
    radial-gradient(50% 50% at 100% 100%,rgba(201,163,82,.08),transparent 60%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative;min-width:0}
.hero-grid > *{min-width:0}
.hero h1{margin-top:18px;overflow-wrap:break-word;word-break:normal;hyphens:manual}
.hero h1 .accent{color:var(--brand)}
.hero h1 .ser{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-weight:500;display:inline}
.hero .lead{margin-top:20px;font-size:clamp(16px,1.2vw,19px);max-width:560px}
.hero-ctas{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
.hero-stats .s b{display:block;font-size:32px;color:var(--brand);font-weight:800;line-height:1}
.hero-stats .s span{font-size:13px;color:var(--muted);display:block;margin-top:6px}
.hero-media{position:relative;border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 80px rgba(20,16,12,.18)}
.hero-media video, .hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.hero-media .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;backdrop-filter:blur(8px);box-shadow:0 8px 30px rgba(0,0,0,.3);cursor:pointer;transition:transform .2s, background .2s}
.hero-media .play:hover{background:#fff;transform:translate(-50%,-50%) scale(1.06)}
.hero-media .play svg{width:30px;height:30px;color:var(--brand)}
.hero-media .badge{position:absolute;left:24px;bottom:24px;display:flex;flex-direction:column;gap:4px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5);z-index:2}
.hero-media .badge b{font-size:24px;font-weight:800}
.hero-media .badge span{font-size:13px;opacity:.9}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.55) 100%);pointer-events:none}
.hero-floating{
  position:absolute;top:20px;right:20px;
  background:#fff;padding:14px 18px;border-radius:16px;
  box-shadow:0 12px 30px rgba(20,16,12,.18),0 2px 6px rgba(20,16,12,.08);
  display:flex;align-items:center;gap:12px;z-index:4;
  border:1px solid var(--line);width:max-content;max-width:240px;
  animation:floatIn .6s .3s ease both;
}
.hero-floating .ic{width:40px;height:40px;border-radius:12px;background:var(--brand-soft);display:grid;place-items:center;color:var(--brand);flex-shrink:0}
.hero-floating .ic svg{width:20px;height:20px}
.hero-floating > div:not(.ic){min-width:0;display:flex;flex-direction:column;gap:2px;color:var(--text)}
.hero-floating b{font-size:15px;line-height:1.2;display:block;color:var(--text);font-weight:700}
.hero-floating span{font-size:12px;color:var(--muted);line-height:1.3;display:block}
.hero-floating-2{
  position:absolute;left:20px;bottom:96px;
  background:#fff;padding:14px 18px;border-radius:16px;
  box-shadow:0 12px 30px rgba(20,16,12,.18),0 2px 6px rgba(20,16,12,.08);
  z-index:4;border:1px solid var(--line);
  width:max-content;max-width:240px;
  animation:floatIn .6s .5s ease both;
}
.hero-floating-2 .stars{color:var(--gold);font-size:14px;margin-bottom:4px;letter-spacing:2px;line-height:1}
.hero-floating-2 p{font-size:13px;color:var(--text);line-height:1.4;margin:0;font-weight:500}
.hero-floating-2 b{font-size:12px;color:var(--brand-2);margin-top:6px;display:block;font-weight:700}
@keyframes floatIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media(max-width:1280px){.hero-floating{max-width:220px}.hero-floating-2{max-width:220px}}
@media(max-width:1100px){.hero-floating{padding:12px 14px}.hero-floating .ic{width:36px;height:36px}.hero-floating b{font-size:13px}.hero-floating span{font-size:11px}.hero-floating-2{padding:12px 14px}.hero-floating-2 p{font-size:12px}}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr}.hero-media{aspect-ratio:16/12}}
@media(max-width:720px){
  .hero-floating{display:none}
  .hero-floating-2{top:14px;left:14px;right:auto;bottom:auto;max-width:calc(100% - 28px)}
}

/* Section head */
.section-head{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:56px;max-width:840px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;align-items:center}
.section-head > .eyebrow{align-self:flex-start}
.section-head.center > .eyebrow{align-self:center}

/* Specs */
.specs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.spec{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;position:relative;overflow:hidden;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.spec:hover{transform:translateY(-4px);box-shadow:var(--shadow-1);border-color:var(--brand)}
.spec .ic{width:48px;height:48px;border-radius:12px;background:var(--brand-soft);display:grid;place-items:center;color:var(--brand);margin-bottom:18px}
.spec h3{font-size:18px;margin-bottom:8px}
.spec p{color:var(--muted);font-size:14px;line-height:1.55}
@media(max-width:880px){.specs-grid{grid-template-columns:1fr;gap:14px}}

/* Formats — visual tiles with photo */
.formats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.fmt{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:4/5;
  background:#222;
  transition:transform .25s, box-shadow .25s;
  cursor:pointer;
  display:block;
}
.fmt:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(20,16,12,.2)}
.fmt img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.fmt:hover img{transform:scale(1.06)}
.fmt::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.85) 100%);z-index:1}
.fmt .info{position:absolute;left:0;right:0;bottom:0;padding:22px;color:#fff;z-index:2}
.fmt .info .num{font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,.6);font-weight:600}
.fmt .info h3{font-size:20px;color:#fff;margin:6px 0 8px}
.fmt .info .meta{color:var(--gold);font-weight:700;font-size:14px}
.fmt .arr{position:absolute;right:18px;top:18px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);display:grid;place-items:center;color:#fff;z-index:2;border:1px solid rgba(255,255,255,.2)}
@media(max-width:1000px){.formats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.formats-grid{grid-template-columns:1fr;}.fmt{aspect-ratio:16/12}}

/* Gallery — perfect square bento grid (no gaps) */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:14px}
.gallery .g{
  position:relative;border-radius:var(--r-lg);overflow:hidden;background:#1a1a1a;
  aspect-ratio:1;
}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery .g:hover img{transform:scale(1.05)}
.gallery .g.big{grid-column:span 2;grid-row:span 2;aspect-ratio:1}
@media(max-width:980px){.gallery{grid-template-columns:repeat(3,1fr);gap:12px}.gallery .g.big{grid-column:span 2;grid-row:span 2}}
@media(max-width:560px){.gallery{grid-template-columns:repeat(2,1fr);gap:10px}.gallery .g.big{grid-column:span 2;grid-row:span 2}}

/* Why us / numbers — with photo background */
.why{
  background:var(--accent);color:#fff;position:relative;overflow:hidden;
}
.why .bg-photo{position:absolute;inset:0;background-position:center;background-size:cover;opacity:.18;filter:saturate(.5)}
.why .container{position:relative;z-index:2}
.why h2{color:#fff}
.why .lead{color:rgba(255,255,255,.7)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:40px}
.why-grid .stat b{font-size:clamp(40px,4vw,64px);color:var(--gold);font-weight:800;display:block;line-height:1;font-family:'Playfair Display',serif;font-style:italic}
.why-grid .stat span{color:rgba(255,255,255,.7);font-size:14px;display:block;margin-top:10px;max-width:240px;line-height:1.5}
.why-locs{display:flex;flex-wrap:wrap;gap:10px;margin-top:48px;justify-content:center}
.why-locs .pill{padding:10px 18px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);font-size:14px;color:#fff;font-weight:500;backdrop-filter:blur(8px)}
@media(max-width:880px){.why-grid{grid-template-columns:repeat(2,1fr);gap:24px}}

/* Metrics */
.metrics{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center}
.metrics .cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.metric-card{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:24px;transition:transform .2s, box-shadow .2s;
}
.metric-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-1)}
.metric-card .k{font-size:11px;color:var(--brand);font-weight:800;letter-spacing:.1em}
.metric-card .v{font-size:32px;font-weight:800;margin:8px 0 4px;font-family:'Playfair Display',serif;font-style:italic;letter-spacing:-.02em}
.metric-card .delta{display:inline-flex;align-items:center;gap:6px;color:#1a7a4a;font-size:13px;font-weight:600;padding:4px 10px;background:rgba(26,122,74,.1);border-radius:999px}
.metric-card .n{font-size:13px;color:var(--muted);margin-top:8px}
@media(max-width:880px){.metrics{grid-template-columns:1fr}}

/* Client logos */
.clients{
  background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:64px 0;
}
.clients .label{text-align:center;color:var(--muted);font-size:13px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;margin-bottom:32px}
.clients-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:18px;align-items:center;
}
.client-logo{
  height:64px;display:flex;align-items:center;justify-content:center;
  padding:14px 18px;border:1px solid var(--line);border-radius:14px;
  color:var(--muted);
  background:var(--bg-2);
  transition:color .2s, border-color .2s, transform .2s;
}
.client-logo:hover{color:var(--text);border-color:var(--line-strong);transform:translateY(-2px)}
.client-logo svg{height:34px;width:auto;max-width:140px}
.client-logo img{height:32px;width:auto;max-width:140px;object-fit:contain;filter:grayscale(1);opacity:.72;transition:filter .2s, opacity .2s}
.client-logo:hover img{filter:none;opacity:1}
@media(max-width:980px){.clients-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.clients-grid{grid-template-columns:repeat(2,1fr)}}

/* Prices */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.price{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
  transition:border-color .2s, transform .2s, box-shadow .2s;
}
.price:hover{transform:translateY(-3px);box-shadow:var(--shadow-1)}
.price.featured{border-color:var(--brand);background:linear-gradient(180deg,#fff,var(--brand-soft))}
.price.featured::before{content:"Хит";position:absolute;top:18px;right:18px;background:var(--brand);color:#fff;padding:5px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.price h3{font-size:20px}
.price .desc{color:var(--muted);font-size:14px;flex:1}
.price .from{font-size:13px;color:var(--muted)}
.price .val{font-size:32px;font-weight:800;color:var(--brand-2);font-family:'Playfair Display',serif;font-style:italic;letter-spacing:-.02em}
.price .val span{font-size:14px;color:var(--muted);font-weight:500;font-family:'Inter',sans-serif;font-style:normal}
@media(max-width:980px){.prices{grid-template-columns:1fr 1fr;gap:16px}}
@media(max-width:680px){.prices{grid-template-columns:1fr;gap:14px}}

/* Cases — magazine style */
.cases{display:grid;grid-template-columns:1fr;gap:24px}
.case{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--r-xl);overflow:hidden;
  transition:transform .25s, box-shadow .25s;
}
.case:hover{transform:translateY(-3px);box-shadow:var(--shadow-1)}
.case:nth-child(even){grid-template-columns:1fr 1.1fr}
.case:nth-child(even) .case-photo{order:2}
.case-photo{position:relative;aspect-ratio:16/12;background:#222;overflow:hidden}
.case-photo > img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.case:hover .case-photo > img{transform:scale(1.05)}
.case-photo .chip{position:absolute;top:18px;left:18px;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);color:#fff;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.04em;white-space:nowrap;z-index:3;max-width:calc(100% - 36px);overflow:hidden;text-overflow:ellipsis}

/* Case carousel */
.case-carousel .carousel-track{
  position:absolute;inset:0;
  display:flex;
  overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;-ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;
  cursor:grab;
}
.case-carousel .carousel-track::-webkit-scrollbar{display:none}
.case-carousel .carousel-track:active{cursor:grabbing}
.case-carousel .carousel-track img{
  flex:0 0 100%;width:100%;height:100%;
  object-fit:cover;
  scroll-snap-align:start;
  scroll-snap-stop:always;
  user-select:none;
  -webkit-user-drag:none;
  transition:none !important;
  transform:none !important;
}
.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:46px;height:46px;border-radius:50%;
  background:rgba(0,0,0,.5);backdrop-filter:blur(10px);
  color:#fff;display:grid;place-items:center;
  z-index:4;border:1px solid rgba(255,255,255,.18);
  cursor:pointer;
  opacity:0;
  transition:opacity .2s, background .2s, transform .15s ease;
}
.case-carousel:hover .carousel-arrow,
.case-carousel:focus-within .carousel-arrow{opacity:.95}
.carousel-arrow:hover{background:rgba(0,0,0,.78)}
.carousel-arrow:active{transform:translateY(-50%) scale(.92)}
.carousel-arrow.prev{left:14px}
.carousel-arrow.next{right:14px}
.carousel-arrow svg{width:22px;height:22px}
.carousel-arrow[disabled]{opacity:0 !important;pointer-events:none}
.carousel-dots{
  position:absolute;left:50%;bottom:14px;transform:translateX(-50%);
  display:flex;gap:6px;z-index:3;
  background:rgba(0,0,0,.38);backdrop-filter:blur(8px);
  padding:7px 12px;border-radius:999px;
  max-width:calc(100% - 28px);overflow:hidden;
}
.carousel-dots button{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.45);border:0;padding:0;
  transition:background .2s, transform .2s, width .2s;
  cursor:pointer;flex-shrink:0;
}
.carousel-dots button:hover{background:rgba(255,255,255,.7)}
.carousel-dots button.active{background:#fff;width:18px;border-radius:4px}
.carousel-counter{
  position:absolute;top:18px;right:18px;z-index:3;
  background:rgba(0,0,0,.6);backdrop-filter:blur(8px);
  color:#fff;padding:6px 12px;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.04em;
  font-variant-numeric:tabular-nums;
  pointer-events:none;
}
@media(hover:none){
  .carousel-arrow{display:none}
  .carousel-dots{bottom:12px;padding:6px 10px}
}
.case-body{padding:40px 40px 40px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.case-body .top{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.case-body .top .dot{width:4px;height:4px;border-radius:50%;background:var(--muted)}
.case-body h3{font-size:clamp(20px,2.2vw,28px);line-height:1.2;word-wrap:break-word}
.case-body .quote{color:var(--muted);font-size:15px;line-height:1.55;font-style:italic;border-left:3px solid var(--brand);padding-left:14px;word-wrap:break-word}
.case-body .meta{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:6px}
.case-body .meta div b{font-size:22px;color:var(--brand-2);font-weight:800;font-family:'Playfair Display',serif;font-style:italic}
.case-body .meta div span{font-size:13px;color:var(--muted);display:block;margin-top:2px}
.case-body .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.case-body .tags span{font-size:12px;padding:5px 10px;border-radius:999px;background:var(--surface-2);color:var(--text);font-weight:500}
@media(max-width:880px){.case,.case:nth-child(even){grid-template-columns:1fr}.case:nth-child(even) .case-photo{order:0}.case-body{padding:28px}}

/* Testimonial */
.testimonial{
  background:var(--accent);color:#fff;
  border-radius:var(--r-xl);
  padding:56px;display:grid;grid-template-columns:auto 1fr auto;gap:36px;align-items:center;
  position:relative;overflow:hidden;
}
.testimonial::before{content:"";position:absolute;inset:0;background:radial-gradient(40% 60% at 100% 0%,rgba(225,81,64,.25),transparent 60%)}
.testimonial > *{position:relative;z-index:1}
.testimonial .quote{font-size:clamp(18px,1.8vw,24px);line-height:1.45;font-weight:500;font-family:'Playfair Display',serif;font-style:italic}
.testimonial .author{margin-top:18px;display:flex;align-items:center;gap:14px}
.testimonial .avatar{width:52px;height:52px;border-radius:50%;background:var(--brand);display:grid;place-items:center;font-weight:700;color:#fff;font-size:18px}
.testimonial .name{font-weight:600}
.testimonial .role{color:rgba(255,255,255,.6);font-size:13px}
.testimonial .open{font-size:140px;line-height:.8;color:var(--brand);font-family:Georgia,serif;align-self:start;font-style:italic}
.testimonial .photo{width:140px;height:180px;border-radius:var(--r-lg);background:#333;overflow:hidden}
.testimonial .photo img{width:100%;height:100%;object-fit:cover}
@media(max-width:880px){.testimonial{grid-template-columns:1fr;padding:32px;gap:20px}.testimonial .open{font-size:60px}.testimonial .photo{display:none}}

/* CTA form — split panel design */
.cta-form{
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--bg-2);
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 20px 60px rgba(20,16,12,.08);
  border:1px solid var(--line);
  isolation:isolate;
}
.cta-form .cta-pitch{
  background:linear-gradient(150deg,var(--brand) 0%,#ff7a5c 60%, #ffa07a 100%);
  color:#fff;
  padding:56px 48px;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;gap:18px;
}
.cta-form .cta-pitch::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(50% 60% at 100% 0%,rgba(255,255,255,.22),transparent 60%),
    radial-gradient(40% 50% at 0% 100%,rgba(255,255,255,.12),transparent 60%);
  pointer-events:none;
}
.cta-form .cta-pitch > *{position:relative;z-index:1}
.cta-form .cta-pitch h2{color:#fff;margin:0;font-size:clamp(26px,2.6vw,38px);line-height:1.1;overflow-wrap:break-word;word-break:normal;hyphens:auto;-webkit-hyphens:auto}
.cta-form .cta-pitch > .eyebrow{align-self:flex-start}
.cta-form .cta-pitch .desc{color:rgba(255,255,255,.92);font-size:15px;line-height:1.55;max-width:440px}
.cta-form .cta-pitch .perks{display:flex;flex-direction:column;gap:10px;margin-top:8px;list-style:none;padding:0}
.cta-form .cta-pitch .perks li{display:flex;align-items:flex-start;gap:10px;color:#fff;font-size:14px;line-height:1.4}
.cta-form .cta-pitch .perks li svg{flex-shrink:0;width:18px;height:18px;margin-top:1px;opacity:.95}
.cta-form .cta-pitch .trust{display:flex;align-items:center;gap:10px;margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.2)}
.cta-form .cta-pitch .trust .ava{display:flex}
.cta-form .cta-pitch .trust .ava span{width:30px;height:30px;border-radius:50%;border:2px solid rgba(255,255,255,.9);background:rgba(255,255,255,.15);margin-left:-8px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px}
.cta-form .cta-pitch .trust .ava span:first-child{margin-left:0}
.cta-form .cta-pitch .trust p{color:rgba(255,255,255,.88);font-size:13px;line-height:1.35}
.cta-form .cta-pitch .trust b{color:#fff;font-weight:700}

.cta-form form{
  background:#fff;
  padding:48px;
  display:flex;flex-direction:column;justify-content:center;
}
.cta-form form h3{color:var(--text);margin:0 0 6px;font-size:22px;font-weight:700}
.cta-form form > p{color:var(--muted);font-size:14px;margin:0 0 22px}
.cta-form .form-content{display:flex;flex-direction:column;gap:14px}
form .field{margin:0}
form label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500}
form input, form select, form textarea{
  width:100%;background:#fff;
  border:1px solid var(--line-strong);
  border-radius:var(--r-sm);padding:13px 14px;
  color:var(--text);font:inherit;
  transition:border-color .15s, box-shadow .15s;
}
form input::placeholder, form textarea::placeholder{color:var(--muted-soft)}
form input:focus, form select:focus, form textarea:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
form .agree{display:flex;align-items:flex-start;gap:10px;color:var(--muted);font-size:12px;margin:4px 0 4px;line-height:1.45}
form .agree input{width:16px;height:16px;margin:2px 0 0;flex-shrink:0;accent-color:var(--brand)}
form button.btn{width:100%;margin-top:4px}
.form-success{display:none;text-align:center;padding:40px 24px;background:var(--brand-soft);border-radius:var(--r-lg)}
.form-success.show{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:240px}
.form-success h3{color:var(--brand-2);margin-bottom:0}

/* Responsive */
@media(max-width:1100px){
  .cta-form{grid-template-columns:1fr}
  .cta-form .cta-pitch{padding:40px}
  .cta-form form{padding:36px}
}
@media(max-width:680px){
  .cta-form .cta-pitch{padding:28px 20px;gap:12px}
  .cta-form .cta-pitch h2{font-size:21px;line-height:1.18}
  .cta-form .cta-pitch .desc{font-size:13.5px}
  .cta-form .cta-pitch .perks li{font-size:13.5px}
  .cta-form form{padding:28px 22px}
  form .row{grid-template-columns:1fr;gap:10px}
  .cta-form .form-content{gap:12px}
}
@media(max-width:380px){
  .cta-form .cta-pitch{padding:24px 20px}
  .cta-form form{padding:24px 20px}
}

/* Footer */
.ftr{background:var(--accent);color:#cbd5e1;padding:72px 0 24px}
.ftr-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.ftr h4{font-size:13px;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;font-weight:600}
.ftr a{color:#cbd5e1;display:block;padding:4px 0;font-size:14px;transition:color .15s}
.ftr a:hover{color:#fff}
.ftr .logo-block img{filter:brightness(0) invert(1)}
.ftr .logo-block p{color:#94a3b8;font-size:14px;max-width:320px;margin-top:14px}
.ftr-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.08);padding-top:24px;color:#94a3b8;font-size:13px;flex-wrap:wrap;gap:10px}
@media(max-width:880px){.ftr-grid{grid-template-columns:1fr 1fr;gap:32px;margin-bottom:40px}}
@media(max-width:680px){.ftr-grid{grid-template-columns:1fr;gap:28px;margin-bottom:32px}}

/* WhatsApp */
.wa{
  position:fixed;right:24px;bottom:24px;z-index:30;
  width:60px;height:60px;border-radius:50%;background:#25D366;
  display:grid;place-items:center;color:#fff;
  box-shadow:0 8px 30px rgba(37,211,102,.4);
  transition:transform .2s;
}
.wa:hover{transform:scale(1.08)}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Final responsive polish */
@media(max-width:1200px){
  .container{padding:0 24px}
  section{padding:80px 0}
}
@media(max-width:880px){
  section{padding:64px 0}
  .section-head{margin-bottom:36px}
  h1{font-size:clamp(30px,7vw,46px);letter-spacing:-.02em}
  h2{font-size:clamp(26px,5vw,40px)}
  .hero{padding:56px 0 64px}
  .hero-stats{grid-template-columns:1fr 1fr;gap:16px}
  .hero-stats .s b{font-size:24px}
  .hero-stats .s span{font-size:12px}
  .hero-ctas .btn{flex:1;justify-content:center}
}
@media(max-width:560px){
  .container{padding:0 18px;max-width:100%}
  section{padding:48px 0}
  .hero{padding:40px 0 48px}
  .hero-grid{gap:24px}
  .hero h1{font-size:26px;line-height:1.18;overflow-wrap:break-word;word-break:keep-all;hyphens:none;max-width:100%}
  .hero .lead{font-size:14.5px;line-height:1.55;overflow-wrap:break-word;max-width:100%}
  .eyebrow .opt{display:none}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%}
  .hero-stats{padding-top:24px;margin-top:32px}
  .section-head{gap:10px;margin-bottom:28px}
  .specs-grid,.formats-grid,.prices,.cases{gap:14px}
  .spec,.case-body{padding:22px}
  .clients-grid{gap:10px}
  .client-logo{height:54px;padding:10px 14px}
  .client-logo svg{height:28px}
  .testimonial{padding:24px}
  .cta-form{padding:24px}
  .cta-form form{padding:22px}
  .why-grid{grid-template-columns:1fr 1fr;gap:18px}
  .why-grid .stat span{font-size:13px}
  .modal-body{padding:28px}
  .modal-body.video{padding:14px}
  .wa{width:54px;height:54px;right:16px;bottom:16px}
}
@media(max-width:380px){
  .container{padding:0 14px}
  h1{font-size:26px;line-height:1.1}
  .hero h1{font-size:24px}
  .clients-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:1fr 1fr;text-align:left}
}

/* Safe-area for iOS notches */
@supports(padding:max(0px)){
  .container{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .reveal,.fmt img,.case-photo img,.gallery .g img{transition:none}
  *{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(20,16,12,.6);display:none;align-items:center;justify-content:center;z-index:100;padding:24px;backdrop-filter:blur(8px)}
.modal.show{display:flex}
.modal-body{background:#fff;border-radius:var(--r-xl);padding:40px;width:100%;max-width:520px;position:relative}
.modal-body.video{max-width:1000px;padding:24px;aspect-ratio:16/9}
.modal-body.video.portrait{max-width:min(440px,90vw);aspect-ratio:9/16;max-height:92vh;padding:14px}
.modal-body.video video{width:100%;height:100%;border-radius:var(--r-lg);background:#000;object-fit:contain}
.modal .close{position:absolute;right:18px;top:18px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.06);display:grid;place-items:center;font-size:18px;color:var(--text);z-index:5}
.modal-body.video .close{background:rgba(255,255,255,.2);color:#fff}
.modal .close:hover{background:rgba(0,0,0,.15)}
