/* ============================================================
   PRESTON — Chartered Accountants  ·  v2
   Aesthetic preserved: "Quiet Authority" editorial luxury
   New: audience switcher, fixed-fee estimator, reworked flow
   ============================================================ */

:root{
  /* Cool mist palette */
  --fog:        #F3F5F6;
  --mist:       #E7EBED;
  --paper:      #FBFCFC;
  --ink:        #12171C;
  --ink-2:      #495159;
  --ink-3:      #7C858C;
  --line:       rgba(18,23,28,.13);
  --line-soft:  rgba(18,23,28,.07);

  /* Warm brass accent */
  --brass:      #A9824B;
  --brass-2:    #C6A063;
  --brass-tint: rgba(169,130,75,.10);

  /* Dark section */
  --deep:       #10161A;
  --deep-2:     #182127;
  --deep-line:  rgba(255,255,255,.12);
  --deep-ink:   #C9D0D4;

  --display: "Fraunces", Georgia, serif;
  --body:    "Hanken Grotesk", system-ui, sans-serif;
  --mono:    "IBM Plex Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --pad: clamp(1.25rem, 5vw, 6rem);
  --maxw: 1480px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--body);
  font-weight:400;
  color:var(--ink);
  background:var(--fog);
  line-height:1.55;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }

/* film grain */
body::after{
  content:"";
  position:fixed; inset:0; z-index:9000; pointer-events:none;
  opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Type helpers ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--brass);
  font-weight:500;
}
.eyebrow--muted{ color:var(--ink-3); }

.h-display{
  font-family:var(--display);
  font-weight:340;
  font-optical-sizing:auto;
  line-height:1.02;
  letter-spacing:-.015em;
}
.lead{
  font-size:clamp(1.05rem,1.5vw,1.35rem);
  color:var(--ink-2);
  font-weight:300;
  max-width:48ch;
}
.idx{ font-family:var(--mono); font-size:.8rem; color:var(--brass); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  padding:1.05em 1.7em;
  font-family:var(--mono);
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  border-radius:100px;
  border:1px solid var(--ink);
  background:var(--ink); color:var(--paper);
  position:relative; overflow:hidden;
  transition:color .5s var(--ease), border-color .5s var(--ease);
}
.btn span{ position:relative; z-index:1; }
.btn::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:var(--brass);
  transform:translateY(101%);
  transition:transform .5s var(--ease);
}
.btn:hover{ color:var(--ink); border-color:var(--brass); }
.btn:hover::before{ transform:translateY(0); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ color:var(--paper); }
.btn--ghost::before{ background:var(--ink); }
.btn .arrow{ transition:transform .5s var(--ease); position:relative; z-index:1; }
.btn:hover .arrow{ transform:translateX(4px); }
.btn--sm{ padding:.85em 1.4em; }

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.4rem var(--pad);
  transition:background .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(243,245,246,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
  padding-top:1rem; padding-bottom:1rem;
}
.brand{ display:flex; flex-direction:column; line-height:1; }
.brand b{ font-family:var(--display); font-weight:420; font-size:1.5rem; letter-spacing:.02em; }
.brand small{ font-family:var(--display); font-weight:400; font-size:.82rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3); margin-top:.34em; }

/* bare logo-only nav for ads landing */
.nav--bare .brand b{ color:var(--ink); font-size:1.95rem; }
.nav--bare .brand small{ font-size:1.07rem; }
.nav-phone{ display:inline-flex; align-items:center; gap:.6em; font-family:var(--mono); font-size:1.04rem; letter-spacing:.06em; color:var(--ink); padding:.3em 0; }
.nav-phone svg{ width:21px; height:21px; color:var(--brass); }
.nav-phone:hover{ color:var(--brass); }
@media(max-width:540px){ .nav-phone span{ display:none; } }

