/* =========================================================================
   KOSE 2026 — Design System
   Schibsted Grotesk (display) + Hanken Grotesk (body)
   Brand emerald #14A44A · warm coral #FF5A33 (deals only)
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Schibsted+Grotesk:wght@500;600;700;800;900&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

/* ---------- Tokens ---------- */
:root{
  --brand:#14A44A;
  --brand-ink:#0B7D38;       /* text-safe green */
  --brand-deep:#085C29;
  --brand-soft:#E6F6EC;
  --brand-soft-2:#D2EFDC;
  --warm:#FF5A33;            /* deals / urgency only */
  --warm-soft:#FFE8E1;
  --gold:#F4B53F;

  --ink:#0C140F;
  --ink-2:#37433C;
  --ink-3:#69756E;
  --line:#E7E5DF;
  --line-2:#EFEDE7;
  --canvas:#F6F5F1;
  --surface:#FFFFFF;
  --surface-2:#FBFAF7;
  --elevated:#FFFFFF;

  --r-xs:8px; --r-sm:12px; --r-md:16px; --r-lg:22px; --r-xl:30px; --r-pill:999px;
  --sp:1;                    /* density multiplier */

  --sh-1:0 1px 2px rgba(12,20,15,.05), 0 1px 1px rgba(12,20,15,.04);
  --sh-2:0 6px 18px -6px rgba(12,20,15,.12), 0 2px 6px -2px rgba(12,20,15,.06);
  --sh-3:0 22px 50px -16px rgba(12,20,15,.24), 0 8px 20px -10px rgba(12,20,15,.12);
  --sh-brand:0 14px 30px -10px rgba(20,164,74,.45);

  --font-display:'Schibsted Grotesk', system-ui, sans-serif;
  --font:'Hanken Grotesk', system-ui, sans-serif;

  --maxw:1320px;
  --header-h:128px;
}

[data-theme="dark"]{
  --ink:#F2F4F1;
  --ink-2:#C3CCC6;
  --ink-3:#8B968F;
  --line:#283029;
  --line-2:#222a24;
  --canvas:#0B0F0C;
  --surface:#12181400;
  --surface:#141B16;
  --surface-2:#10160F;
  --elevated:#1A221C;
  --brand-soft:#10271A;
  --brand-soft-2:#16331F;
  --warm-soft:#33180F;
  --sh-1:0 1px 2px rgba(0,0,0,.4);
  --sh-2:0 6px 18px -6px rgba(0,0,0,.55), 0 2px 6px -2px rgba(0,0,0,.4);
  --sh-3:0 22px 50px -16px rgba(0,0,0,.7), 0 8px 20px -10px rgba(0,0,0,.5);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--canvas);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv01";
  overflow-x:hidden;
}
img{display:block;max-width:100%}
svg{width:18px;height:18px;flex-shrink:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
ul{list-style:none}
:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px;border-radius:6px}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:800;line-height:1.04;letter-spacing:-.02em;color:var(--ink)}
.display{font-family:var(--font-display);font-weight:900;letter-spacing:-.035em;line-height:.98}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.page{min-height:100vh;padding-bottom:80px}
.section{padding:calc(48px * var(--sp)) 0}
.row{display:flex;align-items:center;gap:12px}
.between{display:flex;align-items:center;justify-content:space-between;gap:16px}
.col{display:flex;flex-direction:column}
.grow{flex:1}
.muted{color:var(--ink-3)}
.center{text-align:center}
.hide{display:none !important}
@media(max-width:720px){ .wrap{padding:0 16px} }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  height:48px;padding:0 22px;border-radius:var(--r-pill);
  font-family:var(--font);font-weight:700;font-size:15px;letter-spacing:-.01em;
  background:var(--surface);color:var(--ink);border:1.5px solid var(--line);
  transition:transform .12s ease, box-shadow .2s ease, background .2s ease, border-color .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:var(--sh-brand)}
.btn--primary:hover{background:var(--brand-ink);border-color:var(--brand-ink)}
.btn--ink{background:var(--ink);color:var(--canvas);border-color:var(--ink)}
.btn--ink:hover{filter:brightness(1.12)}
.btn--warm{background:var(--warm);color:#fff;border-color:var(--warm)}
.btn--ghost{background:transparent}
.btn--ghost:hover{background:var(--surface-2);border-color:var(--line)}
.btn--soft{background:var(--brand-soft);color:var(--brand-deep);border-color:transparent}
.btn--lg{height:56px;padding:0 30px;font-size:16.5px}
.btn--sm{height:40px;padding:0 16px;font-size:14px}
.btn--block{display:flex;width:100%}
.btn--icon{width:48px;height:48px;padding:0;border-radius:var(--r-pill)}
.btn[disabled]{opacity:.5;pointer-events:none}

/* ---------- Badges / chips ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 11px;border-radius:var(--r-pill);
  font-size:12px;font-weight:700;letter-spacing:.01em;background:var(--brand-soft);color:var(--brand-deep)}
.tag--warm{background:var(--warm);color:#fff}
.tag--deal{background:var(--warm-soft);color:#C2381A}
.tag--ink{background:var(--ink);color:var(--canvas)}
.tag--gold{background:#fdf2d8;color:#8a6410}
.tag--line{background:transparent;border:1.5px solid var(--line);color:var(--ink-2)}
.chip{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:var(--r-pill);
  background:var(--surface);border:1.5px solid var(--line);font-weight:600;font-size:14px;color:var(--ink-2);
  transition:.16s;white-space:nowrap}
.chip:hover{border-color:var(--ink-3);color:var(--ink)}
.chip--on{background:var(--ink);border-color:var(--ink);color:var(--canvas)}
.chip svg{width:16px;height:16px}

.verified{display:inline-flex;align-items:center;gap:5px;color:var(--brand-ink);font-weight:700;font-size:12.5px}
.verified svg{width:15px;height:15px}

/* triangle motif */
.tri{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;
  border-top:7px solid var(--brand);vertical-align:middle}

/* ---------- Star rating ---------- */
.stars{display:inline-flex;align-items:center;gap:3px;color:var(--gold)}
.stars svg{width:14px;height:14px}
.rate{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--ink-2)}
.rate b{color:var(--ink)}

