/* Ruffin It — shared design system. One file, every page. */
:root{
  --navy:#1B2A4A; --navy-deep:#12203C; --gold:#C9A227; --gold-soft:#E7D9A8;
  --cream:#FBF8F2; --sand:#F3EDDF; --card:#FFFFFF; --ink:#22293A; --muted:#4E5568;
  --line:#E7E1D2; --shadow:0 6px 24px rgba(27,42,74,.08); --r:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;background:var(--cream);color:var(--ink);font-size:19px;line-height:1.65}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
h1,h2,h3,.price{font-family:'Bricolage Grotesque',sans-serif}
h2{font-size:clamp(28px,4vw,38px);font-weight:800;color:var(--navy);line-height:1.15}
h3{color:var(--navy)}
.kicker{font-size:15px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px}
a{color:var(--navy)}
a:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
.btn{display:inline-block;background:var(--gold);color:var(--navy-deep);font-weight:700;padding:15px 28px;border-radius:12px;text-decoration:none;font-size:19px;border:none;cursor:pointer}
.btn:hover{background:#B8931F}
.btn.dark{background:var(--navy);color:#fff}
.btn.dark:hover{background:var(--navy-deep)}
.btn.big{font-size:21px;padding:17px 34px}
.btn.sm{font-size:17px;padding:12px 22px}

/* shell */
.topbar{background:var(--navy-deep);color:#D9DEEA;font-size:16px;padding:9px 0}
.topbar .wrap{display:flex;flex-wrap:wrap;gap:6px 28px;justify-content:space-between;align-items:center}
.topbar a{color:var(--gold-soft);font-weight:700;text-decoration:none;font-size:17px}
nav.site{background:rgba(251,248,242,.95);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
nav.site .wrap{display:flex;align-items:center;gap:26px;padding-top:14px;padding-bottom:14px;flex-wrap:wrap}
.logo{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:25px;color:var(--navy);text-decoration:none}
.logo span{color:var(--gold)}
nav.site ul{display:flex;gap:24px;list-style:none;flex-wrap:wrap}
nav.site ul a{text-decoration:none;font-weight:600;font-size:18px}
nav.site ul a:hover,nav.site ul a.on{color:var(--gold)}
nav.site .cta{margin-left:auto}
footer{background:var(--navy-deep);color:#D9DEEA;padding:52px 0 34px;font-size:18px}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:30px}
footer h4{color:#fff;font-size:18px;margin-bottom:10px}
footer a{color:var(--gold-soft)}
footer ul{list-style:none}
footer li{margin-bottom:8px}
.copyright{margin-top:36px;font-size:15px;color:#8B93A8;display:flex;flex-wrap:wrap;gap:8px 24px;justify-content:space-between}

/* sections */
section{padding:58px 0}
section.tint{background:var(--sand)}
.lede{color:var(--muted);max-width:64ch;margin:10px 0 30px;font-size:20px}
.hero{padding:56px 0 52px}
.hero .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:44px;align-items:center}
.hero h1{font-size:clamp(34px,5vw,54px);font-weight:800;line-height:1.07;color:var(--navy)}
.hero p.sub{font-size:21px;color:var(--muted);margin:18px 0 8px;max-width:52ch}
.hero p.cap{font-size:18px;color:var(--navy);font-weight:600;margin-bottom:24px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:16px;font-weight:600;color:var(--navy);box-shadow:var(--shadow)}
.hero-photo{position:relative}
.hero-img{width:100%;min-height:420px;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow);display:block}
.imgslot{background:linear-gradient(135deg,var(--sand),var(--gold-soft));border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:15px;font-weight:600;text-align:center;padding:12px;box-shadow:var(--shadow);min-height:220px}
.hero-photo .imgslot{min-height:420px}
.float-badge{position:absolute;left:-18px;bottom:26px;background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:16px 20px;max-width:270px}
.float-badge .t{font-weight:800;font-family:'Bricolage Grotesque',sans-serif;font-size:19px;color:var(--navy)}
.float-badge .d{font-size:15px;color:var(--muted);margin-top:2px}

/* capacity strip */
.capacity{background:var(--navy-deep);color:#D9DEEA;padding:20px 0}
.capacity .row{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}
.paws{display:flex;gap:5px;flex-wrap:wrap;max-width:420px}
.paw{width:12px;height:12px;border-radius:50%;background:var(--gold)}
.paw.open{background:transparent;border:1.5px solid var(--gold)}
.capacity strong{color:#fff}

/* cards */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svccard{background:var(--card);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);text-decoration:none;display:block;transition:transform .15s ease}
.svccard:hover{transform:translateY(-3px)}
.svccard .imgslot{border-radius:0;min-height:190px}
.svccard .body{padding:22px}
.svccard h3{font-size:22px}
.svccard .tag{font-size:16px;color:var(--gold);font-weight:700;margin:2px 0 8px}
.svccard p{font-size:17px;color:var(--muted)}
.feat{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:26px}
.featcard{background:var(--card);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.featcard .em{font-size:28px}
.featcard h3{font-size:21px;margin:8px 0 6px}
.featcard p{font-size:17px;color:var(--muted)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}
.step{background:var(--card);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.step .n{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:30px;color:var(--gold)}
.step h3{font-size:21px;margin:8px 0 6px}
.step p{font-size:17px;color:var(--muted)}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:26px}
.duocard{background:var(--card);border-radius:var(--r);padding:28px;box-shadow:var(--shadow)}
.duocard h3{font-size:22px;margin-bottom:8px}
.duocard p{font-size:18px;color:var(--muted)}

/* pricing */
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:10px}
.tier{background:var(--card);border-radius:var(--r);padding:28px;position:relative;box-shadow:var(--shadow)}
.tier.featured{border:3px solid var(--gold)}
.badge{position:absolute;top:-14px;left:22px;background:var(--gold);color:var(--navy-deep);font-size:14px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 14px;border-radius:8px}
.badge.limited{background:var(--navy);color:var(--gold-soft)}
.tier h3{font-size:22px}
.price{font-size:44px;font-weight:800;color:var(--navy)}
.price small{font-size:18px;font-weight:600;color:var(--muted)}
.permo{font-size:17px;color:var(--muted);margin-bottom:12px}
.tier ul{list-style:none;margin-top:6px}
.tier li{padding:8px 0 8px 28px;position:relative;font-size:18px;border-top:1px solid var(--sand)}
.tier li::before{content:"";position:absolute;left:3px;top:16px;width:13px;height:13px;border-radius:50%;background:var(--gold)}
.packrow{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.pack{background:var(--card);border-radius:16px;padding:18px;text-align:center;box-shadow:var(--shadow)}
.pack .price{font-size:28px}
.pack p{font-size:16px;color:var(--muted)}
.dayline{margin-top:20px;border:1px dashed #CFC7B2;border-radius:14px;padding:16px 20px;font-size:18px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px 26px;align-items:baseline}
.dayline b{color:var(--ink);font-size:19px}
.pricecard{background:var(--card);border-radius:var(--r);padding:32px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px;text-align:center}
.pricecard p.lbl{font-size:17px;color:var(--muted)}
.menu{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:26px}
.menucard{background:var(--card);border-radius:var(--r);padding:28px;box-shadow:var(--shadow)}
.menucard h3{font-size:22px}
.menucard .price{font-size:30px;margin:4px 0 8px}
.menucard p{font-size:18px;color:var(--muted)}
.alacarte{margin-top:20px;background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);padding:24px 28px;display:flex;flex-wrap:wrap;gap:12px 40px;font-size:19px}
.alacarte b{color:var(--navy)}

/* tables */
table.peak{width:100%;border-collapse:collapse;margin-top:20px;background:var(--card);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
table.peak th,table.peak td{padding:16px 20px;text-align:left;font-size:18px;border-bottom:1px solid var(--sand)}
table.peak th{background:var(--navy);color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-size:17px}
table.peak tr:last-child td{border-bottom:none}

/* misc */
.ask{background:var(--navy);color:#fff;border-radius:var(--r);padding:38px;box-shadow:var(--shadow)}
.ask h2{color:#fff}
.ask ol{margin:18px 0 10px 22px;font-size:19px;line-height:1.9}
.ask li b{color:var(--gold-soft)}
.ask p.close{color:#D9DEEA;font-size:18px}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}
.review{background:var(--card);border-radius:var(--r);padding:24px;font-size:18px;box-shadow:var(--shadow)}
.stars{color:var(--gold);font-size:20px;letter-spacing:2px}
.review .who{margin-top:12px;font-weight:700;color:var(--navy);font-size:17px}
.review .when{font-size:15px;color:var(--muted)}
.ig{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}
.ig .imgslot{min-height:170px;font-size:14px}
.ctaband{background:var(--navy);border-radius:var(--r);padding:44px;text-align:center;box-shadow:var(--shadow)}
.ctaband h2{color:#fff}
.ctaband p{color:#D9DEEA;max-width:56ch;margin:10px auto 22px;font-size:19px}
.ctaband .fine{font-size:16px;color:var(--gold-soft);margin-top:14px}
.req{columns:2;column-gap:40px;font-size:18px;list-style:none;margin-top:22px}
.req li{margin-bottom:12px;break-inside:avoid}

@media (max-width:880px){
  .hero .wrap{grid-template-columns:1fr}
  .hero-img,.hero-photo .imgslot{min-height:280px}
  .float-badge{left:12px}
  .svc,.steps,.tiers,.packrow,.reviews,.foot-grid,.duo,.pricecard,.menu{grid-template-columns:1fr}
  .feat{grid-template-columns:1fr}
  .ig{grid-template-columns:repeat(2,1fr)}
  nav.site ul{gap:16px}
  .req{columns:1}
  body{font-size:18px}
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.svccard:hover{transform:none}}

/* dropdown nav */
.dd{position:relative}
.dd>a{cursor:pointer}
.dd-menu{display:none;position:absolute;top:100%;left:-10px;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:8px;min-width:230px;z-index:60}
.dd:hover .dd-menu,.dd:focus-within .dd-menu{display:block}
.dd-menu a{display:block;padding:12px 14px;border-radius:8px;font-size:18px;font-weight:600;text-decoration:none}
.dd-menu a:hover{background:var(--sand);color:var(--navy)}
.dd-menu small{display:block;font-size:14px;color:var(--muted);font-weight:400}

/* promo popup */
.promo-overlay{position:fixed;inset:0;background:rgba(18,32,60,.55);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.promo-overlay.show{display:flex}
.promo{background:var(--card);border-radius:var(--r);box-shadow:0 20px 60px rgba(18,32,60,.35);max-width:480px;width:100%;padding:34px 30px;position:relative;text-align:center;border-top:8px solid var(--gold)}
.promo h2{font-size:30px;margin:6px 0 10px}
.promo p{font-size:18px;color:var(--muted)}
.promo .x{position:absolute;top:12px;right:14px;background:none;border:none;font-size:26px;color:var(--muted);cursor:pointer;line-height:1;padding:6px}
.promo .btn{margin-top:18px;width:100%}
.promo .later{display:block;margin-top:12px;font-size:16px;color:var(--muted);background:none;border:none;cursor:pointer;text-decoration:underline}

/* referral */
.miles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.mile{background:var(--card);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);text-align:center}
.mile .m{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:34px;color:var(--gold)}
.mile h3{font-size:20px;margin:6px 0}
.mile p{font-size:16px;color:var(--muted)}
@media (max-width:880px){.miles{grid-template-columns:1fr}.dd-menu{position:static;box-shadow:none;border:none;background:transparent;padding:4px 0 0 14px}}
