/* =========================================================
   M&A WORLDWIDE — Premium stone/marble aesthetic
   Shared design system
   ========================================================= */

:root{
  /* Warm neutral stone palette */
  --bg:        #F6F3EE;        /* warm off-white */
  --surface:   #FFFFFF;
  --surface-2: #FBF9F5;
  --ink:       #1C1A17;        /* warm near-black */
  --ink-soft:  #4A453E;
  --muted:     #8A8378;        /* stone gray */
  --line:      #E4DED4;        /* hairline */
  --line-2:    #D7CFC2;

  /* Construction orange accent */
  --accent:        #E0641F;
  --accent-deep:   #C5520F;
  --accent-tint:   #FBEBDF;

  /* Type */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:  "Space Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Layout */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --radius-lg: 10px;

  --shadow-sm: 0 1px 2px rgba(28,26,23,.05), 0 2px 8px rgba(28,26,23,.04);
  --shadow-md: 0 8px 30px rgba(28,26,23,.08);
  --shadow-lg: 0 24px 60px rgba(28,26,23,.14);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body{
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; }

/* ---------- Typography ---------- */
.display{
  font-family: var(--serif);
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
h1.display{ font-size: clamp(44px, 7.5vw, 104px); }
h2.display{ font-size: clamp(34px, 5vw, 64px); }
h3.display{ font-size: clamp(26px, 3.4vw, 40px); }

.eyebrow{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent-deep);
  font-weight: 700;
}
.lead{ font-size: clamp(18px, 2vw, 22px); color: var(--ink-soft); line-height:1.55; text-wrap:pretty; }
.muted{ color: var(--muted); }

/* ---------- Layout helpers ---------- */
.wrap{ max-width: var(--maxw); margin-inline:auto; padding-inline: var(--gutter); }
.section{ padding-block: clamp(64px, 9vw, 130px); }
.section--tight{ padding-block: clamp(48px, 6vw, 84px); }
.center{ text-align:center; }
.stack > * + *{ margin-top: 1rem; }

.section-head{ max-width: 720px; }
.section-head.center{ margin-inline:auto; }
.section-head .eyebrow{ display:block; margin-bottom: 18px; }
.section-head h2{ margin:0 0 .4em; }

/* ---------- Buttons ---------- */
.btn{
  --b: var(--accent);
  display:inline-flex; align-items:center; gap:.6em;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .01em;
  padding: 15px 26px;
  border-radius: var(--radius);
  border: 1.5px solid transparent;
  transition: transform .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease), color .2s var(--ease);
  white-space: nowrap;
}
.btn:active{ transform: translateY(1px); }
.btn--primary{ background: var(--accent); color:#fff; box-shadow: 0 6px 18px rgba(224,100,31,.28); }
.btn--primary:hover{ background: var(--accent-deep); box-shadow: 0 10px 28px rgba(224,100,31,.36); transform: translateY(-2px); }
.btn--ghost{ background: transparent; color: var(--ink); border-color: var(--line-2); }
.btn--ghost:hover{ border-color: var(--ink); background: var(--surface); }
.btn--light{ background:#fff; color: var(--ink); }
.btn--light:hover{ background: var(--surface-2); transform: translateY(-2px); }
.btn--lg{ padding: 18px 34px; font-size: 16px; }
.btn .arr{ transition: transform .25s var(--ease); }
.btn:hover .arr{ transform: translateX(4px); }

.link-arrow{
  font-weight:700; font-size:15px; display:inline-flex; align-items:center; gap:.5em;
  color: var(--ink); border-bottom: 1.5px solid var(--accent); padding-bottom:2px;
  transition: gap .2s var(--ease), color .2s var(--ease);
}
.link-arrow:hover{ gap:.9em; color: var(--accent-deep); }

/* ---------- Top bar / nav ---------- */
.topbar{
  background: var(--ink); color: #EDE8DF;
  font-size: 13px;
}
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:9px; }
.topbar a{ color:#EDE8DF; opacity:.85; transition: opacity .2s; }
.topbar a:hover{ opacity:1; color:#fff; }
.topbar .tb-contacts{ display:flex; gap: 22px; align-items:center; flex-wrap:wrap; }
.topbar .tb-contacts .mono{ font-family:var(--mono); letter-spacing:.02em; }

.nav{
  position: sticky; top:0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; gap: 20px; height: 76px; }
.brand{ display:flex; align-items:baseline; gap:10px; font-family:var(--serif); font-weight:700; font-size:25px; letter-spacing:-0.01em; line-height:1; }
.brand .amp{ color: var(--accent); }
.brand .ww{ font-family:var(--mono); font-size:10px; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); font-weight:700; align-self:center; }
.nav-links{ display:flex; align-items:center; gap: 30px; }
.nav-links a{ font-weight:600; font-size:15px; color: var(--ink-soft); transition: color .2s; position:relative; }
.nav-links a:hover{ color: var(--ink); }
.nav-links a.has-menu{ display:inline-flex; align-items:center; gap:5px; }

.nav-right{ display:flex; align-items:center; gap:14px; }
.lang-toggle{
  display:inline-flex; border:1.5px solid var(--line-2); border-radius:999px; overflow:hidden; font-family:var(--mono);
}
.lang-toggle button{ background:transparent; border:0; padding:6px 12px; font-size:12px; font-weight:700; letter-spacing:.05em; color:var(--muted); }
.lang-toggle button.active{ background: var(--ink); color:#fff; }

.nav-toggle{ display:none; background:none; border:0; padding:8px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.3s; }
.nav-cta-m{ display:none; }

/* dropdown for materials */
.has-dd{ position:relative; }
.dd{
  position:absolute; top: calc(100% + 14px); left:50%; transform: translateX(-50%) translateY(8px);
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-md);
  padding:10px; min-width: 260px; opacity:0; visibility:hidden; transition: .22s var(--ease); z-index:60;
}
.has-dd:hover .dd{ opacity:1; visibility:visible; transform: translateX(-50%) translateY(0); }
.dd a{ display:flex; align-items:center; gap:13px; padding:10px 12px; border-radius:6px; font-size:15px; font-weight:600; color:var(--ink); }
.dd a:hover{ background: var(--surface-2); }
.dd a .sw{ width:26px; height:26px; border-radius:4px; flex:none; border:1px solid var(--line); }
.dd a img.sw{ width:42px; height:42px; border-radius:7px; object-fit:cover; display:block; }

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }

/* Hero A — editorial split */
.heroA{ display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px,5vw,72px); align-items:center; padding-block: clamp(24px,4vw,56px); }
.heroA__copy .eyebrow{ display:block; margin-bottom:20px; }
.heroA__copy h1{ margin:0 0 .45em; font-size: clamp(40px, 5.4vw, 80px); }
.heroA__copy .lead{ max-width:540px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.hero-badges{ display:flex; gap:22px; flex-wrap:wrap; margin-top:30px; }
.hb{ display:inline-flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--ink-soft); }
.hb-dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); flex:none; }
.heroA__media{ position:relative; }
.hero-float{ position:absolute; left:-22px; bottom:34px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:18px 22px; }
.hero-float .hf-num{ font-family:var(--serif); font-size:46px; font-weight:600; color:var(--accent); line-height:.9; }
.hero-float .hf-lbl{ font-size:13px; color:var(--ink-soft); margin-top:2px; }

