:root{
  --bg:#f7f8fb;
  --surface:#ffffff;
  --surface-2:#f3f5fa;
  --border:#e4e8f0;
  --text:#0e1726;
  --muted:#607089;

  --accent:#0ea5e9;     /* blue */
  --accent-2:#7c4dff;   /* violet */
  --warm:#ffe7c2;       /* warm wash */
  --cta:#ff9f43;
  --cta-2:#ff7f11;

  --ring:rgba(14,165,233,.25);
  --radius:16px;
  --shadow:0 10px 30px rgba(14,23,38,.08);
  --shadow-2:0 16px 36px rgba(14,23,38,.12);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;background:
    radial-gradient(900px 500px at -10% -10%, rgba(124,77,255,.08), transparent 60%),
    radial-gradient(900px 500px at 110% 0%, rgba(14,165,233,.10), transparent 60%),
    var(--surface-2);
  color:var(--text);
  font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial;
}
a{text-decoration:none;color:inherit}
.wrap{max-width:1200px;margin:0 auto;padding:18px 24px}
.muted{color:var(--muted)}

/* Topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,#fff,rgba(255,255,255,.94));
  border-bottom:1px solid var(--border);
  backdrop-filter:saturate(140%) blur(6px);
}
.topbar .wrap{display:flex;align-items:center;gap:12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.logo-dot{width:24px;height:24px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 18px rgba(124,77,255,.25)}
.links{margin-left:auto;display:flex;gap:14px}
.links a{color:inherit}
.links a:hover{color:var(--accent-2)}

/* Hero Carousel */
.hero{
  background:
    linear-gradient(135deg, rgba(124,77,255,.06), rgba(14,165,233,.05)),
    var(--surface-2);
  border-bottom:1px solid var(--border);
}
.carousel{
  position:relative;border:1px solid var(--border);border-radius:20px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow)
}
.track{display:flex;transition:transform .4s ease}
.slide{
  min-width:100%;display:grid;grid-template-columns:1fr 1.1fr;gap:18px;align-items:center;padding:22px
}
@media (max-width:900px){.slide{grid-template-columns:1fr}}
.slide .copy h2{
  margin:0 0 8px;font-size:1.6rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent
}
.slide .copy p{margin:0 0 12px;color:var(--muted)}
.slide .actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:12px;border:1px solid #ff9a2b;
  background:linear-gradient(180deg,var(--cta),var(--cta-2));color:#201a10;font-weight:800
}
.btn.alt{
  border:1px solid var(--border);
  background:linear-gradient(180deg,#fff,#f8f9fc);color:#0e1726
}
.slide .visual{
  border:1px solid var(--border);border-radius:16px;overflow:hidden;background:linear-gradient(180deg,#fbfbff,#f4f6ff);
  min-height:200px; /* stable height during lazy load */
}
.slide .visual img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/9}

/* Carousel nav: inside image area, not over text */
.nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:44px;height:44px;border-radius:999px;border:1px solid var(--border);
  background:rgba(255,255,255,.85);backdrop-filter:blur(4px);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:#334155;
  box-shadow:0 6px 18px rgba(14,23,38,.12);
  border-color:rgba(0,0,0,.06);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.nav:hover{background:#fff;transform:translateY(-50%) scale(1.04);box-shadow:0 10px 28px rgba(14,23,38,.16)}
.nav:focus-visible{outline:2px solid var(--ring);outline-offset:2px}
@media (min-width:900px){
  .prev{ left: calc(50% + 18px); } /* aligns with start of .visual column */
  .next{ right:12px; }
}
@media (max-width:899px){
  .prev{ left:6px; }
  .next{ right:6px; }
}
.dots{position:absolute;left:50%;transform:translateX(-50%);bottom:12px;display:flex;gap:8px}
.dots button{
  width:12px;height:12px;border-radius:999px;border:1px solid var(--border);background:#fff;opacity:.6;cursor:pointer
}
.dots button.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));opacity:1}

