:root{
  --bg:#0f1115; --panel:#161a22; --muted:#9fb0c3; --accent:#62d98a; --text:#e7eef7;
  --ink:#121417; --line:#242b33; --btn:#2a3242; --star:#f4c150; --danger:#ff6b6b;
  --radius:18px; --shadow:0 10px 30px rgba(0,0,0,.25); --shadow-soft:0 6px 18px rgba(0,0,0,.18);
  --maxw:1200px; --gap:22px; --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --cols: 3;
}
*{ box-sizing:border-box }
body{ margin:0; background:var(--bg); color:var(--text); font:17px/1.55 var(--font) }
a{ color:var(--accent); text-decoration:none } a:hover{ text-decoration:underline }

.site-head-wrap{ position:sticky; top:0; z-index:50; backdrop-filter: blur(6px); background: rgba(15,17,21,0.85); border-bottom:1px solid var(--line) }
.site-head{ max-width: var(--maxw);
    margin: 0 auto;
    padding: 0px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
}


.header-search{ flex:1; display:flex; align-items:center }
.header-search input{
width: 100%;
    background: #fff;
    color: #333;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 12px 16px;
    font: inherit;
    outline: none;
    background: #fff url(https://ghosttogether.net/loom/magnify.png);
    background-size: 21px;
    background-repeat: no-repeat;
    background-position: 17px 16px;
    padding-left: 50px;
}
.header-search input::placeholder{ color:#666 }
.header-search input:focus{ border-color:#3b82f6; box-shadow:0 0 0 3px rgba(59,130,246,.15) }
.header-actions{ display:flex; align-items:center; gap: 0px }
.header-pill{ position:relative; display:inline-flex; align-items:center; justify-content:center; gap:10px; border:1px solid var(--line); border-radius:999px; padding:10px 16px; font-size:16px; color:var(--text); text-decoration:none; font-weight:500; min-height:40px; line-height:1; background:#0c1016 }
.checkout-link{ background:#fff; color:#333; border-color:#ddd }
.checkout-link.hidden{ display:none }
.cart-icon{ font-size:20px }
.cart-badge{ position:absolute; top:-8px; right:-8px; min-width:24px; height:24px; border-radius:999px; background:#e11d48; color:#fff; font-size:14px; font-weight:700; display:grid; place-items:center; padding:0 6px }
.cart-badge.hidden{ display:none }
@media (max-width:560px){ .logo{ font-size:32px } }

.hero{ max-width:var(--maxw); margin:0 auto; padding:40px 20px 10px; display:grid; gap:18px }
.hero-title{ font-size: clamp(34px, 4.4vw + 14px, 64px); line-height:1.05; margin:0; letter-spacing:1px }
.hero-tag{ font-size: clamp(16px, 1.2vw + 12px, 22px); color:var(--muted); margin:0 }

.hero { display:none }

.value-grid{ display:grid; gap:12px; grid-template-columns: repeat(4, 1fr); margin-top:10px }
.value{ background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:12px 14px; box-shadow:var(--shadow-soft); font-size:21px; color:var(--muted) }
.value b{ color:var(--text) }
@media (max-width:900px){ .value-grid{ grid-template-columns: repeat(2, 1fr) } }
@media (max-width:560px){ .value-grid{ grid-template-columns: 1fr } }

.section{ max-width:var(--maxw); margin:0 auto; padding:10px 20px 30px }
.section-head{ display:flex; align-items:center; gap:16px; justify-content:space-between; margin:10px 0 12px ;     margin-bottom: 16px;}
.section-head h2{ margin:0; font-size:22px }
.cols-control{ display:flex; align-items:center; gap:10px; color:var(--muted); font-size:14px; white-space:nowrap }
.cols-control input[type="range"]{ width:220px; accent-color: var(--accent) }
.cols-count{ color:var(--text); font-weight:700; min-width:28px; text-align:right }

.grid{ display:flex; flex-wrap:wrap; gap:var(--gap) }
.card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-soft); display:flex; flex-direction:column;
  width: calc( (100% - (var(--gap) * (var(--cols) - 1))) / var(--cols) );
}
.card-media{ aspect-ratio: 4/3; background:#0a0c10; display:grid; place-items:center; overflow:hidden; border-bottom:1px solid var(--line) }
.card-media img{ width:100%; height:100%; object-fit:cover; display:block }
.card-body{ padding:12px 14px; display:grid; gap:8px }
.card-title{ margin:0; font-size:18px; line-height:1.3 }
.card-title a{ color:var(--text); text-decoration:none }
.card-title a:hover{ text-decoration:none }
.price{ font-weight:800; font-size:18px }
.card-actions{ display:flex; gap:10px; margin-top:4px }
.btn{ border:none; border-radius:12px; padding:10px 12px; font-weight:500; cursor:pointer; font-size:15px }
.btn.primary{ background:var(--accent); color:#0a1116 }
.btn.ghost{ background:#0c1016; color:var(--text); border:1px solid var(--line) }

footer.site-footer{ border-top:1px solid var(--line); background:#0d1015 }
.footer-inner{ max-width:var(--maxw); margin:0 auto; padding:24px 20px; display:grid; grid-template-columns: 1fr auto; gap:16px; align-items:center }
.footer-links{ display:flex; gap:18px; flex-wrap:wrap; font-size:15px }
.footer-links a{ color:var(--muted) }
.footer-meta{ color:var(--muted); font-size:14px; text-align:right }
@media (max-width:700px){ .footer-inner{ grid-template-columns:1fr; text-align:center } .footer-meta{ text-align:center } .footer-links{ justify-content:center } }

.card-title a {
  display: -webkit-box;
  -webkit-line-clamp: 3; /* limit to 3 lines */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.card-title a {
  line-height: 1.4;
  max-height: calc(1.4em * 3); /* 3 lines of text */
}

.none { display: none }

.bigtext {
  width: 100%;
  margin-top: 13px;
  font-size: 18px;
}

/* Default: Desktop & Tablet - Always 4 columns */
.value-grid {
  grid-auto-flow: row;
  grid-template-columns: repeat(4, 1fr);
}

/* Center card spans two columns in the middle on non-mobile */
.value-grid .value.cta { 
  grid-column: 2 / span 2; 
}

/* Orange CTA button (white text) */
:root { --cta-orange: #ff7a00; --cta-orange-2: #ffba38; }
.cta-btn {
  background: var(--cta-orange) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 10px 30px rgba(255,122,0,.35);
}

/* Spacing and structure */
.value.cta b { 
  display: block; 
  /*margin-bottom: 6px; */
}
.value.side a,
.value.cta a { 
  margin-top: 12px; 
}

/* Mobile: show ONLY the middle card when viewport is < 1000px */
@media (max-width:999px){
  .value-grid { 
    grid-template-columns: 1fr !important; 
  }
  .value.side { 
    display: none !important; 
  }
  .value.cta { 
    grid-column: auto !important; 
  }
}

.to-loom {
  font-size: 28px; height: 66px;
}

/* Flex container */
.f {
  display: flex;
}

/* Center vertically */
.v {
  align-items: center;
}

/* Center horizontally */
.h {
  justify-content: center;
}
/* ====== Infinite Carousel ====== */
.carousel {
  --cols: 8; /* fixed at 8 wide on desktop */
  overflow: hidden;
  width: 100%;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
}

.carousel-viewport {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 10px 20px;
  overflow: hidden;
}

.carousel-track {
  display: flex;
  gap: var(--gap);
  will-change: transform;
  transform: translate3d(0,0,0);
}

.carousel-item {
  width: calc((100% - (var(--gap) * (var(--cols) - 1))) / var(--cols));
  flex: 0 0 auto;
}

.loom-btn-white {
    background: #ff7a00 !important;
    color: #fff !important;
    box-shadow: 0 10px 30px rgba(255, 122, 0, .35);
}

.store-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #eb6d20; /* orange background */
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  margin-left: 12px;
  font-size: 14px;
  cursor: pointer;
  transition: background 0.2s ease;
}

.store-button:hover {
  background: #d45c10;
}

/* Wide orange CTA used when no store + empty cart */
.open-store-wide {
  appearance: none;
  height: 44px; 
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.0);
  background: linear-gradient(180deg, var(--ok, #eb6d20), var(--ok-2, #d45f16));
  color: #ffffff;
  letter-spacing: .3px;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(18, 183, 106, .35);
  transition: 150ms ease;
  width: 100%;
  font-size: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
    padding: 24px;
    font-size: 18px;
    font-weight: 600;
}

.logo {
      font-weight: 900;
    margin-top: -7px;
    letter-spacing: 6px;
    font-size: 66px;
    color: var(--text);
    text-decoration: none;
    white-space: nowrap;
}

 .marg-15 {
  margin-left: 15px;
 }