/* WhatsApp CTA */
.btn--wa{ background:#25D366; border-color:#25D366; color:#fff; }
.btn--wa::before{ background:#128C45; }
.btn--wa:hover{ color:#fff; border-color:#128C45; }
.btn .wa{ width:18px; height:18px; position:relative; z-index:1; }
.btn--lg{ padding:1.05em 2em; font-family:var(--display); font-size:1.18rem; font-weight:500; letter-spacing:0; text-transform:none; }
.btn--lg .wa{ width:22px; height:22px; }

/* creative Google reviews cell */
.gmark{ display:inline-flex; align-self:center; }
.gmark svg{ width:1.5em; height:1.5em; }
.trust--google .trust__v{ gap:.45em; }
.trust--google .trust__l .stars{ display:block; font-size:.95rem; margin-bottom:.55rem; }

/* red ACCA accreditation badge */
.acca-logo{
  display:inline-flex; align-items:center; justify-content:center;
  background:#E2231A; color:#fff;
  font-family:var(--body); font-weight:700; font-size:clamp(1.05rem,1.6vw,1.4rem);
  letter-spacing:.05em; line-height:1; padding:.4em .62em; border-radius:6px;
  box-shadow:0 6px 18px -8px rgba(226,35,26,.7);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.trust--acca:hover .acca-logo{ transform:translateY(-2px); box-shadow:0 12px 26px -8px rgba(226,35,26,.75); }

/* minimal legal strip */
.legal{ background:var(--paper); border-top:1px solid var(--line); }
.legal__row{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding:1.4rem 0; font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.legal__links{ display:flex; gap:1.6rem; }
.legal__links a:hover{ color:var(--brass); }
.nav-links{ display:flex; align-items:center; gap:2.4rem; }
.nav-links a{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-2);
  position:relative; padding:.3em 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--brass);
  transition:width .4s var(--ease);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }
.nav-toggle{ display:none; }

/* ===========================================================
   HERO — scroll-scrubbed video
   =========================================================== */
.hero{ position:relative; height:100vh; }
.hero__stage{
  position:sticky; top:0; height:100vh; overflow:hidden;
  display:grid; place-items:center;
  padding-top:clamp(4.5rem,9vh,7rem);
  background:var(--mist);
}
.hero__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center 42%;
  will-change:transform;
  filter:contrast(1.02) brightness(1.02);
}
.hero__veil{
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 30% 35%, rgba(243,245,246,0) 40%, rgba(243,245,246,.4) 100%),
    linear-gradient(to bottom, rgba(243,245,246,.5) 0%, rgba(243,245,246,0) 22% 70%, rgba(243,245,246,.95) 100%);
}
.hero__inner{
  position:relative; z-index:2;
  width:100%; max-width:var(--maxw); margin:0 auto;
  padding:0 var(--pad);
}
.hero__brand{ margin-bottom:1.6rem; display:flex; align-items:center; gap:1.1rem; flex-wrap:wrap; }
.hero__brand b{ font-family:var(--display); font-weight:460; font-size:1.45rem; letter-spacing:.01em; color:var(--ink); }
/* location pin chip */
.locpin{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-2);
  border:1px solid var(--line); border-radius:100px; padding:.5em .9em; background:rgba(251,252,252,.55);
  backdrop-filter:blur(6px);
}
.locpin svg{ width:13px; height:13px; color:var(--brass); }
.hero h1{
  font-size:clamp(1.95rem, 4.3vw, 3.9rem);
  margin:0;
  max-width:24ch;
  line-height:1.04;
}
.hero h1 em{ font-style:italic; font-weight:320; color:var(--brass); }

/* direct one-line promise to the reader */
.hero__line{
  margin:clamp(1.3rem,2.6vw,2rem) 0 0;
  font-size:clamp(1.15rem,1.9vw,1.6rem);
  font-weight:300;
  line-height:1.3;
  color:var(--ink-2);
  max-width:30ch;
  text-wrap:balance;
}
.hero__line em{
  font-family:var(--display);
  font-style:italic;
  font-weight:340;
  color:var(--ink);
}

.hero__sub{
  display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:2rem;
  margin-top:2.4rem;
}
.hero__cta{ display:flex; gap:1rem; flex-wrap:wrap; margin-top:clamp(1.6rem,3vw,2.2rem); }

/* refined proof cluster — Google rating + years */
.proof{
  display:flex; align-items:center; gap:clamp(1.4rem,3vw,2.6rem);
  margin-top:clamp(2.2rem,4.5vw,3.4rem); flex-wrap:wrap;
}
.proof__item{ display:flex; flex-direction:column; gap:.6rem; }
.proof__top{ display:flex; align-items:center; gap:.6rem; }
.proof__top .gmark svg{ width:1.7rem; height:1.7rem; }
.proof__num{
  font-family:var(--display); font-weight:340; line-height:1; letter-spacing:-.01em;
  font-size:clamp(1.9rem,3.4vw,2.7rem); color:var(--ink);
}
.proof__num .u{ font-family:var(--mono); font-weight:500; font-size:.42em; color:var(--brass); vertical-align:.35em; }
.proof__top .stars{ font-size:1rem; }
.proof__cap{
  font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3);
}
.proof__div{ width:1px; align-self:stretch; min-height:2.6rem; background:var(--line); }
@media(max-width:460px){ .proof{ gap:1.2rem; } .proof__div{ display:none; } }

.reveal-line{ display:block; overflow:hidden; }
.reveal-line > *{ display:block; }

.scrollcue{
  position:absolute; left:50%; bottom:2.2rem; transform:translateX(-50%);
  z-index:3; display:flex; flex-direction:column; align-items:center; gap:.8rem;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--ink-3);
}
.scrollcue .bar{ width:1px; height:46px; background:linear-gradient(var(--ink-3),transparent); position:relative; overflow:hidden; }
.scrollcue .bar::after{ content:""; position:absolute; top:-40%; left:0; width:100%; height:40%; background:var(--brass); animation:drop 2.4s var(--ease) infinite; }
@keyframes drop{ to{ top:120%; } }

