/* BoardDay Partner — для исполнителей и поставщиков активностей */
:root{
  --bg:#fafafa;
  --bg-2:#ffffff;
  --surface:#ffffff;
  --surface-2:#f3f4f6;
  --line:rgba(15,23,42,.08);
  --line-strong:rgba(15,23,42,.14);
  --text:#0f172a;
  --muted:#64748b;
  --muted-soft:#94a3b8;
  --brand:#e15140;
  --brand-2:#c83f30;
  --brand-soft:#fff1ee;
  --brand-glow:rgba(225,81,64,.18);
  --accent:#0f172a;
  --success:#10b981;
  --r-xs:8px; --r-sm:12px; --r-md:18px; --r-lg:24px; --r-xl:32px;
  --container:1240px;
  --shadow-1:0 1px 3px rgba(15,23,42,.06),0 6px 24px rgba(15,23,42,.04);
  --shadow-2:0 12px 40px rgba(225,81,64,.18);
}
*{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}

h1,h2,h3,h4{font-weight:700;letter-spacing:-.02em;line-height:1.12}
h1{font-size:clamp(36px,5.5vw,68px)}
h2{font-size:clamp(28px,3.6vw,46px);margin-bottom:14px}
h3{font-size:clamp(20px,2vw,26px)}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--muted);max-width:720px}
.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:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  border:1px solid rgba(225,81,64,.18);
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand)}

.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)}
.btn-ghost:hover{background:#fff;border-color:var(--text)}
.btn-dark{background:var(--accent);color:#fff}
.btn-dark:hover{background:#1e293b;transform:translateY(-2px)}
.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(255,255,255,.85);
  border-bottom:1px solid var(--line);
  transition:box-shadow .2s, background .2s;
}
.hdr.scrolled{box-shadow:0 4px 24px rgba(15,23,42,.04);background:rgba(255,255,255,.96)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:72px;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:.06em;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(--muted);font-weight:500;transition:color .15s}
.hdr-nav a:hover{color:var(--text)}
.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;
}
.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:72px;left:0;right:0;bottom:0;z-index:49;
  background:var(--bg-2);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}
.mobile-menu .mob-contact a.btn{justify-content:center;background:var(--brand);color:#fff}
@keyframes slideIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}

@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:380px){.hdr-inner{gap:10px}.hdr-tel-mobile{width:40px;height:40px}.hdr-burger{width:40px;height:40px}}