/* Hero B — immersive full-bleed banner */
.heroB{ display:block; padding:0; }
.heroB__img{ display:block; width:100%; height:auto; }
.heroB__cta{ background:var(--surface); border-bottom:1px solid var(--line); }
.heroB__cta .wrap{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:24px; padding:clamp(30px,4.5vw,54px) 0; }
.heroB__cta .hero-cta{ margin-top:0; justify-content:center; }
.heroB__cta .hero-badges{ margin-top:0; justify-content:center; }
.heroB__lead{ max-width:620px; margin:0 auto; }

/* Hero C — gallery */
.heroC{ padding-top: clamp(48px,7vw,88px); }
.heroC .eyebrow{ display:block; margin-bottom:20px; }
.heroC__title{ margin:0 auto .55em; max-width:16ch; font-size: clamp(38px, 5.6vw, 82px); line-height:1.06; }
.heroC__strip{ display:grid; grid-template-columns: repeat(6,1fr); gap:16px; margin-top:54px; }
.hcs{ display:flex; flex-direction:column; gap:10px; }
.hcs .ph{ aspect-ratio:3/4; border-radius:var(--radius-lg); transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.hcs:hover .ph{ transform: translateY(-6px); box-shadow: var(--shadow-md); }
.hcs small{ font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--muted); text-align:center; }