/* ---------- HERO TRUST STRIP ---------- */
.hero__trust{
  list-style:none; margin:clamp(2.2rem,4vw,3.2rem) 0 0; padding:0;
  display:flex; flex-wrap:wrap; gap:0;
  border-top:1px solid var(--line);
}
.trust{
  flex:1 1 0; min-width:150px;
  padding:1.4rem clamp(1rem,2vw,1.8rem) 1.2rem;
  border-right:1px solid var(--line);
  position:relative; cursor:default;
  transition:transform .5s var(--ease), background .5s var(--ease);
}
.trust:last-child{ border-right:none; }
.trust::after{ content:""; position:absolute; left:0; bottom:-1px; height:2px; width:0; background:var(--brass); transition:width .5s var(--ease); }
.trust:hover{ transform:translateY(-4px); }
.trust:hover::after{ width:100%; }
.trust:hover .trust__v{ color:var(--brass); }
.trust__v{
  display:flex; align-items:baseline; gap:.35em;
  font-family:var(--display); font-weight:360; font-size:clamp(1.7rem,3vw,2.5rem); line-height:1;
  letter-spacing:-.01em; color:var(--ink); transition:color .5s var(--ease);
}
.trust__v .u{ font-family:var(--mono); font-weight:500; font-size:.5em; color:var(--brass); letter-spacing:0; }
.trust__l{ display:block; font-family:var(--mono); font-size:.68rem; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3); margin-top:.85rem; }

.stars{ position:relative; display:inline-block; font-size:.62em; line-height:1; letter-spacing:.05em; color:rgba(18,23,28,.16); }
.stars::before{ content:"\2605\2605\2605\2605\2605"; }
.stars::after{
  content:"\2605\2605\2605\2605\2605"; position:absolute; left:0; top:0; overflow:hidden; white-space:nowrap;
  color:var(--brass); width:0; animation:starfill 1.4s var(--ease) .9s forwards;
}
@keyframes starfill{ to{ width:var(--pct,96%); } }

.pulse{ width:8px; height:8px; border-radius:50%; background:var(--brass); position:relative; align-self:center; margin-left:.2em; }
.pulse::after{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--brass); animation:ping 2s var(--ease) infinite; }
@keyframes ping{ 0%{ transform:scale(1); opacity:.6; } 70%,100%{ transform:scale(3.2); opacity:0; } }

.trust__seal{
  font-family:var(--mono)!important; font-weight:500; font-size:1.15rem!important; letter-spacing:.12em;
  border:1.5px solid var(--brass); color:var(--brass)!important; border-radius:100px;
  padding:.45em .9em; align-self:flex-start;
  transition:background .5s var(--ease), color .5s var(--ease);
}
.trust:hover .trust__seal{ background:var(--brass); color:var(--paper)!important; }

@media(max-width:680px){
  .hero__trust{ border-top:none; }
  .trust{ flex:1 1 45%; border-right:none; border-top:1px solid var(--line); padding-left:0; }
  .trust:nth-child(odd){ padding-right:1.2rem; }
}

/* ===========================================================
   ACCREDITATIONS / PARTNER LOGOS
   =========================================================== */
.accreds{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--paper);
  padding:clamp(2rem,4vw,3.2rem) 0;
}
.accreds__eyebrow{
  text-align:center; margin:0 0 clamp(1.4rem,3vw,2.2rem);
  font-family:var(--mono); font-size:.66rem; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-3);
}
.logo-marquee{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%);
  mask-image:linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%);
}
.logo-track{
  display:flex; width:max-content;
  animation:logoScroll 42s linear infinite;
}
.logo-marquee:hover .logo-track{ animation-play-state:paused; }
.logo-cell{
  flex:none;
  display:flex; align-items:center; justify-content:center; text-align:center;
  width:clamp(120px,12vw,170px); height:68px;
  margin-right:clamp(2.4rem,5vw,4.5rem);
  font-family:var(--display); font-weight:440; font-size:clamp(.95rem,1.2vw,1.15rem);
  letter-spacing:.01em; color:var(--ink); line-height:1.1;
  filter:grayscale(1); opacity:.55;
  transition:filter .45s var(--ease), opacity .45s var(--ease), transform .45s var(--ease);
}
.logo-marquee:hover .logo-cell{ filter:grayscale(0); opacity:1; }
.logo-cell img{ max-width:100%; max-height:100%; object-fit:contain; }
.logo-cell:hover{ transform:translateY(-3px); }
@keyframes logoScroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.accreds__hint{
  text-align:center; margin:clamp(1.4rem,3vw,2rem) 0 0;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3);
  opacity:.6;
}
@media (prefers-reduced-motion: reduce){
  .logo-track{ animation:none !important; }
}

/* ===========================================================
   SECTION SCAFFOLD
   =========================================================== */
section{ position:relative; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.section-pad{ padding:clamp(5rem,11vw,11rem) 0; }
.section-head{ display:grid; grid-template-columns:1fr; gap:1.4rem; max-width:62ch; margin-bottom:clamp(3rem,6vw,5.5rem); }
.section-head h2{ font-size:clamp(2.1rem,5vw,4.2rem); margin:0; }
.section-head .lead{ margin:0; }

/* ===========================================================
   AUDIENCE SWITCHER  (NEW)
   "Tell us who you are" — personalises services + estimator
   =========================================================== */
.audience{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.aud-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap; margin-bottom:clamp(2rem,4vw,3rem); }
.aud-head h2{ font-size:clamp(1.9rem,4vw,3.4rem); margin:.8rem 0 0; max-width:18ch; }
.aud-tabs{
  display:flex; flex-wrap:wrap; gap:.6rem;
  border-bottom:1px solid var(--line); padding-bottom:1.4rem; margin-bottom:0;
}
.aud-tab{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-2); background:transparent; border:1px solid var(--line); border-radius:100px;
  padding:.7em 1.2em; display:inline-flex; align-items:center; gap:.6em;
  transition:color .4s var(--ease), border-color .4s var(--ease), background .4s var(--ease), transform .4s var(--ease);
}
.aud-tab .dot{ width:7px; height:7px; border-radius:50%; background:var(--line); transition:background .4s var(--ease); }
.aud-tab:hover{ border-color:var(--brass); color:var(--ink); transform:translateY(-2px); }
.aud-tab.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.aud-tab.is-active .dot{ background:var(--brass-2); }

