:root{
/* Klinker — warm editorial light system */
--paper:#F7F4EF;--paper2:#F1ECE3;--paper3:#E8E1D4;--card:#FFFFFF;
--ink:#1B1714;--ink2:#3A332C;--body:#5E564D;--body2:#8A8178;
--accent:#B4502E;--accent-d:#933C1F;--accent2:#C76A44;--on-accent:#FBF7F1;
--line:rgba(27,23,20,.14);--line2:rgba(27,23,20,.07);
/* dark "Beton" inversion surface */
--d-bg:#1B1714;--d-bg2:#241E19;--d-bg3:#2E2720;
--d-ink:#F5F0E8;--d-ink2:#E7DFD3;--d-body:rgba(245,240,232,.66);--d-body2:rgba(245,240,232,.44);
--d-line:rgba(245,240,232,.15);--d-line2:rgba(245,240,232,.08);
--maxw:1280px;--gut:clamp(16px,4.2vw,56px);
--disp:"Archivo",system-ui,sans-serif;--mono:"Space Mono",ui-monospace,monospace;--body-f:"Inter",system-ui,sans-serif;
--ease:cubic-bezier(.23,1,.32,1);--ease2:cubic-bezier(.22,.61,.36,1);--r:4px;--nav-h:64px;
--shadow:0 32px 64px -42px rgba(27,23,20,.34);--shadow-sm:0 16px 34px -24px rgba(27,23,20,.26);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{background:var(--paper);color:var(--body);font-family:var(--body-f);font-size:16px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg,video,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,textarea,select{font:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:var(--on-accent)}
h1,h2,h3,h4{font-family:var(--disp);color:var(--ink);font-weight:700;line-height:1.04;letter-spacing:-.02em}
.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink);color:var(--paper);padding:.7rem 1.1rem;font-weight:700}
.skip:focus{left:8px;top:8px}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{position:relative;padding:clamp(60px,9vw,128px) 0;scroll-margin-top:84px}
.section--tight{padding:clamp(44px,6vw,84px) 0}

/* grain overlay — tactile paper, kills flat-vector look */
body::after{content:"";position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.025;mix-blend-mode:multiply;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---- section tones (light is base) ---- */
section.sec-light{background:var(--card)}
section.sec-light2{background:var(--paper2)}

/* ---- type helpers ---- */
.kicker{display:inline-flex;align-items:center;gap:.55em;font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-d);font-weight:700}
.kicker::before{content:"";width:1.4em;height:1px;background:currentColor;opacity:.55}
.kicker--dark{color:var(--accent-d)}
.kicker--mut{color:var(--body2)}
.mark{color:var(--accent-d)}
.shead{max-width:760px;margin-bottom:clamp(34px,5vw,58px)}
.shead--center{margin-inline:auto;text-align:center}
.shead--center .kicker::before{display:none}
.shead__title{font-size:clamp(1.95rem,4.4vw,3.3rem);margin-top:.7rem;letter-spacing:-.025em;overflow-wrap:break-word;hyphens:auto}
.shead__sub{margin-top:1.1rem;font-size:1.06rem;max-width:58ch;color:var(--body)}
.lead-strong{color:var(--ink2)}

/* ---- buttons ---- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55em;
font-family:var(--disp);font-weight:600;font-size:.92rem;letter-spacing:.005em;
padding:.95rem 1.5rem;border-radius:var(--r);overflow:hidden;border:1px solid transparent;
transition:color .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease),transform .3s var(--ease)}
.btn .t,.btn svg{position:relative;z-index:1}
.btn svg{width:18px;height:18px}
.btn::before{content:"";position:absolute;inset:0;transform:translateY(101%);transition:transform .45s var(--ease);z-index:0}
.btn--accent{background:var(--accent);color:var(--on-accent)}
.btn--accent::before{background:var(--accent-d)}
.btn--accent:hover::before{transform:translateY(0)}
.btn--dark{background:var(--ink);color:var(--paper)}
.btn--dark::before{background:var(--accent)}
.btn--dark:hover{color:var(--on-accent)}
.btn--dark:hover::before{transform:translateY(0)}
.btn--outline{background:transparent;border-color:var(--line);color:var(--ink)}
.btn--outline::before{background:var(--ink)}
.btn--outline:hover{color:var(--paper);border-color:var(--ink)}
.btn--outline:hover::before{transform:translateY(0)}
.btn--outline-d{background:transparent;border-color:rgba(251,247,241,.34);color:var(--d-ink)}
.btn--outline-d::before{background:var(--d-ink)}
.btn--outline-d:hover{color:var(--d-bg)}
.btn--outline-d:hover::before{transform:translateY(0)}
.btn--ghost-l{background:transparent;border-color:rgba(245,240,232,.32);color:var(--d-ink)}
.btn--ghost-l::before{background:var(--d-ink)}
.btn--ghost-l:hover{color:var(--d-bg)}
.btn--ghost-l:hover::before{transform:translateY(0)}
.btn--sm{padding:.66rem 1.05rem;font-size:.82rem}
.btn--lg{padding:1.12rem 1.85rem;font-size:.98rem}
.btn--block{width:100%}
.btn__ic{width:16px;height:16px}

/* ---- top info bar ---- */
.topinfo{background:var(--ink);color:var(--d-body);font-family:var(--mono);font-size:.72rem}
.topinfo__row{display:flex;align-items:center;justify-content:center;gap:.9rem;height:36px;letter-spacing:.04em;flex-wrap:wrap}
.topinfo__i{color:var(--d-body)}
.topinfo__i:hover{color:var(--accent2)}
.topinfo__sep{color:var(--accent2);opacity:.7}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:120;background:rgba(247,244,239,.78);backdrop-filter:blur(14px) saturate(1.3);-webkit-backdrop-filter:blur(14px) saturate(1.3);border-bottom:1px solid transparent;transition:background .3s,border-color .3s}
.nav.stuck{background:rgba(247,244,239,.92);border-bottom-color:var(--line)}
.nav__row{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);gap:1rem}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--ink)}
.brand__mono{width:34px;height:34px;display:block;flex:none;color:var(--accent)}
.brand__mono svg{width:100%;height:100%}
.brand__wm{font-family:var(--disp);font-weight:800;font-size:1.04rem;letter-spacing:.005em}
.nav__links{display:flex;align-items:center;gap:.2rem}
.navdd{position:relative}
.nav__link{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.76rem;letter-spacing:.05em;text-transform:uppercase;color:var(--body);padding:.7rem .75rem;transition:color .2s}
.nav__link:hover,.navdd:hover .nav__link{color:var(--ink)}
.nav__ic{width:11px;height:11px;color:var(--accent);transition:transform .3s}
.navdd:hover .nav__ic{transform:rotate(90deg)}
.nav__link.is-active{color:var(--accent-d)}
.dd{position:absolute;top:calc(100% + 8px);left:0;min-width:290px;background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:.25s var(--ease2);border-radius:var(--r)}
.dd--svc{min-width:340px}
.navdd:hover .dd,.navdd:focus-within .dd{opacity:1;visibility:visible;transform:translateY(0)}
.navdd:focus-within .nav__ic{transform:rotate(90deg)}
.dd__item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.62rem .8rem;font-size:.92rem;color:var(--body);border-bottom:1px solid var(--line2)}
.dd__item:last-child{border-bottom:none}
.dd__item span{font-family:var(--body-f)}
.dd__item:hover{color:var(--ink);background:var(--paper2)}
.dd__arr{width:14px;height:14px;color:var(--accent);opacity:0;transform:translateX(-6px);transition:.2s}
.dd__item:hover .dd__arr{opacity:1;transform:translateX(0)}
.dd--areas{min-width:440px;max-height:min(78vh,640px);overflow-y:auto}
.dd__label{font-family:var(--mono);text-transform:uppercase;font-size:.64rem;letter-spacing:.12em;color:var(--body2);padding:.6rem .8rem .35rem;border-top:1px solid var(--line2)}
.dd__label:first-child{border-top:none;padding-top:.25rem}
.dd__cols{display:grid;grid-template-columns:1fr 1fr;gap:0 .2rem}
.dd__cols .dd__item{border-bottom:none;padding:.5rem .7rem}
.dd__cols .dd__item:hover{border-radius:6px}
.nav__cta{display:flex;align-items:center;gap:.7rem}
.nav__phone{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--mono);font-size:.8rem;color:var(--ink);letter-spacing:.01em}
.nav__phone:hover{color:var(--accent-d)}
.nav__phic{width:15px;height:15px;color:var(--accent)}
.burger{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:var(--r);flex-direction:column;align-items:center;justify-content:center;gap:4px}
.burger span{width:18px;height:1.6px;background:var(--ink);transition:.3s var(--ease)}
.burger[aria-expanded=true] span:nth-child(1){transform:translateY(5.6px) rotate(45deg)}
.burger[aria-expanded=true] span:nth-child(2){opacity:0}
.burger[aria-expanded=true] span:nth-child(3){transform:translateY(-5.6px) rotate(-45deg)}