/* Filters chips */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 8px}
.filters .chip{
  padding:8px 12px;border-radius:999px;border:1px solid #d7dcef;background:#f8faff;color:#3a4a64;cursor:pointer;font-weight:600;font-size:.92rem
}
.filters .chip.active{border-color:var(--accent);background:rgba(14,165,233,.1);color:#0e7490}

/* Collections (horizontal rows) */
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:22px 0 12px}
.section-head h3{margin:0;font-size:1.15rem}
.section-head a{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:10px;border:1px solid var(--border);
  background:linear-gradient(180deg,#fff,#f8f9fc);
  color:var(--text);font-weight:600;font-size:.9rem;text-decoration:none;opacity:.9;
  transition: box-shadow .15s ease, border-color .15s ease, opacity .15s ease;
}
.section-head a:hover{opacity:1;border-color:#d7dcef;box-shadow:0 4px 12px rgba(14,23,38,.08)}
.section-head a:focus-visible{outline:2px solid var(--ring);outline-offset:2px}

.row{
  display:grid;grid-auto-flow:column;grid-auto-columns:260px;gap:14px;overflow:auto;padding-bottom:6px;
  scrollbar-width:none;-ms-overflow-style:none;overscroll-behavior-x:contain;scroll-snap-type:x proximity;
}
.row::-webkit-scrollbar{display:none}
.row > *{scroll-snap-align:start}

.card-h{
  display:grid;grid-template-columns:110px 1fr;gap:12px;
  background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:10px;min-height:120px
}
.card-h .thumb{display:grid;place-items:center;border-radius:12px;background:linear-gradient(180deg,#fbfbff,#f4f6ff);overflow:hidden}
.card-h img{width:100%;height:100%;object-fit:contain;aspect-ratio:1/1}
.card-h .title{margin:0 0 6px;font-size:1rem}
.card-h .brand-line{color:var(--muted)}
.card-h .meta{display:flex;gap:10px;align-items:center}
.card-h .price{
  font-weight:800;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent
}

/* Tags (rows + grid) */
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.tags .chip{padding:5px 8px;border-radius:999px;border:1px solid #e0e3ec;background:#f8faff;color:#556070;font-size:.8rem}

/* Gallery grid */
.gallery{margin-top:10px}
.gallery-head{display:flex;align-items:center;justify-content:space-between;margin:16px 0 8px}
.select{padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#fff;outline:none}
.grid{display:grid;gap:14px}
@media (min-width:700px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1050px){.grid{grid-template-columns:repeat(3,1fr)}}

.card{
  background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);
  transition:transform .2s, box-shadow .2s, border-color .2s;overflow:hidden
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:#d7dcef}
.card .thumb{display:grid;place-items:center;background:linear-gradient(180deg,#fbfbff,#f4f6ff)}
.card .thumb img{width:100%;height:100%;object-fit:contain;aspect-ratio:4/3}
.card .body{padding:12px 14px 14px}
.card .title{margin:0 0 6px;font-size:1.02rem}
.card .brand-line{color:var(--muted)}
.card .meta{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.card .price{font-weight:800;color:#0e1726}
.badge{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.72rem;background:linear-gradient(135deg,#ffd27a,#ffb300);color:#2d2100;padding:5px 9px;border-radius:999px;border:1px solid #f2c25c}

/* Bigger, centered CTA only for grid (Browse All) */
.gallery .card .btn.cta{
  display:block;
  margin:12px auto 0;
  padding:12px 16px;
  min-width:140px;
  border-radius:12px;
  font-weight:800;
  text-align:center;
}
@media (max-width:700px){
  .gallery .card .btn.cta{width:100%}
}

/* Keep small/clean CTAs in row cards even if classes leak in */
.card-h .btn,
.card-h [data-url].btn,
.card-h [data-url].cta{
  background:none !important;
  border:0 !important;
  padding:0 !important;
  box-shadow:none !important;
  color:inherit !important;
}

/* Hide all rating stars sitewide (JS may still generate them) */
[data-stars], .stars{display:none !important}

/* Accessibility focus */
.btn:focus-visible, .filters .chip:focus-visible{outline:2px solid var(--ring);outline-offset:2px}

/* Lazy-load shimmer placeholders (triggered while 1x1 gif placeholder is set) */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.card .thumb, .card-h .thumb, .slide .visual{background-size:200% 100%}
.card .thumb{
  position:relative;
  background:linear-gradient(90deg, rgba(14,165,233,.06) 25%, rgba(14,165,233,.12) 37%, rgba(14,165,233,.06) 63%) #f3f5fa
}
.card .thumb:has(img[src^="data:image/gif"]){animation:shimmer 1.2s linear infinite}
.card-h .thumb{
  position:relative;
  background:linear-gradient(90deg, rgba(124,77,255,.06) 25%, rgba(124,77,255,.12) 37%, rgba(124,77,255,.06) 63%) #f3f5fa
}
.card-h .thumb:has(img[src^="data:image/gif"]){animation:shimmer 1.2s linear infinite}
.slide .visual{
  position:relative;
  background:linear-gradient(90deg, rgba(124,77,255,.05) 25%, rgba(14,165,233,.10) 37%, rgba(124,77,255,.05) 63%) #f3f5fa
}
.slide .visual:has(img[src^="data:image/gif"]){animation:shimmer 1.3s linear infinite}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .track{transition:none}
  .card, .nav{transition:none}
  .card:hover{transform:none;box-shadow:var(--shadow)}
  .row, .card .thumb, .card-h .thumb, .slide .visual{animation:none !important}
}

/* Footer */
.foot{border-top:1px solid var(--border);background:linear-gradient(180deg,#fff,#f6f8fb)}
.foot small{color:#6b778c}

/* Make rail "View" look like a real button (without affecting other links) */
.card-h .btn.view-link{
  background: linear-gradient(180deg, var(--cta), var(--cta-2)) !important;
  border: 1px solid #ff9a2b !important;
  color: #201a10 !important;
  padding: 8px 10px !important;
  border-radius: 10px !important;
  font-weight: 800 !important;
  box-shadow: var(--shadow) !important;
}
.card-h .btn.view-link:hover{ box-shadow: var(--shadow-2) !important; transform: translateY(-1px); }
.card-h .btn.view-link:focus-visible{ outline: 2px solid var(--ring); outline-offset: 2px; }

/* Make Browse All buttons full card width (inside 14px gutters) */
.gallery .card{
  position: relative;
  padding-bottom: 72px;           /* room for the fixed button */
}

.gallery .card .btn.cta{
  position: absolute;
  bottom: 14px;
  left: 14px;                     /* match card’s inner gutter */
  right: 14px;                    /* match card’s inner gutter */
  margin: 0;
  width: auto;                    /* spans full width between gutters */
  transform: none;                /* override earlier centering */
  display: block;
}

/* (Optional) If you want true edge-to-edge, use this instead of left/right 14px:
.gallery .card .btn.cta{ left:0; right:0; }
*/

/* Rails (horizontal cards) — white background behind loaded images */
.card-h .thumb{ background:#fff !important; }

/* Keep the shimmer gradient ONLY while lazy placeholder is visible */
.card-h .thumb:has(img[src^="data:image/gif"]){
  background:linear-gradient(90deg, rgba(124,77,255,.06) 25%, rgba(124,77,255,.12) 37%, rgba(124,77,255,.06) 63%) #f3f5fa !important;
}

/* Rails: reserve space so the bottom-fixed View button doesn't cover chips */
.card-h{ 
  position: relative;
  padding-bottom: 68px;            /* space for the button (≈44px high) + breathing room */
}

/* Pin the rail View button to the bottom-left of the right column */
.card-h .view-link{
  position: absolute;
  bottom: 12px;
  left: calc(10px + 110px + 12px); /* card left padding + thumb width + grid gap */
  z-index: 1;
  /* If you want it to span the right column, also add: right: 12px; display:block; text-align:center; */
}

/* Rails: make the View button cover the full bottom of each card */
.row .card-h{
  position: relative;
  /* reserve space for the bottom button so it doesn't cover chips/text */
  padding-bottom: 82px; /* tweak 72–90px if you want tighter/looser */
}

.row .card-h .view-link{
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  display: block;
  width: auto;            /* fills between left/right */
  text-align: center;
  padding: 12px 16px !important;
  border-radius: 12px !important;
  border: 1px solid #ff9a2b !important;
  background: linear-gradient(180deg,var(--cta),var(--cta-2)) !important;
  color: #201a10 !important;
  font-weight: 800;
  box-shadow: var(--shadow);
  z-index: 1;
}

/* Slides: remove baseline gap so image fills the visual area */
.slide .visual{ line-height:0; }
.slide .visual img{
  display:block;          /* kill the baseline gap */
  width:100%;
  height:100%;
  object-fit:cover;
  /* optional: drop aspect-ratio if you set it earlier */
  aspect-ratio:auto;
}

@media (min-width: 1100px){
  .slide{ grid-template-columns: .65fr 1.35fr; }  /* ~32% / 68% split */
}

/* ===== About page (Site 2) ===== */
.about-page .about-hero{
  display:grid;grid-template-columns:1.2fr 1fr;gap:22px;align-items:center;
  border:1px solid var(--border);border-radius:20px;background:var(--surface);
  box-shadow:var(--shadow);padding:22px;
}
@media (max-width:900px){.about-page .about-hero{grid-template-columns:1fr}}
.about-page .about-hero .visual{
  border:1px solid var(--border);border-radius:16px;overflow:hidden;
  background:linear-gradient(180deg,#fbfbff,#f4f6ff);min-height:220px;
}
.about-page .about-hero .visual img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/9}
.about-page h1{
  margin:0 0 8px;font-size:1.8rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.about-page .lede{color:var(--muted);margin:0 0 14px}
.about-page .section{margin:28px 0 8px}
.about-page .section .grid{margin-top:12px}
.about-page .card ul{margin:8px 0 0 18px}
.about-page .step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  font-weight:800;margin-right:8px;font-size:.9rem;
}
.about-page .cta-band{
  margin:26px 0 10px;padding:18px;border:1px solid var(--border);border-radius:16px;
  background:linear-gradient(180deg,#fff,#f8f9fc);display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.about-page .cta-band p{margin:0;color:var(--muted)}
@media (max-width:700px){.about-page .cta-band{flex-direction:column;align-items:flex-start}}

/* ===== Site 2 • Contact page ===== */
.contact-page .contact-hero{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:22px;
  align-items:center;
  border:1px solid var(--border);
  border-radius:20px;
  background:var(--surface);
  box-shadow:var(--shadow);
  padding:22px;
}
@media (max-width:900px){ .contact-page .contact-hero{ grid-template-columns:1fr; } }
.contact-page .contact-hero .visual{
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  background:linear-gradient(180deg,#fbfbff,#f4f6ff);
  min-height:220px;
}
.contact-page .contact-hero .visual img{
  width:100%; height:100%; object-fit:cover; aspect-ratio:16/9;
}
.contact-page h1{
  margin:0 0 8px; font-size:1.8rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.contact-page .lede{ color:var(--muted); margin:0 0 14px; }

/* Back to Top */
.back-to-top{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 60;
  width: 44px; height: 44px;
  display: none;                /* hidden until scrolled */
  align-items: center; justify-content: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: linear-gradient(180deg,#fff,#f8f9fc);
  box-shadow: var(--shadow);
  color: #334155;
  cursor: pointer;
}
.back-to-top.show{ display: inline-flex; }
.back-to-top:focus-visible{ outline:2px solid var(--ring); outline-offset:2px; }

/* Nice-to-have: smooth anchor/scroll globally */
html { scroll-behavior: smooth; }

/* Center footer content (Site 2 + Site 3) */
footer.foot {
  text-align: center;
}

footer.foot .wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px; /* space between the small text and links */
}

footer.foot small {
  display: block; /* ensures it breaks onto its own line */
}

footer.foot .foot-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center; /* center the link row */
  gap: 8px;
}

footer.foot .foot-links span[aria-hidden="true"] {
  opacity: 0.6; /* subtle separators */
}

/* MOBILE FIX: Slide cards should fit screen width */
@media (max-width: 500px) {
  .slide-card {
    max-width: 88% !important;
    margin-left: auto;
    margin-right: auto;
  }

  /* Reduce horizontal padding in slider wrapper */
  .rail-inner {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/* === Showcase legal pages (Affiliate / Privacy / Terms) === */
body.legal-page main.wrap {
  padding: 24px 0 40px;
  max-width: 720px;
}

/* Give headings a consistent rhythm */
body.legal-page main.wrap h1 {
  margin-bottom: 8px;
}

body.legal-page main.wrap h2 {
  margin-top: 22px;
}

/* Extra breathing room on narrow screens */
@media (max-width: 640px) {
  body.legal-page main.wrap {
    padding-left: 20px;
    padding-right: 20px;
  }
}



/* ===== Rail arrows (Showcase collections) ===== */

.rail-wrap {
  position: relative;
}

.rail-scroller {
  padding: 0 54px; /* space for arrows */
}

/* the arrow buttons */
.rail-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;

  width: 42px;
  height: 42px;
  border-radius: 999px;

  border: 1px solid rgba(0, 0, 0, 0.12);
  background: rgba(255, 255, 255, 0.92);

  display: flex;
  align-items: center;
  justify-content: center;

  font-size: 24px;
  line-height: 1;
  cursor: pointer;

  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
  opacity: 0.95;
}

.rail-arrow--left { left: 10px; }
.rail-arrow--right { right: 10px; }

.rail-arrow:disabled {
  cursor: default;
  opacity: 0.35;
}

/* optional: only show arrows on hover (desktop only) */
@media (hover: hover) and (pointer: fine) {
  .rail-arrow { opacity: 0; pointer-events: none; }
  .rail-wrap:hover .rail-arrow { opacity: 0.95; pointer-events: auto; }
}

/* hide arrows on mobile (swipe already works) */
@media (max-width: 768px) {
  .rail-arrow { display: none; }
  .rail-scroller { padding: 0; }
}