.aud-panel{
  display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(2rem,5vw,5rem);
  align-items:center; padding-top:clamp(2.4rem,5vw,4rem);
}
.aud-copy .eyebrow{ display:block; margin-bottom:1.1rem; }
.aud-copy h3{
  font-family:var(--display); font-weight:340; font-size:clamp(1.6rem,3.4vw,2.9rem);
  line-height:1.08; letter-spacing:-.01em; margin:0 0 1.2rem; max-width:20ch;
}
.aud-copy h3 em{ font-style:italic; color:var(--brass); }
.aud-copy p{ color:var(--ink-2); max-width:46ch; margin:0 0 1.8rem; }
.aud-chips{ display:flex; flex-wrap:wrap; gap:.6rem; margin:0 0 2rem; padding:0; list-style:none; }
.aud-chips li{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; color:var(--ink-2);
  border:1px solid var(--line); border-radius:8px; padding:.55em .9em; background:var(--fog);
  transition:transform .4s var(--ease), border-color .4s var(--ease);
}
.aud-chips li::before{ content:"\2726"; color:var(--brass); margin-right:.6em; font-size:.8em; }
.aud-from{ display:flex; align-items:baseline; gap:.8rem; flex-wrap:wrap; }
.aud-from .k{ font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); }
.aud-from .v{ font-family:var(--display); font-weight:360; font-size:clamp(2rem,4vw,3.2rem); line-height:1; }
.aud-from .v .u{ font-family:var(--mono); font-size:.4em; color:var(--brass); vertical-align:.2em; }
.aud-from .per{ font-family:var(--mono); font-size:.74rem; color:var(--ink-3); }

/* slide when audience changes — transform-only so content is never trapped invisible */
.aud-copy.swap{ animation:audSwap .5s var(--ease); }
@keyframes audSwap{ from{ transform:translateY(12px); } to{ transform:none; } }

/* aside visual — abstract "for your business" placeholder card */
.aud-aside{
  position:relative; aspect-ratio:4/3.4; border:1px solid var(--line); border-radius:18px;
  overflow:hidden; background:var(--mist);
}
.aud-aside__img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
}
.aud-aside__img.swap{ animation:audImgIn .6s var(--ease); }
@keyframes audImgIn{ from{ opacity:0; transform:scale(1.04); } to{ opacity:1; transform:none; } }
@media(max-width:900px){ .aud-panel{ grid-template-columns:1fr; } .aud-aside{ order:-1; aspect-ratio:16/9; } }

/* ===========================================================
   SERVICES — reworked: persistent cards, audience-aware
   =========================================================== */
.services{ background:var(--fog); }
.svc-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
}
.svc-card{
  background:var(--fog); padding:clamp(1.6rem,2.6vw,2.4rem);
  display:flex; flex-direction:column; gap:1rem; min-height:248px;
  position:relative; cursor:pointer; overflow:hidden;
  transition:background .5s var(--ease);
}
.svc-card::before{
  content:""; position:absolute; left:0; top:0; height:2px; width:0; background:var(--brass);
  transition:width .55s var(--ease);
}
.svc-card:hover{ background:var(--paper); }
.svc-card:hover::before{ width:100%; }
.svc-card__top{ display:flex; align-items:center; justify-content:space-between; }
.svc-card__num{ font-family:var(--mono); font-size:.8rem; color:var(--brass); }
.svc-card__go{
  width:38px; height:38px; border-radius:50%; border:1px solid var(--line);
  display:grid; place-items:center; color:var(--ink-2);
  transition:transform .5s var(--ease), color .5s var(--ease), border-color .5s var(--ease);
}
.svc-card:hover .svc-card__go{ transform:rotate(0) translate(2px,-2px); color:var(--brass); border-color:var(--brass); }
.svc-card__go svg{ width:16px; height:16px; }
.svc-card h3{
  font-family:var(--display); font-weight:360; font-size:clamp(1.3rem,2vw,1.65rem);
  line-height:1.1; letter-spacing:-.01em; margin:0;
}
.svc-card p{ color:var(--ink-2); font-size:.95rem; margin:0; max-width:36ch; }
.svc-card__rel{
  margin-top:auto; font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass); display:flex; align-items:center; gap:.5em; opacity:0;
  transform:translateY(6px); transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.svc-card__rel::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--brass); }
/* highlight services relevant to the chosen audience */
.svc-card.is-relevant{ background:var(--paper); }
.svc-card.is-relevant::before{ width:100%; }
.svc-card.is-relevant .svc-card__rel{ opacity:1; transform:none; }
.svc-card.is-dim{ opacity:.5; transition:opacity .5s var(--ease); }
.svc-card.is-dim:hover{ opacity:1; }
@media(max-width:980px){ .svc-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .svc-grid{ grid-template-columns:1fr; } }