/* ---- drawer (dark) ---- */
.drawer{position:fixed;inset:0;z-index:150;background:var(--d-bg);color:var(--d-body);transform:translateX(100%);transition:transform .45s var(--ease);overflow-y:auto;visibility:hidden}
.drawer.open{transform:translateX(0);visibility:visible}
.drawer__inner{padding:var(--gut);min-height:100%;display:flex;flex-direction:column;gap:1.4rem}
.drawer__top{display:flex;align-items:center;justify-content:space-between}
.drawer .brand,.brand--light{color:var(--d-ink)}
.drawer .brand__mono{color:var(--accent2)}
.drawer__close{width:46px;height:46px;border:1px solid var(--d-line);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--d-ink)}
.drawer__close .x{width:20px;height:20px;transform:rotate(45deg)}
.drawer__cta{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.drawer__cta .btn{padding:.95rem 1rem}
.drawer__cta .btn svg{width:16px;height:16px}
.drawer__grp{border-top:1px solid var(--d-line2);padding-top:1rem}
.drawer__lbl{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--d-body2);margin-bottom:.5rem;display:flex;gap:.6rem}
.drawer__lbl span{color:var(--accent2)}
.drawer__item{display:flex;align-items:center;justify-content:space-between;padding:.8rem 0;border-bottom:1px solid var(--d-line2);font-family:var(--disp);font-weight:600;font-size:1.2rem;color:var(--d-ink);letter-spacing:-.01em}
.drawer__item:last-child{border-bottom:none}
.drawer__sublbl{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent2);padding:.9rem 0 .2rem;border-top:1px solid var(--d-line2);margin-top:.4rem}
.drawer__arr{width:18px;height:18px;color:var(--accent2)}
.drawer__phic{width:17px;height:17px}
.drawer__foot{margin-top:auto;padding-top:1rem;border-top:1px solid var(--d-line2);font-family:var(--mono);font-size:.78rem;color:var(--d-body2)}
.drawer__hours{margin-bottom:.6rem}
.drawer__legal{display:flex;gap:1rem;flex-wrap:wrap}
.drawer__legal a:hover{color:var(--accent2)}

/* ---- hero (light editorial) ---- */
.hero{position:relative;border-bottom:1px solid var(--line);overflow:hidden;background:var(--paper)}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center right;filter:saturate(1.02) contrast(1.02)}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,var(--paper) 0%,var(--paper) 30%,rgba(247,244,239,.82) 50%,rgba(247,244,239,.34) 72%,rgba(247,244,239,.08) 100%)}
.hero__in{position:relative;z-index:1;display:grid;grid-template-columns:1.18fr .82fr;gap:clamp(28px,4vw,64px);align-items:center;padding-block:clamp(44px,6.5vw,92px) clamp(40px,5vw,64px)}
.hero__eyebrow{margin-bottom:1.2rem}
.ratingpill{display:inline-flex;align-items:center;gap:.6rem;border:1px solid var(--line);border-radius:999px;padding:.42rem .95rem;font-family:var(--mono);font-size:.76rem;color:var(--ink2);margin-bottom:1.5rem;background:rgba(255,255,255,.55)}
.ratingpill .stars{display:inline-flex;gap:1px}
.ratingpill .star{width:14px;height:14px;color:var(--accent)}
.hero__h1{font-size:clamp(2rem,6.4vw,5rem);color:var(--ink);letter-spacing:-.035em;line-height:1.02;font-weight:700;overflow-wrap:break-word}
.hero__sub{margin-top:1.5rem;font-size:clamp(1.02rem,1.4vw,1.2rem);max-width:46ch;color:var(--ink2)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.statrow{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(34px,5vw,58px);border-top:1px solid var(--line)}
.stat{padding:1.3rem 1.1rem 0;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat__n{font-family:var(--disp);font-weight:700;font-size:clamp(1.7rem,3.2vw,2.5rem);color:var(--ink);line-height:1;letter-spacing:-.03em}
.stat__l{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--body2);margin-top:.5rem}

/* ---- hero card / lead form ---- */
.herocard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);position:relative}
.herocard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent)}
.herocard__head{padding:1.6rem 1.6rem 0}
.herocard .kicker{margin-bottom:.5rem}
.herocard__title{font-size:1.55rem;margin-top:.3rem;letter-spacing:-.02em}
.herocard__sub{font-size:.86rem;margin-top:.5rem;color:var(--body)}
.a2lead-form--hero{padding:1.2rem 1.6rem 1.6rem;display:flex;flex-direction:column;gap:.7rem}
.herocard__foot{font-family:var(--mono);font-size:.76rem;color:var(--body2);text-align:center;margin-top:.2rem}
.herocard__foot a{color:var(--accent-d)}
.herocard__rating{display:flex;justify-content:center;margin-top:.15rem}
.herocard__rating .ratingpill{margin-bottom:0}

