/* =========================================================
   RYBY.IN — PREMIUM EDITION
   Zero external deps · System fonts · Max performance
========================================================= */
:root{
--ink:#0f0f0f;--ink-2:#1c1c1c;--ink-soft:#4a4a4a;--ink-muted:#8c8c8c;--ink-faint:#c0c0c0;
--canvas:#fafaf8;--surface:#f4f3f0;--surface-2:#eeede9;--white:#fff;
--border:rgba(0,0,0,.08);--border-md:rgba(0,0,0,.13);
--accent:#e8540a;--accent-d:#d44800;--accent-bg:rgba(232,84,10,.06);--accent-bg2:rgba(232,84,10,.13);
--green:#16a34a;--green-bg:rgba(22,163,74,.08);
--wa:#25d366;--wa-d:#1db954;
--sh-xs:0 1px 2px rgba(0,0,0,.04);
--sh-sm:0 2px 8px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
--sh-md:0 8px 24px rgba(0,0,0,.07),0 2px 6px rgba(0,0,0,.04);
--sh-lg:0 20px 60px rgba(0,0,0,.09),0 4px 12px rgba(0,0,0,.05);
--sh-xl:0 40px 100px rgba(0,0,0,.12),0 8px 24px rgba(0,0,0,.06);
--r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-2xl:32px;--r-full:999px;
/* 100% system font — zero network requests */
--font:-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
--serif:Georgia,"Times New Roman",serif;
--ease:cubic-bezier(.16,1,.3,1);--df:160ms;--dn:280ms;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:var(--font);background:var(--canvas);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeSpeed}
img,svg{display:block;max-width:100%}
button,input,textarea,select{font:inherit}
button{cursor:pointer;border:none;background:none}
a{text-decoration:none;color:inherit}
ul{list-style:none}

h1,h2,h3,h4{color:var(--ink);line-height:1.12;letter-spacing:-.022em;font-weight:700}
h1{font-family:var(--serif);font-size:clamp(2.4rem,5.5vw,4.6rem);font-weight:400;letter-spacing:-.025em;font-style:italic}
h2{font-size:clamp(1.75rem,3.4vw,2.7rem)}
h3{font-size:clamp(1.05rem,1.9vw,1.28rem)}
h4{font-size:.97rem;font-weight:600}
p{color:var(--ink-soft);line-height:1.7}
.lead{font-size:1.05rem;line-height:1.78;max-width:600px}
strong{color:var(--ink);font-weight:600}