/* ===========================================================
   FEE ESTIMATOR  (NEW)
   =========================================================== */
.estimator{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.est-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(2.5rem,6vw,6rem); align-items:start; }
.est-copy .eyebrow{ display:block; margin-bottom:1.2rem; }
.est-copy h2{ font-size:clamp(2rem,4.4vw,3.6rem); margin:0 0 1.4rem; max-width:16ch; }
.est-copy .lead{ margin:0 0 2rem; }
.est-assure{ list-style:none; margin:0; padding:0; display:grid; gap:1rem; }
.est-assure li{ display:flex; gap:.9rem; align-items:flex-start; color:var(--ink-2); font-size:.97rem; }
.est-assure li svg{ width:20px; height:20px; color:var(--brass); flex:none; margin-top:.15rem; }

.est-card{
  background:var(--paper); border:1px solid var(--line); border-radius:18px;
  box-shadow:0 30px 80px -50px rgba(18,23,28,.5);
  overflow:hidden;
}
.est-card__body{ padding:clamp(1.6rem,3vw,2.4rem); display:grid; gap:1.8rem; }
.est-field > .est-label{
  display:flex; align-items:baseline; justify-content:space-between; gap:1rem;
  font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3);
  margin-bottom:.9rem;
}
.est-field > .est-label .hint{ color:var(--brass); letter-spacing:.08em; }
.seg{ display:flex; flex-wrap:wrap; gap:.5rem; }
.seg button{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.04em; color:var(--ink-2);
  border:1px solid var(--line); background:var(--fog); border-radius:10px; padding:.6em .85em;
  transition:all .35s var(--ease);
}
.seg button:hover{ border-color:var(--brass); color:var(--ink); }
.seg button.on{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* turnover slider */
.est-range{ position:relative; padding-top:.4rem; }
.est-range input[type=range]{ width:100%; -webkit-appearance:none; appearance:none; background:transparent; cursor:pointer; }
.est-range input[type=range]::-webkit-slider-runnable-track{ height:2px; background:var(--line); }
.est-range input[type=range]::-moz-range-track{ height:2px; background:var(--line); }
.est-range input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:20px; height:20px; border-radius:50%; background:var(--paper); border:1.5px solid var(--brass); margin-top:-9px; box-shadow:0 2px 8px rgba(18,23,28,.18); transition:transform .2s var(--ease); }
.est-range input[type=range]::-moz-range-thumb{ width:20px; height:20px; border-radius:50%; background:var(--paper); border:1.5px solid var(--brass); box-shadow:0 2px 8px rgba(18,23,28,.18); }
.est-range input[type=range]:active::-webkit-slider-thumb{ transform:scale(1.12); }
.est-range__val{ display:flex; justify-content:space-between; margin-top:.9rem; font-family:var(--mono); font-size:.72rem; color:var(--ink-2); }
.est-range__val b{ color:var(--ink); font-weight:500; }

/* add-on toggles */
.est-addons{ display:grid; grid-template-columns:1fr 1fr; gap:.6rem; }
.addon{
  display:flex; align-items:center; justify-content:space-between; gap:.8rem;
  border:1px solid var(--line); border-radius:10px; padding:.8em .95em; background:var(--fog);
  transition:all .35s var(--ease); user-select:none;
}
.addon:hover{ border-color:var(--brass); }
.addon.on{ background:var(--paper); border-color:var(--brass); }
.addon__t{ display:flex; flex-direction:column; gap:.15rem; }
.addon__t b{ font-weight:500; font-size:.92rem; }
.addon__t small{ font-family:var(--mono); font-size:.62rem; letter-spacing:.04em; color:var(--ink-3); }
.addon__sw{ width:34px; height:20px; border-radius:100px; background:var(--line); position:relative; flex:none; transition:background .35s var(--ease); }
.addon__sw::after{ content:""; position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:var(--paper); box-shadow:0 1px 3px rgba(0,0,0,.2); transition:transform .35s var(--ease); }
.addon.on .addon__sw{ background:var(--brass); }
.addon.on .addon__sw::after{ transform:translateX(14px); }

/* result footer */
.est-out{
  background:var(--deep); color:var(--deep-ink); padding:clamp(1.6rem,3vw,2.2rem);
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap;
}
.est-out__price{ display:flex; flex-direction:column; gap:.3rem; }
.est-out__price .est-k{ font-family:var(--mono); font-size:.64rem; letter-spacing:.18em; text-transform:uppercase; color:var(--brass-2); }
.est-out__price .est-v{ font-family:var(--display); font-weight:350; font-size:clamp(2.4rem,5vw,3.4rem); line-height:1; color:#F4F1EC; display:flex; align-items:baseline; gap:.1em; }
.est-out__price .est-v .u{ font-family:var(--mono); font-size:.34em; color:var(--brass-2); }
.est-out__price .est-v .per{ font-family:var(--mono); font-size:.26em; color:var(--ink-3); letter-spacing:.06em; }
.est-out .btn{ border-color:var(--paper); background:var(--paper); color:var(--ink); }
.est-out .btn::before{ background:var(--brass); }
.est-out .btn:hover{ color:var(--ink); border-color:var(--brass); }
.est-note{ font-family:var(--mono); font-size:.744rem; letter-spacing:.06em; color:var(--ink-3); margin-top:.6rem; flex-basis:100%; }
@media(max-width:980px){ .est-grid{ grid-template-columns:1fr; } .est-addons{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .est-addons{ grid-template-columns:1fr; } }

/* ===========================================================
   WHY US
   =========================================================== */
.why{ background:var(--fog); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); margin-bottom:clamp(3.5rem,6vw,6rem);
}
.stat{ background:var(--fog); padding:clamp(1.8rem,3.5vw,3rem); }
.stat__num{ font-family:var(--display); font-weight:340; font-size:clamp(2.6rem,5.5vw,4.6rem); line-height:1; letter-spacing:-.02em; }
.stat__num .u{ color:var(--brass); }
.stat__label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-top:1rem; }