/* ---- form fields ---- */
.a2lead-form{display:flex;flex-direction:column;gap:.95rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.field label{font-family:var(--mono);font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:var(--body2)}
.req{color:var(--accent)}
.inp{width:100%;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:.85rem .9rem;color:var(--ink);font-size:16px;transition:border-color .2s,background .2s,box-shadow .2s}
.inp::placeholder{color:var(--body2)}
.inp:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(180,80,46,.12)}
textarea.inp{resize:vertical;min-height:64px}
.check{display:flex;gap:.6rem;align-items:flex-start;font-size:.82rem;color:var(--body);cursor:pointer}
.check input{margin-top:.2rem;width:17px;height:17px;flex:none;accent-color:var(--accent)}
.check a{color:var(--accent-d);text-decoration:underline}
.check--sm{font-size:.74rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.a2lead-msg{font-size:.85rem;display:none;padding:.7rem .85rem;border-radius:var(--r)}
.a2lead-msg.show{display:block}
.a2lead-msg.ok{background:rgba(70,135,80,.12);color:#3c7a44;border:1px solid rgba(70,135,80,.32)}
.a2lead-msg.err{background:rgba(180,80,46,.1);color:var(--accent-d);border:1px solid rgba(180,80,46,.34)}
.lead-hint{font-family:var(--mono);font-size:.72rem;color:var(--body2);text-align:center}

/* ---- trust strip (light) ---- */
.trust{background:var(--card);border-bottom:1px solid var(--line)}
.trust__in{padding-block:clamp(40px,5vw,68px);display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(24px,4vw,64px);align-items:center}
.trust__title{color:var(--ink);font-size:clamp(1.7rem,3.2vw,2.6rem);letter-spacing:-.025em}
.trust__sub{color:var(--body);margin-top:.8rem;font-size:1.02rem;max-width:42ch}
.trust__items{display:flex;flex-direction:column;gap:0}
.trustitem{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;padding:1.2rem 0;border-top:1px solid var(--line);align-items:start}
.trustitem:last-child{border-bottom:1px solid var(--line)}
.trustitem__n{font-family:var(--mono);font-weight:700;font-size:.8rem;color:var(--accent-d)}
.trustitem h3{color:var(--ink);font-size:1.12rem;letter-spacing:-.01em}
.trustitem p{color:var(--body);font-size:.94rem;margin-top:.25rem}

/* ---- services grid ---- */
.svc__grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.svccard{position:relative;display:flex;flex-direction:column;gap:1rem;padding:clamp(22px,2.4vw,34px);border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:236px;background:transparent;transition:background .35s var(--ease)}
.svccard::after{content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.svccard:hover{background:var(--card)}
.svccard:hover::after{transform:scaleX(1)}
.svccard__top{display:flex;align-items:flex-start;justify-content:space-between}
.svccard__n{font-family:var(--mono);font-size:.76rem;color:var(--body2);letter-spacing:.08em}
.svccard__ic{width:34px;height:34px;color:var(--accent);transition:transform .4s var(--ease)}
.svccard:hover .svccard__ic{transform:translateY(-3px)}
.svccard__t{font-size:1.32rem;color:var(--ink);margin-top:auto;letter-spacing:-.015em;font-weight:600}
.svccard__d{font-size:.92rem;color:var(--body)}
.svccard__arr{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-d);opacity:0;transform:translateY(6px);transition:.3s var(--ease)}
.svccard__arr svg{width:15px;height:15px}
.svccard:hover .svccard__arr{opacity:1;transform:translateY(0)}
.svccard--feat{background:var(--accent);color:var(--on-accent)}
.svccard--feat::after{display:none}
.svccard--feat:hover{background:var(--accent-d)}
.svccard--feat .svccard__n{color:rgba(251,247,241,.66)}
.svccard--feat .svccard__ic,.svccard--feat .svccard__t{color:var(--on-accent)}
.svccard--feat .svccard__d{color:rgba(251,247,241,.84)}
.svccard--feat .svccard__arr{color:var(--on-accent);opacity:1;transform:none}

/* ---- process ---- */
.proc__list{border-top:1px solid var(--line)}
.procstep{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,64px);padding:clamp(24px,3vw,40px) 0;border-bottom:1px solid var(--line);align-items:baseline;transition:padding-left .35s var(--ease)}
.procstep:hover{padding-left:12px}
.procstep__n{font-family:var(--disp);font-weight:700;font-size:clamp(2rem,4vw,3.4rem);color:var(--paper3);line-height:1;letter-spacing:-.04em;transition:color .35s}
.procstep:hover .procstep__n{color:var(--accent)}
.procstep__b{max-width:60ch}
.procstep__t{font-size:clamp(1.3rem,2vw,1.7rem);color:var(--ink);letter-spacing:-.02em;font-weight:600}
.procstep__d{margin-top:.5rem;font-size:1rem;color:var(--body)}

/* ---- reviews marquee ---- */
.rev{overflow:hidden}
.rev__marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.rev__track{display:flex;gap:1.1rem;width:max-content;animation:marq 60s linear infinite}
.rev:hover .rev__track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}
.revcard{width:min(86vw,400px);flex:none;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;box-shadow:var(--shadow-sm)}
.revcard__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.revcard__stars{display:inline-flex;gap:2px;color:var(--accent)}
.revcard__stars .star{width:16px;height:16px}
.revcard__g{font-family:var(--mono);font-size:.7rem;color:var(--body2);display:inline-flex;align-items:center;gap:.35rem}
.revcard__gic{width:13px;height:13px;color:#4587de}
.revcard__text{color:var(--ink2);font-size:.97rem;line-height:1.6}
.revcard__author{margin-top:1.1rem;display:flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:.78rem;color:var(--body)}
.revcard__ava{width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--disp);flex:none}
.revcard__date{color:var(--body2)}

