:root{
  --bg:#f6f0e8;
  --bg-soft:#fffaf3;
  --ink:#111827;
  --muted:#667085;
  --line:rgba(17,24,39,.11);
  --card:rgba(255,255,255,.9);
  --brand:#0f766e;
  --brand-deep:#115e59;
  --gold:#c89b3c;
  --gold-soft:#f2c86f;
  --max:1180px;
  --radius:28px;
  --shadow:0 22px 70px rgba(17,24,39,.11);
}
*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  overscroll-behavior-x:none;
}
body{
  margin:0;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  position:relative;
  touch-action:pan-y;
  font-family:"Segoe UI",Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(200,155,60,.16), transparent 26rem),
    radial-gradient(circle at top right, rgba(15,118,110,.12), transparent 32rem),
    var(--bg);
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{width:min(var(--max), calc(100% - 32px));margin:0 auto}
.section{padding:72px 0}
.section.compact{padding:48px 0}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.72);
  color:var(--brand-deep);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.eyebrow::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 5px rgba(200,155,60,.16);
}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(40px,6vw,76px);line-height:.95;letter-spacing:-.06em;margin-bottom:18px}
h2{font-size:clamp(30px,4vw,50px);line-height:1.02;letter-spacing:-.04em;margin:18px 0}
h3{font-size:22px;line-height:1.15;letter-spacing:-.02em;margin-bottom:10px}
.lead{font-size:clamp(18px,2vw,22px);max-width:760px;color:#475467}
.muted{color:var(--muted)}
.ui-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:14px;
  background:linear-gradient(180deg, rgba(15,118,110,.12), rgba(200,155,60,.16));
  color:var(--brand-deep);
  border:1px solid rgba(15,118,110,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  flex:0 0 auto;
}
.ui-icon svg{
  width:20px;
  height:20px;
  display:block;
}
.title-with-icon{
  display:inline-flex;
  align-items:center;
  gap:12px;
  line-height:1.2;
}
.grid{display:grid;gap:20px}
.cards-2{grid-template-columns:repeat(2,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.pad{padding:28px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 20px;
  border-radius:999px;
  font-weight:800;
  border:0;
  cursor:pointer;
}
.btn-primary{background:var(--ink);color:#fff}
.btn-secondary{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:#241b0a}
.topbar{
  background:
    linear-gradient(90deg, rgba(15,118,110,.28), transparent 28%),
    #111827;
  color:#fff;
  font-size:14px;
}
.topbar-inner,.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.topbar-inner{padding:10px 0;flex-wrap:wrap}
.topbar-line,.topbar-meta{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.topbar-line span:first-child{font-weight:800}
.topbar-line span + span,.topbar-meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:rgba(255,255,255,.82);
}
.topbar-line span + span::before,.topbar-meta span::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--gold-soft);
  box-shadow:0 0 14px rgba(242,200,111,.9);
}
.header{
  position:sticky;
  top:0;
  z-index:1000;
  isolation:isolate;
  background:
    linear-gradient(90deg, rgba(255,255,255,.82), rgba(255,255,255,.58)),
    repeating-linear-gradient(90deg, rgba(15,118,110,.09) 0 1px, transparent 1px 88px),
    rgba(246,240,232,.9);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(17,24,39,.08);
  box-shadow:0 14px 42px rgba(17,24,39,.07);
  transform:translateZ(0);
  transition:background .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.header.is-stuck{
  background:
    linear-gradient(90deg, rgba(255,255,255,.94), rgba(255,255,255,.82)),
    repeating-linear-gradient(90deg, rgba(15,118,110,.08) 0 1px, transparent 1px 88px),
    rgba(246,240,232,.96);
  border-bottom-color:rgba(17,24,39,.12);
  box-shadow:0 18px 48px rgba(17,24,39,.12);
}
.nav{min-height:76px}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:180px;
}
.brand-mark{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:50%;
  background:#fff;
  overflow:hidden;
}
.brand-mark img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.brand strong{display:block;font-size:21px;line-height:1}
.brand-name{
  letter-spacing:.02em;
}
.brand-rainbow-m{
  display:inline-block;
  color:transparent;
  background:
    linear-gradient(90deg,
      #4b63db 0%,
      #30d7ed 6%,
      #34dfad 12%,
      #89e936 18%,
      #fff13d 24%,
      #ff9b24 30%,
      #f31638 36%,
      #ff74bd 42%,
      #8b35c3 48%,
      #4b63db 50%,
      #30d7ed 56%,
      #34dfad 62%,
      #89e936 68%,
      #fff13d 74%,
      #ff9b24 80%,
      #f31638 86%,
      #ff74bd 92%,
      #8b35c3 98%,
      #4b63db 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  filter:drop-shadow(0 2px 5px rgba(200,155,60,.26));
  animation:brand-rainbow-shift 6.5s linear infinite;
}
@keyframes brand-rainbow-shift{
  0%{background-position:0% 50%}
  100%{background-position:-100% 50%}
}
.menu{display:flex;gap:8px;flex-wrap:wrap}
.menu a{
  padding:10px 12px;
  border-radius:999px;
  color:#344054;
  font-weight:700;
}
.menu a:hover,.menu a.active{background:#fff;color:var(--ink)}
.nav-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}
.nav-chip{
  display:grid;
  gap:1px;
  padding:9px 13px;
  border:1px solid rgba(15,118,110,.16);
  border-radius:18px;
  background:rgba(255,255,255,.78);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.nav-chip span{
  font-size:12px;
  color:var(--muted);
  font-weight:800;
}
.nav-chip strong{
  font-size:13px;
  color:var(--brand-deep);
  line-height:1.05;
}
.menu-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  padding:0;
  border:1px solid rgba(17,24,39,.12);
  border-radius:14px;
  background:rgba(255,255,255,.9);
  box-shadow:0 10px 28px rgba(17,24,39,.1);
  cursor:pointer;
}
.menu-toggle span{
  position:absolute;
  width:20px;
  height:2px;
  border-radius:999px;
  background:var(--ink);
  transition:transform .2s ease, opacity .2s ease;
}
.menu-toggle span:nth-child(1){transform:translateY(-7px)}
.menu-toggle span:nth-child(2){transform:translateY(0)}
.menu-toggle span:nth-child(3){transform:translateY(7px)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg)}
.mobile-menu{
  display:none;
  position:absolute;
  left:0;
  right:0;
  top:100%;
  z-index:999;
  border-top:1px solid rgba(17,24,39,.08);
  background:rgba(255,250,243,.98);
  box-shadow:0 18px 40px rgba(17,24,39,.12);
  max-height:calc(100vh - 68px);
  overflow:auto;
  overscroll-behavior:contain;
}
.mobile-menu-inner{
  display:grid;
  gap:16px;
  padding:14px 0 18px;
}
.mobile-menu-links{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.mobile-menu-links a{
  display:flex;
  align-items:center;
  min-height:46px;
  padding:12px 14px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(17,24,39,.08);
  color:#344054;
  font-weight:800;
}
.mobile-menu-links a.active{
  color:var(--ink);
  border-color:rgba(200,155,60,.38);
  background:linear-gradient(135deg, rgba(200,155,60,.14), #fff);
}
.mobile-menu-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.body-menu-open{overflow:hidden}
.hero{padding-top:52px}
.hero-variant-one,.visual-header,.ceiling-types-showcase{
  position:relative;
}
.hero-grid,.contact-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;align-items:center}
.hero-panel{
  min-height:460px;
  padding:30px;
  border-radius:40px;
  color:#fff;
  background:
    linear-gradient(135deg,rgba(17,24,39,.14),rgba(17,24,39,.84)),
    linear-gradient(135deg,#374151,#111827 58%,#0f766e);
  box-shadow:var(--shadow);
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0}
.hero-lead-short{
  max-width:none;
  margin-bottom:26px;
  color:#344054;
  font-weight:900;
  letter-spacing:.01em;
}
.hero-media{
  display:grid;
  gap:14px;
}
.hero-media-main{
  position:relative;
  min-height:500px;
  margin:0;
  overflow:hidden;
  border-radius:34px;
  background:#111827;
  box-shadow:var(--shadow);
  isolation:isolate;
}
.hero-media-main::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(180deg, rgba(17,24,39,.04) 0%, rgba(17,24,39,.16) 42%, rgba(17,24,39,.74) 100%),
    radial-gradient(circle at 78% 14%, rgba(242,200,111,.28), transparent 28%);
}
.hero-media-main img{
  width:100%;
  height:100%;
  min-height:500px;
  object-fit:cover;
  transform:scale(1.02);
}
.hero-media-main figcaption{
  position:absolute;
  z-index:2;
  left:24px;
  right:24px;
  bottom:24px;
  display:grid;
  gap:8px;
  color:#fff;
}
.hero-media-main figcaption span{
  width:max-content;
  max-width:100%;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(12px);
  font-size:11px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.hero-media-main figcaption strong{
  max-width:560px;
  font-size:clamp(24px,3.1vw,38px);
  line-height:1.02;
  letter-spacing:-.03em;
}
.hero-media-tags{
  position:absolute;
  z-index:2;
  top:20px;
  left:20px;
  right:20px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.hero-media-tags span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:8px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.86);
  color:#111827;
  font-size:12px;
  font-weight:900;
  box-shadow:0 10px 26px rgba(17,24,39,.12);
}
.hero-texture-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.hero-texture-strip a{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:54px;
  padding:10px;
  border-radius:18px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(17,24,39,.08);
  box-shadow:0 14px 34px rgba(17,24,39,.06);
  font-size:12px;
  font-weight:900;
}
.hero-texture-strip span{
  width:24px;
  height:24px;
  border-radius:50%;
  flex:0 0 auto;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.95), transparent 34%),
    var(--swatch);
  border:1px solid rgba(17,24,39,.1);
}
.hero-media-facts{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.hero-media-facts .fact{
  min-height:82px;
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.84);
  border:1px solid rgba(17,24,39,.08);
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}
.ceiling-types-showcase{
  padding-top:38px;
  padding-bottom:52px;
}
.ceiling-types-shell{
  position:relative;
}
.ceiling-types-head{
  max-width:780px;
  margin-bottom:24px;
}
.ceiling-types-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.ceiling-type-card{
  position:relative;
  display:grid;
  gap:12px;
  min-height:0;
  overflow:hidden;
  padding:10px;
  border:1px solid rgba(17,24,39,.08);
  border-radius:22px;
  background:rgba(255,255,255,.82);
  box-shadow:0 18px 44px rgba(17,24,39,.08);
  isolation:isolate;
}
.ceiling-type-card::before{
  content:"";
  position:absolute;
  z-index:1;
  top:10px;
  left:10px;
  right:10px;
  aspect-ratio:16/10;
  border-radius:16px;
  background:linear-gradient(180deg, transparent 44%, rgba(17,24,39,.2));
  pointer-events:none;
}
.ceiling-type-card img{
  width:100%;
  aspect-ratio:16/10;
  min-height:0;
  object-fit:cover;
  border-radius:16px;
  background:#f7f1e8;
  transition:transform .35s ease;
}
.ceiling-type-card:hover img{
  transform:translateY(-2px);
}
.ceiling-type-card span,
.ceiling-type-card strong{
  position:static;
  color:var(--ink);
}
.ceiling-type-card span{
  width:max-content;
  max-width:100%;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(200,155,60,.14);
  border:1px solid rgba(200,155,60,.24);
  color:#7a5510;
  font-size:11px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.ceiling-type-card strong{
  font-size:20px;
  line-height:1.05;
  letter-spacing:-.02em;
}
.ceiling-style-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:18px;
}
.ceiling-style-badges span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:8px 11px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(17,24,39,.09);
  color:#344054;
  font-size:12px;
  font-weight:900;
  box-shadow:0 10px 24px rgba(17,24,39,.05);
}
.visual-header{
  padding-top:48px;
  padding-bottom:38px;
}
.visual-header-shell{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);
  gap:18px;
  align-items:stretch;
}
.visual-header-main{
  position:relative;
  min-height:640px;
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#111827;
}
.visual-header-main img{
  width:100%;
  height:100%;
  min-height:640px;
  object-fit:cover;
  display:block;
}
.visual-header-main::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(17,24,39,.9), rgba(17,24,39,.42) 48%, rgba(17,24,39,.08)),
    linear-gradient(180deg, rgba(17,24,39,.08), rgba(17,24,39,.56));
}
.visual-header-main figcaption{
  position:absolute;
  z-index:1;
  left:38px;
  right:38px;
  bottom:36px;
  display:grid;
  gap:16px;
  max-width:620px;
  color:#fff;
}
.visual-header-kicker{
  width:max-content;
  max-width:100%;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#f5d995;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}
.visual-header-main figcaption strong{
  font-size:clamp(34px,4.5vw,68px);
  line-height:.98;
}
.visual-header-copy{
  display:block;
  max-width:540px;
  color:rgba(255,255,255,.84);
  font-size:18px;
  font-weight:700;
}
.visual-header-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.btn-light{
  background:rgba(255,255,255,.92);
  color:#111827;
}
.visual-header-gallery{
  display:grid;
  grid-template-rows:1.12fr .88fr;
  gap:18px;
  min-width:0;
}
.visual-accent-stack{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.visual-accent{
  position:relative;
  overflow:hidden;
  min-height:0;
  border-radius:24px;
  background:#111827;
  box-shadow:0 12px 30px rgba(17,24,39,.14);
}
.visual-accent-large{min-height:360px}
.visual-accent img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.visual-accent::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 32%, rgba(17,24,39,.72));
}
.visual-accent figcaption{
  position:absolute;
  z-index:1;
  left:18px;
  right:18px;
  bottom:18px;
  display:grid;
  gap:4px;
  color:#fff;
}
.visual-accent figcaption strong{
  font-size:22px;
  line-height:1;
}
.visual-accent figcaption span{
  color:rgba(255,255,255,.82);
  font-size:13px;
  font-weight:800;
}
.lead-form{
  display:grid;
  gap:14px;
  margin-top:18px;
  padding:24px;
  border-radius:26px;
  background:rgba(255,255,255,.92);
  color:var(--ink);
  box-shadow:var(--shadow);
}
.lead-form-compact{
  margin-top:14px;
  padding:20px;
  background:rgba(255,255,255,.96);
}
.lead-form h3{margin-bottom:2px}
.lead-form label{display:grid;gap:8px}
.lead-form label span{
  font-size:13px;
  font-weight:800;
  color:#344054;
}
.lead-form input,.lead-form textarea{
  width:100%;
  padding:14px 16px;
  border:1px solid rgba(17,24,39,.14);
  border-radius:18px;
  background:#fff;
  color:var(--ink);
  font:inherit;
}
.lead-form textarea{resize:vertical;min-height:110px}
.lead-form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
.lead-form-actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.lead-form-note,.lead-form-status{
  margin:0;
  font-size:13px;
  color:var(--muted);
}
.lead-form-status{
  padding:12px 14px;
  border-radius:16px;
  background:rgba(15,118,110,.08);
  color:var(--brand-deep);
  font-weight:700;
}
.breadcrumbs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:18px;
  color:#667085;
  font-size:14px;
  font-weight:700;
}
.crumb-sep{opacity:.45}
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.fact{
  padding:16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
}
.fact strong{display:block;font-size:22px}
.trust-row,.quick-links,.footer-links{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.trust-chip,.quick-link,.footer-links a,.filter-btn{
  padding:10px 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:#344054;
  font-weight:700;
}
.trust-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  max-width:620px;
}
.trust-chip{
  display:grid;
  gap:3px;
  min-height:74px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.78);
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}
.trust-chip strong{
  color:var(--ink);
  font-size:15px;
  line-height:1.05;
}
.trust-chip span{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
.list{margin:0;padding-left:18px}
.list li{margin:8px 0}
.catalog-grid,.cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.popular-rooms-grid{align-items:stretch}
.popular-room-card{
  display:grid;
  gap:16px;
  min-height:100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(246,241,233,.92)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 12rem);
}
.popular-room-top{display:grid;gap:12px}
.popular-room-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.78);
  color:#344054;
  font-size:13px;
  font-weight:800;
}
.popular-room-chip .ui-icon{
  width:28px;
  height:28px;
  border-radius:10px;
}
.popular-room-list{margin-top:-2px}
.catalog-card{display:grid;gap:14px;height:100%}
.catalog-card-body{display:grid;gap:14px;height:100%}
.catalog-card-copy{display:grid;gap:10px}
.catalog-card-no-visual{
  position:relative;
  overflow:hidden;
}
.catalog-card-no-visual::before{
  content:"";
  display:block;
  height:6px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--gold), rgba(17,24,39,.18));
}
.catalog-visual{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,240,232,.92));
}
.catalog-visual img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}
.catalog-visual-badge{
  position:absolute;
  left:14px;
  top:14px;
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(17,24,39,.82);
  color:#fff;
  font-size:12px;
  letter-spacing:.02em;
}
.cluster-card{min-height:240px}
.cluster-card > .cluster-meta{
  display:none;
}
.cluster-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}
.cluster-kicker{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(15,118,110,.08);
  color:var(--brand-deep);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.cluster-meta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--muted);
  font-size:14px;
  font-weight:700;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
}
.cluster-meta strong{
  color:var(--ink);
  font-size:18px;
  line-height:1;
}
.cluster-card .ui-icon,
.catalog-card .ui-icon{
  width:32px;
  height:32px;
  border-radius:12px;
}
.cluster-card h3{
  margin-top:0;
}
.portfolio-case{display:grid;gap:12px}
.case-visual{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,240,232,.92));
}
.case-visual img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}
.case-visual-badge{
  position:absolute;
  left:14px;
  top:14px;
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(17,24,39,.82);
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}
.case-top,.case-meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.case-badge{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(15,118,110,.08);
  color:var(--brand-deep);
  font-size:12px;
  font-weight:800;
}
.case-badge-soft{
  background:rgba(200,155,60,.12);
  color:#7a5610;
}
.case-result{
  margin:0;
  padding:14px 16px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(15,118,110,.08), rgba(15,118,110,.03));
  border:1px solid rgba(15,118,110,.12);
  color:#23403c;
}
.cluster-meta{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  margin-bottom:12px;
  background:rgba(15,118,110,.1);
  color:var(--brand-deep);
  font-size:12px;
  font-weight:800;
}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 30px}
.filter-btn{cursor:pointer;font-weight:800}
.filter-btn.is-active{background:var(--ink);border-color:var(--ink);color:#fff}
[data-filter-item][hidden]{display:none !important}
.price-card{min-height:260px}
.guarantee-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,244,238,.9)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 12rem);
}
.review-card{
  display:grid;
  gap:18px;
  min-height:100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(243,238,230,.92));
}
.review-text{
  margin:0;
  font-size:18px;
  line-height:1.65;
  color:#344054;
}
.review-meta{
  display:grid;
  gap:4px;
  padding-top:12px;
  border-top:1px solid var(--line);
}
.review-meta strong{
  font-size:16px;
}
.review-meta span{
  color:var(--muted);
  font-size:14px;
  font-weight:700;
}
.price-sections{
  display:grid;
  gap:28px;
}
.price-category{
  display:grid;
  gap:18px;
}
.price-notes{margin-top:28px}
.price-tag{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-weight:900;
  margin-bottom:16px;
}
.steps-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.step-card{
  padding:22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
}
.step-num{
  display:inline-grid;
  place-items:center;
  width:42px;
  height:42px;
  margin-bottom:14px;
  border-radius:14px;
  background:#111827;
  color:#fff;
  font-weight:900;
}
.before-after-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.before-after-card{
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(15,118,110,.14);
  box-shadow:0 16px 42px rgba(17,24,39,.08);
  background:#fff;
}
.before-after-card img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  display:block;
}
.before-after-card figcaption{
  display:grid;
  gap:6px;
  padding:18px 20px 22px;
}
.before-after-card strong{
  font-size:18px;
}
.before-after-card span{
  color:var(--muted);
  font-size:14px;
  font-weight:700;
}
.faq details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:18px 20px;
}
.faq details + details{margin-top:12px}
.faq summary{
  list-style:none;
  cursor:pointer;
  font-weight:850;
}
.seo-copy p + p{margin-top:14px}
.detail-panels{margin-top:22px}
.detail-copy{margin-top:24px}
.detail-faq{padding-top:18px}
.detail-facts-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:22px 0 8px;
}
.detail-fact-chip{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:20px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.82);
  box-shadow:0 10px 30px rgba(17,24,39,.06);
}
.detail-fact-chip .ui-icon{
  width:30px;
  height:30px;
  border-radius:11px;
}
.detail-fact-chip strong,
.detail-fact-chip span{
  display:block;
}
.detail-fact-chip strong{
  font-size:14px;
  line-height:1.1;
}
.detail-fact-chip span{
  font-size:12px;
  color:var(--muted);
  line-height:1.2;
  margin-top:3px;
}
.detail-lead-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin:28px 0 22px;
  align-items:start;
}
.detail-hero-visual{
  overflow:hidden;
  margin:24px 0 18px;
  border:1px solid rgba(15,118,110,.14);
  box-shadow:0 18px 46px rgba(17,24,39,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,239,230,.94)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 14rem);
}
.detail-hero-visual picture,
.detail-hero-visual img{
  display:block;
  width:100%;
}
.detail-hero-visual img{
  aspect-ratio:16/9;
  object-fit:cover;
}
.detail-hero-visual figcaption{
  display:grid;
  gap:6px;
  padding:18px 22px 22px;
}
.detail-hero-visual strong{
  font-size:18px;
}
.detail-hero-visual span{
  color:var(--muted);
  font-size:14px;
  font-weight:700;
}
.detail-lead-copy{
  min-height:100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.88)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 14rem);
}
.detail-highlight-grid{
  margin-bottom:22px;
  align-items:stretch;
}
.detail-highlight-card{
  min-height:100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(246,241,233,.92)),
    radial-gradient(circle at top right, rgba(200,155,60,.12), transparent 10rem);
}
.detail-highlight-card p{
  margin-bottom:0;
}
.detail-trust-box{
  display:grid;
  gap:18px;
}
.detail-trust-grid{
  align-items:stretch;
}
.detail-reviews-box{
  display:grid;
  gap:18px;
}
.detail-copy .title-with-icon,
.detail-trust-box .title-with-icon,
.detail-reviews-box .title-with-icon,
.detail-cta-box .title-with-icon,
.detail-faq .title-with-icon,
.detail-before-after .title-with-icon,
.detail-gallery .title-with-icon,
.detail-cases .title-with-icon,
.detail-prices .title-with-icon{
  align-items:flex-start;
}
.detail-reviews-grid{
  align-items:stretch;
}
.detail-gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.detail-gallery-card{
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(15,118,110,.14);
  box-shadow:0 14px 36px rgba(17,24,39,.08);
  background:#fff;
}
.detail-gallery-card img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  display:block;
}
.detail-gallery-card figcaption{
  padding:14px 16px 18px;
  color:#475467;
  font-size:14px;
  font-weight:700;
}
.detail-review-card{
  min-height:100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(243,238,230,.92)),
    radial-gradient(circle at top right, rgba(15,118,110,.06), transparent 10rem);
}
.trust-mini-card{
  min-height:100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,244,238,.92)),
    radial-gradient(circle at top right, rgba(200,155,60,.12), transparent 10rem);
}
.detail-cta-box{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:center;
  margin-top:22px;
}
.detail-article-stack{
  display:grid;
  gap:22px;
}
.detail-article-head{
  display:grid;
  gap:12px;
  margin-bottom:22px;
}
.detail-article-head .lead{
  max-width:880px;
}
.detail-article-card{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);
  gap:22px;
  align-items:center;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,240,232,.94)),
    radial-gradient(circle at top right, rgba(15,118,110,.06), transparent 12rem);
}
.detail-article-card.is-reverse .detail-article-body{
  order:2;
}
.detail-article-card.is-reverse .detail-article-visual{
  order:1;
}
.detail-article-body{
  display:grid;
  align-content:start;
}
.detail-article-card h2{
  margin-top:0;
  margin-bottom:14px;
}
.detail-article-visual{
  margin:0;
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(15,118,110,.14);
  box-shadow:0 14px 36px rgba(17,24,39,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(246,240,232,.92)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 12rem);
}
.detail-article-visual img{
  width:100%;
  height:auto;
  aspect-ratio:16/9;
  object-fit:cover;
}
.detail-article-visual figcaption{
  padding:12px 16px 16px;
  font-size:14px;
  color:var(--muted);
}
.detail-article-card .list{
  margin-top:14px;
}
.detail-hero-visual img[src$=".svg"],
.before-after-card img[src$=".svg"],
.detail-gallery-card img[src$=".svg"],
.detail-article-visual img[src$=".svg"]{
  padding:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,236,228,.94)),
    radial-gradient(circle at top right, rgba(15,118,110,.07), transparent 12rem);
}
.detail-cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.calculator-shell{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:20px;
  align-items:start;
  margin-top:24px;
}
.calculator-main,
.calculator-summary{
  min-height:100%;
}
.calculator-main{
  background:
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(246,240,232,.92)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 14rem);
}
.calculator-shell-compact{
  margin-top:18px;
}
.detail-calculator-wrap{
  padding-top:12px;
}
.detail-calculator-drawer{
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,240,232,.94)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 14rem);
}
.detail-calculator-drawer summary{
  display:grid;
  gap:10px;
  cursor:pointer;
  list-style:none;
}
.detail-calculator-drawer summary::-webkit-details-marker{
  display:none;
}
.detail-calculator-drawer summary strong{
  font-size:24px;
  line-height:1.08;
  letter-spacing:-.03em;
}
.detail-calculator-drawer summary span:last-child{
  color:var(--muted);
}
.detail-calculator-drawer[open] summary{
  margin-bottom:18px;
}
.calculator-main-compact,
.calculator-summary-compact{
  border-radius:26px;
}
.calculator-main-compact .calculator-grid{
  gap:12px;
}
.calculator-main-compact .calculator-options{
  grid-template-columns:1fr;
}
.calculator-main-compact .calculator-check{
  grid-template-columns:auto 1fr;
  align-items:start;
  column-gap:12px;
}
.calculator-main-compact .calculator-check span,
.calculator-main-compact .calculator-check small{
  grid-column:2;
}
.calculator-summary-compact .calculator-total{
  font-size:clamp(30px,4vw,42px);
}
.calculator-summary-compact .calculator-note{
  padding:16px;
}
.calculator-presets{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:14px;
}
.calculator-layouts{
  display:grid;
  gap:12px;
  margin-bottom:18px;
}
.calculator-layouts-head{
  display:grid;
  gap:4px;
}
.calculator-layouts-head strong{
  font-size:15px;
}
.calculator-layouts-head span{
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
.calculator-layout-chips{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.calculator-layout-chip{
  display:grid;
  gap:4px;
  text-align:left;
  padding:14px 16px;
  border-radius:20px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.calculator-layout-chip:hover,
.calculator-layout-chip.is-active{
  transform:translateY(-1px);
  border-color:rgba(15,118,110,.32);
  box-shadow:0 14px 38px rgba(17,24,39,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(242,248,247,.94));
}
.calculator-layout-chip strong{
  font-size:14px;
}
.calculator-layout-chip span{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
}
.calculator-scenario{
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
  margin-bottom:18px;
  padding:16px 18px;
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.84);
}
.calculator-scenario strong{
  display:block;
  margin-bottom:4px;
}
.calculator-scenario span{
  color:var(--muted);
  font-size:14px;
}
.calculator-scenario-btn{
  border:0;
  border-radius:999px;
  padding:12px 16px;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  color:#241b0a;
  font-weight:800;
  cursor:pointer;
}
.calculator-preset{
  display:grid;
  gap:3px;
  text-align:left;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.calculator-preset:hover,
.calculator-preset.is-active{
  transform:translateY(-1px);
  border-color:rgba(15,118,110,.32);
  box-shadow:0 14px 38px rgba(17,24,39,.08);
}
.calculator-preset strong{
  font-size:13px;
  line-height:1.15;
}
.calculator-preset span{
  color:var(--muted);
  font-size:11px;
  line-height:1.2;
}
.detail-prices-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.detail-prices-head h2{
  margin:0;
}
.detail-prices-trigger{
  flex:0 0 auto;
}
.calculator-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.calculator-field{
  display:grid;
  gap:8px;
}
.calculator-field span{
  font-size:13px;
  font-weight:800;
  color:#344054;
}
.calculator-field input,
.calculator-field select{
  width:100%;
  padding:14px 16px;
  border:1px solid rgba(17,24,39,.14);
  border-radius:18px;
  background:#fff;
  color:var(--ink);
  font:inherit;
}
.calculator-field small,
.calculator-check small{
  color:var(--muted);
  font-size:13px;
}
.calculator-options{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:18px;
}
.calculator-check{
  display:grid;
  gap:6px;
  padding:16px 18px;
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.82);
}
.calculator-check input{
  width:18px;
  height:18px;
  margin:0;
}
.calculator-check span{
  font-weight:800;
}
.calculator-summary{
  position:sticky;
  top:98px;
  background:
    linear-gradient(180deg, rgba(17,24,39,.98), rgba(17,24,39,.92)),
    radial-gradient(circle at top right, rgba(200,155,60,.22), transparent 12rem);
  color:#fff;
}
.calculator-summary-top .eyebrow{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.12);
  color:#fff;
}
.calculator-total{
  display:block;
  margin-top:18px;
  font-size:clamp(36px,5vw,54px);
  line-height:.95;
  letter-spacing:-.05em;
}
.calculator-subtotal{
  margin:10px 0 0;
  color:rgba(255,255,255,.74);
  font-size:15px;
  font-weight:700;
}
.calculator-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.calculator-badges span{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:13px;
  font-weight:800;
}
.calculator-recommend{
  margin-top:20px;
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.calculator-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:grid;
  place-items:center;
  padding:24px;
}
.calculator-modal[hidden]{
  display:none !important;
}
.calculator-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(17,24,39,.56);
  backdrop-filter:blur(4px);
}
.calculator-modal-dialog{
  position:relative;
  z-index:1;
  width:min(1120px, 100%);
  max-height:min(88vh, 980px);
  overflow:auto;
  background:
    linear-gradient(180deg, rgba(255,255,255,.99), rgba(247,243,236,.96)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 16rem);
  box-shadow:0 28px 90px rgba(17,24,39,.28);
}
.calculator-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:42px;
  height:42px;
  border:none;
  border-radius:999px;
  background:rgba(17,24,39,.08);
  color:var(--ink);
  font-size:28px;
  line-height:1;
  cursor:pointer;
}
body.modal-open{
  overflow:hidden;
}
.calculator-recommend strong{
  display:block;
  margin-bottom:10px;
}
.calculator-recommend ul{
  margin:0;
  padding-left:18px;
  display:grid;
  gap:8px;
}
.calculator-recommend li{
  color:rgba(255,255,255,.82);
}
.calculator-recommend{
  margin-top:20px;
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.calculator-recommend strong{
  display:block;
  margin-bottom:10px;
}
.calculator-recommend ul{
  margin:0;
  padding-left:18px;
  display:grid;
  gap:8px;
}
.calculator-recommend li{
  color:rgba(255,255,255,.82);
}
.calculator-breakdown{
  margin-top:22px;
}
.calculator-breakdown strong,
.calculator-note strong{
  display:block;
  margin-bottom:12px;
}
.calculator-breakdown ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.calculator-breakdown li{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.calculator-breakdown li span{
  color:rgba(255,255,255,.74);
}
.calculator-breakdown li strong{
  margin:0;
  font-size:15px;
}
.calculator-note{
  margin-top:22px;
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.calculator-note p{
  margin:0;
  color:rgba(255,255,255,.8);
}
.calculator-actions{
  display:grid;
  gap:12px;
  margin-top:22px;
}
.calculator-actions .btn{
  width:100%;
}
.calculator-helper{
  margin:14px 0 0;
  color:rgba(255,255,255,.74);
  font-size:13px;
}
.cta-band{
  padding:40px;
  border-radius:40px;
  background:#111827;
  color:#fff;
}
.cta-band-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:22px;
  align-items:start;
}
.cta-points{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}
.cta-points span{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-weight:700;
}
.cross-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:24px}
.contact-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:22px;
}
.contact-meta{margin-top:22px}
.sitemap-stats-wrap{
  display:flex;
  justify-content:flex-end;
  margin-top:22px;
}
.sitemap-stats{
  width:min(100%, 460px);
}
.sitemap-stats-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-top:18px;
}
.sitemap-stats-grid div{
  display:grid;
  gap:6px;
  padding:16px 18px;
  border-radius:20px;
  background:#fff;
  border:1px solid var(--line);
}
.sitemap-stats-grid strong{
  font-size:32px;
  line-height:1;
  letter-spacing:-.04em;
}
.sitemap-stats-grid span{
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
.footer{padding:36px 0 90px}
.footer-main{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr .9fr;
  gap:18px;
  padding-top:24px;
  border-top:1px solid var(--line);
}
.footer-brand p,.footer-column p{margin:8px 0;color:#475467}
.footer-column h3{font-size:18px}
.feedback-widget{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:80;
  display:grid;
  gap:12px;
  justify-items:end;
  transition:transform .35s ease;
}
.feedback-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:96px;
  min-width:96px;
  height:64px;
  border:0;
  border-radius:22px;
  padding:0;
  background:linear-gradient(135deg,#111827,#1f2937);
  color:#fff;
  font-weight:850;
  cursor:pointer;
  box-shadow:0 14px 40px rgba(17,24,39,.24);
  transition:width .35s ease, min-width .35s ease, height .35s ease, border-radius .35s ease, transform .35s ease, box-shadow .22s ease;
}
.feedback-toggle:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 46px rgba(17,24,39,.28);
}
.feedback-toggle-dot{
  width:14px;
  height:14px;
  border-radius:50%;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  box-shadow:0 0 0 6px rgba(200,155,60,.16);
  flex:0 0 auto;
}
.feedback-widget.is-scrolled{
  transform:translateX(10px);
}
.feedback-widget.is-scrolled .feedback-toggle{
  width:58px;
  min-width:58px;
  height:42px;
  border-radius:13px 0 0 13px;
}
.feedback-panel{
  position:absolute;
  right:0;
  bottom:calc(100% + 12px);
  display:grid;
  gap:12px;
  width:min(330px, calc(100vw - 24px));
  padding:14px;
  border:1px solid var(--line);
  border-radius:24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,240,232,.96)),
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 12rem);
  box-shadow:var(--shadow);
  opacity:0;
  transform:translateY(10px) scale(.98);
  transform-origin:bottom right;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
}
.feedback-widget.is-open .feedback-panel{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.feedback-widget.is-open .feedback-toggle{
  box-shadow:0 18px 48px rgba(17,24,39,.3);
}
.feedback-panel-head{
  display:grid;
  gap:6px;
  padding:2px 2px 0;
}
.feedback-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(15,118,110,.1);
  color:var(--brand-deep);
  font-size:11px;
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.feedback-panel-head strong{
  font-size:18px;
}
.feedback-panel-head small{
  color:var(--muted);
  line-height:1.45;
}
.feedback-actions{
  display:grid;
  gap:8px;
}
.feedback-link{
  display:grid;
  gap:2px;
  padding:12px 14px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(17,24,39,.08);
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.feedback-link:hover{
  transform:translateY(-1px);
  border-color:rgba(15,118,110,.24);
  box-shadow:0 12px 28px rgba(17,24,39,.08);
}
.feedback-link strong{
  font-size:14px;
}
.feedback-link span{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
}
.feedback-link-primary{
  background:linear-gradient(135deg, rgba(200,155,60,.16), rgba(255,255,255,.98));
  border-color:rgba(200,155,60,.28);
}
.prose p{margin-bottom:14px}
@media (max-width:1040px){
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .nav-chip{display:none}
  .hero-media-main,.hero-media-main img{min-height:460px}
  .trust-row{grid-template-columns:repeat(2,1fr);max-width:none}
  .ceiling-types-grid{grid-template-columns:repeat(2,1fr)}
  .visual-header-shell{grid-template-columns:1fr}
  .visual-header-main,.visual-header-main img{min-height:520px}
  .visual-header-gallery{grid-template-rows:auto;grid-template-columns:1fr}
  .visual-accent-large{min-height:280px}
  .cards-3,.catalog-grid,.cluster-grid,.portfolio-grid,.split-grid,.hero-grid,.contact-grid,.footer-main{grid-template-columns:1fr}
  .cards-2,.cross-grid,.facts,.steps-grid,.before-after-grid,.calculator-shell,.calculator-grid,.calculator-options,.calculator-presets{grid-template-columns:1fr}
  .calculator-layout-chips{grid-template-columns:repeat(2,1fr)}
  .lead-form-grid,.cta-band-grid,.detail-lead-grid,.detail-cta-box,.sitemap-stats-grid,.detail-gallery-grid{grid-template-columns:1fr}
  .detail-article-card{grid-template-columns:1fr}
  .detail-article-card.is-reverse .detail-article-body,
  .detail-article-card.is-reverse .detail-article-visual{order:initial}
  .calculator-summary{position:static}
  .calculator-scenario{grid-template-columns:1fr}
  .detail-prices-head{flex-direction:column}
}
@media (max-width:720px){
  .container{width:min(var(--max), calc(100% - 22px))}
  .topbar{display:none}
  .menu,.nav-phone,.nav-actions{display:none}
  .nav{min-height:68px}
  .brand{min-width:0}
  .brand strong{font-size:19px}
  .menu-toggle{display:inline-flex;position:relative;flex:0 0 auto}
  .mobile-menu.is-open{display:block}
  .mobile-menu-actions{grid-template-columns:1fr}
  .brand-mark{width:44px;height:44px}
  .hero{padding-top:34px}
  .hero-media-main,.hero-media-main img{min-height:420px}
  .hero-media-main{border-radius:24px}
  .hero-media-main figcaption{left:18px;right:18px;bottom:18px}
  .hero-media-tags{top:14px;left:14px;right:14px}
  .hero-media-tags span{min-height:31px;font-size:11px}
  .hero-texture-strip{grid-template-columns:1fr 1fr}
  .hero-media-facts{grid-template-columns:1fr}
  .trust-row{grid-template-columns:1fr 1fr}
  .trust-chip{min-height:68px}
  .ceiling-types-showcase{padding-top:20px}
  .ceiling-types-grid{grid-template-columns:1fr}
  .visual-header{padding-top:26px}
  .visual-header-main,.visual-header-main img{min-height:520px}
  .visual-header-main{border-radius:22px}
  .visual-header-main figcaption{left:18px;right:18px;bottom:18px;gap:12px}
  .visual-header-copy{font-size:16px}
  .visual-header-kicker{font-size:11px}
  .visual-accent-stack{grid-template-columns:1fr}
  .visual-accent-large,.visual-accent{min-height:220px;border-radius:18px}
  .btn{width:100%}
  .hero-actions .btn{width:100%}
  .lead-form-actions .btn,.contact-actions .btn,.detail-cta-actions .btn{width:100%}
  .detail-facts-row{display:grid;grid-template-columns:1fr}
  .calculator-layout-chips{grid-template-columns:1fr}
  .calculator-modal{padding:12px}
  .feedback-widget{right:12px;left:auto;justify-items:end}
  .feedback-panel{
    right:0;
    left:auto;
    width:min(330px, calc(100vw - 24px));
    transform-origin:bottom center;
  }
  .feedback-toggle{
    width:88px;
    min-width:88px;
    justify-content:center;
  }
  .feedback-widget.is-scrolled .feedback-toggle{width:54px;min-width:54px}
}