.why-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(2.5rem,6vw,6rem); align-items:start; }
.why-points{ display:grid; gap:0; }
.point{ display:grid; grid-template-columns:auto 1fr; gap:1.6rem; padding:1.8rem 0; border-bottom:1px solid var(--line-soft); }
.point:first-child{ border-top:1px solid var(--line-soft); }
.point__k{ font-family:var(--mono); font-size:.8rem; color:var(--brass); padding-top:.35rem; }
.point h3{ font-family:var(--display); font-weight:380; font-size:clamp(1.2rem,2vw,1.6rem); margin:0 0 .4rem; }
.point p{ margin:0; color:var(--ink-2); font-size:.97rem; max-width:42ch; }
.why-aside{ position:sticky; top:7rem; }
.why-aside .h-display{ font-size:clamp(1.7rem,3vw,2.6rem); }
.why-aside .lead{ margin-top:1.4rem; }
.sig{ font-family:var(--display); font-style:italic; font-size:1.5rem; color:var(--ink); margin-top:2rem; }
.sig small{ display:block; font-family:var(--mono); font-style:normal; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3); margin-top:.6rem; }

/* ===========================================================
   PROCESS — timeline
   =========================================================== */
.process{ background:var(--paper); }
.timeline{ position:relative; margin-top:clamp(2rem,4vw,3rem); }
.timeline__rail{ position:absolute; left:11px; top:0; bottom:0; width:2px; background:var(--line); }
.timeline__rail::after{ content:""; position:absolute; left:0; top:0; width:100%; height:var(--fill,0%); background:var(--brass); transition:height .1s linear; }
.step{ position:relative; display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,4rem); padding:clamp(2rem,4vw,3.5rem) 0; align-items:start; }
.step__dot{
  width:24px; height:24px; border-radius:50%; border:2px solid var(--line); background:var(--paper);
  display:grid; place-items:center; flex:none; transition:border-color .5s var(--ease), background .5s var(--ease);
}
.step__dot i{ width:8px; height:8px; border-radius:50%; background:var(--line); transition:background .5s var(--ease); display:block; }
.step.is-on .step__dot{ border-color:var(--brass); }
.step.is-on .step__dot i{ background:var(--brass); }
.step__body{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,4rem); }
.step__no{ font-family:var(--mono); font-size:.85rem; color:var(--brass); padding-top:.4rem; }
.step h3{ font-family:var(--display); font-weight:360; font-size:clamp(1.5rem,3.2vw,2.4rem); margin:0 0 .7rem; letter-spacing:-.01em; }
.step p{ margin:0; color:var(--ink-2); max-width:50ch; }
@media(max-width:760px){ .step__body{ grid-template-columns:1fr; gap:.6rem; } }

/* ===========================================================
   TESTIMONIALS — dark editorial break
   =========================================================== */