/* ---- counter tiles ---- */
.counter__grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.cnt{padding:clamp(24px,3vw,40px);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.cnt__n{font-family:var(--disp);font-weight:700;font-size:clamp(2rem,4.5vw,3.4rem);color:var(--accent-d);line-height:1;letter-spacing:-.03em}
.cnt__l{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--body2);margin-top:.7rem}

/* ---- highlights strip (Auf einen Blick) ---- */
.shead--mini{margin-bottom:1.2rem}
.hlstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.hltile{background:var(--card);padding:clamp(18px,2.3vw,30px) clamp(16px,1.9vw,26px);position:relative}
.hltile::before{content:"";position:absolute;top:0;left:0;width:32px;height:3px;background:var(--accent)}
.hltile__v{font-family:var(--disp);font-weight:700;font-size:clamp(1.12rem,1.85vw,1.65rem);color:var(--ink);letter-spacing:-.02em;line-height:1.08;margin-top:.5rem;overflow-wrap:break-word;hyphens:auto}
.hltile__l{font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--body2);margin-top:.55rem;line-height:1.4}
@media(max-width:760px){.hlstrip{grid-template-columns:1fr 1fr}}

/* ---- pull quote (dark accent beat) ---- */
.pullq{background:var(--d-bg);color:var(--d-ink)}
.pullq__q{position:relative;max-width:26ch;margin-inline:auto;text-align:center;font-family:var(--disp);font-weight:700;font-size:clamp(1.5rem,3.3vw,2.55rem);line-height:1.16;letter-spacing:-.02em;color:var(--d-ink)}
.pullq__mark{display:block;font-family:var(--disp);font-size:3.2em;line-height:.5;color:var(--accent2);margin-bottom:.04em}

/* ---- feat reverse (alternating image side) ---- */
.feat--rev .feat__media{order:-1}
@media(max-width:900px){.feat--rev .feat__media{order:0}}

/* ---- system band (DARK beat) ---- */
.system{background:var(--d-bg);color:var(--d-body);border-block:1px solid var(--ink)}
.system .kicker,.system .shead__title,.system .shead__sub{color:inherit}
.system .kicker{color:var(--accent2)}
.system .shead__title{color:var(--d-ink)}
.system .shead__sub{color:var(--d-body)}
.system__in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
.system__media{position:relative;border:1px solid var(--d-line);border-radius:var(--r);overflow:hidden;background:#0f0c0a}
.system__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/11}
.system__points{margin-top:1.6rem;display:flex;flex-direction:column}
.syspoint{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:center;padding:.95rem 0;border-top:1px solid var(--d-line);color:var(--d-ink2)}
.syspoint:last-child{border-bottom:1px solid var(--d-line)}
.syspoint svg{width:20px;height:20px;color:var(--accent2)}
.system .btn--outline{border-color:rgba(245,240,232,.34);color:var(--d-ink)}
.system .btn--outline::before{background:var(--d-ink)}
.system .btn--outline:hover{color:var(--d-bg)}

/* ---- gallery ---- */
.gal__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.gal__item{position:relative;overflow:hidden;background:var(--paper2);aspect-ratio:4/3;cursor:pointer}
.gal__img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s var(--ease);filter:saturate(.96)}
.gal__item:hover .gal__img{transform:scale(1.05);filter:saturate(1.05)}
.gal__item::after{content:"+";position:absolute;top:10px;right:14px;color:#fff;font-family:var(--mono);opacity:0;transition:opacity .3s;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.gal__item:hover::after{opacity:1}
.glb{position:fixed;inset:0;z-index:200;background:rgba(27,23,20,.93);display:none;align-items:center;justify-content:center;padding:5vw}
.glb.open{display:flex}
.glb__img{max-width:92vw;max-height:86vh;object-fit:contain;border:1px solid var(--d-line)}
.glb__close,.glb__nav{position:absolute;width:48px;height:48px;border:1px solid var(--d-line);background:rgba(36,30,25,.7);color:var(--d-ink);display:flex;align-items:center;justify-content:center;border-radius:var(--r)}
.glb__close{top:5vw;right:5vw}
.glb__nav{top:50%;transform:translateY(-50%)}
.glb__prev{left:3vw}.glb__next{right:3vw}
.glb__close svg,.glb__nav svg{width:22px;height:22px}

/* ---- about teaser ---- */
.about__in{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,4vw,64px);align-items:center}
.about__media{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.about__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.about__values{margin-top:1.6rem;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.aval{background:var(--card);padding:1.3rem}
.aval h3{font-size:1.06rem;color:var(--ink);margin-bottom:.35rem;letter-spacing:-.01em}
.aval p{font-size:.9rem;color:var(--body)}
.aval__n{font-family:var(--mono);font-size:.72rem;color:var(--accent-d)}

/* ---- areas ---- */
.areas{background:var(--paper2);border-block:1px solid var(--line)}
.areas__in{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:center}
.areas__title{font-size:clamp(2rem,4vw,3rem);margin-top:.5rem;letter-spacing:-.025em}
.areas__sub{color:var(--body);margin:.8rem 0 1.4rem}
.areas__pills{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.areapill{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--card);padding:1.15rem 1.25rem;font-family:var(--disp);font-weight:600;font-size:1.08rem;color:var(--ink);letter-spacing:-.01em;transition:background .25s,color .25s}
.areapill:hover{background:var(--accent);color:var(--on-accent)}
.areapill__arr{width:16px;height:16px;color:var(--accent)}
.areapill:hover .areapill__arr{color:var(--on-accent)}
.areapill--home{background:var(--ink);color:var(--paper)}
.areapill--home .areapill__arr{color:var(--accent2)}
.areapill--home:hover{background:var(--accent)}
.areapill--home:hover .areapill__arr{color:var(--on-accent)}

/* ---- lead section ---- */
.leadsec{background:var(--paper2);border-top:1px solid var(--line)}
.leadsec__in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,64px);align-items:start}
.leadsec__title{font-size:clamp(1.9rem,4vw,3rem);margin-top:.5rem;letter-spacing:-.025em}
.leadsec__desc{margin:1rem 0 1.6rem;max-width:48ch;color:var(--body)}
.leadsec__list{display:flex;flex-direction:column;gap:0}
.leadsec__card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:clamp(20px,2.4vw,32px);box-shadow:var(--shadow-sm)}
.leadsec__formhead{margin-bottom:1.2rem}
.leadsec__formhead h3{font-size:1.3rem;letter-spacing:-.02em}