.container{width:min(calc(100% - 3rem),1160px);margin-inline:auto}
.container-md{width:min(calc(100% - 3rem),760px);margin-inline:auto}
.section{padding-block:5.5rem}
.section-sm{padding-block:3.5rem}
.section-intro{margin-bottom:3.5rem}
.section-intro .lead{margin-top:.85rem}
.text-center{text-align:center}
.text-center .lead{margin-inline:auto}
.grid{display:grid;gap:1.4rem}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.flex{display:flex}.items-center{align-items:center}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.flex-wrap{flex-wrap:wrap}
.mt-4{margin-top:1rem}.mt-6{margin-top:2rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:2rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.header{position:sticky;top:0;z-index:200;background:rgba(250,250,248,.94);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);border-bottom:1px solid var(--border)}
.navbar{height:66px;display:flex;align-items:center;justify-content:space-between;gap:1.75rem}
.logo{display:flex;align-items:center;gap:.55rem;font-size:1.25rem;font-weight:800;color:var(--ink);letter-spacing:-.04em;white-space:nowrap}
.logo-mark{width:30px;height:30px;border-radius:var(--r-sm);background:var(--ink);color:var(--canvas);display:grid;place-items:center;font-size:.88rem;font-weight:900;flex-shrink:0;line-height:1}
.logo em{font-style:normal;color:var(--accent)}
.nav-links{display:none;align-items:center;gap:1.85rem}
.nav-link{font-size:.87rem;font-weight:500;color:var(--ink-soft);transition:color var(--df) var(--ease);letter-spacing:-.01em}
.nav-link:hover{color:var(--ink)}
.nav-actions{display:flex;align-items:center;gap:.7rem}
.mobile-btn{width:38px;height:38px;border-radius:var(--r-sm);background:var(--surface);display:grid;place-items:center;color:var(--ink);transition:background var(--df)}
.mobile-btn:hover{background:var(--surface-2)}
.mobile-nav{background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--sh-sm)}
.mobile-nav-inner{display:flex;flex-direction:column;padding:.75rem 0 1.25rem}
.mobile-nav-inner .nav-link{padding:.85rem 0;font-size:1rem;border-bottom:1px solid var(--border)}
.mobile-nav-inner .nav-link:last-of-type{border-bottom:none}
.mobile-nav-actions{display:flex;flex-direction:column;gap:.7rem;margin-top:1.2rem}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;padding:.75rem 1.55rem;border-radius:var(--r-full);font-weight:600;font-size:.92rem;letter-spacing:-.01em;transition:background var(--df) var(--ease),color var(--df) var(--ease),transform var(--df) var(--ease),box-shadow var(--df) var(--ease),border-color var(--df) var(--ease)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--ink);color:var(--white)}
.btn-primary:hover{background:var(--ink-2);transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-accent{background:var(--accent);color:var(--white);box-shadow:0 4px 14px rgba(232,84,10,.26)}
.btn-accent:hover{background:var(--accent-d);transform:translateY(-1px);box-shadow:0 8px 26px rgba(232,84,10,.32)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--border-md)}
.btn-outline:hover{border-color:var(--ink);background:var(--surface)}
.btn-white{background:var(--white);color:var(--ink);box-shadow:var(--sh-sm)}
.btn-white:hover{transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-whatsapp{background:var(--wa);color:var(--white);box-shadow:0 4px 14px rgba(37,211,102,.24)}
.btn-whatsapp:hover{background:var(--wa-d);transform:translateY(-1px);box-shadow:0 8px 26px rgba(37,211,102,.3)}
.btn-block{width:100%}
.btn-sm{min-height:38px;padding:.48rem 1.05rem;font-size:.83rem}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}

.form-group{margin-bottom:1.05rem}
.label{display:block;margin-bottom:.42rem;font-size:.76rem;font-weight:600;color:var(--ink-muted);letter-spacing:.07em;text-transform:uppercase}
.input,.select,.textarea{width:100%;padding:.84rem 1rem;border:1.5px solid var(--border-md);border-radius:var(--r-md);background:var(--white);color:var(--ink);font-size:.93rem;outline:none;transition:border-color var(--df) var(--ease),box-shadow var(--df) var(--ease)}
.input::placeholder,.textarea::placeholder{color:var(--ink-faint)}
.input:hover,.select:hover,.textarea:hover{border-color:rgba(0,0,0,.2)}
.input:focus,.select:focus,.textarea:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.06)}
.select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238c8c8c' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.textarea{min-height:118px;resize:vertical}
.field-hint{display:block;font-size:.77rem;color:var(--ink-muted);margin-top:.28rem}
.alert{padding:.88rem 1.1rem;border-radius:var(--r-md);font-size:.87rem;font-weight:500;margin-bottom:.72rem}
.alert-success{background:var(--green-bg);color:var(--green);border:1px solid rgba(22,163,74,.15)}
.alert-warning{background:rgba(217,119,6,.08);color:#92400e;border:1px solid rgba(217,119,6,.15)}
.alert-danger{background:rgba(220,38,38,.08);color:#991b1b;border:1px solid rgba(220,38,38,.12)}

.hero{background:var(--canvas);padding-block:5.5rem 5rem;position:relative;overflow:hidden}
.hero-bg{position:absolute;top:-150px;right:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle at 40% 40%,rgba(232,84,10,.055) 0%,transparent 62%);pointer-events:none}
.hero-grid{display:grid;gap:3.75rem;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--accent);margin-bottom:1.4rem}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:blink 2.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.hero-h1{margin-bottom:1.35rem}
.hero-h1-top{display:block;font-family:var(--font);font-style:normal;font-size:clamp(.88rem,1.7vw,1.05rem);font-weight:600;color:var(--ink);letter-spacing:-.015em;margin-bottom:.4rem}
.hero-sub{margin-bottom:2.2rem;font-size:1.02rem;max-width:520px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-bottom:3rem}
.hero-proof{display:flex;flex-wrap:wrap;align-items:center;gap:1.85rem;padding-top:1.85rem;border-top:1px solid var(--border)}
.proof-item{display:flex;align-items:center;gap:.6rem}
.proof-avatars{display:flex}
.proof-avatars span{width:25px;height:25px;border-radius:50%;background:var(--surface-2);border:2px solid var(--white);display:grid;place-items:center;font-size:.57rem;font-weight:700;color:var(--ink-muted);margin-left:-7px}
.proof-avatars span:first-child{margin-left:0}
.proof-text strong{display:block;font-size:.89rem;font-weight:700;color:var(--ink);line-height:1.2}
.proof-text span{font-size:.73rem;color:var(--ink-muted)}
.proof-sep{width:1px;height:24px;background:var(--border-md)}
.hero-card{background:var(--white);border-radius:var(--r-2xl);box-shadow:var(--sh-xl);border:1px solid var(--border);overflow:hidden}
.hero-card-head{padding:1.55rem 1.9rem 1.35rem;background:var(--surface);border-bottom:1px solid var(--border)}
.hero-card-head h3{font-size:1.03rem;margin-bottom:.2rem}
.hero-card-head p{font-size:.81rem;color:var(--ink-muted)}
.hero-card-body{padding:1.7rem 1.9rem 1.9rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.88rem}
.form-privacy{text-align:center;font-size:.72rem;color:var(--ink-muted);margin-top:.78rem;display:flex;align-items:center;justify-content:center;gap:.32rem}