.quotes{ background:var(--deep); color:var(--deep-ink); position:relative; overflow:hidden; }
.quotes::before{
  content:""; position:absolute; inset:0; opacity:.5; pointer-events:none;
  background:radial-gradient(80% 60% at 70% 0%, rgba(169,130,75,.16), transparent 60%);
}
.quotes .eyebrow{ color:var(--brass-2); }
.quotes__stage{ position:relative; min-height:clamp(22rem,40vw,30rem); }
.quote__stars{ color:var(--brass-2); font-size:1.15rem; letter-spacing:.22em; margin-bottom:1.5rem; }
.quote{
  position:absolute; inset:0; opacity:0; transform:translateY(16px);
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  pointer-events:none;
  display:flex; flex-direction:column; justify-content:center; max-width:70ch;
}
.quote.is-active{
  opacity:1; transform:none; pointer-events:auto;
  transition:opacity .6s var(--ease) .3s, transform .6s var(--ease) .3s;
}
.quote blockquote{
  font-family:var(--display); font-weight:330; font-style:italic;
  font-size:clamp(1.5rem,3.6vw,3rem); line-height:1.2; letter-spacing:-.01em; margin:0; color:#F4F1EC;
}
.quote blockquote b{ font-style:normal; color:var(--brass-2); font-weight:400; }
.quote__by{ margin-top:2.4rem; display:flex; align-items:center; justify-content:space-between; gap:1.5rem 2rem; flex-wrap:wrap; }
.quote__id{ display:flex; flex-direction:column; gap:.5rem; }
.quote__by .nm{ font-family:var(--display); font-weight:440; font-size:clamp(1.4rem,2.4vw,1.95rem); letter-spacing:-.01em; color:#F4F1EC; line-height:1.05; }
.quote__by .ro{ font-family:var(--mono); font-size:clamp(.82rem,1.1vw,.95rem); letter-spacing:.04em; color:var(--brass-2); }
.quote__src{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.05em; color:var(--deep-ink);
  border:1px solid var(--deep-line); border-radius:100px; padding:.6em 1em; background:rgba(255,255,255,.04);
  white-space:nowrap;
}
.quote__src .gicon{ width:17px; height:17px; flex:none; }
.quote__by .ro{ color:var(--ink-3); font-size:.84rem; }
.quotes__nav{ display:flex; align-items:center; gap:1.5rem; margin-top:3rem; }
.q-dots{ display:flex; gap:.7rem; }
.q-dot{ width:34px; height:2px; background:var(--deep-line); border:none; padding:0; position:relative; overflow:hidden; }
.q-dot::after{ content:""; position:absolute; inset:0; background:var(--brass-2); transform:scaleX(0); transform-origin:left; }
.q-dot.is-active::after{ animation:fill 7s linear forwards; }
@keyframes fill{ to{ transform:scaleX(1); } }
.q-count{ font-family:var(--mono); font-size:.75rem; letter-spacing:.12em; color:var(--ink-3); }

/* ===========================================================
   FAQ — accordion
   =========================================================== */
.faq{ background:var(--fog); border-top:1px solid var(--line); }
.faq-grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(2.5rem,6vw,6rem); align-items:start; }
.faq-head{ position:sticky; top:7rem; }
.faq-head h2{ font-size:clamp(2.1rem,4.6vw,3.8rem); margin:0 0 1.4rem; }
.faq-head .lead{ margin:0 0 2rem; }
.btn--faq{ font-family:var(--display); font-size:1.02rem; letter-spacing:0; text-transform:none; padding:.95em 1.6em; }
.btn--faq .wa{ width:20px; height:20px; }

.faq-list{ border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; background:none; border:none; cursor:pointer; text-align:left;
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  padding:clamp(1.3rem,2.4vw,1.8rem) 0;
  color:var(--ink); transition:color .4s var(--ease);
}
.faq-q__t{ font-family:var(--display); font-weight:380; font-size:clamp(1.1rem,1.9vw,1.45rem); line-height:1.25; letter-spacing:-.005em; }
.faq-q:hover{ color:var(--brass); }
.faq-ico{ position:relative; flex:none; width:22px; height:22px; }
.faq-ico::before,.faq-ico::after{
  content:""; position:absolute; top:50%; left:50%; background:var(--brass);
  transform:translate(-50%,-50%); transition:transform .45s var(--ease), opacity .45s var(--ease);
}
.faq-ico::before{ width:16px; height:1.5px; }
.faq-ico::after{ width:1.5px; height:16px; }
.faq-item.is-open .faq-ico::after{ transform:translate(-50%,-50%) rotate(90deg); opacity:0; }
.faq-item.is-open .faq-q{ color:var(--brass); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .55s var(--ease); }
.faq-item.is-open .faq-a{ max-height:520px; }
.faq-a__in{ overflow:hidden; }
.faq-a p{
  margin:0 0 clamp(1.3rem,2.4vw,1.8rem); padding-right:clamp(0px,4vw,3rem);
  color:var(--ink-2); font-size:1.02rem; line-height:1.6; max-width:60ch;
}
@media(max-width:900px){
  .faq-grid{ grid-template-columns:1fr; }
  .faq-head{ position:static; }
}

/* ===========================================================
   CTA + FORM
   =========================================================== */
.cta{ position:relative; overflow:hidden; background:var(--mist); border-top:1px solid var(--line); }
.cta__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.35; filter:grayscale(.2) contrast(1.02); }
.cta__veil{ position:absolute; inset:0; background:linear-gradient(110deg, rgba(243,245,246,.96) 38%, rgba(243,245,246,.6) 100%); }
.cta__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.cta__copy h2{ font-size:clamp(2.3rem,5vw,4.6rem); margin:0 0 1.6rem; }
.cta__copy .lead{ margin:0 0 2rem; }
.cta__list{ list-style:none; padding:0; margin:0; display:grid; gap:.9rem; }
.cta__list li{ display:flex; gap:.9rem; align-items:center; font-size:.98rem; color:var(--ink-2); }
.cta__list li::before{ content:"\2726"; color:var(--brass); font-size:.8rem; }
/* quote summary chip injected from estimator */
.cta__summary{
  margin-top:2rem; border:1px dashed var(--line); border-radius:12px; padding:1rem 1.2rem;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.04em; color:var(--ink-2);
  display:none; align-items:center; gap:.8rem; background:rgba(251,252,252,.6);
}
.cta__summary.show{ display:flex; }
.cta__summary b{ color:var(--brass); }