/* ---- info cards ---- */
.infocard{display:flex;gap:.9rem;align-items:center;padding:1.05rem 0;border-top:1px solid var(--line)}
.infocard:last-child{border-bottom:1px solid var(--line)}
.infocard__ic{width:22px;height:22px;color:var(--accent);flex:none}
.infocard__l{display:block;font-family:var(--mono);font-size:.68rem;letter-spacing:.07em;text-transform:uppercase;color:var(--body2)}
.infocard__v{display:block;color:var(--ink);font-size:.98rem;margin-top:.15rem}
a.infocard:hover .infocard__v{color:var(--accent-d)}

/* ---- maps ---- */
.maps__grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(20px,3vw,40px);align-items:start}
.maps__embed{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper2)}
.maps__embed iframe{filter:grayscale(.28) contrast(1.02)}

/* ---- faq ---- */
.faq__list{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{display:flex;align-items:center;gap:1rem;width:100%;text-align:left;padding:1.3rem 0;color:var(--ink)}
.faq__n{font-family:var(--mono);font-size:.78rem;color:var(--accent-d);flex:none}
.faq__qt{font-family:var(--disp);font-weight:600;font-size:clamp(1.05rem,1.7vw,1.28rem);flex:1;letter-spacing:-.015em}
.faq__ic{width:20px;height:20px;color:var(--accent);flex:none;transition:transform .3s var(--ease)}
.faq__item.open .faq__ic{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq__ai{padding:0 0 1.3rem 2.4rem;max-width:72ch;color:var(--body)}

/* ---- final cta (DARK beat) ---- */
.fcta{background:var(--d-bg);color:var(--d-body);overflow:hidden;border-top:1px solid var(--ink)}
.fcta__in{position:relative}
.fcta__mono{position:absolute;right:-3%;top:50%;transform:translateY(-50%);width:min(40vw,420px);color:rgba(245,240,232,.05);pointer-events:none}
.fcta__glyph svg{width:100%;height:auto}
.fcta__body{position:relative;max-width:680px}
.fcta .kicker{color:var(--accent2)}
.fcta__title{color:var(--d-ink);font-size:clamp(2rem,5vw,3.5rem);margin:.7rem 0 1rem;letter-spacing:-.03em;line-height:1.02}
.fcta__sub{color:var(--d-body);font-size:1.08rem;max-width:52ch}
.fcta__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.fcta .btn--dark{background:var(--accent);color:var(--on-accent)}
.fcta .btn--dark::before{background:var(--accent-d)}
.fcta .btn--dark:hover{color:var(--on-accent)}
.fcta .btn--outline-d{border-color:rgba(245,240,232,.34);color:var(--d-ink)}

/* ---- footer (dark) ---- */
.foot{background:#161210;color:var(--d-body);border-top:1px solid var(--ink);padding-top:clamp(48px,6vw,80px);position:relative;overflow:hidden}
.foot__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(24px,3vw,48px);padding-bottom:clamp(40px,5vw,64px)}
.foot .brand{color:var(--d-ink);margin-bottom:1rem}
.foot .brand__mono{color:var(--accent2)}
.foot__tag{font-size:.92rem;max-width:34ch;margin-bottom:1.3rem;color:var(--d-body)}
.foot__contact{display:flex;flex-direction:column;gap:.55rem;font-family:var(--mono);font-size:.8rem}
.foot__contact a,.foot__contact span{display:inline-flex;align-items:center;gap:.5rem;color:var(--d-body)}
.foot__contact a:hover{color:var(--accent2)}
.foot__ic{width:15px;height:15px;color:var(--accent2);flex:none}
.foot__col h3{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--d-body2);margin-bottom:1rem}
.foot__col .foot__h2{margin-top:1.6rem}
.foot__col ul li{margin-bottom:.55rem}
.foot__col a{font-size:.92rem;color:var(--d-body)}
.foot__col a:hover{color:var(--d-ink)}
.foot__glyph{position:absolute;left:50%;bottom:-14%;transform:translateX(-50%);width:min(70vw,640px);color:rgba(245,240,232,.025);pointer-events:none}
.foot__glyph svg{width:100%}
.foot__bottom{position:relative;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;padding:1.4rem 0;border-top:1px solid var(--d-line2);font-family:var(--mono);font-size:.74rem;color:var(--d-body2)}
.foot__credit a{color:var(--d-body);border-bottom:1px solid var(--d-line2)}
.foot__credit a:hover{color:var(--accent2);border-color:var(--accent2)}

/* ---- persistent ---- */
.fab{position:fixed;right:clamp(14px,3vw,26px);bottom:clamp(14px,3vw,26px);z-index:110;width:54px;height:54px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;box-shadow:0 16px 32px -12px rgba(180,80,46,.6);opacity:0;visibility:hidden;transform:scale(.7);transition:.35s var(--ease)}
.scrolled .fab{opacity:1;visibility:visible;transform:scale(1)}
.fab__ic{width:24px;height:24px}
.fab:hover{background:var(--accent-d)}
.smb{position:fixed;left:0;right:0;bottom:0;z-index:109;display:none;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-top:1px solid var(--line);transform:translateY(100%);transition:transform .35s var(--ease)}
.scrolled .smb{transform:translateY(0)}
.smb.hide{transform:translateY(100%)}
.smb__b{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;font-family:var(--disp);font-weight:600;font-size:.88rem;letter-spacing:.01em}
.smb__b--ghost{background:var(--card);color:var(--ink)}
.smb__b--accent{background:var(--accent);color:var(--on-accent)}
.smb__ic{width:18px;height:18px}

/* ---- page hero (subpages) ---- */
.phero{position:relative;border-bottom:1px solid var(--line);overflow:hidden;background:var(--paper2)}
.phero__bg{position:absolute;inset:0;z-index:0}
.phero__bg img{width:100%;height:100%;object-fit:cover;filter:saturate(1.02) contrast(1.02)}
.phero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,var(--paper) 0%,rgba(247,244,239,.88) 42%,rgba(247,244,239,.42) 72%,rgba(247,244,239,.12) 100%)}
.phero__in{position:relative;z-index:1;padding-block:clamp(48px,7vw,108px) clamp(40px,5vw,72px);max-width:860px}
.phero__h1{font-size:clamp(1.8rem,5.2vw,4rem);color:var(--ink);margin:1rem 0;letter-spacing:-.03em;line-height:1.04;font-weight:700;overflow-wrap:break-word;hyphens:auto}
.phero__sub{font-size:clamp(1rem,1.5vw,1.2rem);max-width:56ch;color:var(--ink2)}
.phero__bullets{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.pbul{display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--line);border-radius:999px;padding:.45rem .9rem;font-family:var(--mono);font-size:.74rem;color:var(--ink2);background:rgba(255,255,255,.5)}
.pbul svg{width:14px;height:14px;color:var(--accent)}
.phero__cta{margin-top:1.8rem;display:flex;flex-wrap:wrap;gap:.7rem}
.breadcrumb{font-family:var(--mono);font-size:.74rem;color:var(--body2);display:flex;gap:.5rem;flex-wrap:wrap;letter-spacing:.03em}
.breadcrumb a:hover{color:var(--accent-d)}
.breadcrumb span{color:var(--accent)}

