/* ============================================================
   Shaheen Honda — Main Stylesheet
   ============================================================ */

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--font-body);font-size:var(--fs-body);
  line-height:1.6;color:var(--text);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;font-weight:700;margin:0;letter-spacing:-.02em}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.5rem)}
.container-wide{max-width:var(--container-wide)}
.section{padding-block:clamp(3.5rem,8vw,7rem)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.section-dark{background:var(--ink);color:var(--on-ink)}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.section-ink{background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);color:var(--on-ink)}
.grid{display:grid;gap:clamp(1rem,2.5vw,2rem)}

/* ---------- Eyebrow / headings ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-display);
  font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:1rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.section-dark .eyebrow{color:var(--gold)}.section-dark .eyebrow::before{background:var(--gold)}
.h2{font-size:var(--fs-h2)}
.lead{font-size:var(--fs-lead);color:var(--text-soft);max-width:60ch}
.section-dark .lead{color:var(--on-ink-soft)}
.text-grad{background:linear-gradient(100deg,var(--red),#ff5a4d 55%,var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-display);font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:.95rem 1.7rem;border-radius:var(--radius-pill);border:1px solid transparent;
  cursor:pointer;transition:transform var(--t-fast) var(--ease),box-shadow var(--t) var(--ease),background var(--t-fast);
  will-change:transform}
.btn svg{width:18px;height:18px}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(120deg,var(--red),var(--red-deep));color:#fff;box-shadow:var(--shadow-red)}
.btn-primary:hover{box-shadow:var(--glow-red)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}
.section-dark .btn-ghost{border-color:var(--glass-line);color:#fff}
.section-dark .btn-ghost:hover{border-color:#fff;background:var(--glass)}
.btn-light{background:#fff;color:var(--ink)}
.btn-lg{padding:1.1rem 2.1rem;font-size:1.05rem}
.btn-block{width:100%}

/* ---------- Header / Nav ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background var(--t),box-shadow var(--t),padding var(--t);
  padding:1.1rem 0}
.site-header.is-scrolled{background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);box-shadow:0 1px 0 var(--line),0 10px 30px -20px rgba(12,17,24,.4);padding:.6rem 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-weight:800;letter-spacing:-.01em}
.brand img{height:46px;width:auto;transition:height var(--t)}
.is-scrolled .brand img{height:40px}
.nav-menu{display:flex;align-items:center;gap:.35rem}
.nav-menu a{position:relative;padding:.55rem .85rem;border-radius:10px;font-weight:500;font-size:.96rem;color:var(--text);transition:color var(--t-fast),background var(--t-fast)}
.nav-menu a::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.35rem;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform var(--t) var(--ease)}
.nav-menu a:hover{color:var(--red)}.nav-menu a:hover::after{transform:scaleX(1)}
.nav-actions{display:flex;align-items:center;gap:.6rem}
.nav-icon{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);color:var(--text);transition:.2s;position:relative}
.nav-icon:hover{border-color:var(--red);color:var(--red)}
.cart-count{position:absolute;top:-4px;right:-4px;min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:var(--red);color:#fff;font-size:.68rem;font-weight:700;display:grid;place-items:center}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);background:none;border-radius:12px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-toggle span{width:22px;height:2px;background:var(--text);transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* hero-dark header variant (transparent over dark hero) */
.header-over-hero:not(.is-scrolled) .nav-menu a,
.header-over-hero:not(.is-scrolled) .brand{color:#fff}
.header-over-hero:not(.is-scrolled) .nav-icon{border-color:var(--glass-line);color:#fff}
.header-over-hero:not(.is-scrolled) .nav-toggle{border-color:var(--glass-line)}
.header-over-hero:not(.is-scrolled) .nav-toggle span{background:#fff}

@media (max-width:560px){
  .nav-actions .btn-primary{display:none}
  .nav-actions .nav-icon[aria-label="Call us"]{display:none}
}
@media (max-width:980px){
  .nav-menu{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:var(--ink);flex-direction:column;
    align-items:stretch;justify-content:flex-start;gap:.2rem;padding:6rem 1.4rem 2rem;transform:translateX(100%);
    transition:transform var(--t) var(--ease);box-shadow:var(--shadow-lg)}
  .nav-menu.open{transform:translateX(0)}
  .nav-menu a{color:#fff!important;padding:.95rem 1rem;font-size:1.1rem;border-bottom:1px solid var(--ink-line)}
  .nav-menu a::after{display:none}
  .nav-toggle{display:flex}
  .nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:.3s;z-index:99}
  .nav-backdrop.open{opacity:1;visibility:visible}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;background:var(--ink);color:#fff;overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-3;background:
  radial-gradient(120% 80% at 80% -10%,rgba(226,0,26,.28),transparent 55%),
  radial-gradient(90% 70% at 0% 110%,rgba(11,63,160,.30),transparent 55%),
  linear-gradient(180deg,#05070b,#0d121b 60%,#05070b)}
.hero__grid{position:absolute;inset:0;z-index:-2;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(100% 80% at 50% 30%,#000 30%,transparent 80%)}
.hero__glow{position:absolute;width:60vw;height:60vw;max-width:760px;max-height:760px;right:-10%;top:-10%;z-index:-2;
  background:radial-gradient(circle,rgba(226,0,26,.5),transparent 60%);filter:blur(40px);opacity:.6}
.hero__inner{padding-top:7rem;padding-bottom:3rem;display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center;width:100%}
.hero__badge{display:inline-flex;align-items:center;gap:.6rem;padding:.5rem 1rem;border-radius:var(--radius-pill);
  background:var(--glass);border:1px solid var(--glass-line);font-size:.82rem;font-weight:500;color:var(--on-ink-soft);margin-bottom:1.6rem;backdrop-filter:blur(10px)}
.hero__badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(21,154,72,.25)}
.hero h1{font-size:var(--fs-hero);letter-spacing:-.03em;margin-bottom:1.2rem}
.hero__urdu{font-family:var(--font-urdu);font-size:clamp(1.4rem,3vw,2.1rem);color:var(--gold);line-height:2;margin-bottom:.4rem;direction:rtl;display:block}
.hero__sub{font-size:var(--fs-lead);color:var(--on-ink-soft);max-width:46ch;margin-bottom:2rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:2.4rem}
.hero__stats{display:flex;gap:2.2rem;flex-wrap:wrap}
.hero__stat .n{font-family:var(--font-display);font-size:2rem;font-weight:800;color:#fff}
.hero__stat .l{font-size:.82rem;color:var(--on-ink-mut);text-transform:uppercase;letter-spacing:.12em}
.hero__visual{position:relative;display:grid;place-items:center;justify-self:center;width:100%}
.hero__bike{width:100%;max-width:560px;filter:drop-shadow(0 40px 60px rgba(0,0,0,.6));animation:floaty 6s var(--ease) infinite;position:relative;z-index:1}
.hero__disc{position:absolute;inset:auto;width:78%;aspect-ratio:1;border-radius:50%;z-index:-1;
  background:radial-gradient(circle,rgba(226,0,26,.35),transparent 62%);filter:blur(10px)}
.hero__ring{position:absolute;width:92%;aspect-ratio:1;border:1px dashed var(--glass-line);border-radius:50%;animation:spin 40s linear infinite}
@keyframes floaty{50%{transform:translateY(-16px)}}
@keyframes spin{to{transform:rotate(360deg)}}
.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-ink-mut)}
.hero__scroll .mouse{width:24px;height:38px;border:2px solid var(--on-ink-mut);border-radius:14px;position:relative}
.hero__scroll .mouse::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;border-radius:2px;background:#fff;transform:translateX(-50%);animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:1;top:7px}70%{opacity:0;top:18px}100%{opacity:0}}
@media (max-width:900px){.hero__inner{grid-template-columns:1fr;text-align:center;padding-top:6rem}
  .hero__cta,.hero__stats{justify-content:center}.hero__sub{margin-inline:auto}.hero__visual{order:-1}.hero__badge{margin-inline:auto}}

/* ---------- 3S strip ---------- */
.threeS{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.s-card{position:relative;border-radius:var(--radius-lg);padding:2.2rem 1.8rem;overflow:hidden;background:var(--paper-2);
  border:1px solid var(--line-soft);box-shadow:var(--shadow-sm);transition:transform var(--t) var(--ease),box-shadow var(--t)}
.s-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.s-card__bar{position:absolute;inset:0 auto 0 0;width:5px}
.s-card .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.1rem;color:#fff}
.s-card h3{font-size:var(--fs-h3);margin-bottom:.5rem}
.s-card p{color:var(--text-muted);margin:0;font-size:.96rem}
.s-card--sales .s-card__bar,.s-card--sales .ico{background:var(--red)}
.s-card--service .s-card__bar,.s-card--service .ico{background:var(--blue)}
.s-card--parts .s-card__bar,.s-card--parts .ico{background:var(--green)}
.s-card .tag{display:inline-block;margin-top:1rem;font-weight:600;font-size:.85rem;color:var(--red)}
.s-card--service .tag{color:var(--blue)}.s-card--parts .tag{color:var(--green)}

/* ---------- Section heading row ---------- */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:2.6rem;flex-wrap:wrap}
.sec-head .lead{margin:0}

/* ---------- Bike lineup ---------- */
.bikes{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem}
.bike-card{position:relative;border-radius:var(--radius-lg);background:linear-gradient(180deg,#fff,#f1f3f6);border:1px solid var(--line-soft);
  padding:1.4rem;overflow:hidden;transition:transform var(--t) var(--ease),box-shadow var(--t);box-shadow:var(--shadow-sm)}
.bike-card::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0,rgba(226,0,26,.10),transparent 70%);opacity:0;transition:opacity var(--t)}
.bike-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.bike-card:hover::before{opacity:1}
.bike-card__img{aspect-ratio:16/10;display:grid;place-items:center;margin-bottom:1rem}
.bike-card__img img{transition:transform var(--t-slow) var(--ease);filter:drop-shadow(0 16px 22px rgba(0,0,0,.18))}
.bike-card:hover .bike-card__img img{transform:scale(1.06) rotate(-1deg)}
.bike-card__cc{position:absolute;top:1rem;right:1rem;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.1em;
  padding:.3rem .7rem;border-radius:999px;background:var(--ink);color:#fff}
.bike-card h3{font-size:1.2rem;margin-bottom:.2rem}
.bike-card .price{color:var(--red);font-weight:700;font-family:var(--font-display);font-size:1.15rem}
.bike-card .price small{color:var(--text-muted);font-weight:500;font-size:.72rem;display:block;letter-spacing:.04em}
.bike-card__row{display:flex;align-items:center;justify-content:space-between;margin-top:.3rem}
.bike-card .arrow{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--paper);border:1px solid var(--line);transition:.25s}
.bike-card:hover .arrow{background:var(--red);color:#fff;border-color:var(--red)}

/* ---------- Parts promo (dark) ---------- */
.parts-promo{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.parts-finder{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius-lg);padding:1.8rem;backdrop-filter:blur(14px)}
.parts-finder h3{color:#fff;margin-bottom:1.2rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{font-size:.8rem;color:var(--on-ink-soft);font-weight:500}
.field select,.field input,.field textarea{width:100%;padding:.85rem 1rem;border-radius:12px;border:1px solid var(--glass-line);
  background:rgba(255,255,255,.04);color:#fff;font-family:inherit;font-size:.98rem;transition:.2s}
.field select:focus,.field input:focus,.field textarea:focus{outline:none;border-color:var(--red);background:rgba(255,255,255,.07)}
.field select option{color:#000}
.chip-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.chip{padding:.5rem 1rem;border-radius:999px;border:1px solid var(--glass-line);font-size:.85rem;color:var(--on-ink-soft);transition:.2s;cursor:pointer}
.chip:hover{border-color:var(--red);color:#fff;background:rgba(226,0,26,.15)}
.parts-promo__list{display:grid;gap:.8rem;margin-top:1.6rem}
.feature-li{display:flex;gap:.8rem;align-items:flex-start;color:var(--on-ink-soft)}
.feature-li .tick{flex:none;width:24px;height:24px;border-radius:50%;background:rgba(21,154,72,.18);color:#37d07a;display:grid;place-items:center;font-size:.8rem}
@media (max-width:860px){.parts-promo,.threeS{grid-template-columns:1fr}}

/* ---------- Why / trust band ---------- */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:center}
.trust__item{padding:1.6rem 1rem;border-radius:var(--radius);background:var(--paper-2);border:1px solid var(--line-soft)}
.trust__item .n{font-family:var(--font-display);font-weight:800;font-size:2.3rem;color:var(--red);line-height:1}
.trust__item .l{color:var(--text-muted);font-size:.92rem;margin-top:.4rem}
@media (max-width:720px){.trust{grid-template-columns:repeat(2,1fr)}}

/* ---------- Booking CTA ---------- */
.cta-band{position:relative;border-radius:var(--radius-xl);overflow:hidden;padding:clamp(2.5rem,5vw,4.5rem);
  background:linear-gradient(120deg,var(--red-deep),var(--red) 55%,#ff4d3d);color:#fff;box-shadow:var(--shadow-lg)}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 90% 10%,rgba(255,255,255,.22),transparent 60%);pointer-events:none}
.cta-band h2{font-size:var(--fs-h2);color:#fff;max-width:18ch;margin-bottom:1rem}
.cta-band p{color:rgba(255,255,255,.9);max-width:52ch}
.cta-band .btn-light{box-shadow:0 12px 30px rgba(0,0,0,.2)}

/* ---------- Showroom / location ---------- */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:center}
.showcase__media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.showcase__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.showcase__media:hover img{transform:scale(1.05)}
.info-list{display:grid;gap:1.1rem;margin-top:1.6rem}
.info-row{display:flex;gap:1rem;align-items:flex-start}
.info-row .ico{flex:none;width:46px;height:46px;border-radius:12px;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center;color:var(--red)}
.info-row b{display:block;font-family:var(--font-display)}
.info-row span{color:var(--text-muted);font-size:.95rem}
@media (max-width:820px){.showcase{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--on-ink-soft);padding-top:clamp(3rem,6vw,5rem)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid var(--ink-line)}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:1.2rem;letter-spacing:.02em}
.site-footer a{color:var(--on-ink-soft);transition:color .2s;font-size:.95rem;display:inline-block;padding:.2rem 0}
.site-footer a:hover{color:#fff}
.footer-brand img{height:54px;margin-bottom:1rem}
.footer-brand p{font-size:.95rem;max-width:34ch}
.foot-links{display:grid;gap:.3rem}
.social{display:flex;gap:.6rem;margin-top:1.2rem}
.social a{width:42px;height:42px;border-radius:50%;border:1px solid var(--ink-line);display:grid;place-items:center;color:#fff}
.social a:hover{background:var(--red);border-color:var(--red)}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.6rem 0;font-size:.85rem;color:var(--on-ink-mut)}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- WhatsApp float ---------- */
.wa-float{position:fixed;right:1.2rem;bottom:1.2rem;z-index:90;width:58px;height:58px;border-radius:50%;
  background:#25D366;display:grid;place-items:center;box-shadow:0 12px 30px rgba(37,211,102,.45);transition:transform .25s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* ---------- Scroll reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.1s}
[data-reveal][data-delay="2"]{transition-delay:.2s}
[data-reveal][data-delay="3"]{transition-delay:.3s}
[data-reveal][data-delay="4"]{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
  .hero__bike,.hero__ring,.hero__scroll .mouse::after{animation:none!important}
}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;padding:9rem 0 3.5rem;background:var(--ink);color:#fff;overflow:hidden}
.page-hero__bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(80% 120% at 85% -20%,rgba(226,0,26,.30),transparent 55%),
  radial-gradient(70% 100% at 0 120%,rgba(11,63,160,.25),transparent 55%),linear-gradient(180deg,#06090e,#0d121b)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);margin-bottom:.8rem}
.page-hero .crumbs{font-size:.85rem;color:var(--on-ink-mut);margin-bottom:1rem}
.page-hero .crumbs a:hover{color:#fff}

/* ---------- Brand wordmark / logo ---------- */
.brand-word{display:flex;flex-direction:column;line-height:1}
.brand-word .bw-1{font-size:1.18rem;letter-spacing:.02em;font-family:var(--font-display);font-weight:800}
.brand-word .bw-2{font-size:.58rem;letter-spacing:.34em;font-weight:600;opacity:.72;font-family:var(--font-body)}
.brand-logo{height:46px;width:auto;transition:height var(--t)}
.is-scrolled .brand-logo{height:40px}

/* ---------- Accessibility helpers ---------- */
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:#fff;color:var(--text);padding:.7rem 1.1rem;border-radius:0 0 10px 0;font-weight:600}
.skip-link:focus{left:0}
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- CTA inner responsive ---------- */
.cta-band__inner{grid-template-columns:1.4fr auto}
@media (max-width:760px){.cta-band__inner{grid-template-columns:1fr}}

/* ---------- Prose ---------- */
.sh-prose{font-size:1.05rem;color:var(--text-soft)}
.sh-prose h2{font-size:var(--fs-h2);margin:1.6rem 0 .8rem;color:var(--text)}
.sh-prose h3{font-size:var(--fs-h3);margin:1.4rem 0 .6rem;color:var(--text)}
.sh-prose p{margin-bottom:1.1rem}
.sh-prose a{color:var(--red);text-decoration:underline;text-underline-offset:3px}
.sh-prose ul{list-style:disc;padding-left:1.3rem;margin-bottom:1.1rem}
.sh-prose li{margin-bottom:.4rem}

/* ---------- Booking ---------- */
.booking-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.5rem;align-items:start}
.booking-aside .feature-li{color:var(--text-soft)}
.booking-aside .tick{background:rgba(21,154,72,.14);color:var(--green)}
.booking-contact{margin-top:1.6rem;display:grid;gap:1rem}
.booking-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--shadow-lg)}
.booking-form .bf-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.2rem}
.booking-form .bf-full{grid-column:1/-1}
.booking-form .field label{color:var(--text-soft);font-weight:600}
.booking-form .field input,.booking-form .field select,.booking-form .field textarea{
  background:var(--paper);border:1px solid var(--line);color:var(--text)}
.booking-form .field input:focus,.booking-form .field select:focus,.booking-form .field textarea:focus{border-color:var(--red);background:#fff;box-shadow:0 0 0 4px rgba(226,0,26,.08)}
.booking-form .field select option{color:#000}
.bf-fine{font-size:.85rem;color:var(--text-muted);text-align:center;margin:.9rem 0 0}
.booking-success{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;box-shadow:var(--shadow-lg);max-width:560px;margin-inline:auto}
.bs-icon{width:66px;height:66px;border-radius:50%;background:rgba(21,154,72,.14);color:var(--green);display:grid;place-items:center;margin:0 auto 1.2rem}
.booking-success h3{font-size:1.5rem;margin-bottom:.6rem}
.booking-success p{color:var(--text-muted);margin-bottom:1.4rem}
@media (max-width:820px){.booking-layout{grid-template-columns:1fr}.booking-form .bf-grid{grid-template-columns:1fr}}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact-card{display:flex;flex-direction:column;gap:.2rem;padding:1.4rem;border-radius:var(--radius);background:var(--paper-2);border:1px solid var(--line-soft);box-shadow:var(--shadow-sm);transition:transform var(--t) var(--ease),box-shadow var(--t)}
a.contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.contact-card .cc-ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff;margin-bottom:.6rem}
.contact-card b{font-family:var(--font-display)}
.contact-card span{color:var(--text-muted);font-size:.92rem}
.contact-map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);min-height:420px}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}.contact-cards{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.contact-cards{grid-template-columns:1fr}}

/* ---------- Contact social row ---------- */
.contact-social{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.contact-social a{padding:.5rem 1.1rem;border-radius:999px;border:1px solid var(--line);font-size:.88rem;font-weight:600;font-family:var(--font-display);color:var(--text-soft);transition:.2s}
.contact-social a:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px)}

/* ---------- FAQ accordion ---------- */
.sh-faq{max-width:840px;margin-inline:auto;display:grid;gap:.8rem}
.sh-faq__item{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-2);box-shadow:var(--shadow-sm);transition:box-shadow var(--t)}
.sh-faq__item[open]{box-shadow:var(--shadow)}
.sh-faq__item summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.4rem;font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--text)}
.sh-faq__item summary::-webkit-details-marker{display:none}
.sh-faq__item[open] summary{color:var(--red)}
.sh-faq__plus{position:relative;flex:none;width:18px;height:18px}
.sh-faq__plus::before,.sh-faq__plus::after{content:"";position:absolute;background:currentColor;border-radius:2px;transition:transform var(--t) var(--ease),opacity var(--t)}
.sh-faq__plus::before{left:0;top:8px;width:18px;height:2px}
.sh-faq__plus::after{left:8px;top:0;width:2px;height:18px}
.sh-faq__item[open] .sh-faq__plus::after{transform:scaleY(0);opacity:0}
.sh-faq__a{padding:0 1.4rem 1.3rem;color:var(--text-soft)}
.sh-faq__a p{margin:0}

/* ---------- Utilities ---------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.center{text-align:center}.mx-auto{margin-inline:auto}
.stack-sm>*+*{margin-top:.6rem}
.split-line{height:1px;background:var(--line);border:0;margin:0}