/* ---------- Cards / product ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-1)}

.pcard{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;transition:transform .18s ease, box-shadow .22s ease, border-color .22s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--sh-2);border-color:transparent}
.pcard__media{position:relative;aspect-ratio:1/1;overflow:hidden}
.pcard__img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.pcard:hover .pcard__img{transform:scale(1.06)}
.pcard__badges{position:absolute;top:10px;left:10px;display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.pcard__fav{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--ink-2);box-shadow:var(--sh-1);transition:.16s}
.pcard__fav:hover{color:var(--warm);transform:scale(1.08)}
.pcard__fav.on{color:var(--warm)}
.pcard__fav svg{width:18px;height:18px}
.pcard__body{padding:calc(14px * var(--sp));display:flex;flex-direction:column;gap:7px;flex:1}
.pcard__store{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--ink-3)}
.pcard__title{font-size:14.5px;font-weight:600;line-height:1.32;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard__price{display:flex;align-items:baseline;gap:8px;margin-top:auto}
.pcard__now{font-family:var(--font-display);font-weight:800;font-size:18px;letter-spacing:-.02em}
.pcard__was{font-size:13px;color:var(--ink-3);text-decoration:line-through}
.pcard__cta{margin-top:4px}
.pcard__add{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:42px;border-radius:var(--r-pill);
  background:var(--brand-soft);color:var(--brand-deep);font-weight:700;font-size:14px;transition:.16s}
.pcard__add:hover{background:var(--brand);color:#fff}
.pcard__add svg{width:17px;height:17px}

/* ---------- Product grid ---------- */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:calc(18px * var(--sp))}
.pgrid--5{grid-template-columns:repeat(5,1fr)}
.pgrid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){ .pgrid--5,.pgrid--4{grid-template-columns:repeat(3,1fr)} }
@media(max-width:720px){
  .pgrid{grid-template-columns:repeat(2,1fr);gap:12px}
  .pgrid--5,.pgrid--4{grid-template-columns:repeat(2,1fr)}
  .pcard__add{height:38px}
  .pcard__now{font-size:16.5px}
}

/* horizontal rail */
.rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,1fr);gap:16px;overflow-x:auto;
  scroll-snap-type:x mandatory;padding-bottom:8px;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.rail>*{scroll-snap-align:start}
@media(max-width:720px){ .rail{grid-auto-columns:minmax(160px,72%)} }

/* ---------- Section heads ---------- */
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px}
.shead__t{font-size:clamp(22px,3vw,30px);font-weight:800}
.shead__s{color:var(--ink-3);font-size:15px;margin-top:4px}
.shead__link{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14.5px;color:var(--brand-ink)}
.shead__link svg{width:16px;height:16px;transition:transform .16s}
.shead__link:hover svg{transform:translateX(3px)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:12.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--brand-ink)}
.eyebrow svg{width:16px;height:16px}
.tag svg{width:14px;height:14px}

/* ---------- Placeholder imagery ---------- */
.ph{position:relative;width:100%;height:100%;overflow:hidden;background:var(--brand-soft)}
.ph__glyph{position:absolute;inset:0;display:grid;place-items:center;opacity:.9}
.ph__glyph svg{width:34%;height:34%;opacity:.42}
.ph__tex{position:absolute;inset:0;opacity:.5;mix-blend-mode:soft-light;
  background-image:radial-gradient(circle at 30% 20%, rgba(255,255,255,.6), transparent 45%)}

/* ---------- Inputs ---------- */
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13.5px;font-weight:700;color:var(--ink-2)}
.input{height:50px;padding:0 16px;border-radius:var(--r-sm);border:1.5px solid var(--line);background:var(--surface);
  font-size:15px;transition:.16s;width:100%}
.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
textarea.input{height:auto;padding:13px 16px;resize:vertical;min-height:96px}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2369756E' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:18px;padding-right:42px}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line);border:0}
.skeleton{background:linear-gradient(90deg,var(--line-2) 25%,var(--surface-2) 50%,var(--line-2) 75%);
  background-size:200% 100%;animation:sk 1.3s infinite}
@keyframes sk{to{background-position:-200% 0}}
.reveal{opacity:0;transform:translateY(14px);animation:reveal .6s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes reveal{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){ *{animation-duration:.001ms !important;transition-duration:.01ms !important} }

/* scrollbar for desktop */
@media(min-width:721px){
  ::-webkit-scrollbar{width:12px;height:12px}
  ::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px;border:3px solid var(--canvas)}
  ::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}
}