/* about grid */
.about-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap: clamp(32px,5vw,64px); align-items:center; }
.about-media .ph{ border-radius: var(--radius-lg); }

/* ---------- Galería (homepage) ---------- */
.gal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.gal-item{ margin:0; display:flex; flex-direction:column; gap:12px; }
.gal-item image-slot{ display:block; width:100%; height:auto; aspect-ratio:4/3; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); }
.gal-cap{ display:flex; align-items:center; gap:10px; font-weight:700; font-size:15px; color:var(--ink); }
.gal-cap .n{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; color:var(--accent-deep); }

@media (max-width: 900px){
  .heroA{ grid-template-columns:1fr; gap:34px; }
  .heroA__media{ order:-1; max-width:480px; }
  .hero-float{ left:auto; right:18px; }
  .about-grid{ grid-template-columns:1fr; }
  .about-media{ max-width:420px; }
  .heroC__strip{ grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 560px){
  .heroC__strip{ grid-template-columns: repeat(2,1fr); }
  .hero-badges{ gap:14px; }
}

/* ---------- Placeholder imagery (striped) ---------- */
.ph{
  position:relative; overflow:hidden; background: var(--t, var(--surface-2));
  background-image: repeating-linear-gradient(135deg, rgba(28,26,23,.05) 0 2px, transparent 2px 11px);
  border:1px solid var(--line); border-radius: var(--radius-lg);
  display:flex; align-items:flex-end;
}
.ph--dark{ background:#231F1A; background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 2px, transparent 2px 11px); border-color:#352f28; }
.ph__tag{
  font-family: var(--mono); font-size:11px; letter-spacing:.05em; color:var(--muted);
  background: color-mix(in srgb, var(--surface) 80%, transparent); border:1px solid var(--line);
  padding:5px 9px; border-radius:4px; margin:12px;
}
.ph--dark .ph__tag{ color:#b8b0a4; background: rgba(0,0,0,.35); border-color:#3a342c; }
.ph__icon{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:.16; }

/* ---------- Cards / grids ---------- */
.grid{ display:grid; gap: clamp(16px, 2vw, 26px); }
.grid-2{ grid-template-columns: repeat(2, 1fr); }
.grid-3{ grid-template-columns: repeat(3, 1fr); }

.material-card{
  position:relative; background:var(--surface); border:1px solid var(--line); border-radius: var(--radius-lg);
  overflow:hidden; transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s;
  display:flex; flex-direction:column;
}
.material-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--line-2); }
.material-card .ph{ border:0; border-radius:0; aspect-ratio: 4/3; }
.material-card__body{ padding: 22px 24px 26px; display:flex; flex-direction:column; gap:10px; flex:1; }
.material-card__num{ font-family:var(--mono); font-size:12px; color:var(--accent-deep); letter-spacing:.1em; }
.material-card h3{ font-family:var(--serif); font-weight:600; font-size:27px; margin:0; line-height:1.05; }
.material-card p{ margin:0; font-size:15px; color:var(--ink-soft); flex:1; }
.material-card .link-arrow{ margin-top:6px; font-size:14px; align-self:flex-start; }

/* ---------- Install steps (Cómo instalarlo) ---------- */
.install-steps{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.install-step{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; }
.install-step:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--line-2); }
.install-step__media{ aspect-ratio:4/3; overflow:hidden; background:var(--surface-2); border-bottom:1px solid var(--line); }
.install-step__media img{ width:100%; height:100%; object-fit:cover; display:block; }
.install-step__body{ padding:18px 20px 22px; display:flex; flex-direction:column; gap:8px; }
.install-step__n{ font-family:var(--mono); font-size:13px; font-weight:700; letter-spacing:.1em; color:var(--accent-deep); }
.install-step__t{ font-family:var(--serif); font-weight:600; font-size:22px; line-height:1.1; margin:0; }
.install-step__d{ margin:0; font-size:15px; color:var(--ink-soft); line-height:1.5; }
.install-notes{ margin-top:50px; }
.install-notes__title{ font-family:var(--serif); font-weight:600; font-size:26px; margin:0 0 24px; }
.install-notes__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px 44px; }
.install-note{ padding-top:18px; border-top:1px solid var(--line-2); }
.install-note__l{ display:block; font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--accent-deep); font-weight:700; margin-bottom:6px; }
.install-note__t{ margin:0; font-size:15px; color:var(--ink-soft); line-height:1.5; }
.install-guide{ margin-top:54px; }
.install-faq{ margin-top:20px; }
.install-faq .faq__q{ font-size:clamp(18px,2vw,21px); padding:20px 0; gap:18px; }
.install-faq .faq__q .pm{ width:30px; height:30px; }
.install-faq .faq__q .pm::before, .install-faq .faq__q .pm::after{ inset:50% 8px auto 8px; }
.install-faq .faq__a > div{ font-size:16px; padding-bottom:24px; }
.install-faq .faq__a p{ margin:0 0 12px; line-height:1.55; }
.install-faq .faq__a p:last-child{ margin-bottom:0; }
.install-faq .faq__a ol, .install-faq .faq__a ul{ margin:0; padding-left:1.25em; display:flex; flex-direction:column; gap:9px; }
.install-faq .faq__a li{ line-height:1.5; }
.install-faq .faq__a li::marker{ color:var(--accent-deep); font-weight:700; }
.install-faq .faq__a strong{ color:var(--ink); font-weight:700; }
@media (max-width:1000px){ .install-steps{ grid-template-columns:repeat(2,1fr); } .install-notes__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .install-steps{ grid-template-columns:1fr; } .install-notes__grid{ grid-template-columns:1fr; } }