.form{
  background:var(--paper); border:1px solid var(--line); border-radius:18px;
  padding:clamp(1.6rem,3vw,2.6rem);
  box-shadow:0 30px 80px -50px rgba(18,23,28,.5);
}
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ position:relative; margin-top:1.1rem; }
.field label{ position:absolute; left:0; top:.9rem; font-size:.95rem; color:var(--ink-3); pointer-events:none; transition:.3s var(--ease); }
.field input,.field select,.field textarea{
  width:100%; background:transparent; border:none; border-bottom:1px solid var(--line);
  padding:.9rem 0 .6rem; font:inherit; color:var(--ink); border-radius:0;
}
.field select{ padding-bottom:.55rem; }
.field textarea{ resize:vertical; min-height:70px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-bottom-color:var(--brass); }
.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label,
.field.filled label{ top:-.55rem; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--brass); font-family:var(--mono); }
.field input::placeholder,.field textarea::placeholder{ color:transparent; }
.consent{ display:flex; gap:.7rem; align-items:flex-start; margin-top:1.4rem; font-size:.82rem; color:var(--ink-3); }
.consent input{ margin-top:.25rem; accent-color:var(--brass); }
.form .btn{ width:100%; justify-content:center; margin-top:1.5rem; }
.form__note{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); text-align:center; margin-top:1.2rem; }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{ background:var(--deep); color:var(--deep-ink); }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem; padding:clamp(3.5rem,7vw,6rem) 0 clamp(2.5rem,5vw,4rem); }
.footer .brand b{ color:#fff; }
.footer .brand small{ color:var(--ink-3); }
.footer p.f-blurb{ color:var(--ink-3); max-width:34ch; margin-top:1.4rem; font-size:.95rem; }
.fcol h4{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--brass-2); margin:0 0 1.2rem; font-weight:500; }
.fcol a,.fcol p{ display:block; color:var(--deep-ink); font-size:.95rem; margin:0 0 .7rem; opacity:.8; transition:opacity .3s, color .3s; }
.fcol a:hover{ opacity:1; color:var(--brass-2); }
.footer__bot{ border-top:1px solid var(--deep-line); padding:1.8rem 0; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }

/* ===========================================================
   REVEAL (JS-gated)
   =========================================================== */
.gsap-ready [data-reveal]{ opacity:0; transform:translateY(28px); }
.gsap-ready [data-reveal-line]{ opacity:0; }
.anim-fallback [data-reveal], .anim-fallback [data-reveal-line]{ opacity:1 !important; transform:none !important; }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1080px){
  .stats{ grid-template-columns:repeat(2,1fr); }
  .why-grid{ grid-template-columns:1fr; }
  .why-aside{ position:static; }
  .cta__grid{ grid-template-columns:1fr; }
}
@media(max-width:860px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,340px);
    background:var(--paper); flex-direction:column; align-items:flex-start; justify-content:center;
    padding:3rem var(--pad); gap:1.6rem; transform:translateX(100%); transition:transform .5s var(--ease);
    border-left:1px solid var(--line); z-index:1001;
  }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1rem; }
  .nav-toggle{ display:inline-flex; flex-direction:column; gap:5px; z-index:1002; background:none; border:none; padding:.4rem; }
  .nav-toggle span{ width:24px; height:2px; background:var(--ink); transition:.4s var(--ease); }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .form__row{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr 1fr; }
}
@media(max-width:540px){
  .stats{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr; }
  .hero__sub{ flex-direction:column; align-items:flex-start; }
}
@media(max-width:600px){
  .nav{ padding:1rem var(--pad); }
  .nav--bare .brand b{ font-size:1.6rem; }
  .nav--bare .brand small{ font-size:.9rem; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

/* ===========================================================
   FLOATING WHATSAPP
   =========================================================== */
.wa-float{
  position:fixed; right:clamp(1rem,2.2vw,1.8rem); bottom:clamp(1rem,2.2vw,1.8rem); z-index:9400;
  display:inline-flex; align-items:center; gap:.7em;
  background:#25D366; color:#fff; border-radius:100px;
  padding:.7em 1.4em .7em 1em;
  font-family:var(--display); font-size:1.02rem; letter-spacing:0; text-transform:none; font-weight:500;
  box-shadow:0 18px 44px -14px rgba(18,134,69,.7);
  opacity:1;
  animation:waIn .6s var(--ease-out) .3s both;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), opacity .4s var(--ease);
}
.wa-float:hover{ transform:translateY(-3px); box-shadow:0 26px 56px -14px rgba(18,134,69,.78); }
.wa-float__ic{ position:relative; display:grid; place-items:center; }
.wa-float .wa{ width:26px; height:26px; }
.wa-float__ic::after{
  content:""; position:absolute; inset:-7px; border-radius:50%;
  box-shadow:0 0 0 0 rgba(255,255,255,.55);
  animation:waPing 2.6s var(--ease) infinite;
}
@keyframes waIn{ from{ transform:translateY(22px) scale(.92); } to{ transform:none; } }
@keyframes waPing{ 0%{ box-shadow:0 0 0 0 rgba(255,255,255,.5); } 70%,100%{ box-shadow:0 0 0 14px rgba(255,255,255,0); } }
.wa-float.is-hidden{ opacity:0; transform:translateY(20px) scale(.92); pointer-events:none; }
@media(max-width:560px){
  .wa-float__tx{ display:none; }
  .wa-float{ padding:.95em; }
  .wa-float .wa{ width:30px; height:30px; }
}