/* ---- service detail ---- */
.svcpage__grid{display:grid;grid-template-columns:1.5fr .9fr;gap:clamp(28px,4vw,56px);align-items:start}
.incl{border-top:1px solid var(--line)}
.incl__item{display:grid;grid-template-columns:auto 1fr;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line)}
.incl__item svg{width:22px;height:22px;color:var(--accent);margin-top:.15rem}
.incl__item h3{font-size:1.12rem;color:var(--ink);margin-bottom:.3rem;letter-spacing:-.01em}
.incl__item p{font-size:.95rem;color:var(--body)}
.notincl{margin-top:2.2rem;border:1px solid var(--line);border-radius:var(--r);padding:clamp(20px,2.4vw,30px);background:var(--card)}
.notincl h3{font-size:1.1rem;margin-bottom:1rem;color:var(--ink);letter-spacing:-.01em}
.notincl li{display:grid;grid-template-columns:auto 1fr;gap:.7rem;padding:.6rem 0;font-size:.92rem;border-top:1px solid var(--line2);color:var(--body)}
.notincl li:first-of-type{border-top:none}
.notincl li::before{content:"—";color:var(--accent);font-family:var(--mono)}
.aside{position:sticky;top:calc(var(--nav-h) + 16px);display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.pricebox{background:var(--card);padding:clamp(20px,2.4vw,30px)}
.pricebox__k{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--body2)}
.pricebox__v{font-family:var(--disp);font-weight:700;font-size:1.7rem;color:var(--ink);margin:.3rem 0 .6rem;letter-spacing:-.02em}
.pricebox p{font-size:.9rem;color:var(--body)}
.timeline{background:var(--card);padding:clamp(20px,2.4vw,30px)}
.timeline h3{font-size:1rem;color:var(--ink);margin-bottom:1rem;letter-spacing:-.01em}
.tstep{display:grid;grid-template-columns:auto 1fr;gap:.8rem;padding-bottom:1rem;position:relative}
.tstep__n{width:26px;height:26px;border:1px solid var(--accent);color:var(--accent-d);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.75rem;flex:none}
.tstep p{font-size:.9rem;color:var(--body)}
.asidecta{background:var(--ink);padding:clamp(20px,2.4vw,30px)}
.asidecta h3{color:var(--paper);margin-bottom:.8rem;font-size:1.15rem;letter-spacing:-.01em}
.asidecta .btn--dark{background:var(--accent);color:var(--on-accent)}
.asidecta .btn--dark::before{background:var(--accent-d)}
.asidecta .btn--dark:hover{color:var(--on-accent)}
.svcprose p{margin-bottom:1rem;color:var(--body)}
.svcprose a,.citylocal__body a,.local__txt a{color:var(--accent-d);text-decoration:underline;text-underline-offset:2px}

/* ---- problem/benefit + local cards ---- */
.pbgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pbcard{background:var(--card);padding:clamp(20px,2.4vw,30px)}
.pbcard__n{font-family:var(--mono);font-size:.74rem;color:var(--accent-d);letter-spacing:.08em}
.pbcard h3{font-size:1.12rem;color:var(--ink);margin:.55rem 0 .4rem;letter-spacing:-.01em}
.pbcard p{font-size:.93rem;color:var(--body)}