/* Hero */
.hero{
  padding:100px 0 120px;
  background:
    radial-gradient(50% 50% at 90% 10%,rgba(225,81,64,.10),transparent 60%),
    radial-gradient(40% 60% at 0% 100%,rgba(15,23,42,.05),transparent 60%),
    var(--bg-2);
  position:relative;overflow:hidden;border-bottom:1px solid var(--line);
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;position:relative}
.hero h1 span{color:var(--brand)}
.hero .badges{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 24px}
.hero .badges b{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:13px;color:var(--text);font-weight:500}
.hero .badges b::before{content:"✓";color:var(--brand);font-weight:700}
.hero p.lead{margin-top:18px}
.hero-ctas{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-meta{display:flex;align-items:center;gap:24px;margin-top:36px;flex-wrap:wrap}
.hero-meta .ava{display:flex}
.hero-meta .ava span{width:36px;height:36px;border-radius:50%;border:2px solid var(--bg-2);background:linear-gradient(135deg,#e15140,#ffd166);margin-left:-8px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px}
.hero-meta .ava span:first-child{margin-left:0}
.hero-meta p{color:var(--muted);font-size:14px}
.hero-meta p b{color:var(--text)}

.dash-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  padding:24px;box-shadow:0 30px 80px rgba(15,23,42,.12);
  position:relative;
}
.dash-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.dash-head .dot{display:flex;gap:6px}
.dash-head .dot span{width:10px;height:10px;border-radius:50%;background:#e2e8f0}
.dash-head .label{font-size:12px;color:var(--muted)}
.dash-tabs{display:flex;gap:6px;background:var(--surface-2);padding:4px;border-radius:10px;margin-bottom:16px}
.dash-tabs span{font-size:12px;padding:6px 12px;border-radius:8px;color:var(--muted);font-weight:500}
.dash-tabs span.active{background:#fff;color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.05)}
.dash-row{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--line);border-radius:14px;margin-bottom:10px;background:#fff}
.dash-row .ic{width:40px;height:40px;border-radius:10px;background:var(--brand-soft);display:grid;place-items:center;color:var(--brand);flex-shrink:0}
.dash-row .info{flex:1;min-width:0}
.dash-row .info b{font-size:14px;display:block}
.dash-row .info p{font-size:12px;color:var(--muted);margin-top:2px}
.dash-row .v{font-weight:700;color:var(--success);font-size:14px;white-space:nowrap}
.dash-row .badge{font-size:11px;padding:4px 8px;border-radius:6px;background:rgba(16,185,129,.1);color:var(--success);font-weight:600}
.dash-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.dash-stats div{padding:14px;background:var(--surface-2);border-radius:12px}
.dash-stats b{font-size:24px;font-weight:700;display:block}
.dash-stats span{font-size:12px;color:var(--muted)}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr}.hero{padding:60px 0}}

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

/* Pains */
.pains{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pains-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pain{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;position:relative;overflow:hidden;
  transition:transform .2s, border-color .2s;
}
.pain:hover{transform:translateY(-3px);border-color:var(--brand)}
.pain .num{font-size:14px;color:var(--muted-soft);font-weight:700;letter-spacing:.1em;margin-bottom:14px}
.pain h3{font-size:18px;margin-bottom:8px}
.pain p{font-size:14px;color:var(--muted)}
@media(max-width:1000px){.pains-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.pains-grid{grid-template-columns:1fr}}

/* How it works */
.hiw{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.hiw::before{
  content:"";position:absolute;top:32px;left:10%;right:10%;height:2px;
  background:linear-gradient(90deg,transparent,var(--line-strong),transparent);
  z-index:0;
}
.step{position:relative;z-index:1;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px}
.step .n{width:48px;height:48px;border-radius:50%;background:var(--brand);color:#fff;font-weight:700;font-size:18px;display:grid;place-items:center;margin-bottom:18px;box-shadow:0 8px 20px var(--brand-glow)}
.step h3{margin-bottom:8px}
.step p{color:var(--muted);font-size:14px}
@media(max-width:880px){.hiw{grid-template-columns:1fr;gap:14px}.hiw::before{display:none}}

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

/* Gallery — clean square bento grid */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:12px}
.gallery .g{position:relative;border-radius:var(--r-md);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:10px}}
@media(max-width:560px){.gallery{grid-template-columns:repeat(2,1fr);gap:10px}}

/* Video block */
.video-block{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  aspect-ratio:16/9;background:#000;
  box-shadow:0 30px 80px rgba(15,23,42,.18);
}
.video-block video{width:100%;height:100%;object-fit:cover;display:block}
.video-block::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6) 100%);pointer-events:none}
.video-block .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.95);display:grid;place-items:center;cursor:pointer;transition:transform .2s, background .2s;z-index:2;border:none}
.video-block .play:hover{transform:translate(-50%,-50%) scale(1.06)}
.video-block .play svg{width:30px;height:30px;color:var(--brand)}
.video-block .badge{position:absolute;left:24px;bottom:24px;z-index:3;color:#fff}
.video-block .badge b{display:block;font-size:18px;font-weight:700}
.video-block .badge span{font-size:13px;opacity:.85}

/* Categories */
.cats{background:var(--accent);color:#fff;border-radius:var(--r-xl);padding:64px;position:relative;overflow:hidden}
.cats::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(50% 70% at 100% 0%,rgba(225,81,64,.3),transparent 60%);
}
.cats > *{position:relative;z-index:1}
.cats .section-head h2{color:#fff}
.cats .section-head .lead{color:#cbd5e1}
.cats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.cat{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:20px;
  display:flex;flex-direction:column;gap:8px;
  transition:background .2s, border-color .2s, transform .2s;
}
.cat:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateY(-2px)}
.cat .emo{font-size:26px;line-height:1}
.cat b{font-size:14px;font-weight:600}
.cat p{font-size:12px;color:#94a3b8;line-height:1.45}
@media(max-width:1000px){.cats-grid{grid-template-columns:repeat(3,1fr)}.cats{padding:32px}}
@media(max-width:560px){.cats-grid{grid-template-columns:repeat(2,1fr)}}

/* Pricing */
.tariffs{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:980px;margin:0 auto}
.tariff{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:40px;position:relative;display:flex;flex-direction:column;gap:22px;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.tariff:hover{transform:translateY(-3px);box-shadow:var(--shadow-1);border-color:var(--brand)}
.tariff.featured{background:linear-gradient(180deg,#fff,var(--brand-soft));border-color:var(--brand)}
.tariff.featured::before{content:"Рекомендуем";position:absolute;top:-12px;left:24px;background:var(--brand);color:#fff;padding:5px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.tariff .head h3{font-size:24px}
.tariff .head p{color:var(--muted);font-size:14px;margin-top:6px}
.tariff .price{display:flex;align-items:baseline;gap:6px}
.tariff .price .v{font-size:44px;font-weight:700;line-height:1}
.tariff .price .u{font-size:14px;color:var(--muted)}
.tariff ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.tariff li{display:flex;align-items:center;gap:10px;font-size:14px}
.tariff li svg{width:18px;height:18px;color:var(--brand);flex-shrink:0}
@media(max-width:880px){.tariffs{gap:18px}}
@media(max-width:760px){.tariffs{grid-template-columns:1fr}.tariff{padding:32px;gap:18px}}

/* Stats */
.stats-block{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-xl);padding:48px;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.stats-nums{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.stats-nums div b{font-size:clamp(36px,4vw,52px);color:var(--brand);font-weight:700;line-height:1;display:block}
.stats-nums div span{color:var(--muted);font-size:14px;display:block;margin-top:8px}
@media(max-width:760px){.stats-block{grid-template-columns:1fr;padding:32px}}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
.faq-item{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);
  margin-bottom:10px;overflow:hidden;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-item:hover{border-color:var(--brand);box-shadow:0 2px 8px rgba(225,81,64,.1)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 26px;font-weight:600;font-size:16px;cursor:pointer;gap:18px;
}
.faq-q .ico{width:32px;height:32px;border-radius:50%;background:var(--brand-soft);display:grid;place-items:center;color:var(--brand);transition:transform .2s ease, background .2s ease;flex-shrink:0}
.faq-q:hover .ico{background:var(--brand);color:#fff}
.faq-item.open .faq-q .ico{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .3s ease;
  color:var(--muted);font-size:15px;line-height:1.65;
}
.faq-item.open .faq-a{max-height:500px}
.faq-a div{padding:0 26px 22px}

/* CTA */
.cta-final{
  background:linear-gradient(135deg,var(--brand) 0%,#ff7a5c 100%);
  border-radius:var(--r-xl);padding:64px;
  display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center;
  color:#fff;position:relative;overflow:hidden;
}
.cta-final::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 80% at 100% 0%,rgba(255,255,255,.18),transparent 60%);
}
.cta-final > *{position:relative;z-index:1}
.cta-final h2{color:#fff;margin-bottom:12px}
.cta-final p{color:rgba(255,255,255,.85);max-width:520px}
.cta-final form{background:#fff;border-radius:var(--r-lg);padding:24px}
.cta-final form h3{font-size:18px;margin-bottom:14px;color:var(--text)}
form .field{margin-bottom:12px}
form label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
form input, form select, form textarea{
  width:100%;background:#fff;
  border:1px solid var(--line-strong);
  border-radius:var(--r-sm);padding:12px 14px;
  color:var(--text);font:inherit;
  transition:border-color .15s;
}
form input:focus, form select:focus, form textarea:focus{outline:0;border-color:var(--brand)}
form .agree{display:flex;align-items:start;gap:10px;color:var(--muted);font-size:12px;margin:12px 0 14px}
form .agree input{width:auto}
form button.btn{width:100%}
.form-success{display:none;text-align:center;padding:24px;background:var(--brand-soft);border-radius:var(--r-lg)}
.form-success.show{display:block}
.form-success h3{color:var(--brand);margin-bottom:6px}
@media(max-width:880px){.cta-final{grid-template-columns:1fr;padding:32px}}

/* Footer */
.ftr{background:var(--accent);color:#cbd5e1;padding:64px 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}}

/* WA */
.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}

/* Responsive polish */
@media(max-width:1200px){.container{padding:0 24px}section{padding:80px 0}}
@media(max-width:880px){
  section{padding:60px 0}
  h1{font-size:clamp(32px,8vw,52px)}
  h2{font-size:clamp(26px,5vw,40px)}
  .section-head{margin-bottom:32px}
  .hero{padding:48px 0 56px}
  .hero-ctas .btn{flex:1;justify-content:center}
  .hero-meta{gap:14px}
  .dash-card{padding:18px}
  .pains-grid{grid-template-columns:1fr 1fr;gap:12px}
  .pain{padding:22px}
}
@media(max-width:560px){
  .container{padding:0 18px}
  section{padding:48px 0}
  .hero{padding:32px 0 48px}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%}
  .hero .badges{gap:6px}
  .hero .badges b{padding:6px 12px;font-size:12px}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:10px}
  .section-head{gap:10px;margin-bottom:24px}
  .pains-grid{grid-template-columns:1fr}
  .step,.why-card,.tariff{padding:24px}
  .stats-block{padding:24px}
  .cta-final{padding:24px}
  .cta-final form{padding:20px}
  .cats{padding:28px}
  .cats-grid{grid-template-columns:1fr 1fr;gap:10px}
  .cat{padding:16px}
  .faq-q{padding:18px 20px;font-size:15px}
  .faq-a div{padding:0 20px 18px}
  .modal-body{padding:28px}
  .wa{width:54px;height:54px;right:16px;bottom:16px}
  .ftr{padding:48px 0 24px}
}
@media(max-width:380px){
  .container{padding:0 14px}
  h1{font-size:32px}
  .hero h1{line-height:1.05}
  .cats-grid{grid-template-columns:1fr}
}
@supports(padding:max(0px)){
  .container{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}
}
@media(prefers-reduced-motion:reduce){
  .reveal{transition:none}
  *{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(15,23,42,.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 .close{position:absolute;right:18px;top:18px;width:32px;height:32px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;font-size:18px;color:var(--muted)}
.modal .close:hover{color:var(--text);background:var(--line)}