.trust-bar{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding-block:1.55rem}
.trust-bar-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.4rem}
.trust-bar-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-faint);white-space:nowrap}
.trust-logos{display:flex;flex-wrap:wrap;align-items:center;gap:1.85rem}
.trust-logo{font-size:.84rem;font-weight:700;color:var(--ink-muted);opacity:.5;transition:opacity var(--df)}
.trust-logo:hover{opacity:.85}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));background:var(--ink);border-radius:var(--r-xl);overflow:hidden}
.stat-cell{padding:2.15rem 1.6rem;text-align:center;border-right:1px solid rgba(255,255,255,.07)}
.stat-cell:last-child{border-right:none}
.stat-val{font-size:clamp(1.65rem,2.8vw,2.4rem);font-weight:800;color:var(--white);line-height:1;display:block;letter-spacing:-.04em}
.stat-val em{font-style:normal;color:#ff6b2b}
.stat-desc{font-size:.7rem;font-weight:500;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.07em;margin-top:.48rem;display:block}

.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.why-list{display:flex;flex-direction:column;gap:1.7rem;margin-top:2.4rem}
.why-item{display:flex;gap:1.05rem;align-items:flex-start}
.why-icon{width:40px;height:40px;flex-shrink:0;border-radius:var(--r-md);background:var(--surface);display:grid;place-items:center;font-size:1.1rem;border:1px solid var(--border)}
.why-item h4{margin-bottom:.28rem}
.why-item p{font-size:.85rem;line-height:1.64}
.why-visual{border-radius:var(--r-xl);background:var(--surface);border:1px solid var(--border);overflow:hidden;aspect-ratio:4/5;display:flex;flex-direction:column;justify-content:flex-end;padding:1.65rem;position:relative}
.why-visual-dots{position:absolute;inset:0;opacity:.04;background-image:radial-gradient(var(--ink) 1px,transparent 1px);background-size:22px 22px}
.why-card-inner{position:relative;z-index:1;background:var(--white);border-radius:var(--r-lg);padding:1.35rem;box-shadow:var(--sh-lg);border:1px solid var(--border)}
.wvi-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-bottom:.82rem}
.wvi-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.52rem}
.wvi-row:last-child{margin-bottom:0}
.wvi-name{font-size:.84rem;font-weight:500}
.wvi-badge{font-size:.68rem;font-weight:700;padding:.2rem .58rem;border-radius:var(--r-full)}
.b-done{background:var(--green-bg);color:var(--green)}
.b-go{background:var(--accent-bg2);color:var(--accent)}
.b-sched{background:rgba(99,102,241,.09);color:#4338ca}

.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(208px,1fr));gap:1.05rem}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.7rem 1.45rem 1.45rem;cursor:pointer;position:relative;overflow:hidden;transition:transform 280ms var(--ease),box-shadow 280ms var(--ease),border-color 280ms var(--ease)}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2.5px;background:var(--accent);opacity:0;transition:opacity 280ms var(--ease)}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.svc-card:hover::after{opacity:1}
.svc-icon{width:48px;height:48px;border-radius:var(--r-md);display:grid;place-items:center;font-size:1.4rem;margin-bottom:1.15rem}
.ic-1{background:#fff3ec}.ic-2{background:#eef6ff}.ic-3{background:#eefaf3}
.ic-4{background:#fefce8}.ic-5{background:#f3f0ff}.ic-6{background:#fdf2f8}
.svc-card h3{font-size:.96rem;margin-bottom:.38rem}
.svc-card p{font-size:.83rem;line-height:1.6}
.svc-price{display:inline-block;margin-top:.95rem;font-size:.78rem;font-weight:700;color:var(--accent)}
.svc-arrow{position:absolute;top:1.35rem;right:1.35rem;width:25px;height:25px;border-radius:50%;background:var(--surface);display:grid;place-items:center;font-size:.7rem;opacity:0;transition:opacity var(--df),transform var(--df)}
.svc-card:hover .svc-arrow{opacity:1;transform:translate(2px,-2px)}

.how-section{background:var(--ink)}
.how-section h2{color:var(--white)}
.how-section .lead{color:rgba(255,255,255,.44)}
.steps-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.9rem;margin-top:3.25rem;position:relative}
.step-card{position:relative}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-full);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);font-size:.78rem;font-weight:700;color:rgba(255,255,255,.32);margin-bottom:1.15rem}
.step-card h3{color:var(--white);font-size:.96rem;margin-bottom:.42rem}
.step-card p{font-size:.85rem;color:rgba(255,255,255,.38);line-height:1.64}
.step-line{position:absolute;top:18px;right:-1rem;width:2rem;height:1px;background:rgba(255,255,255,.07)}

