/* ==========================================================================
   Varsity Supreme — base.css
   Design tokens, reset, and shared primitives. Loaded globally.
   Tokens are the single source of truth for the design system.
   ========================================================================== */

:root{
  --ink:#101010;
  --paper:#F4F2EC;
  --surface:#FFFFFF;
  --soft:#E8E5DB;
  --red:#E12826;
  --red-dark:#c11e1a;
  --grey:#76746C;
  --line:rgba(16,16,16,.12);
  --r:14px;
  --wrap:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body.vs-theme{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* Link reset kept at low specificity (bare `a`) so button/pill classes
   (.vs-pill, .vs-btn--*) win their text colour instead of inheriting --ink. */
a{color:inherit;text-decoration:none}
.vs-theme img{max-width:100%;display:block}

/* Layout primitives */
.vs-wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(18px,4vw,40px)}
.vs-section{padding:clamp(40px,6vw,72px) 0}
.vs-eyebrow{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}

/* Headings */
.vs-h1{font-family:'Archivo',sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:-.03em;line-height:.95;font-size:clamp(2rem,5vw,3.2rem)}
.vs-h2{font-family:'Archivo',sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:-.03em;line-height:.92;font-size:clamp(2rem,5.2vw,3.6rem)}

/* Prose (default page / blog body) */
.vs-prose{max-width:760px;font-size:15.5px;color:#2c2c2c}
.vs-prose h2{font-family:'Archivo';font-weight:800;text-transform:uppercase;letter-spacing:-.02em;font-size:clamp(1.4rem,3vw,1.9rem);margin:1.6em 0 .6em}
.vs-prose h3{font-family:'Archivo';font-weight:700;font-size:1.2rem;margin:1.4em 0 .5em}
.vs-prose p{margin:0 0 1em}
.vs-prose a{color:var(--red);text-decoration:underline}

/* Buttons */
.vs-btn{
  border-radius:100px;padding:15px 28px;font-weight:600;font-size:15px;cursor:pointer;
  border:1.5px solid var(--ink);
  transition:transform .15s,background .15s,color .15s;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;text-align:center;
}
.vs-btn--solid,.vs-btn--red{background:var(--red);border-color:var(--red);color:#fff}
.vs-btn--solid:hover,.vs-btn--red:hover{transform:translateY(-2px);background:var(--red-dark);border-color:var(--red-dark)}
.vs-btn--ink{background:var(--ink);color:var(--paper)}
.vs-btn--ink:hover{transform:translateY(-2px)}
.vs-btn--out{background:transparent;color:var(--ink)}
.vs-btn--out:hover{background:var(--ink);color:var(--paper)}

/* Color chips */
.vs-chips{display:flex;gap:10px;flex-wrap:wrap}
.vs-chip{width:32px;height:32px;border-radius:50%;border:2px solid var(--line);cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s}
.vs-chip:hover{transform:scale(1.12)}
.vs-chip--sel{border-color:var(--ink);box-shadow:0 0 0 3px rgba(225,40,38,.4)}

/* Price */
.vs-price{font-family:'Space Mono',monospace;font-weight:700;font-size:15px;white-space:nowrap}

/* Selects — custom chevron, no native OS dropdown look */
.vs-theme select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  border:1.5px solid var(--line);border-radius:10px;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--ink);
  padding:10px 38px 10px 14px;cursor:pointer;line-height:1.2;
  background-color:var(--surface);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23101010' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:12px 8px;
}
.vs-theme select:focus{border-color:var(--ink);outline:none}
.vs-theme select::-ms-expand{display:none}

/* Product card + grid (shared: homepage, collection) */
.vs-prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,22px)}
.vs-prod{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.vs-prod:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(16,16,16,.12)}
.vs-prod-vis{background:var(--soft);aspect-ratio:1/.92;display:grid;place-items:center;position:relative;overflow:hidden}
.vs-prod-tag{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.06em;padding:4px 9px;border-radius:5px;z-index:2}
.vs-prod-tag--red{background:var(--red)}
.vs-prod-cust{position:absolute;inset:auto 0 0 0;background:var(--ink);color:var(--paper);text-align:center;font-size:12.5px;font-weight:600;padding:11px;transform:translateY(100%);transition:transform .2s}
.vs-prod:hover .vs-prod-cust{transform:none}
.vs-prod-info{padding:15px 17px 19px;display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.vs-prod-info h3,.vs-prod-info h4{font-size:15px;font-weight:600;line-height:1.2}
.vs-prod-sub{font-size:12px;color:var(--grey);margin-top:2px}
@media(max-width:900px){.vs-prod-grid{grid-template-columns:1fr 1fr}}

/* Breadcrumb (all page types) */
.vs-crumb{font-family:'Space Mono',monospace;font-size:12px;color:var(--grey);letter-spacing:.04em;padding:20px 0}
.vs-crumb a{color:var(--grey)}
.vs-crumb a:hover{color:var(--red)}
.vs-crumb span[aria-current]{color:var(--ink)}

/* ---- Jacket illustration (PLACEHOLDER for real/AI photography) ---- */
.vs-jacket{width:clamp(150px,26vw,230px);aspect-ratio:1/1.1;position:relative;filter:drop-shadow(0 18px 30px rgba(16,16,16,.18))}
.vs-jacket--sm{width:54%}
.vs-jk-body{position:absolute;left:24%;right:24%;top:13%;bottom:0;background:var(--jb,#101010);border-radius:10px 10px 5px 5px}
.vs-jk-sleeve{position:absolute;top:15%;width:21%;height:70%;background:var(--js,#F4F2EC);border-radius:10px}
.vs-jk-sleeve--l{left:3%;transform:rotate(5deg)}
.vs-jk-sleeve--r{right:3%;transform:rotate(-5deg)}
.vs-jk-collar{position:absolute;left:24%;right:24%;top:8%;height:9%;background:var(--js,#F4F2EC);border-radius:7px}
.vs-jk-stripe{position:absolute;left:24%;right:24%;bottom:0;height:8%;background:repeating-linear-gradient(90deg,var(--js,#F4F2EC) 0 9px,var(--red) 9px 13px);border-radius:0 0 5px 5px}
.vs-jk-mono{position:absolute;left:50%;top:34%;transform:translateX(-50%);font-family:'Archivo';font-weight:900;font-size:clamp(28px,5vw,40px);color:var(--js,#F4F2EC)}

/* Reveal-on-scroll (gated by reduced-motion) */
@media (prefers-reduced-motion:no-preference){
  .vs-reveal{opacity:0;transform:translateY(22px);transition:opacity .6s,transform .6s}
  .vs-reveal.vs-in{opacity:1;transform:none}
}
