/* Rally Grooming Co. — premium pet spa · warm coral & cream edition
   Fonts: Bricolage Grotesque (display) + Nunito Sans (body) */
:root{
  --cream:#faf4ec;--cream2:#f4ebdf;--blush:#f8e2d8;--blush2:#f3d5c8;
  --esp:#2b1f1a;--esp2:#231915;--esp3:#3a2b24;
  --coral:#ff6f61;--coral-d:#e85a4d;--coral-soft:rgba(255,111,97,.14);
  --ink:#2b1f1a;--body:#5d4d44;--mut:#94827a;
  --d-ink:#faf1e7;--d-body:#dcccc1;--d-mut:#a8968c;--d-line:rgba(250,241,231,.12);
  --line:#e7d9cc;--r:26px;--container:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Nunito Sans',system-ui,sans-serif;background:var(--cream);color:var(--body);line-height:1.7;-webkit-font-smoothing:antialiased;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90'%3E%3Cg fill='%232b1f1a' fill-opacity='.035'%3E%3Ccircle cx='12' cy='18' r='1.4'/%3E%3Ccircle cx='48' cy='6' r='1'/%3E%3Ccircle cx='74' cy='30' r='1.5'/%3E%3Ccircle cx='30' cy='52' r='1.1'/%3E%3Ccircle cx='64' cy='70' r='1.3'/%3E%3Ccircle cx='8' cy='78' r='1'/%3E%3Ccircle cx='86' cy='84' r='1.2'/%3E%3C/g%3E%3C/svg%3E")}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;letter-spacing:-.015em;color:var(--ink);line-height:1.06}
.container{max-width:var(--container);margin:0 auto;padding:0 26px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--coral-d);margin-bottom:16px}
.eyebrow::before{content:'';width:22px;height:2.5px;border-radius:3px;background:var(--coral)}
.hl{color:var(--coral-d)}
.dark .hl{color:var(--coral)}
section{width:100%}