.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(252px,1fr));gap:1.05rem;max-width:870px;margin-inline:auto}
.p-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.8rem;transition:transform 280ms var(--ease),box-shadow 280ms var(--ease)}
.p-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.p-card.featured{background:var(--ink);border-color:var(--ink)}
.p-icon{font-size:1.8rem;margin-bottom:.85rem}
.p-cat{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-muted);margin-bottom:.28rem}
.p-card.featured .p-cat{color:rgba(255,255,255,.34)}
.p-amount{font-size:2.35rem;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-.05em;margin-bottom:.18rem}
.p-card.featured .p-amount{color:var(--white)}
.p-unit{font-size:.77rem;color:var(--ink-muted);margin-bottom:1.35rem}
.p-card.featured .p-unit{color:rgba(255,255,255,.34)}
.p-feats{display:flex;flex-direction:column;gap:.58rem;margin-bottom:1.55rem}
.p-feats li{font-size:.84rem;color:var(--ink-soft);display:flex;align-items:center;gap:.48rem}
.p-card.featured .p-feats li{color:rgba(255,255,255,.6)}
.p-check{color:var(--green);font-size:.78rem}
.p-card.featured .p-check{color:#ff6b2b}
.p-popular{display:inline-block;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;background:var(--accent-bg2);color:var(--accent);padding:.26rem .72rem;border-radius:var(--r-full);margin-bottom:1.05rem}

.tgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(268px,1fr));gap:1.05rem}
.tcard{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.65rem;transition:box-shadow 280ms var(--ease)}
.tcard:hover{box-shadow:var(--sh-md)}
.tcard-stars{color:#f59e0b;font-size:.88rem;letter-spacing:.09em;margin-bottom:.88rem}
.tcard blockquote{font-size:.9rem;line-height:1.72;color:var(--ink-soft);font-style:italic}
.tcard-user{display:flex;align-items:center;gap:.78rem;margin-top:1.15rem;padding-top:.95rem;border-top:1px solid var(--border)}
.t-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:var(--surface-2);display:grid;place-items:center;font-size:.67rem;font-weight:700;color:var(--ink-soft)}
.tcard-user strong{display:block;font-size:.85rem;color:var(--ink)}
.tcard-user span{font-size:.72rem;color:var(--ink-muted)}