/* ---- price factors ---- */
.pfac{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.pfac__item{background:var(--card);padding:1.1rem 1.3rem;display:grid;grid-template-columns:auto 1fr;gap:.8rem;align-items:start;font-size:.95rem;color:var(--ink2)}
.pfac__item svg{width:18px;height:18px;color:var(--accent);margin-top:.2rem}

/* ---- related services ---- */
.relrow{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.relcard{background:var(--card);padding:1.15rem 1.35rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--disp);font-weight:600;font-size:1rem;color:var(--ink);letter-spacing:-.01em;transition:background .2s,color .2s}
.relcard:hover{background:var(--accent);color:var(--on-accent)}
.relcard svg{width:16px;height:16px;color:var(--accent);flex:none}
.relcard:hover svg{color:var(--on-accent)}
@media(max-width:980px){.pbgrid,.relrow{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.pbgrid,.relrow,.pfac{grid-template-columns:1fr}}

/* ---- prose (legal/about long text) ---- */
.prose{max-width:74ch}
.prose h1{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:1.2rem;letter-spacing:-.025em}
.prose h2{font-size:1.4rem;margin:2rem 0 .8rem;color:var(--ink);letter-spacing:-.015em}
.prose h3{font-size:1.1rem;margin:1.4rem 0 .6rem;color:var(--ink)}
.prose p{margin-bottom:1rem;color:var(--body)}
.prose ul{margin:0 0 1rem 1.2rem;list-style:square}
.prose li{margin-bottom:.4rem;color:var(--body)}
.prose a{color:var(--accent-d);text-decoration:underline}
.prose strong{color:var(--ink)}

/* ---- city local ---- */
.citylocal__grid{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(28px,4vw,56px);align-items:start}
.citylocal__body p{margin-bottom:1rem;color:var(--body)}
.facts{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.fact{background:var(--card);padding:1.2rem}
.fact__l{font-family:var(--mono);font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:var(--accent-d)}
.fact__v{color:var(--ink);margin-top:.25rem}

/* ---- rating gate ---- */
.rgate{width:100%;max-width:560px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:clamp(24px,5vw,48px);text-align:center;box-shadow:var(--shadow)}
.rgate h1{overflow-wrap:break-word}
.rgate__stars{flex-wrap:wrap}
.rgate__step{display:none}
.rgate__step.active{display:block;animation:fade .4s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.rgate h1{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:.8rem;letter-spacing:-.025em}
.rgate p{margin-bottom:1.6rem;color:var(--body)}
.rgate__stars{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}
.rgate__star{width:46px;height:46px;color:var(--body2);transition:color .15s,transform .15s}
.rgate__star svg{width:100%;height:100%}
.rgate__star:hover,.rgate__star.on{color:var(--accent);transform:scale(1.1)}
.rgate__scale{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.7rem;color:var(--body2);max-width:300px;margin:0 auto}
.rgate .a2lead-form{text-align:left;margin-top:1rem}
.rgate__read{display:inline-block;margin-top:1.2rem;font-family:var(--mono);font-size:.78rem;color:var(--body2)}
.rgate__read:hover{color:var(--accent-d)}

/* ---- all reviews grid ---- */
.allrev{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}

/* ---- reveal motion ---- */
html.reveal-on [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.reveal-on [data-reveal].is-visible{opacity:1;transform:none}

/* ============ chatbot ============ */
#a2cb-widget{position:fixed;right:clamp(14px,3vw,26px);bottom:calc(clamp(14px,3vw,26px) + 64px);z-index:111}
.a2cb-toggle{width:56px;height:56px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);position:relative;transition:.3s var(--ease)}
.a2cb-toggle:hover{background:var(--accent);color:var(--on-accent)}
.a2cb-toggle svg{width:25px;height:25px}
.a2cb-toggle-close{display:none}
.a2cb-toggle.active .a2cb-toggle-open{display:none}
.a2cb-toggle.active .a2cb-toggle-close{display:block}
.a2cb-toggle.active{background:var(--accent);color:var(--on-accent)}
.a2cb-badge-notify{position:absolute;top:-3px;right:-3px;width:20px;height:20px;border-radius:50%;background:var(--accent);color:var(--on-accent);font-family:var(--mono);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--paper)}
.a2cb-panel{position:absolute;bottom:70px;right:0;width:min(92vw,376px);height:min(74vh,560px);background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(16px) scale(.98);transform-origin:bottom right;transition:.3s var(--ease)}
.a2cb-panel.active{opacity:1;visibility:visible;transform:none}
.a2cb-header{display:flex;align-items:center;gap:.7rem;padding:.9rem 1rem;background:var(--ink);color:var(--d-ink)}
.a2cb-header-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;flex:none}
.a2cb-header-name{font-family:var(--disp);font-weight:700;color:var(--d-ink);font-size:.98rem}
.a2cb-header-status{font-family:var(--mono);font-size:.7rem;color:var(--d-body2);display:flex;align-items:center;gap:.35rem}
.a2cb-status-dot{width:7px;height:7px;border-radius:50%;background:#4caf72;box-shadow:0 0 0 3px rgba(76,175,114,.18)}
.a2cb-header-close{margin-left:auto;width:30px;height:30px;color:var(--d-body2);display:flex;align-items:center;justify-content:center}
.a2cb-header-close:hover{color:var(--d-ink)}
.a2cb-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.7rem}
.a2cb-msg{max-width:84%;padding:.7rem .9rem;border-radius:var(--r);font-size:.9rem;line-height:1.5;white-space:pre-wrap}
.a2cb-msg-bot{background:var(--paper2);color:var(--ink2);align-self:flex-start;border:1px solid var(--line)}
.a2cb-msg-user{background:var(--accent);color:var(--on-accent);align-self:flex-end}
.a2cb-msg-typing{align-self:flex-start;display:flex;gap:4px;padding:.7rem .9rem;background:var(--paper2);border:1px solid var(--line);border-radius:var(--r)}
.a2cb-dot{width:7px;height:7px;border-radius:50%;background:var(--body2);animation:cbdot 1.2s infinite}
.a2cb-dot:nth-child(2){animation-delay:.2s}.a2cb-dot:nth-child(3){animation-delay:.4s}
@keyframes cbdot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.a2cb-lead-form{display:none;flex-direction:column;gap:.55rem;padding:.9rem 1rem;border-top:1px solid var(--line);background:var(--paper2)}
.a2cb-lead-form.active{display:flex}
.a2cb-lead-title{font-size:.85rem;color:var(--ink)}
.a2cb-lead-input{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:.6rem .7rem;color:var(--ink);font-size:16px}
.a2cb-lead-input:focus{outline:none;border-color:var(--accent)}
.a2cb-lead-hint{font-family:var(--mono);font-size:.68rem;color:var(--body2)}
.a2cb-lead-btns{display:flex;gap:.5rem}
.a2cb-lead-submit{flex:1;background:var(--accent);color:var(--on-accent);padding:.6rem;border-radius:var(--r);font-family:var(--disp);font-weight:600;font-size:.85rem}
.a2cb-lead-skip{background:var(--card);border:1px solid var(--line);color:var(--body);padding:.6rem .9rem;border-radius:var(--r);font-size:.82rem}
.a2cb-input-area{display:flex;gap:.5rem;padding:.8rem;border-top:1px solid var(--line);background:var(--paper2)}
.a2cb-input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:.7rem .8rem;color:var(--ink);font-size:16px}
.a2cb-input:focus{outline:none;border-color:var(--accent)}
.a2cb-send{width:42px;height:42px;background:var(--accent);color:var(--on-accent);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex:none}
.a2cb-send:disabled{opacity:.4;cursor:default}
.a2cb-send svg{width:18px;height:18px}

/* ============ cookie ============ */
.a2cookie-overlay{position:fixed;inset:0;background:rgba(27,23,20,.4);z-index:159;opacity:0;visibility:hidden;transition:.3s}
.a2cookie-overlay.show{opacity:1;visibility:visible}
.a2cookie-banner{position:fixed;left:50%;bottom:clamp(14px,3vw,26px);transform:translateX(-50%) translateY(20px);z-index:160;width:min(94vw,460px);background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:.35s var(--ease)}
.a2cookie-banner.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.a2cookie-content{padding:1.3rem}
.a2cookie-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem}
.a2cookie-ic{width:18px;height:18px;color:var(--accent)}
.a2cookie-title{font-family:var(--disp);font-weight:700;color:var(--ink)}
.a2cookie-desc{font-size:.86rem;margin-bottom:.8rem;color:var(--body)}
.a2cookie-details{display:none;margin-bottom:.8rem}
.a2cookie-details.show{display:block}
.a2cookie-category{padding:.6rem 0;border-top:1px solid var(--line2)}
.a2cookie-cat-row{display:flex;align-items:center;justify-content:space-between}
.a2cookie-cat-title{font-size:.88rem;color:var(--ink)}
.a2cookie-badge{font-family:var(--mono);font-size:.68rem;color:var(--accent-d)}
.a2cookie-toggle{position:relative;display:inline-block;width:40px;height:22px}
.a2cookie-toggle input{opacity:0;width:0;height:0}
.a2cookie-slider{position:absolute;inset:0;background:var(--paper3);border-radius:999px;transition:.2s;cursor:pointer}
.a2cookie-slider::before{content:"";position:absolute;left:3px;top:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.a2cookie-toggle input:checked+.a2cookie-slider{background:var(--accent)}
.a2cookie-toggle input:checked+.a2cookie-slider::before{transform:translateX(18px)}
.a2cookie-foot{display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem;font-family:var(--mono);font-size:.76rem}
.a2cookie-link,.a2cookie-privacy{color:var(--body2)}
.a2cookie-link:hover,.a2cookie-privacy:hover{color:var(--accent-d)}
.a2cookie-actions{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.a2cookie-btn{padding:.7rem;border-radius:var(--r);font-family:var(--disp);font-weight:600;font-size:.82rem}
.a2cookie-btn-reject{background:var(--paper2);border:1px solid var(--line);color:var(--ink)}
.a2cookie-btn-accept{background:var(--accent);color:var(--on-accent)}

/* ---- feature image block ---- */
.feat__media{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--card)}
.feat__media img{width:100%;height:100%;object-fit:cover;display:block}
.feat{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center}
@media(max-width:900px){.feat{grid-template-columns:1fr}}

/* ============ cookbook typed blocks ============ */
.cblocks>*+*{margin-top:1rem}
.cblocks .lead{font-size:1.18rem;line-height:1.55;color:var(--ink2);font-weight:500;max-width:64ch}
.cblocks p{font-size:1rem;color:var(--body);max-width:66ch}
.cblocks a{text-decoration:underline;text-underline-offset:2px;color:var(--accent-d)}
.list{display:flex;flex-direction:column;gap:.55rem;margin:1.1rem 0}
.list__h{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--body2);margin-bottom:.2rem}
.list li{display:grid;grid-template-columns:auto 1fr;gap:.65rem;align-items:start;color:var(--body);font-size:.97rem}
.list li svg{width:18px;height:18px;color:var(--accent);margin-top:.18rem;flex:none}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.chip{border:1px solid var(--line);border-radius:999px;padding:.4rem .85rem;font-family:var(--mono);font-size:.76rem;color:var(--ink2);background:var(--card)}
.key{display:grid;grid-template-columns:auto 1fr;gap:.8rem;align-items:start;background:var(--paper2);border-left:3px solid var(--accent);border-radius:var(--r);padding:1rem 1.2rem;margin:1.2rem 0;color:var(--ink2);font-size:.98rem}
.key svg{width:20px;height:20px;color:var(--accent);margin-top:.1rem;flex:none}

