/* R Ranch Enterprises WARM EDITORIAL pack. Fraunces + Inter. Western leather + cream + turquoise. */
:root{
  --ink:#241b13; --leather:#7a4a24; --leather-deep:#5a3719;
  --accent:#0e8a7f; --accent-deep:#0b6b62; --gold:#bd9230;
  --cream:#f7f0e1; --card:#fffdf8; --sand:#efe5cf; --line:#e4d8bf;
  --muted:#6e6253; --shadow:0 10px 30px rgba(60,40,18,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:'Inter',system-ui,sans-serif;font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,.disp{font-family:'Fraunces',Georgia,serif;font-weight:600;letter-spacing:-.01em;line-height:1.08}
a{color:var(--accent-deep);text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
.eyebrow{font-family:'Inter';font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--accent-deep)}
.rule{height:1px;background:var(--line);border:0;margin:0}
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:15px;padding:13px 22px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:transform .15s ease, background .15s, color .15s, box-shadow .15s;will-change:transform}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--leather)}
.btn-ghost:hover{background:var(--leather);color:#fff}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-light:hover{border-color:var(--leather)}
.icon{width:1.15em;height:1.15em;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}

/* Header */
.topbar{background:var(--leather-deep);color:#f3e7d2;font-size:13px}
.topbar .wrap{display:flex;flex-wrap:wrap;gap:6px 20px;align-items:center;justify-content:space-between;padding:8px 22px}
.topbar a{color:#f3e7d2}
.topbar .tb-item{display:inline-flex;align-items:center;gap:7px}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:#7fd1c6;box-shadow:0 0 0 3px rgba(127,209,198,.25)}
header.site{position:sticky;top:0;z-index:50;background:rgba(247,240,225,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 22px;max-width:1140px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.brandmark{width:46px;height:46px;flex:0 0 auto}
.brand .bn{font-family:'Fraunces';font-weight:600;font-size:21px;line-height:1;color:var(--ink)}
.brand .bs{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.navlinks{display:flex;align-items:center;gap:26px}
.navlinks a{color:var(--ink);font-weight:500;font-size:15px}
.navlinks a:hover{color:var(--accent-deep)}
.nav .navcta{display:inline-flex}
.burger{display:none;background:none;border:0;cursor:pointer;padding:6px}
.burger svg{width:28px;height:28px;stroke:var(--ink)}
.mobnav{display:none;background:var(--card);border-bottom:1px solid var(--line)}
.mobnav a{display:block;padding:13px 22px;color:var(--ink);border-top:1px solid var(--line);font-weight:500}
@media(max-width:860px){
  .navlinks{display:none}
  .nav .navcta{display:none}
  .burger{display:block}
  .mobnav.open{display:block}
}

/* Hero */
.hero{position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch}
.hero-copy{padding:64px 22px 56px;max-width:600px;margin-left:auto}
.hero h1{font-size:clamp(38px,5.6vw,62px);margin:14px 0 18px}
.hero h1 .tq{color:var(--accent-deep);font-style:italic}
.hero p.lede{font-size:19px;color:#4a3f31;max-width:520px}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.hero-media{position:relative;min-height:420px}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-media .scrim{position:absolute;inset:0;background:linear-gradient(90deg,var(--cream) 0%,rgba(247,240,225,.2) 22%,transparent 45%)}
.float-card{position:absolute;background:rgba(255,253,248,.96);border:1px solid var(--line);border-radius:13px;padding:12px 15px;box-shadow:var(--shadow);display:flex;align-items:center;gap:11px}
.float-card .big{font-family:'Fraunces';font-weight:600;font-size:20px;line-height:1}
.float-card .sm{font-size:11.5px;color:var(--muted);letter-spacing:.02em}
.float-rating{left:-26px;bottom:34px}
.float-trust{right:18px;top:26px}
.stars{color:var(--gold);letter-spacing:1px;font-size:14px}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr}
  .hero-copy{padding:40px 22px 30px;margin:0;max-width:none}
  .hero-media{min-height:340px;order:-1}
  .hero-media .scrim{background:linear-gradient(0deg,var(--cream),transparent 55%)}
  .float-rating{left:14px;bottom:14px}
  .float-trust{right:14px;top:14px}
}

/* Shipping banner */
.shipbar{background:var(--accent);color:#fff;overflow:hidden}
.shipbar .shiptrack{display:flex;white-space:nowrap;animation:scroll 13s linear infinite;will-change:transform}
.shipbar span{padding:9px 0;font:700 12px/1 Inter;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center}
.shipbar span::after{content:"\2605";color:rgba(255,255,255,.6);font-size:9px;margin:0 18px}
@media(prefers-reduced-motion:reduce){.shipbar .shiptrack{animation:none;justify-content:center}}

/* Marquee */
.marquee{background:var(--leather);color:#f6ead4;overflow:hidden;border-top:1px solid var(--leather-deep);border-bottom:1px solid var(--leather-deep)}
.marquee .track{display:flex;gap:0;white-space:nowrap;animation:scroll 18s linear infinite;will-change:transform}
.marquee span{padding:13px 26px;font-family:'Fraunces';font-style:italic;font-size:17px;display:inline-flex;align-items:center;gap:26px}
.marquee span::after{content:"✦";color:var(--gold);font-style:normal;font-size:12px}
@keyframes scroll{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee .track{animation:none}}

/* Sections */
section{padding:70px 0}
.sec-intro{max-width:720px}
.sec-intro h2{font-size:clamp(28px,4vw,40px);margin:10px 0 14px}
.sec-intro p{color:#4a3f31;font-size:18px}
.dropcap::first-letter{font-family:'Fraunces';font-weight:600;float:left;font-size:62px;line-height:.8;padding:6px 12px 0 0;color:var(--leather)}

/* Department / product cards with 3D tilt */
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
@media(max-width:860px){.cardgrid{grid-template-columns:1fr}}
.tilt{perspective:900px}
.tilt-card{display:flex;flex-direction:column;height:100%;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);transition:transform .18s ease, box-shadow .2s;transform-style:preserve-3d;will-change:transform;position:relative}
.tilt-card:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.tilt-card .glare{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at var(--gx,50%) var(--gy,0%), rgba(255,255,255,.35), transparent 45%);opacity:0;transition:opacity .2s;mix-blend-mode:soft-light}
.tilt-card.lift .glare{opacity:1}
.tilt-card .ph{height:178px;overflow:hidden;background:var(--sand)}
.tilt-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.tilt-card:hover .ph img{transform:scale(1.05)}
.tilt-card .body{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1 1 auto;transform:translateZ(30px)}
.tilt-card .ic{width:38px;height:38px;border-radius:9px;background:var(--sand);display:flex;align-items:center;justify-content:center;color:var(--leather);margin-bottom:12px}
.tilt-card .ic .icon{width:21px;height:21px;stroke-width:1.8}
.tilt-card h3{font-size:21px;margin:0 0 7px}
.tilt-card p{margin:0 0 16px;color:#52483a;font-size:15px;line-height:1.55}
.tilt-card .go{margin-top:auto;display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--accent-deep);font-size:15px}
.tilt-card .go .icon{width:17px;height:17px;transition:transform .2s}
.tilt-card:hover .go .icon{transform:translateX(4px)}
.feat-note{font-size:13px;color:var(--muted);margin-top:14px;display:inline-flex;align-items:center;gap:8px}
@media(hover:none){.feat-note{display:none}}

/* feature bullets */
.bullets{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:36px}
@media(max-width:860px){.bullets{grid-template-columns:1fr}}
.bullet .ic{width:44px;height:44px;border-radius:10px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--accent-deep);margin-bottom:12px}
.bullet h3{font-size:19px;margin:0 0 6px}
.bullet p{margin:0;color:#52483a;font-size:15.5px}

/* Signature service band */
.signature{background:var(--leather-deep);color:#f4e9d6}
.signature .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.signature h2{color:#fff;font-size:clamp(26px,3.6vw,38px)}
.signature .eyebrow{color:#8fd8cd}
.signature p{color:#e7d9c2}
.signature .pts{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:12px}
.signature .pts li{display:flex;gap:11px;align-items:flex-start;font-size:16px}
.signature .pts .icon{color:#7fd1c6;margin-top:3px}
.signature-card{background:rgba(255,253,248,.06);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:26px}
.signature-card .num{font-family:'Fraunces';font-size:46px;color:#fff;line-height:1}
.signature-card .lbl{color:#cdbb9f}
@media(max-width:860px){.signature .wrap{grid-template-columns:1fr;gap:26px}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:34px;counter-reset:s}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:24px 18px;background:var(--card);border:1px solid var(--line);border-radius:13px}
.step .n{font-family:'Fraunces';font-size:15px;font-weight:600;width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.step h3{font-size:18px;margin:0 0 6px}
.step p{margin:0;font-size:14.5px;color:#52483a}

/* gallery */
.gallery{columns:3;column-gap:14px}
@media(max-width:860px){.gallery{columns:2}}
@media(max-width:520px){.gallery{columns:1}}
.gallery img{width:100%;margin:0 0 14px;border-radius:12px;border:1px solid var(--line);break-inside:avoid}

/* reviews */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}
@media(max-width:860px){.rev-grid{grid-template-columns:1fr}}
.rev{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;height:100%}
.rev .stars{margin-bottom:10px}
.rev p{margin:0 0 16px;font-size:15.5px;color:#3f3528;line-height:1.6}
.rev .who{margin-top:auto;display:flex;align-items:center;gap:11px}
.rev .av{width:38px;height:38px;border-radius:50%;background:var(--leather);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Fraunces';font-size:16px}
.rev .nm{font-weight:600;font-size:14.5px}
.rev .dt{font-size:12.5px;color:var(--muted)}
.carousel{overflow:hidden;margin-top:26px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.carousel .ctrack{display:flex;gap:18px;width:max-content;animation:rev 46s linear infinite}
.carousel:hover .ctrack{animation-play-state:paused}
.carousel .rev{width:340px;flex:0 0 auto}
@keyframes rev{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.carousel .ctrack{animation:none;overflow-x:auto}}

/* story */
.story{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
@media(max-width:860px){.story{grid-template-columns:1fr;gap:26px}}
.story img{border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow);width:100%}

/* faq */
.faq{max-width:820px;margin-top:30px}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{cursor:pointer;list-style:none;font-family:'Fraunces';font-weight:600;font-size:19px;padding:16px 40px 16px 0;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:14px;font-size:24px;color:var(--accent-deep);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:0 0 16px;color:#52483a;font-size:16px}

/* CTA band */
.cta{background:linear-gradient(135deg,var(--accent-deep),#0a544c);color:#eafffb;text-align:center}
.cta h2{color:#fff;font-size:clamp(28px,4vw,42px)}
.cta p{color:#cdeee9;max-width:560px;margin:14px auto 0;font-size:18px}
.cta .cta-row{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.cta .btn-primary{background:#fff;color:var(--accent-deep)}
.cta .btn-primary:hover{background:#eafffb}
.cta .btn-ghost{border-color:rgba(255,255,255,.6);color:#fff}
.cta .btn-ghost:hover{background:rgba(255,255,255,.12)}

/* footer */
footer.site{background:var(--ink);color:#d9ccb8;padding:56px 0 26px;font-size:15px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
@media(max-width:860px){footer.site .cols{grid-template-columns:1fr;gap:24px}}
footer.site h4{font-family:'Fraunces';color:#fff;font-size:18px;margin:0 0 14px}
footer.site a{color:#d9ccb8}
footer.site a:hover{color:#fff}
footer.site .frow{display:flex;gap:9px;margin:8px 0;align-items:flex-start}
footer.site .frow .icon{color:var(--gold);margin-top:3px}
footer.site ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
footer.site .hours{display:grid;grid-template-columns:auto auto;gap:4px 16px;font-size:14px}
footer.site .hours .d{color:#bcae98}
footer.site .legal{border-top:1px solid #3a2f22;margin-top:34px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;color:#a89a83;font-size:13px}

/* page hero (inner) */
.phead{background:var(--sand);border-bottom:1px solid var(--line);padding:46px 0 40px}
.phead h1{font-size:clamp(32px,4.6vw,48px);margin:10px 0 10px}
.phead p{color:#52483a;max-width:660px;font-size:18px;margin:0}
.crumb{font-size:13px;color:var(--muted)}
.crumb a{color:var(--muted)}

/* detail layout */
.detail{display:grid;grid-template-columns:1.5fr .9fr;gap:40px;align-items:start}
@media(max-width:860px){.detail{grid-template-columns:1fr;gap:28px}}
.detail .lead{font-size:19px;color:#4a3f31}
.specs{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:24px 0}
.specs .row{background:var(--card);padding:14px 18px;display:grid;grid-template-columns:150px 1fr;gap:14px}
.specs .k{font-weight:600;color:var(--leather);font-size:14px}
.specs .v{font-size:15.5px;color:#3f3528}
.includes{list-style:none;padding:0;margin:18px 0;display:grid;gap:11px}
.includes li{display:flex;gap:10px;align-items:flex-start;font-size:16px}
.includes .icon{color:var(--accent-deep);margin-top:3px}
.aside{position:sticky;top:96px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:var(--shadow)}
.aside h3{font-size:21px;margin:0 0 6px}
.aside .ph{font-family:'Fraunces';font-size:24px;color:var(--accent-deep);margin:10px 0}
.minirev{margin-top:18px;border-top:1px dashed var(--line);padding-top:16px}
.minirev .stars{font-size:13px}
.minirev p{font-size:14.5px;color:#52483a;margin:6px 0 4px}
.minirev .nm{font-size:13px;color:var(--muted)}

/* audio */
.podwrap{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:var(--shadow);margin:30px 0;display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.podwrap .pico{width:54px;height:54px;border-radius:12px;background:var(--leather);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.podwrap audio{width:100%;max-width:420px;margin-top:6px}
.article{max-width:760px;margin:0 auto}
.article h2{font-size:clamp(24px,3.4vw,32px);margin:38px 0 12px}
.article h3{font-size:22px;margin:28px 0 8px}
.article p{margin:0 0 18px;font-size:17.5px;color:#352c20}
.article ul{margin:0 0 18px;padding-left:22px}
.article li{margin:7px 0}
.article .lead{font-size:21px;color:#42382a}

.float-trust .big,.float-trust .sm{display:block}

/* Global cart — floating button + drawer, available on every page */
.sheet-x{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:20px;line-height:1;color:var(--muted);cursor:pointer;z-index:2}
.drawer-wrap{position:fixed;inset:0;z-index:85;display:none}
.drawer-wrap.show{display:block}
.drawer-back{position:absolute;inset:0;background:rgba(36,27,19,.55)}
.drawer{position:absolute;top:0;right:0;height:100%;width:min(420px,92vw);background:var(--cream);box-shadow:-10px 0 40px rgba(0,0,0,.25);display:flex;flex-direction:column;padding:18px;overflow-y:auto;overflow-x:hidden}
.dhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dhead h3{font-family:'Fraunces';font-weight:600;font-size:22px;color:var(--ink)}
.dhead .sheet-x{position:static}
.ditems{flex:0 0 auto}
.crow{display:flex;gap:11px;padding:12px 0;border-bottom:1px solid var(--line)}
.crow img{width:60px;height:60px;border-radius:9px;object-fit:cover;flex:0 0 auto}
.cmid{flex:1;min-width:0}
.cn{font:600 14.5px Inter;color:var(--ink)}
.cmeta{font-size:11.5px;color:var(--muted);margin-top:1px}
.cmax{color:#b4452e !important}
.cqty{display:flex;align-items:center;gap:6px;margin-top:6px}
.cqty button{width:24px;height:24px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer}
.cqty button:disabled{opacity:.4;cursor:default}
.cqty span{width:24px;text-align:center;font-weight:700;font-size:13px}
.cp{font-family:'Fraunces';font-weight:600;color:var(--ink);white-space:nowrap}
.cempty{color:var(--muted);text-align:center;padding:36px 0}
.ctot{display:flex;justify-content:space-between;font-family:'Fraunces';font-weight:600;font-size:18px;color:var(--ink);padding-top:14px;margin-top:6px;border-top:1px solid var(--line)}
.cnote{font-size:11.5px;color:var(--muted);margin-top:6px;line-height:1.4}
.cart-fab{position:fixed;right:16px;bottom:16px;z-index:70;display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;border:0;border-radius:999px;padding:13px 20px;font:700 14px Inter;cursor:pointer;box-shadow:0 8px 24px rgba(14,138,127,.4)}
.cart-fab svg{width:20px;height:20px}
.cart-fab b{background:#fff;color:var(--accent-deep);border-radius:999px;min-width:20px;height:20px;display:grid;place-items:center;font-size:12px;padding:0 5px}
#cart-drawer *{box-sizing:border-box}