.cta-wrap{background:var(--surface);border-radius:var(--r-2xl);padding:4rem;text-align:center;position:relative;overflow:hidden;border:1px solid var(--border)}
.cta-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(232,84,10,.055) 0%,transparent 62%);pointer-events:none}
.cta-wrap h2,.cta-wrap .lead{position:relative}
.cta-actions{position:relative;display:flex;flex-wrap:wrap;justify-content:center;gap:.95rem;margin-top:1.9rem}

.faq-wrap{max-width:680px;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;padding:1.25rem 0;font-weight:600;font-size:.94rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color var(--df)}
.faq-q:hover,.faq-q[aria-expanded="true"]{color:var(--accent)}
.faq-chevron{width:21px;height:21px;border-radius:50%;flex-shrink:0;background:var(--surface);display:grid;place-items:center;font-size:.58rem;color:var(--ink-muted);transition:transform 280ms var(--ease),background var(--df),color var(--df)}
.faq-q[aria-expanded="true"] .faq-chevron{transform:rotate(180deg);background:var(--accent);color:var(--white)}
.faq-a{padding-bottom:1.25rem;font-size:.9rem;line-height:1.74;color:var(--ink-soft)}

.footer{background:#0d0d0d;color:rgba(255,255,255,.44);padding-top:4.5rem}
.footer-top{display:grid;gap:2.75rem;padding-bottom:3.75rem}
.footer-brand{max-width:258px}
.footer-brand p{font-size:.85rem;line-height:1.7;margin-top:.78rem}
.footer-logo{display:flex;align-items:center;gap:.55rem;font-size:1.18rem;font-weight:800;color:var(--white);letter-spacing:-.04em}
.footer-logo-mark{width:27px;height:27px;border-radius:var(--r-xs);background:var(--white);color:#0d0d0d;display:grid;place-items:center;font-size:.8rem;font-weight:900;line-height:1}
.footer-logo em{font-style:normal;color:#ff6b2b}
.footer-contact{margin-top:1.15rem;display:flex;flex-direction:column;gap:.48rem}
.footer-contact a{display:flex;align-items:center;gap:.48rem;font-size:.84rem;color:rgba(255,255,255,.4);transition:color var(--df)}
.footer-contact a:hover{color:var(--white)}
.footer-col h5{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:rgba(255,255,255,.24);margin-bottom:.95rem}
.footer-col ul{display:flex;flex-direction:column;gap:.58rem}
.footer-col a{font-size:.85rem;color:rgba(255,255,255,.38);transition:color var(--df)}
.footer-col a:hover{color:var(--white)}
.footer-social{display:flex;gap:.52rem;margin-top:1.35rem;flex-wrap:wrap}
.s-icon{width:33px;height:33px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);display:grid;place-items:center;transition:background var(--df),border-color var(--df),transform var(--df)}
.s-icon:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.17);transform:translateY(-2px)}
.s-icon svg{width:14px;height:14px;fill:rgba(255,255,255,.52);transition:fill var(--df)}
.s-icon:hover svg{fill:var(--white)}
.s-icon.s-wa:hover{background:rgba(37,211,102,.18);border-color:rgba(37,211,102,.28)}
.s-icon.s-wa:hover svg{fill:var(--wa)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-block:1.35rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.95rem}
.footer-bottom p{font-size:.77rem}
.footer-chips{display:flex;gap:.55rem;flex-wrap:wrap}
.footer-chip{font-size:.68rem;font-weight:600;padding:.26rem .68rem;border-radius:var(--r-full);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.33)}