/* ---- high CTA archetypes ---- */
.ctaband{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ctaphone{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem;background:var(--ink);color:var(--d-body);padding:clamp(22px,3vw,38px)}
.ctaphone__t{font-family:var(--disp);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--d-ink);letter-spacing:-.02em}
.ctaphone__p{font-family:var(--mono);font-size:.92rem;color:var(--d-body);margin-top:.3rem}
.ctaphone__big{font-family:var(--disp);font-weight:700;font-size:clamp(1.4rem,2.4vw,2rem);color:var(--d-ink);letter-spacing:-.02em;transition:color .25s var(--ease)}
.ctaphone__big:hover{color:var(--accent2)}
.ctaseal{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:1.6rem}
.ctaseal__i{background:var(--card);padding:1.1rem 1.2rem;display:grid;grid-template-columns:auto 1fr;gap:.7rem;align-items:center;font-size:.92rem;color:var(--ink2)}
.ctaseal__i svg{width:20px;height:20px;color:var(--accent)}
@media(max-width:680px){.ctaseal{grid-template-columns:1fr}}

/* ============ responsive ============ */
@media(max-width:1024px){
.foot__top{grid-template-columns:1fr 1fr}
.svc__grid{grid-template-columns:repeat(2,1fr)}
.statrow{grid-template-columns:repeat(2,1fr)}
.stat:nth-child(2n){border-right:none}
.stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
.counter__grid{grid-template-columns:repeat(2,1fr)}
.allrev{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1180px){
.nav__links{display:none}
.burger{display:flex}
.nav__phone{display:none}
.hero__in{grid-template-columns:1fr;gap:clamp(24px,4vw,40px)}
.hero__bg::after{background:linear-gradient(180deg,rgba(247,244,239,.86) 0%,rgba(247,244,239,.96) 34%,var(--paper) 64%)}
.herocard{order:2;max-width:560px;width:100%}
}
@media(max-width:980px){
.trust__in,.system__in,.about__in,.areas__in,.leadsec__in,.maps__grid,.svcpage__grid,.citylocal__grid{grid-template-columns:1fr}
.aside{position:static}
.about__media{max-width:440px}
.about__media img{aspect-ratio:16/10}
.phero__bg::after{background:linear-gradient(180deg,rgba(247,244,239,.62) 0%,rgba(247,244,239,.9) 42%,var(--paper2) 78%)}
}
@media(max-width:768px){
.smb{display:grid}
.fab{display:none}
#a2cb-widget{bottom:calc(56px + 14px)}
body.has-smb{padding-bottom:60px}
.svc__grid{grid-template-columns:1fr}
.gal__grid{grid-template-columns:repeat(2,1fr)}
.allrev{grid-template-columns:1fr}
.about__values{grid-template-columns:1fr}
.areas__pills{grid-template-columns:1fr}
.foot__top{grid-template-columns:1fr;gap:2rem}
.foot__bottom{flex-direction:column}
.field2{grid-template-columns:1fr}
}
@media(max-width:520px){
.statrow{grid-template-columns:1fr 1fr}
.gal__grid{grid-template-columns:1fr}
.counter__grid{grid-template-columns:1fr 1fr}
.cnt:nth-child(2n){border-right:none}
.trust__items{margin-top:.5rem}
.topinfo__row{font-size:.66rem;gap:.5rem}
.drawer__cta{grid-template-columns:1fr}
.nav__cta .btn{display:none}
.hero__h1{font-size:clamp(1.6rem,6.6vw,2.3rem);letter-spacing:-.02em}
.phero__h1{font-size:clamp(1.45rem,5.6vw,2.1rem);letter-spacing:-.02em}
.hero__sub,.phero__sub{max-width:none}
.rgate{padding:1.5rem 1.15rem}
.rgate h1{font-size:clamp(1.05rem,4.6vw,1.55rem)}
}
@media(prefers-reduced-motion:reduce){
*{animation-duration:.001ms!important;transition-duration:.001ms!important}
html.reveal-on [data-reveal]{opacity:1!important;transform:none!important}
.rev__track{animation:none}
}
