/* ─── Bright Weekend landing — Variant B (Friendly Family, refined) ───── */
:root{
  --coral:#FF6B35;
  --coral-2:#F0501F;
  --sun:#FFD23F;
  --sun-soft:#FFE9A0;
  --teal:#2EC4B6;
  --pink:#FF3C8A;
  --navy:#13213A;
  --ink:#13213A;
  --mute:#6B7280;
  --cream:#FFF6E6;
  --paper:#FFFBF1;
  --line:rgba(19,33,58,.10);

  --rad-s:14px;
  --rad-m:22px;
  --rad-l:32px;

  --shadow-sm:0 2px 0 rgba(19,33,58,.08);
  --shadow-md:0 14px 30px -12px rgba(19,33,58,.22), 0 2px 0 rgba(19,33,58,.06);
  --shadow-lg:0 30px 60px -20px rgba(19,33,58,.30), 0 2px 0 rgba(19,33,58,.06);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--cream);color:var(--ink);font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
button{font-family:inherit}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.app{max-width:1220px;margin:0 auto;position:relative}
.wrap{padding:0 20px}

/* ─── Page texture (subtle paper) ─────────────────────────────────────── */
.app::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(1px 1px at 20% 30%, rgba(19,33,58,.04) 50%, transparent 51%),
    radial-gradient(1px 1px at 70% 80%, rgba(19,33,58,.04) 50%, transparent 51%),
    radial-gradient(1px 1px at 40% 60%, rgba(19,33,58,.04) 50%, transparent 51%);
  background-size: 240px 240px, 360px 360px, 180px 180px;
  opacity:.6;
}

/* ─── Top bar ──────────────────────────────────────────────────────────── */
.topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;
  background:rgba(255,246,230,.88);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px;font-family:'Unbounded',sans-serif;font-weight:800;font-size:15px;letter-spacing:-.01em}
.brand-mark{
  width:30px;height:30px;border-radius:10px;background:var(--coral);
  position:relative;display:grid;place-items:center;color:#fff;
  border:1.5px solid var(--ink);box-shadow:2px 2px 0 0 var(--ink);
}
.topbar-cta{
  font-weight:700;font-size:13px;padding:10px 14px;border-radius:999px;
  background:var(--navy);color:#fff;border:1.5px solid var(--navy);cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  transition:transform .15s ease, background .2s ease;
}
.topbar-cta:hover{background:#0a1124;transform:translateY(-1px)}
.topbar-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--sun);box-shadow:0 0 0 0 rgba(255,210,63,.7);animation:pulse 1.6s infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,210,63,.7)}
  70%{box-shadow:0 0 0 8px rgba(255,210,63,0)}
  100%{box-shadow:0 0 0 0 rgba(255,210,63,0)}
}

/* ─── Hero ─────────────────────────────────────────────────────────────── */
.hero{position:relative;padding:18px 20px 36px;overflow:hidden;z-index:1}