.floating-wa{position:fixed;right:1.35rem;bottom:1.5rem;z-index:300;display:flex;flex-direction:column;align-items:center;gap:.38rem}
.wa-btn{width:52px;height:52px;border-radius:50%;background:var(--wa);color:var(--white);display:grid;place-items:center;box-shadow:0 6px 22px rgba(37,211,102,.38);transition:transform var(--df) var(--ease),box-shadow var(--df);position:relative}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 10px 30px rgba(37,211,102,.48)}
.wa-btn svg{width:22px;height:22px}
.wa-pulse{position:absolute;top:1px;right:1px;width:12px;height:12px;border-radius:50%;background:var(--accent);border:2px solid var(--canvas);animation:wap 2.5s infinite}
@keyframes wap{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.55);opacity:.55}}
.wa-label{font-size:.62rem;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em}
/* Urban Company-style section tag */
.section-tag{font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:1rem;display:block}
.reveal{opacity:0;transform:translateY(14px);transition:opacity .48s var(--ease),transform .48s var(--ease)}
.reveal.visible{opacity:1;transform:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
@media(min-width:900px){
.nav-links{display:flex}.mobile-btn{display:none}.mobile-nav{display:none!important}
.hero-grid{grid-template-columns:1.05fr .95fr}
.footer-top{grid-template-columns:1.4fr 1fr 1fr 1fr}
.why-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:899px){
.section{padding-block:3.75rem}.hero{padding-block:3.25rem 2.75rem}.hero-bg{display:none}
.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}
.why-grid{grid-template-columns:1fr}.why-visual{display:none}.step-line{display:none}
.cta-wrap{padding:2.4rem 1.65rem}.cta-actions .btn{width:100%;justify-content:center}
.footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1;max-width:none}
.form-row{grid-template-columns:1fr}.stats-row{grid-template-columns:1fr 1fr}
.stat-cell{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
.stat-cell:nth-child(odd){border-right:1px solid rgba(255,255,255,.07)}
.stat-cell:last-child{border-bottom:none}
}
@media(max-width:500px){
.container{width:calc(100% - 2rem)}.footer-top{grid-template-columns:1fr}
.trust-logos{gap:1.1rem}.hero-proof{gap:1.1rem}.proof-sep{display:none}
}
@media print{.header,.footer,.floating-wa,.btn{display:none!important}body{background:#fff;color:#000}}

/* ── URBAN COMPANY-INSPIRED ADDITIONS ── */

/* Section label (small uppercase eyebrow above h2) */
.section-label{
  display:inline-block;
  font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;color:var(--accent);margin-bottom:.9rem;
}

/* Service card grid — UC uses tight uniform tiles */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(208px,1fr));
  gap:1.05rem;
}

/* UC-style category pill on service cards */
.svc-cat-pill{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.7rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.07em;color:var(--ink-muted);
  margin-bottom:.55rem;
}

/* UC-style horizontal divider accent */
.divider-accent{
  width:40px;height:3px;background:var(--accent);
  border-radius:var(--r-full);margin-block:.9rem;
}

/* UC-style tag/chip on cards */
.tag{
  display:inline-flex;align-items:center;
  font-size:.72rem;font-weight:600;
  padding:.25rem .65rem;border-radius:var(--r-full);
  background:var(--surface-2);color:var(--ink-muted);
}

/* Active nav link underline (UC-style) */
.nav-link.active{color:var(--ink)}
.nav-link.active::after{width:100%}

/* UC-style "as seen on" / press strip */
.press-strip{
  background:var(--canvas);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding-block:1.4rem;
}
.press-inner{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:2.25rem;
}
.press-item{
  font-size:.82rem;font-weight:700;color:var(--ink-faint);
  letter-spacing:-.01em;opacity:.45;
  transition:opacity var(--df);
}
.press-item:hover{opacity:.8}

/* UC-style feature highlight row */
.feature-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:0;
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  overflow:hidden;
  background:var(--white);
}
.feature-cell{
  padding:1.75rem 1.5rem;
  border-right:1px solid var(--border);
  text-align:center;
}
.feature-cell:last-child{border-right:none}
.feature-cell-icon{font-size:1.6rem;margin-bottom:.65rem}
.feature-cell h4{font-size:.93rem;margin-bottom:.3rem}
.feature-cell p{font-size:.82rem}

/* Smooth section alternation (UC pattern) */
.section:nth-child(even){background:var(--white)}

/* UC-style booking confirmation tick animation */
@keyframes tickIn{
  0%{transform:scale(0);opacity:0}
  60%{transform:scale(1.2)}
  100%{transform:scale(1);opacity:1}
}
.tick-animate{animation:tickIn .4s var(--ease) both}

/* ═══════════════════════════════════════
   LANDING PAGE ADDITIONS
═══════════════════════════════════════ */