/* buttons — soft pills, two-tone hierarchy */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;font-size:15.5px;padding:16px 30px;border-radius:999px;cursor:pointer;transition:.2s;border:0;font-family:'Nunito Sans',sans-serif}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--coral);color:#311b15;box-shadow:0 8px 22px rgba(255,111,97,.32)}
.btn-primary:hover{background:var(--coral-d);color:#fff7f0;transform:translateY(-2px) rotate(-.5deg)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.dark .btn-ghost{color:var(--d-ink);border-color:rgba(250,241,231,.4)}
.dark .btn-ghost:hover{background:var(--d-ink);color:var(--esp)}
.btn-sm{padding:11px 20px;font-size:14px}
.link-arrow{font-weight:800;color:var(--coral-d);display:inline-flex;align-items:center;gap:7px;font-size:15px}
.link-arrow svg{width:16px;height:16px;transition:.15s}
.link-arrow:hover svg{transform:translateX(4px)}
.dark .link-arrow{color:var(--coral)}

/* sticker badges — the Rally Grooming signature */
.sticker{display:inline-block;background:#fffdf9;border:2px solid var(--ink);border-radius:999px;padding:8px 18px;font-weight:900;font-size:13px;letter-spacing:.04em;color:var(--ink);box-shadow:4px 4px 0 var(--coral);transform:rotate(-3deg)}
.sticker.alt{transform:rotate(2.5deg);box-shadow:4px 4px 0 var(--blush2)}
.sticker.on-dark{background:var(--esp3);border-color:var(--coral);color:var(--d-ink);box-shadow:4px 4px 0 rgba(255,111,97,.45)}

/* nav */
.promo{background:var(--esp);color:var(--d-ink);text-align:center;font-size:13px;font-weight:700;padding:9px 16px}
.promo b{color:var(--coral)}
header.nav{position:sticky;top:0;z-index:90;background:rgba(250,244,236,.93);backdrop-filter:blur(12px);border-bottom:1.5px solid var(--line)}
.nav-in{max-width:var(--container);margin:0 auto;padding:0 26px;display:flex;align-items:center;gap:24px;height:78px}
.nav-links{display:flex;gap:2px;margin-left:auto;align-items:center}
.nav-links>a,.dd>button{font-weight:800;font-size:14.5px;color:var(--ink);padding:10px 13px;border-radius:999px;background:none;border:0;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:5px}
.nav-links>a:hover,.dd>button:hover{color:var(--coral-d);background:var(--coral-soft)}
.dd{position:relative}
.dd svg{width:13px;height:13px}
.dd-menu{position:absolute;top:100%;left:0;background:#fffdf9;border:1.5px solid var(--line);border-radius:18px;min-width:250px;padding:9px;display:none;box-shadow:0 24px 54px rgba(43,31,26,.16);margin-top:6px}
.dd:hover .dd-menu,.dd:focus-within .dd-menu{display:block}
.dd-menu a{display:block;padding:10px 13px;border-radius:12px;font-size:14px;color:var(--body);font-weight:700}
.dd-menu a:hover{background:var(--coral-soft);color:var(--coral-d)}
.nav-cta{margin-left:8px}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.burger svg{width:26px;height:26px;stroke:var(--ink)}
@media(max-width:1040px){
  .nav-links{position:fixed;inset:78px 0 0 0;background:var(--cream);flex-direction:column;align-items:stretch;padding:18px 24px;display:none;overflow-y:auto;gap:4px}
  .nav-links.open{display:flex}
  .dd-menu{position:static;display:none;box-shadow:none;border:0;background:var(--cream2);margin-top:2px}
  .dd.open .dd-menu{display:block}
  .burger{display:block}
  .nav-cta{margin:12px 0 0}
}
.bookbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:95;background:var(--coral);color:#311b15;text-align:center;padding:15px;font-weight:900;font-size:16px;box-shadow:0 -8px 24px rgba(43,31,26,.18)}
.bookbar svg{width:18px;height:18px;vertical-align:-3px;margin-right:7px}
@media(max-width:680px){.bookbar{display:block}body{padding-bottom:54px}}

/* wavy section dividers */
.wave{display:block;width:100%;height:46px;line-height:0;margin:-1px 0}
.wave svg{display:block;width:100%;height:100%}

/* hero — asymmetric arch composition */
.hero{position:relative;overflow:hidden;padding:74px 0 0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero h1{font-size:clamp(42px,5.6vw,76px);max-width:14ch;letter-spacing:-.025em}
.hero p.lead{font-size:18.5px;max-width:50ch;margin:22px 0 30px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.trust{display:flex;gap:24px;flex-wrap:wrap;margin-top:34px;font-size:13.5px;font-weight:800;color:var(--ink)}
.trust span{display:inline-flex;align-items:center;gap:8px}
.trust svg{width:17px;height:17px;stroke:var(--coral-d);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.hero-art{position:relative;padding:12px 8px 0}
.arch{background:var(--esp);border-radius:300px 300px 30px 30px;overflow:hidden;position:relative}
.arch.blush-fill{background:var(--blush)}
.arch.coral-fill{background:var(--coral)}
.hero-art .arch{aspect-ratio:4/4.9;transform:rotate(1.2deg)}
.hero-art .arch svg{width:100%;height:100%;display:block}
.hero-art .sticker{position:absolute;z-index:3}
.hero-art .st1{top:9%;left:-14px}
.hero-art .st2{bottom:13%;right:-10px}
.porthole{position:absolute;z-index:2;border-radius:50%;border:5px solid var(--cream);overflow:hidden;background:var(--blush)}
.hero-art .porthole{width:31%;aspect-ratio:1;left:-7%;bottom:-4%;transform:rotate(-4deg)}
.porthole svg{width:100%;height:100%;display:block}

/* sections */
.sec{padding:92px 0}
.sec-tight{padding:64px 0}
.sec-head{max-width:660px;margin-bottom:48px}
.sec-head h2{font-size:clamp(30px,3.5vw,46px)}
.sec-head p{margin-top:14px;font-size:16.5px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.blush{background:var(--blush)}
.cream2{background:var(--cream2)}
.dark{background:var(--esp);color:var(--d-body)}
.dark h1,.dark h2,.dark h3,.dark h4{color:var(--d-ink)}
.dark .eyebrow{color:var(--coral)}
.dark .trust{color:var(--d-ink)}

/* cards & grids */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:960px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.grid3,.grid2{grid-template-columns:1fr}}
.svc-card{background:#fffdf9;border:1.5px solid var(--line);border-radius:var(--r);padding:0;overflow:hidden;transition:.22s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-5px) rotate(-.4deg);border-color:var(--coral);box-shadow:0 20px 44px rgba(43,31,26,.13)}
.svc-card .vign{background:var(--blush);border-radius:0 0 60px 0;padding:26px 26px 20px;display:flex;align-items:flex-end;min-height:118px}
.svc-card:nth-child(even) .vign{background:var(--cream2);border-radius:0 0 0 60px}
.svc-card .vign svg{width:62px;height:62px;stroke:var(--esp);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.svc-card .bd{padding:22px 26px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.svc-card h3{font-size:21px}
.svc-card p{font-size:14.5px;flex:1}
.svc-card .price-tag{align-self:flex-start;background:var(--coral-soft);color:var(--coral-d);font-weight:900;font-size:13px;border-radius:999px;padding:5px 13px}
.dark .svc-card{background:var(--esp3);border-color:var(--d-line)}
.dark .svc-card h3{color:var(--d-ink)}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:36px}}
.split .arch{aspect-ratio:4/4.4}
.split .arch svg{width:100%;height:100%}
.checks{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:13px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.checks svg{width:21px;height:21px;stroke:var(--coral-d);flex:0 0 auto;margin-top:3px;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.dark .checks svg{stroke:var(--coral)}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}}
.stat .n{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:44px;color:var(--coral)}
.stat .l{font-size:12.5px;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--d-mut);margin-top:4px}

/* reviews */
.rev{background:#fffdf9;border:1.5px solid var(--line);border-radius:var(--r);padding:28px;position:relative}
.rev::before{content:'';position:absolute;top:-9px;left:28px;width:46px;height:18px;background:var(--blush2);border-radius:4px;transform:rotate(-2deg);opacity:.85}
.rev .stars{color:var(--coral);letter-spacing:2px;font-size:15px;margin-bottom:12px}
.rev p{font-size:14.5px}
.rev .who{margin-top:16px;font-weight:900;color:var(--ink);font-size:14px}
.rev .who small{display:block;font-weight:700;color:var(--mut);font-size:12.5px;margin-top:2px}

/* pricing tickets */
.tickets{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
@media(max-width:920px){.tickets{grid-template-columns:1fr}}
.ticket{background:#fffdf9;border:2px solid var(--ink);border-radius:24px;padding:32px 30px;position:relative;display:flex;flex-direction:column;box-shadow:7px 7px 0 var(--blush2);transition:.2s}
.ticket:hover{transform:translateY(-4px)}
.ticket.featured{box-shadow:7px 7px 0 var(--coral);transform:rotate(-1deg)}
.ticket.featured:hover{transform:rotate(-1deg) translateY(-4px)}
.ticket .size{font-size:12.5px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--coral-d)}
.ticket h3{font-size:26px;margin:8px 0 2px}
.ticket .wt{font-size:13.5px;font-weight:800;color:var(--mut)}
.ticket .amt{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:42px;color:var(--ink);margin:16px 0 2px}
.ticket .amt small{font-size:15px;color:var(--mut);font-weight:700}
.ticket ul{list-style:none;margin:18px 0 24px;display:flex;flex-direction:column;gap:9px;flex:1}
.ticket li{display:flex;gap:10px;font-size:14.5px;align-items:flex-start}
.ticket li svg{width:17px;height:17px;stroke:var(--coral-d);fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto;margin-top:4px}
.ticket .ribbon{position:absolute;top:-15px;right:22px}

/* a la carte table */
.menu-table{width:100%;border-collapse:collapse;background:#fffdf9;border:1.5px solid var(--line);border-radius:var(--r);overflow:hidden}
.menu-table th{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;text-align:left;padding:16px 22px;background:var(--esp);color:var(--d-ink);font-size:14.5px}
.menu-table td{padding:15px 22px;border-top:1.5px solid var(--line);font-size:15px}
.menu-table td:last-child{font-weight:900;color:var(--ink);white-space:nowrap}
.menu-table tr:hover td{background:var(--coral-soft)}
.table-wrap{border-radius:var(--r);overflow:auto}

/* page hero (interior) */
.phero{position:relative;padding:84px 0 64px;background:var(--blush);overflow:hidden}
.phero::after{content:'';position:absolute;right:-130px;top:-130px;width:340px;height:340px;border-radius:50%;background:var(--coral-soft);border:2.5px dashed rgba(232,90,77,.4)}
.phero h1{font-size:clamp(36px,4.6vw,60px);position:relative;z-index:2;max-width:18ch;letter-spacing:-.02em}
.phero .crumb{position:relative;z-index:2;font-size:13px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-d);margin-bottom:14px}
.phero .sub{position:relative;z-index:2;margin-top:16px;max-width:56ch;font-size:17px}
.phero .hero-ctas{position:relative;z-index:2;margin-top:26px}
.prose{max-width:740px}
.prose p{margin-bottom:18px;font-size:16px}
.prose h2{font-size:29px;margin:38px 0 16px}
.prose h3{font-size:21px;margin:28px 0 12px}
.prose ul{margin:0 0 18px 22px}
.prose li{margin-bottom:8px}
.svc-layout{display:grid;grid-template-columns:1fr 330px;gap:56px;align-items:start}
@media(max-width:920px){.svc-layout{grid-template-columns:1fr}}
.price-card{position:sticky;top:104px;background:#fffdf9;border:2px solid var(--ink);border-radius:24px;padding:28px;box-shadow:7px 7px 0 var(--coral);transform:rotate(1deg)}
.price-card h3{font-size:20px;margin-bottom:6px}
.price-card .amt{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:34px;color:var(--coral-d);margin:6px 0 4px}
.price-card p{font-size:13.5px}
.price-card .btn{width:100%;margin-top:16px}
.price-card .note{margin-top:12px;font-size:12.5px;font-weight:700;color:var(--mut)}

/* booking band */
.book-band{background:var(--coral);border-radius:30px;padding:42px 46px;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;box-shadow:0 22px 50px rgba(255,111,97,.3)}
.book-band h3{font-size:clamp(22px,2.6vw,30px);color:#311b15;max-width:24ch}
.book-band p{color:#5a312a;font-weight:700;font-size:14.5px;margin-top:6px}
.book-band .btn-ghost{border-color:#311b15;color:#311b15}
.book-band .btn-ghost:hover{background:#311b15;color:var(--cream)}
.book-band .btn-primary{background:var(--esp);color:var(--d-ink);box-shadow:none}
.book-band .btn-primary:hover{background:var(--esp2);color:var(--d-ink)}

/* FAQ */
.faq{max-width:800px}
.faq details{background:#fffdf9;border:1.5px solid var(--line);border-radius:18px;margin-bottom:12px;overflow:hidden;transition:.15s}
.faq details[open]{border-color:var(--coral)}
.faq summary{cursor:pointer;padding:19px 24px;font-weight:800;color:var(--ink);font-size:15.5px;list-style:none;display:flex;justify-content:space-between;gap:14px;font-family:'Nunito Sans',sans-serif}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--coral-d);font-size:23px;font-weight:600;line-height:1}
.faq details[open] summary::after{content:'\2013'}
.faq .a{padding:0 24px 20px;font-size:15px}
.dark .faq details{background:var(--esp3);border-color:var(--d-line)}
.dark .faq summary{color:var(--d-ink)}

/* forms */
.form-card{background:#fffdf9;border:1.5px solid var(--line);border-radius:28px;padding:36px;max-width:680px;box-shadow:0 20px 50px rgba(43,31,26,.08)}
.form-card label{display:block;font-size:13px;font-weight:900;color:var(--ink);margin:16px 0 7px;letter-spacing:.05em}
.form-card label .req{color:var(--coral-d)}
.form-card input,.form-card select,.form-card textarea{width:100%;background:var(--cream);border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;color:var(--ink);font-family:inherit;font-size:15px;font-weight:600}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3.5px var(--coral-soft)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.check-line{display:flex;gap:11px;align-items:flex-start;margin-top:18px;font-size:14.5px;font-weight:700;color:var(--ink)}
.check-line input{width:auto;margin-top:4px;accent-color:var(--coral)}
.form-msg{margin-top:14px;font-size:14.5px;min-height:20px;font-weight:800}
.form-msg.ok{color:var(--coral-d)}
.promise{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:13.5px;font-weight:800;color:var(--ink)}
.promise svg{width:19px;height:19px;stroke:var(--coral-d);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}

/* CTA band */
.cta-band{background:var(--esp);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;left:-110px;bottom:-110px;width:300px;height:300px;border-radius:50%;border:2.5px dashed rgba(255,111,97,.35)}
.cta-band h2{font-size:clamp(32px,4.2vw,54px);max-width:20ch;margin:0 auto;color:var(--d-ink)}
.cta-band p{margin:18px auto 30px;max-width:52ch;color:var(--d-body)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
@media(max-width:880px){.steps{grid-template-columns:1fr}}
.step{background:#fffdf9;border:1.5px solid var(--line);border-radius:var(--r);padding:30px;position:relative}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:15px;color:#311b15;background:var(--coral);width:42px;height:42px;border-radius:50%;display:grid;place-items:center;margin-bottom:16px}
.step h3{font-size:19px;margin-bottom:8px}
.step p{font-size:14.5px}
.dark .step{background:var(--esp3);border-color:var(--d-line)}

/* misc */
.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.paw-trail{display:flex;gap:18px;justify-content:center;margin:0 auto;opacity:.5}
.paw-trail svg{width:22px;height:22px;fill:var(--coral);transform:rotate(14deg)}
.paw-trail svg:nth-child(even){transform:rotate(-12deg) translateY(7px)}

/* footer */
footer{background:var(--esp2);color:var(--d-body);padding:0 0 110px;font-size:14.5px}
footer .foot-wave{height:46px;line-height:0}
footer .foot-wave svg{display:block;width:100%;height:100%}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-top:54px}
@media(max-width:880px){.foot{grid-template-columns:1fr 1fr}}
.foot h4{font-size:15px;letter-spacing:.06em;margin-bottom:16px;color:var(--d-ink)}
.foot a{display:block;padding:5px 0;color:var(--d-body)}
.foot a:hover{color:var(--coral)}
.foot .about{color:var(--d-mut)}
.foot address{font-style:normal;color:var(--d-body);line-height:1.9}
.copy{margin-top:48px;padding-top:22px;border-top:1px solid var(--d-line);color:var(--d-mut);font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