.hero-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Unbounded',sans-serif;font-weight:800;font-size:12px;letter-spacing:.04em;
  padding:8px 12px;border-radius:12px;border:1.5px solid var(--ink);
  box-shadow:2px 2px 0 0 var(--ink);
}
.badge.day{background:var(--coral);color:#fff;transform:rotate(-2deg)}
.badge.date{background:var(--sun);color:var(--ink)}
.badge.time{background:#fff;color:var(--ink);transform:rotate(1.5deg)}
.badge .glyph{font-size:14px;line-height:1}

.hero h1{
  font-family:'Unbounded',sans-serif;font-weight:900;
  font-size:clamp(48px,14vw,108px);line-height:.9;letter-spacing:-.035em;
  margin:18px 0 0;color:var(--ink);
  text-wrap:balance;
}
.hero h1 .accent{color:var(--coral);position:relative;display:inline-block}
.hero h1 .accent::before{
  content:"";position:absolute;left:-2%;right:-2%;bottom:8%;height:22%;
  background:var(--sun);z-index:-1;border-radius:6px;transform:rotate(-1.2deg);
}
.hero h1 .em{display:block}
.hero-caveat{
  font-family:'Caveat',cursive;font-size:24px;color:var(--coral-2);
  transform:rotate(-3deg);display:inline-block;margin-top:6px;
  position:relative;padding-left:30px;
}
.hero-caveat::before{
  content:"";position:absolute;left:0;top:50%;width:24px;height:2px;background:var(--coral-2);
  transform:rotate(8deg);border-radius:2px;
}

.hero-sub{margin:18px 0 0;font-size:17px;line-height:1.5;color:#3b4358;max-width:38ch;text-wrap:pretty}
.hero-sub b{color:var(--ink);font-weight:800}

/* Hero photo cluster */
.cluster{
  position:relative;margin-top:28px;height:300px;
}
.cluster .photo{
  position:absolute;border-radius:18px;border:1.5px solid var(--ink);
  background:repeating-linear-gradient(135deg,#f1eadb 0 8px,#e9e0cc 8px 16px);
  overflow:hidden;display:grid;place-items:center;text-align:center;
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;color:var(--mute);
  padding:8px;box-shadow:var(--shadow-md);
}
.cluster .photo > img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  display:block;
}
.cluster .photo .tag{
  position:absolute;top:8px;left:8px;background:var(--ink);color:#fff;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:10px;padding:3px 8px;border-radius:999px;
  letter-spacing:.04em;
}
.cluster .p1{left:0;top:0;width:54%;height:62%;transform:rotate(-4deg)}
.cluster .p2{right:0;top:14%;width:46%;height:58%;transform:rotate(3deg)}
.cluster .p3{left:18%;bottom:0;width:60%;height:46%;transform:rotate(-1.5deg);z-index:2}
.cluster .sun-spark{
  position:absolute;right:-10px;top:-6px;width:64px;height:64px;
  background:var(--sun);border-radius:50%;border:1.5px solid var(--ink);
  display:grid;place-items:center;font-family:'Caveat',cursive;font-weight:700;
  transform:rotate(8deg);font-size:14px;line-height:1;text-align:center;color:var(--ink);
  box-shadow:3px 3px 0 0 var(--ink);
  z-index:3;
}
.cluster .scribble-arrow{
  position:absolute;left:50%;bottom:-32px;color:var(--coral-2);
  transform:translateX(-50%) rotate(-8deg);
  font-family:'Caveat',cursive;font-size:18px;font-weight:700;
}

/* Hero info card */
.hero-card{
  margin-top:48px;background:#fff;border:1.5px solid var(--ink);
  border-radius:var(--rad-l);
  padding:18px;box-shadow:var(--shadow-md);
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.hero-fact{display:flex;flex-direction:column;gap:4px;padding:6px 6px}
.hero-fact + .hero-fact{border-left:1px dashed var(--line)}
.hero-fact .label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);font-weight:700}
.hero-fact .value{font-family:'Unbounded',sans-serif;font-weight:800;font-size:17px;line-height:1.05;letter-spacing:-.01em}

/* Countdown */
.countdown{
  margin:18px 0 0;background:var(--ink);color:#fff;border-radius:18px;padding:14px 16px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:1.5px solid var(--ink);
}
.countdown-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#a8b2cc;font-weight:700;line-height:1.2}
.countdown-label b{display:block;color:#fff;font-family:'Unbounded',sans-serif;font-size:14px;margin-top:2px;letter-spacing:0}
.countdown-grid{display:flex;gap:6px}
.cd-cell{background:rgba(255,255,255,.08);border-radius:10px;padding:8px 10px;min-width:48px;text-align:center}
.cd-cell .n{font-family:'Unbounded',sans-serif;font-weight:800;font-size:20px;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.cd-cell .u{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#a8b2cc;margin-top:4px;font-weight:700}

.hero-cta-row{margin-top:18px;display:flex;flex-direction:column;gap:10px;align-items:stretch}
.btn{
  appearance:none;border:1.5px solid var(--ink);cursor:pointer;
  font-family:'Unbounded',sans-serif;font-weight:700;font-size:16px;letter-spacing:-.01em;
  padding:18px 22px;border-radius:18px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:transform .12s ease, box-shadow .12s ease, background .2s ease;
}
.btn-primary{background:var(--coral);color:#fff;box-shadow:4px 4px 0 0 var(--ink)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--ink)}
.btn-primary:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink)}
.btn-secondary{background:var(--sun);color:var(--ink);box-shadow:4px 4px 0 0 var(--ink)}
.btn-secondary:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--ink)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:#fff}

.hero-meta{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px;font-size:13.5px;color:#3b4358;align-items:center}
.hero-meta b{font-weight:800;color:var(--ink)}
.hero-meta .pip{width:4px;height:4px;border-radius:50%;background:var(--ink);opacity:.4}

/* ─── Section base ─────────────────────────────────────────────────────── */
section{padding:56px 20px;position:relative;z-index:1}
section.tight{padding:36px 20px}
.section-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--coral);
}
.section-eyebrow .bar{width:24px;height:3px;background:currentColor;border-radius:2px}
h2{
  font-family:'Unbounded',sans-serif;font-weight:800;
  font-size:clamp(28px,7vw,46px);line-height:1;letter-spacing:-.025em;
  margin:14px 0 0;text-wrap:balance;
}
h2 .h{background:var(--sun);padding:0 8px;border-radius:6px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.lede{margin:14px 0 0;font-size:16px;line-height:1.5;color:#3b4358;max-width:52ch;text-wrap:pretty}

/* ─── About ─────────────────────────────────────────────────────────────── */
.about{background:var(--paper)}
.about-card{
  margin-top:26px;background:#fff;border:1.5px solid var(--ink);border-radius:var(--rad-l);
  padding:24px;box-shadow:var(--shadow-md);position:relative;overflow:hidden;
  display:grid;grid-template-columns:1fr;gap:18px;
}
.about-photo{
  position:relative;width:100%;aspect-ratio:4/3;border-radius:18px;
  border:1.5px solid var(--ink);overflow:hidden;
  box-shadow:var(--shadow-md);
  transform:rotate(-1.5deg);
  background:#f1eadb;
}
.about-photo > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.about-photo .cap{
  position:absolute;left:10px;bottom:10px;background:#fff;color:var(--ink);
  font-family:'Manrope',sans-serif;font-weight:800;font-size:11px;letter-spacing:.04em;
  padding:5px 10px;border-radius:999px;border:1.5px solid var(--ink);
  box-shadow:2px 2px 0 0 var(--ink);
}
.about-photo .stamp-svechka{
  position:absolute;right:-8px;top:-8px;width:60px;height:60px;border-radius:50%;
  background:var(--sun);border:1.5px solid var(--ink);box-shadow:2px 2px 0 0 var(--ink);
  display:grid;place-items:center;font-family:'Caveat',cursive;font-weight:700;font-size:14px;
  transform:rotate(10deg);text-align:center;line-height:1.05;color:var(--ink);
  z-index:2;
}
.about-quote{
  font-family:'Unbounded',sans-serif;font-weight:700;font-size:22px;line-height:1.18;letter-spacing:-.015em;
  position:relative;text-wrap:balance;z-index:1;
}
.about-quote em{font-style:normal;color:var(--coral)}
.about-list{margin:18px 0 0;display:grid;grid-template-columns:1fr;gap:10px;position:relative;z-index:1}
.about-item{display:flex;gap:12px;align-items:flex-start;font-size:15px;line-height:1.45}
.about-item .check{
  flex:0 0 24px;width:24px;height:24px;border-radius:8px;background:var(--coral);
  display:grid;place-items:center;color:#fff;
  border:1.5px solid var(--ink);box-shadow:2px 2px 0 0 var(--ink);
}

/* ─── Timeline (Program) ──────────────────────────────────────────────── */
.tline{background:var(--cream)}
.tline-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.tline-grid{
  margin-top:30px;position:relative;
  display:grid;grid-template-columns:1fr;gap:14px;
}
.tline-grid::before{
  content:"";position:absolute;left:34px;top:14px;bottom:14px;width:3px;
  background:repeating-linear-gradient(180deg,var(--ink) 0 6px,transparent 6px 12px);
  border-radius:2px;opacity:.7;
}
.tline-item{
  display:grid;grid-template-columns:74px 1fr;gap:14px;align-items:start;
  position:relative;z-index:1;
}
.tline-time{
  font-family:'Unbounded',sans-serif;font-weight:800;font-size:14px;letter-spacing:-.01em;
  background:#fff;border:1.5px solid var(--ink);border-radius:12px;padding:8px 8px;text-align:center;
  box-shadow:2px 2px 0 0 var(--ink);min-height:44px;display:grid;place-items:center;
}
.tline-card{
  background:#fff;border:1.5px solid var(--ink);border-radius:18px;padding:14px 16px;
  box-shadow:var(--shadow-sm);display:flex;gap:14px;align-items:flex-start;
}
.tline-icon{
  flex:0 0 40px;width:40px;height:40px;border-radius:11px;
  border:1.5px solid var(--ink);display:grid;place-items:center;
  font-family:'Unbounded',sans-serif;font-weight:800;font-size:14px;
}
.tline-card.c1 .tline-icon{background:var(--coral);color:#fff}
.tline-card.c2 .tline-icon{background:var(--sun);color:var(--ink)}
.tline-card.c3 .tline-icon{background:var(--teal);color:#fff}
.tline-card.c4 .tline-icon{background:var(--pink);color:#fff}
.tline-card.c5 .tline-icon{background:var(--navy);color:#fff}
.tline-card.c6 .tline-icon{background:#fff;color:var(--ink)}
.tline-body h3{margin:0;font-family:'Unbounded',sans-serif;font-weight:700;font-size:15px;letter-spacing:-.01em;line-height:1.2}
.tline-body .desc{font-size:13.5px;color:#3b4358;line-height:1.4;text-wrap:pretty;margin-top:4px}
.tline-card.break{background:transparent;border-style:dashed;box-shadow:none}
.tline-card.break .tline-body h3{color:var(--mute);font-weight:700}

.tline-foot{
  margin-top:22px;background:var(--ink);color:#fff;border:1.5px solid var(--ink);
  border-radius:var(--rad-m);padding:18px 20px;display:flex;align-items:center;gap:14px;
  position:relative;overflow:hidden;
}
.tline-foot .big{font-family:'Unbounded',sans-serif;font-weight:800;font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--sun)}
.tline-foot .txt{font-size:14px;line-height:1.4;color:#dfe5f2}

/* ─── Mosaic "Из жизни смен" ──────────────────────────────────────────── */
.mosaic{background:var(--cream);padding:48px 20px}
.mosaic-head{display:flex;justify-content:space-between;align-items:end;gap:14px;flex-wrap:wrap}
.mosaic-strip{
  margin-top:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.mosaic-tile{
  position:relative;aspect-ratio:3/4;border-radius:18px;border:1.5px solid var(--ink);
  overflow:hidden;background:#f1eadb;box-shadow:var(--shadow-md);
}
.mosaic-tile > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.mosaic-tile:nth-child(1){transform:rotate(-1.8deg)}
.mosaic-tile:nth-child(2){transform:rotate(1deg);margin-top:14px}
.mosaic-tile:nth-child(3){transform:rotate(-1deg)}
.mosaic-tile .cap{
  position:absolute;left:8px;top:8px;background:#fff;color:var(--ink);
  font-family:'Manrope',sans-serif;font-weight:800;font-size:10px;letter-spacing:.04em;
  padding:4px 8px;border-radius:999px;border:1.5px solid var(--ink);
  text-transform:uppercase;
}

/* ─── Team ─────────────────────────────────────────────────────────────── */
.team{background:var(--paper)}
.team-grid{margin-top:30px;display:grid;grid-template-columns:1fr;gap:14px}
.tcard{
  background:#fff;border:1.5px solid var(--ink);border-radius:22px;
  padding:22px;box-shadow:var(--shadow-md);position:relative;
  display:flex;flex-direction:column;gap:6px;
  min-height:180px;
}
.tcard.t1{background:linear-gradient(180deg,#fff 0%,#fff 70%,rgba(255,107,53,.06) 100%)}
.tcard.t2{background:linear-gradient(180deg,#fff 0%,#fff 70%,rgba(46,196,182,.07) 100%)}
.tcard.t3{background:linear-gradient(180deg,#fff 0%,#fff 70%,rgba(255,60,138,.05) 100%)}
.tcard.t1{transform:rotate(-.6deg)}
.tcard.t3{transform:rotate(.6deg)}
.tcard .role{
  font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  display:inline-block;padding:5px 10px;border-radius:999px;color:#fff;
  align-self:flex-start;border:1.5px solid var(--ink);box-shadow:2px 2px 0 0 var(--ink);
}
.tcard.t1 .role{background:var(--coral)}
.tcard.t2 .role{background:var(--teal)}
.tcard.t3 .role{background:var(--pink)}
.tcard h3{
  margin:14px 0 0;font-family:'Unbounded',sans-serif;font-weight:800;
  font-size:22px;letter-spacing:-.02em;line-height:1.05;text-wrap:balance;
}
.tcard p{margin:8px 0 0;font-size:14px;color:#3b4358;line-height:1.45;text-wrap:pretty}
.tcard-years{
  margin-top:auto;padding-top:14px;border-top:1px dashed var(--line);
  font-size:12px;color:var(--mute);font-weight:700;letter-spacing:.04em;text-transform:uppercase;
}
.tcard-years b{
  font-family:'Unbounded',sans-serif;font-weight:800;font-size:20px;color:var(--ink);
  letter-spacing:-.01em;margin-right:4px;
}
.tcard .stamp{
  position:absolute;right:-8px;top:-8px;width:54px;height:54px;border-radius:50%;
  background:var(--sun);border:1.5px solid var(--ink);box-shadow:2px 2px 0 0 var(--ink);
  display:grid;place-items:center;font-family:'Caveat',cursive;font-weight:700;font-size:12px;
  transform:rotate(8deg);text-align:center;line-height:1.05;color:var(--ink);
}

/* ─── Why ──────────────────────────────────────────────────────────────── */
.why{background:var(--cream)}
.why-grid{margin-top:26px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.why-card{
  background:#fff;border:1.5px solid var(--ink);border-radius:var(--rad-m);
  padding:16px;display:flex;flex-direction:column;gap:8px;
  box-shadow:var(--shadow-sm);min-height:150px;
}
.why-card .ico{
  width:36px;height:36px;border-radius:11px;display:grid;place-items:center;
  border:1.5px solid var(--ink);font-weight:800;font-family:'Unbounded',sans-serif;font-size:16px;
}
.why-card.coral .ico{background:var(--coral);color:#fff}
.why-card.sun   .ico{background:var(--sun);color:var(--ink)}
.why-card.teal  .ico{background:var(--teal);color:#fff}
.why-card.pink  .ico{background:var(--pink);color:#fff}
.why-card h3{margin:0;font-family:'Unbounded',sans-serif;font-weight:700;font-size:14px;letter-spacing:-.01em;line-height:1.2}
.why-card .desc{font-size:13px;color:#3b4358;line-height:1.4;text-wrap:pretty}

/* ─── Reviews ──────────────────────────────────────────────────────────── */
.rev{background:var(--paper)}
.rev-eyebrow-row{display:flex;justify-content:space-between;align-items:end;gap:14px;flex-wrap:wrap}
.rev-eyebrow-row > div:first-child{min-width:0;flex:1 1 240px}
.rev-meta{
  display:flex;flex-direction:row;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute);font-weight:700;
}
.rev-grid{margin-top:28px;display:grid;grid-template-columns:1fr;gap:14px}
.rev-card{
  background:#fff;border:1.5px solid var(--ink);border-radius:22px;padding:20px;
  box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.rev-card::before{
  content:"\201C";position:absolute;right:14px;top:-14px;
  font-family:'Unbounded',sans-serif;font-weight:900;font-size:120px;color:var(--sun);
  line-height:1;
}
.rev-card.coral::before{color:var(--coral);opacity:.25}
.rev-card .quote{
  font-family:'Unbounded',sans-serif;font-weight:600;font-size:17px;line-height:1.35;
  letter-spacing:-.01em;position:relative;z-index:1;text-wrap:pretty;
}
.rev-card .who{
  margin-top:14px;display:flex;align-items:center;gap:10px;position:relative;z-index:1;
}
.rev-card .who .av{
  width:36px;height:36px;border-radius:50%;border:1.5px solid var(--ink);
  background:var(--cream);display:grid;place-items:center;
  font-family:'Unbounded',sans-serif;font-weight:800;font-size:13px;
}
.rev-card .who .nm{font-size:13.5px;font-weight:800}
.rev-card .who .mt{font-size:12px;color:var(--mute);margin-top:1px}
.rev-card .tag-fake{
  margin-top:14px;font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;color:var(--mute);background:var(--cream);
  border:1px dashed var(--line);padding:6px 8px;border-radius:8px;
  display:inline-block;
}

/* ─── Gift ─────────────────────────────────────────────────────────────── */
.gift{background:var(--cream)}
.gift-card{
  margin-top:24px;background:#fff;border:1.5px solid var(--ink);border-radius:var(--rad-l);
  padding:24px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.gift-tape{
  position:absolute;top:18px;right:-44px;transform:rotate(28deg);
  background:var(--coral);color:#fff;font-family:'Unbounded',sans-serif;font-weight:800;
  font-size:12px;letter-spacing:.1em;padding:6px 50px;border:1.5px solid var(--ink);
}

.price-row{
  display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;
  margin:6px 0 4px;padding:18px 6px;
  border-top:1.5px dashed var(--line);border-bottom:1.5px dashed var(--line);
}
.price-was{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.price-was s{
  font-family:'Unbounded',sans-serif;font-weight:700;font-size:22px;letter-spacing:-.02em;
  color:var(--mute);text-decoration:line-through;text-decoration-thickness:2px;
}
.price-was .caption{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute);font-weight:700}
.price-arrow{
  width:40px;height:40px;border-radius:50%;background:var(--sun);
  border:1.5px solid var(--ink);box-shadow:2px 2px 0 0 var(--ink);
  display:grid;place-items:center;color:var(--ink);
  transform:rotate(0deg);
}
.price-now{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.price-now .value{
  font-family:'Unbounded',sans-serif;font-weight:900;font-size:38px;letter-spacing:-.03em;
  color:var(--ink);line-height:1;
}
.price-now .caption{
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--coral);font-weight:800;
  background:var(--sun);padding:3px 8px;border-radius:999px;border:1.5px solid var(--ink);
  margin-top:6px;
}

.gift-card p{margin:14px 0 0;font-size:15px;line-height:1.5;color:#3b4358;text-wrap:pretty}
.gift-card p b{font-weight:800;color:var(--ink)}

.gift-coupon{
  margin-top:18px;padding:14px;border:1.5px dashed var(--ink);border-radius:14px;
  background:var(--cream);display:flex;align-items:center;gap:12px;
}
.gift-coupon .ic{
  width:42px;height:42px;border-radius:12px;background:var(--coral);color:#fff;
  display:grid;place-items:center;font-size:20px;border:1.5px solid var(--ink);
}
.gift-coupon .ct{font-size:13.5px;line-height:1.3}
.gift-coupon .ct b{display:block;font-family:'Unbounded',sans-serif;font-weight:800;font-size:15px;letter-spacing:0;margin-bottom:2px;font-variant-numeric:tabular-nums}

/* Price strip inside form */
.price-strip{
  margin-top:6px;background:rgba(255,210,63,.10);border:1.5px solid rgba(255,210,63,.35);
  border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:4px;
}
.price-strip-l{font-size:13.5px;color:#dfe5f2}
.price-strip-l s{color:#8a93a8;margin-right:6px;font-weight:600}
.price-strip-l b{
  color:var(--sun);font-family:'Unbounded',sans-serif;font-weight:800;font-size:16px;
  letter-spacing:-.01em;font-variant-numeric:tabular-nums;
}
.price-strip-tag{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;
  color:#a8b2cc;letter-spacing:.04em;
}

/* ─── CTA form ─────────────────────────────────────────────────────────── */
.cta{background:var(--ink);color:#fff;border-radius:40px 40px 0 0;margin-top:24px}
.cta .section-eyebrow{color:var(--sun)}
.cta h2{color:#fff}
.cta h2 .h{background:var(--sun);color:var(--ink)}
.cta .lede{color:#bfc6d6;max-width:42ch}

.form{margin-top:24px;display:grid;grid-template-columns:1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#a8b2cc}
.field input, .field select{
  appearance:none;border:1.5px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);
  color:#fff;font-family:inherit;font-size:16px;padding:14px 14px;border-radius:14px;
  outline:none;transition:border .2s ease, background .2s ease;
}
.field input::placeholder{color:#7a8299}
.field input:focus, .field select:focus{border-color:var(--sun);background:rgba(255,210,63,.08)}
.field.err input, .field.err select{border-color:var(--coral)}
.field .hint{font-size:12px;color:#7a8299}
.field .errmsg{font-size:12px;color:#ffb097;font-weight:600}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-foot{margin-top:6px;display:flex;flex-direction:column;gap:14px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:12px;color:#a8b2cc;line-height:1.4}
.consent input{margin-top:2px;accent-color:var(--coral)}
.consent a{color:var(--sun);text-decoration:underline;text-underline-offset:2px}

.spots{
  margin-top:14px;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.16);
  border-radius:14px;padding:14px;display:flex;align-items:center;gap:12px;
}
.spots-bar{flex:1;height:8px;border-radius:99px;background:rgba(255,255,255,.1);overflow:hidden}
.spots-bar .fill{height:100%;background:linear-gradient(90deg,var(--coral),var(--sun));border-radius:99px}
.spots-info{font-size:13px;color:#dfe5f2}
.spots-info b{color:#fff;font-family:'Unbounded',sans-serif;font-weight:800}

.success-card{
  margin-top:24px;background:#fff;color:var(--ink);border-radius:var(--rad-l);
  padding:24px;border:1.5px solid var(--ink);box-shadow:var(--shadow-lg);
  text-align:center;
}
.success-card .ok{
  width:56px;height:56px;border-radius:50%;background:var(--teal);color:#fff;
  display:grid;place-items:center;margin:0 auto;border:1.5px solid var(--ink);
  font-size:28px;font-weight:800;box-shadow:2px 2px 0 0 var(--ink);
}
.success-card h3{font-family:'Unbounded',sans-serif;font-weight:800;font-size:24px;letter-spacing:-.02em;margin:14px 0 0}
.success-card p{font-size:15px;line-height:1.45;color:#3b4358;margin:8px 0 0}

/* ─── Address ──────────────────────────────────────────────────────────── */
.addr{padding:48px 20px 24px;background:var(--paper)}
.addr-card{
  margin-top:22px;background:#fff;border:1.5px solid var(--ink);border-radius:var(--rad-l);
  padding:20px;box-shadow:var(--shadow-md);
  display:grid;grid-template-columns:1fr;gap:16px;
}
.map{
  display:block;position:relative;
  aspect-ratio:16/10;border-radius:18px;border:1.5px solid var(--ink);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .15s ease, box-shadow .15s ease;
}
.map > img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
}
.map:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.map-cta{
  position:absolute;left:12px;bottom:12px;
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--ink);
  font-family:'Manrope',sans-serif;font-weight:800;font-size:12px;letter-spacing:.04em;
  padding:9px 12px;border-radius:999px;border:1.5px solid var(--ink);
  box-shadow:2px 2px 0 0 var(--ink);
}
.addr-info .city{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mute)}
.addr-info .street{font-family:'Unbounded',sans-serif;font-weight:800;font-size:22px;letter-spacing:-.01em;margin-top:4px}
.addr-info .meta{margin-top:10px;font-size:14px;color:#3b4358;line-height:1.5}
.addr-info .meta b{color:var(--ink)}

/* ─── FAQ ──────────────────────────────────────────────────────────────── */
.faq{padding:24px 20px 120px;background:var(--paper)}
.faq-list{margin-top:24px;display:flex;flex-direction:column;gap:10px}
.faq-item{
  background:#fff;border:1.5px solid var(--ink);border-radius:18px;
  box-shadow:var(--shadow-sm);overflow:hidden;
}
.faq-q{
  appearance:none;background:none;border:none;cursor:pointer;width:100%;
  text-align:left;padding:16px 18px;font-family:'Unbounded',sans-serif;font-weight:700;
  font-size:15px;letter-spacing:-.01em;color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  line-height:1.3;
}
.faq-q .chev{
  flex:0 0 28px;width:28px;height:28px;border-radius:9px;background:var(--cream);
  border:1.5px solid var(--ink);display:grid;place-items:center;
  transition:transform .25s ease;font-weight:800;
}
.faq-item.open .faq-q .chev{transform:rotate(45deg);background:var(--coral);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a-inner{padding:0 18px 16px;font-size:14.5px;color:#3b4358;line-height:1.5;text-wrap:pretty}
.faq-item.open .faq-a{max-height:320px}

/* ─── Footer ───────────────────────────────────────────────────────────── */
.footer{padding:24px 20px 120px;background:var(--paper);border-top:1px solid var(--line)}
.footer .row{display:flex;flex-direction:column;gap:14px}
.footer .brand{font-size:14px}
.footer .legal{font-size:12px;color:var(--mute);line-height:1.5}
.footer .legal a{text-decoration:underline;text-underline-offset:2px}

/* ─── Sticky bottom bar (mobile) ───────────────────────────────────────── */
.dock{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,246,230,.94);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-top:1px solid var(--line);
  display:flex;align-items:center;gap:10px;
}
.dock-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.dock-info .small{font-size:11px;color:var(--mute);font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.dock-info .big{font-family:'Unbounded',sans-serif;font-weight:800;font-size:15px;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dock .btn{padding:14px 18px;font-size:14px;border-radius:14px}

/* ─── Responsive (≥ 760px desktop) ─────────────────────────────────────── */
@media (min-width:760px){
  .wrap{padding:0 40px}
  .hero{padding:32px 40px 64px;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
  .hero-side{align-self:stretch;display:flex;align-items:center;justify-content:center;width:100%}
  .cluster{width:100%;height:440px;margin-top:0}
  .hero-card{grid-column:1/-1;grid-template-columns:repeat(3,1fr);margin-top:32px}
  .hero-cta-row{grid-column:1/-1;flex-direction:row;align-items:center}
  .hero-cta-row .btn-primary{max-width:280px}
  section{padding:80px 40px}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .tcard{min-height:240px;padding:26px}
  .tcard h3{font-size:26px;margin-top:18px}
  .tcard p{font-size:15px}
  .about-card{grid-template-columns:1fr 1fr;align-items:center;gap:32px;padding:32px}
  .about-photo{aspect-ratio:4/3}
  .mosaic{padding:64px 40px}
  .mosaic-strip{gap:18px}
  .why-grid{grid-template-columns:repeat(4,1fr)}
  .rev-grid{grid-template-columns:1fr 1fr}
  .gift-card{padding:32px}
  .form{grid-template-columns:1fr 1fr;gap:14px}
  .form .full{grid-column:1/-1}
  .addr{padding:72px 40px 40px}
  .addr-card{grid-template-columns:1.2fr 1fr;align-items:center}
  .faq{padding:40px 40px 120px}
  .footer{padding:40px}
  .dock{display:none}
}

@media (max-width:359px){
  .topbar-cta .label{display:none}
  .hero h1{font-size:42px}
  .cluster{height:240px}
}