/* ── Page Hero (service-specific) ── */
.page-hero{
  background:var(--canvas);
  padding-block:4.5rem 4rem;
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--border);
}
.page-hero-bg{
  position:absolute;top:-120px;right:-160px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(232,84,10,.055) 0%,transparent 62%);
  pointer-events:none;
}
.page-hero-grid{display:grid;gap:3rem;align-items:center}
.page-hero-eyebrow{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.1rem;
  background:var(--accent-bg2);padding:.35rem .85rem;border-radius:var(--r-full);
}
.page-hero h1{
  font-family:var(--font);font-style:normal;font-weight:800;
  font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.03em;
  line-height:1.1;margin-bottom:1.1rem;
}
.page-hero h1 em{font-style:normal;color:var(--accent)}
.page-hero-sub{font-size:1.02rem;max-width:540px;margin-bottom:2rem;line-height:1.75}
.page-hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.hero-badge-pill{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.78rem;font-weight:600;
  padding:.4rem .9rem;border-radius:var(--r-full);
  background:var(--white);border:1px solid var(--border);
  color:var(--ink-soft);box-shadow:var(--sh-xs);
}
.hero-badge-pill .dot{
  width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;
}
.page-hero-actions{display:flex;flex-wrap:wrap;gap:.85rem}

/* Lead form card */
.lead-card{
  background:var(--white);border-radius:var(--r-2xl);
  box-shadow:var(--sh-xl);border:1px solid var(--border);
  overflow:hidden;position:sticky;top:80px;
}
.lead-card-head{
  padding:1.5rem 1.85rem 1.3rem;
  background:var(--ink);
}
.lead-card-head h3{color:var(--white);font-size:1.05rem;margin-bottom:.2rem}
.lead-card-head p{color:rgba(255,255,255,.55);font-size:.81rem}
.lead-card-body{padding:1.65rem 1.85rem 1.85rem}
.lead-guarantee{
  display:flex;align-items:center;gap:.45rem;
  font-size:.76rem;color:var(--ink-muted);
  margin-top:.85rem;text-align:center;justify-content:center;
}

/* ── Trust bar (mini) ── */
.mini-trust{
  background:var(--white);border-bottom:1px solid var(--border);
  padding-block:1.2rem;
}
.mini-trust-inner{
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:center;gap:1.75rem;
}
.mini-trust-item{
  display:flex;align-items:center;gap:.45rem;
  font-size:.82rem;font-weight:600;color:var(--ink-soft);
}
.mini-trust-item svg{flex-shrink:0}

/* ── Service detail sections ── */
.detail-section{padding-block:5rem}
.detail-grid{display:grid;gap:3.5rem;align-items:start}
.detail-content h2{margin-bottom:1rem}
.detail-content p{margin-bottom:1rem}
.detail-content p:last-child{margin-bottom:0}

/* Checklist */
.checklist{display:flex;flex-direction:column;gap:.7rem;margin-block:1.25rem}
.checklist li{
  display:flex;align-items:flex-start;gap:.75rem;
  font-size:.93rem;color:var(--ink-soft);line-height:1.6;
}
.check-icon{
  width:20px;height:20px;border-radius:50%;
  background:var(--green-bg);display:grid;place-items:center;
  flex-shrink:0;margin-top:.15rem;font-size:.65rem;color:var(--green);
}

/* ── Pricing table ── */
.price-table{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;margin-block:1.5rem;
}
.price-table-head{
  background:var(--surface);padding:1.1rem 1.5rem;
  display:grid;grid-template-columns:1fr auto;align-items:center;
  border-bottom:1px solid var(--border);
}
.price-table-head h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-muted)}
.price-row{
  display:grid;grid-template-columns:1fr auto;align-items:center;
  padding:.95rem 1.5rem;border-bottom:1px solid var(--border);
  transition:background var(--df);
}
.price-row:last-child{border-bottom:none}
.price-row:hover{background:var(--surface)}
.price-row-name{font-size:.92rem;font-weight:500}
.price-row-val{
  font-size:.92rem;font-weight:700;color:var(--accent);
  background:var(--accent-bg);padding:.22rem .7rem;
  border-radius:var(--r-full);white-space:nowrap;
}
.price-note{font-size:.78rem;color:var(--ink-muted);padding:1rem 1.5rem;background:var(--surface)}