/* feature / service cards */
.svc{
  background:var(--surface); border:1px solid var(--line); border-radius: var(--radius-lg);
  padding: 36px 34px; display:flex; flex-direction:column; gap:14px; height:100%;
  transition: box-shadow .3s var(--ease), transform .3s var(--ease);
}
.svc:hover{ box-shadow: var(--shadow-md); transform: translateY(-4px); }
.svc__ico{ width:54px; height:54px; border-radius:10px; background: var(--accent-tint); color:var(--accent-deep); display:flex; align-items:center; justify-content:center; }
.svc h3{ font-family:var(--serif); font-weight:600; font-size:28px; margin:6px 0 0; }
.svc p{ margin:0; color:var(--ink-soft); font-size:16px; }
.svc ul{ margin:6px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:9px; }
.svc li{ display:flex; gap:10px; align-items:flex-start; font-size:15px; color:var(--ink-soft); }
.svc li::before{ content:""; width:7px; height:7px; border-radius:2px; background:var(--accent); margin-top:8px; flex:none; }

/* stats / differentiators */
.bene{ display:flex; gap:16px; align-items:flex-start; }
.bene__n{ font-family:var(--serif); font-size:40px; font-weight:600; color:var(--accent); line-height:1; flex:none; width:54px; }
.bene h4{ margin:0 0 4px; font-size:18px; font-weight:700; }
.bene p{ margin:0; color:var(--ink-soft); font-size:15px; }