/* ── Process steps (horizontal) ── */
.process-steps{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:1.25rem;margin-top:2.5rem;
}
.process-step{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:1.6rem 1.3rem;
  text-align:center;position:relative;
  transition:box-shadow var(--dn) var(--ease),transform var(--dn) var(--ease);
}
.process-step:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.ps-num{
  width:36px;height:36px;border-radius:50%;
  background:var(--ink);color:var(--white);
  display:grid;place-items:center;
  font-size:.8rem;font-weight:800;
  margin:0 auto .9rem;
}
.process-step h4{font-size:.92rem;margin-bottom:.35rem}
.process-step p{font-size:.82rem;line-height:1.6}

/* ── Benefits grid ── */
.benefits-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.15rem;
}
.benefit-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:1.6rem;
  transition:box-shadow var(--dn) var(--ease),transform var(--dn) var(--ease);
}
.benefit-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.benefit-icon{
  font-size:1.75rem;margin-bottom:.85rem;
  width:48px;height:48px;display:grid;place-items:center;
  border-radius:var(--r-md);background:var(--surface);
}
.benefit-card h4{margin-bottom:.4rem;font-size:.97rem}
.benefit-card p{font-size:.85rem;line-height:1.65}

/* ── FAQ (landing page variant) ── */
.lp-faq{background:var(--surface);padding-block:5rem}
.lp-faq h2{margin-bottom:2.5rem}

/* ── Reviews strip ── */
.reviews-section{padding-block:5rem}
.rating-summary{
  display:flex;align-items:center;gap:1.5rem;
  background:var(--ink);border-radius:var(--r-xl);
  padding:2rem 2.5rem;margin-bottom:2.5rem;flex-wrap:wrap;
}
.rating-big{
  font-size:3.5rem;font-weight:900;color:var(--white);
  line-height:1;letter-spacing:-.05em;
}
.rating-big span{font-size:1.4rem;color:#f59e0b}
.rating-meta p{color:rgba(255,255,255,.5);font-size:.85rem;margin-top:.25rem}
.rating-meta strong{color:var(--white);font-size:1.05rem}
.rating-stars-row{color:#f59e0b;font-size:1.2rem;letter-spacing:.08em}

/* ── CTA Bottom ── */
.bottom-cta{
  background:var(--ink);padding-block:5rem;
  text-align:center;position:relative;overflow:hidden;
}
.bottom-cta::before{
  content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,84,10,.12) 0%,transparent 65%);
  pointer-events:none;
}
.bottom-cta h2{color:var(--white);position:relative}
.bottom-cta .lead{color:rgba(255,255,255,.55);margin-inline:auto;position:relative}
.bottom-cta-actions{
  position:relative;display:flex;flex-wrap:wrap;
  justify-content:center;gap:.95rem;margin-top:2rem;
}
.bottom-cta .btn-outline{
  border-color:rgba(255,255,255,.3);color:var(--white);
}
.bottom-cta .btn-outline:hover{
  border-color:var(--white);background:rgba(255,255,255,.08);
}

/* ── Breadcrumb ── */
.breadcrumb{
  display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;
  font-size:.78rem;color:var(--ink-muted);
  padding-block:.85rem;border-bottom:1px solid var(--border);
}
.breadcrumb a{color:var(--ink-muted);transition:color var(--df)}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb-sep{color:var(--ink-faint)}

/* ── Sticky CTA bar (mobile) ── */
.sticky-cta-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:150;
  background:var(--white);border-top:1px solid var(--border);
  padding:.75rem 1rem;
  display:none;
  gap:.65rem;
  box-shadow:0 -4px 20px rgba(0,0,0,.08);
}
.sticky-cta-bar .btn{min-height:44px;font-size:.88rem;flex:1}

/* ── Responsive overrides ── */
@media(min-width:900px){
  .page-hero-grid{grid-template-columns:1.1fr .9fr}
  .detail-grid{grid-template-columns:1.1fr .9fr}
}
@media(max-width:899px){
  .page-hero{padding-block:3rem 2.5rem}
  .page-hero-bg{display:none}
  .page-hero-actions{flex-direction:column}
  .page-hero-actions .btn{width:100%}
  .lead-card{position:static}
  .detail-grid{grid-template-columns:1fr}
  .rating-summary{padding:1.5rem}
  .bottom-cta{padding-block:3.5rem}
  .bottom-cta-actions .btn{width:100%;justify-content:center}
  .sticky-cta-bar{display:flex}
  body{padding-bottom:74px}
}