/* ---------- FAQ ---------- */
.faq{ border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{
  width:100%; background:none; border:0; text-align:left; padding: 26px 0; display:flex;
  align-items:center; justify-content:space-between; gap:24px; font-family:var(--serif); font-size: clamp(20px,2.4vw,26px); font-weight:600; color:var(--ink);
}
.faq__q .pm{ flex:none; width:34px; height:34px; border:1.5px solid var(--line-2); border-radius:50%; position:relative; transition:.25s var(--ease); }
.faq__q .pm::before, .faq__q .pm::after{ content:""; position:absolute; background:var(--ink); inset:50% 9px auto 9px; height:1.5px; transform:translateY(-50%); transition:.25s var(--ease); }
.faq__q .pm::after{ transform: translateY(-50%) rotate(90deg); }
.faq__item.open .pm{ background:var(--accent); border-color:var(--accent); }
.faq__item.open .pm::before, .faq__item.open .pm::after{ background:#fff; }
.faq__item.open .pm::after{ transform: translateY(-50%) rotate(0); opacity:0; }
.faq__a{ overflow:hidden; max-height:0; transition: max-height .4s var(--ease); }
.faq__a > div{ padding: 0 0 28px; max-width:780px; color:var(--ink-soft); font-size:17px; }

/* ---------- Quote form + map ---------- */
.quote{ background: var(--ink); color:#EFEAE1; }
.quote .eyebrow{ color:#F0A06A; }
.quote h2{ color:#fff; }
.quote__grid{ display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(24px,3vw,48px); align-items:start; }
.qform{ background:#fff; color:var(--ink); border-radius: var(--radius-lg); padding: clamp(24px,3vw,40px); box-shadow: var(--shadow-lg); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:700; letter-spacing:.02em; margin-bottom:7px; }
.field .req{ color:var(--accent); }
.field input, .field select, .field textarea{
  width:100%; font-family:inherit; font-size:15px; color:var(--ink); background:var(--surface-2);
  border:1.5px solid var(--line-2); border-radius: var(--radius); padding:13px 14px; transition: border-color .2s, background .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--accent); background:#fff; }
.field textarea{ resize:vertical; min-height:96px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field-hint{ font-size:12.5px; color:var(--muted); margin-top:6px; }

.delivery-toggle{ display:flex; gap:10px; margin-bottom:6px; }
.seg{ flex:1; position:relative; }
.seg input{ position:absolute; opacity:0; pointer-events:none; }
.seg label{
  display:flex; flex-direction:column; gap:3px; cursor:pointer; border:1.5px solid var(--line-2); border-radius:var(--radius);
  padding:12px 14px; font-size:14px; font-weight:700; transition:.2s var(--ease); height:100%;
}
.seg label small{ font-weight:500; font-size:12px; color:var(--muted); }
.seg input:checked + label{ border-color:var(--accent); background:var(--accent-tint); }
.seg input:focus-visible + label{ outline:2px solid var(--accent); outline-offset:2px; }

.addr-block{ overflow:hidden; transition: max-height .4s var(--ease), opacity .3s; }
.addr-block[hidden]{ display:none; }

.pickup-block[hidden]{ display:none; }
.pickup-addr{ display:flex; align-items:center; gap:10px; margin-top:10px; padding:12px 14px;
  border:1.5px solid var(--line-2); border-radius:var(--radius); background:var(--accent-tint);
  font-size:14px; font-weight:600; color:var(--ink); }
.pickup-addr__dot{ width:12px; height:12px; border-radius:50%; background:var(--accent);
  border:3px solid #fff; box-shadow:0 0 0 1px var(--line); flex:none; }

#map{ width:100%; height:280px; border-radius: var(--radius); border:1px solid var(--line-2); background:var(--surface-2); z-index:0; }
.map-card{ background:#fff; color:var(--ink); border-radius:var(--radius-lg); padding:20px; box-shadow: var(--shadow-md); }
.dist-readout{ margin-top:16px; display:grid; grid-template-columns: repeat(3,1fr); gap:12px; }
.dist-readout .cell{ background:var(--surface-2); border:1px solid var(--line); border-radius:var(--radius); padding:12px 14px; }
.dist-readout .cell .k{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; color:var(--muted); text-transform:uppercase; }
.dist-readout .cell .v{ font-family:var(--serif); font-size:26px; font-weight:600; line-height:1.1; margin-top:3px; }
.dist-note{ font-size:13px; color:var(--ink-soft); margin-top:14px; display:flex; gap:9px; align-items:flex-start; }
.dist-note .dot{ width:9px;height:9px;border-radius:50%; margin-top:6px; flex:none; }
.zone-in{ color:#1c7a4a; } .zone-edge{ color:#b07a12; } .zone-out{ color:var(--accent-deep); }

.form-note{ font-size:12.5px; color:var(--muted); margin-top:4px; }

/* price estimate */
.price-est{ margin:20px 0 4px; background:var(--surface-2); border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px; }
.price-est__row{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; }
.price-est__label{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); }
.price-est__total{ font-family:var(--serif); font-size:34px; font-weight:600; line-height:1; color:var(--accent-deep); }
.price-est__line{ font-size:14px; color:var(--ink-soft); margin-top:8px; }
.price-est__line b{ color:var(--ink); }
.price-est__note{ font-size:12px; color:var(--muted); margin-top:10px; line-height:1.45; }
.q-success{ display:none; text-align:center; padding:20px 0; }
.q-success.show{ display:block; }
.q-success .check{ width:64px;height:64px;border-radius:50%; background:var(--accent-tint); color:var(--accent-deep); display:flex;align-items:center;justify-content:center; margin:0 auto 16px; }

/* contact persons */
.contacts-2{ display:flex; flex-wrap:wrap; gap:14px; margin-top:8px; }
.contact-chip{ display:flex; align-items:center; gap:12px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius); padding:12px 16px; }
.contact-chip .av{ width:38px;height:38px;border-radius:50%; background:var(--accent); color:#fff; display:flex;align-items:center;justify-content:center; font-weight:700; font-family:var(--mono); font-size:14px; flex:none; }
.contact-chip .nm{ font-weight:700; font-size:14px; white-space:nowrap; }
.contact-chip .ph{ all:unset; font-family:var(--mono); font-size:13px; color:#cfc8bd; display:block; white-space:nowrap; }

/* ---------- About strip ---------- */
.about-figures{ display:grid; grid-template-columns: repeat(4,1fr); gap:20px; margin-top:40px; }
.figure{ border-top:2px solid var(--ink); padding-top:14px; }
.figure .big{ font-family:var(--serif); font-size: clamp(36px,4vw,52px); font-weight:600; line-height:1; }
.figure .lbl{ font-size:14px; color:var(--ink-soft); margin-top:6px; }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:#CFC8BD; padding-block: 64px 30px; }
.footer a{ color:#CFC8BD; transition:color .2s; }
.footer a:hover{ color:#fff; }
.footer__top{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.12); }
.footer .brand{ color:#fff; }
.footer .brand .ww{ color:#8c857a; }
.footer h5{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:#8c857a; margin:0 0 16px; font-weight:700; }
.footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; font-size:15px; }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; padding-top:24px; font-size:13px; color:#8c857a; flex-wrap:wrap; }
.footer__bottom .mono{ font-family:var(--mono); }

/* ---------- Reveal on scroll ---------- */
[data-reveal]{ opacity:0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal-d="1"]{ transition-delay:.08s; }
[data-reveal-d="2"]{ transition-delay:.16s; }
[data-reveal-d="3"]{ transition-delay:.24s; }

/* ---------- Marquee ---------- */
.marquee{ overflow:hidden; border-block:1px solid var(--line); background:var(--surface-2); }
.marquee__track{ display:flex; gap:48px; padding-block:16px; white-space:nowrap; width:max-content; animation: scroll-x 30s linear infinite; }
.marquee__track span{ font-family:var(--mono); font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); display:inline-flex; gap:48px; align-items:center; }
.marquee__track span::after{ content:"✦"; color:var(--accent); }
@keyframes scroll-x{ to{ transform: translateX(-50%); } }

/* ---------- Page hero (material pages) ---------- */
.page-hero{ border-bottom:1px solid var(--line); }

/* ---------- Cinematic image reel ("video") ---------- */
.reel{ position:relative; width:100%; aspect-ratio:16/9; max-height:80vh; overflow:hidden; background:#0c0b0a; isolation:isolate; }
.reel__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0;
  animation: reelFade 52s linear infinite, reelZoom 52s ease-out infinite;
  will-change:opacity, transform; pointer-events:none; }
.reel.is-paused .reel__img, .reel.is-paused .reel__fill{ animation-play-state:paused; }
.reel::after{ content:""; position:absolute; inset:0; pointer-events:none; z-index:2;
  background:linear-gradient(180deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,0) 16%, rgba(0,0,0,0) 78%, rgba(0,0,0,.30) 100%); }
.reel__bar{ position:absolute; left:0; right:0; bottom:0; height:3px; background:rgba(255,255,255,.16); z-index:3; }
.reel__fill{ display:block; height:100%; width:0; background:#fff; animation: reelBar 5.2s linear infinite; }
@keyframes reelFade{ 0%{opacity:0} 1.5%{opacity:1} 10%{opacity:1} 11.5%{opacity:0} 100%{opacity:0} }
@keyframes reelZoom{ 0%{transform:scale(1.045)} 11.5%{transform:scale(1.17)} 100%{transform:scale(1.17)} }
@keyframes reelBar{ 0%{width:0} 92%{width:100%} 100%{width:100%} }
/* 9-slide variant (total 9 x 5.2s = 46.8s) — slot = 11.11%, fade ~0.78s = 1.67% */
.reel--n9 .reel__img{ animation-name: reelFade9, reelZoom9; animation-duration: 46.8s; }
@keyframes reelFade9{ 0%{opacity:0} 1.67%{opacity:1} 11.11%{opacity:1} 12.78%{opacity:0} 100%{opacity:0} }
@keyframes reelZoom9{ 0%{transform:scale(1.0)} 12.78%{transform:scale(1.06)} 100%{transform:scale(1.06)} }
/* 10-slide variant (total 10 x 5.2s = 52s) — slot = 10%, fade ~0.78s = 1.5% */
.reel--n10 .reel__img{ animation-name: reelFade10, reelZoom10; animation-duration: 52s; }
.reel--n10.reel--fill .reel__layer--blur .reel__img{ animation-name: reelFade10; }
@keyframes reelFade10{ 0%{opacity:0} 1.5%{opacity:1} 10%{opacity:1} 11.5%{opacity:0} 100%{opacity:0} }
@keyframes reelZoom10{ 0%{transform:scale(1.0)} 11.5%{transform:scale(1.06)} 100%{transform:scale(1.06)} }
/* blurred-fill variant: portrait renders show the WHOLE scene (object-fit:contain) over a soft blurred backdrop, no crop, no black bars */
.reel__layer{ position:absolute; inset:0; }
.reel--fill .reel__layer--blur .reel__img{ object-fit:cover; transform:scale(1.18); filter:blur(34px) brightness(.6) saturate(1.05); animation-name: reelFade9; }
.reel--fill .reel__layer--sharp .reel__img{ object-fit:contain; }
@media (max-width:760px){ .reel{ aspect-ratio:3/4; max-height:none; } }
@media (prefers-reduced-motion: reduce){
  /* the global reset below forces animation-duration:.001ms !important; re-assert so
     the montage still cross-fades (zoom dropped for low motion) — same trick as .marquee__track */
  .reel__img{ animation-name: reelFade !important; animation-duration: 52s !important; }
  .reel--n9 .reel__img{ animation-name: reelFade9 !important; animation-duration: 46.8s !important; }
  .reel--n10 .reel__img{ animation-name: reelFade10 !important; animation-duration: 52s !important; }
  .reel__fill{ animation:none; width:100%; }
}

.crumbs{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--muted); margin-bottom:20px; display:flex; gap:8px; align-items:center; }
.crumbs a:hover{ color:var(--accent-deep); }
.spec-table{ width:100%; border-collapse:collapse; }
.spec-table td{ padding:14px 0; border-bottom:1px solid var(--line); font-size:15px; vertical-align:top; }
.spec-table td:first-child{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); width:42%; }
.chip{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:600; background:var(--surface); border:1px solid var(--line-2); border-radius:999px; padding:7px 14px; }
.chip .sw{ width:14px;height:14px;border-radius:3px; }
.gallery{ display:grid; grid-template-columns: repeat(3,1fr); gap:14px; }
.gallery .ph{ aspect-ratio:1; }
.ph img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .quote__grid{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns: 1fr 1fr; gap:32px; }
  .about-figures{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 980px){
  .nav-links{ position:fixed; inset:76px 0 auto 0; background:var(--bg); flex-direction:column; align-items:stretch; gap:0; padding: 10px var(--gutter) 24px; border-bottom:1px solid var(--line); transform:translateY(-120%); transition:.35s var(--ease); box-shadow:var(--shadow-md); }
  .nav-links.open{ transform:none; }
  .nav-links a{ padding:15px 0; border-bottom:1px solid var(--line); font-size:17px; }
  .nav-toggle{ display:block; }
  .has-dd .dd{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0; padding:0 0 8px 14px; min-width:auto; }
  .grid-3{ grid-template-columns: 1fr 1fr; }
  .topbar .tb-contacts .tb-hide{ display:none; }
  /* move quote CTA into the slide-down menu */
  .nav-right > .btn--primary{ display:none; }
  .nav-links a.nav-cta-m{ display:inline-flex; justify-content:center; color:#fff; background:var(--accent); border:0; border-radius:var(--radius); padding:16px 22px; margin-top:18px; font-size:16px; font-weight:700; box-shadow:0 6px 18px rgba(224,100,31,.28); }
  .nav-links a.nav-cta-m:hover{ background:var(--accent-deep); color:#fff; }
}
@media (max-width: 620px){
  .grid-2, .grid-3{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .dist-readout{ grid-template-columns:1fr 1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .gal-grid{ grid-template-columns:1fr 1fr; }
  body{ font-size:16px; }
}
@media (max-width: 480px){
  /* tighter section rhythm on phones */
  .section{ padding-block: clamp(48px, 11vw, 72px); }
  .nav .wrap{ gap:12px; height:64px; }
  .nav-links{ inset:64px 0 auto 0; }
  .brand{ font-size:22px; }
  .lang-toggle button{ padding:8px 12px; }
  .nav-toggle{ padding:10px; }
  /* full-width, comfortable tap targets for hero buttons */
  .hero-cta{ width:100%; }
  .hero-cta .btn{ flex:1 1 100%; justify-content:center; }
  .btn--lg{ padding:16px 24px; font-size:15px; }
  /* stack the delivery options so labels aren't cramped */
  .delivery-toggle{ flex-direction:column; }
  /* one clean column of stats / footer links */
  .about-figures{ grid-template-columns:1fr 1fr; gap:16px; }
  .footer__top{ grid-template-columns:1fr; gap:28px; }
  .footer__bottom{ flex-direction:column; align-items:flex-start; gap:8px; }
  #map{ height:240px; }
  .gal-grid{ grid-template-columns:1fr; }
}

/* ---------- Tweaks panel (vanilla) ---------- */
.twk{
  position:fixed; right:16px; bottom:16px; z-index:2147483646; width:248px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  -webkit-backdrop-filter: blur(20px) saturate(150%); backdrop-filter: blur(20px) saturate(150%);
  border:1px solid var(--line); border-radius:14px; box-shadow: var(--shadow-lg);
  font-family: var(--sans); color: var(--ink); overflow:hidden;
}
.twk[hidden]{ display:none; }
.twk-hd{ display:flex; align-items:center; justify-content:space-between; padding:11px 10px 11px 16px; cursor:move; user-select:none; border-bottom:1px solid var(--line); }
.twk-hd b{ font-size:13px; font-weight:700; font-family:var(--sans); }
.twk-close{ border:0; background:transparent; color:var(--muted); width:24px; height:24px; border-radius:6px; font-size:12px; }
.twk-close:hover{ background: var(--surface-2); color:var(--ink); }
.twk-bd{ padding:6px 16px 16px; display:flex; flex-direction:column; gap:8px; }
.twk-sect{ font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); padding-top:10px; }
.twk-seg{ display:flex; background:var(--surface-2); border:1px solid var(--line); border-radius:9px; padding:3px; gap:3px; }
.twk-seg .twk-opt{ flex:1; border:0; background:transparent; border-radius:6px; padding:7px 4px; font-size:12px; font-weight:600; color:var(--ink-soft); font-family:var(--sans); }
.twk-seg .twk-opt:hover{ color:var(--ink); }
.twk-seg .twk-opt.on{ background:var(--surface); color:var(--ink); box-shadow:var(--shadow-sm); }
.twk-sw-row{ display:flex; gap:10px; }
.twk-sw{ width:34px; height:34px; border-radius:50%; border:2px solid transparent; background:var(--c); cursor:pointer; transition:.18s var(--ease); padding:0; }
.twk-sw:hover{ transform: scale(1.08); }
.twk-sw.on{ border-color:var(--ink); box-shadow:0 0 0 2px var(--surface) inset; }

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
  [data-reveal]{ opacity:1; transform:none; }
  /* keep the decorative marquee scrolling gently (it would otherwise flicker) */
  .marquee__track{ animation-duration:30s !important; }
}
