/*!
 * Kırcalı Giyim — Vitrin Tasarım Sistemi · "Sessiz Zarafet"
 * ZefreNET AI Internet Technologies | Muhsin İŞSEVER | 2026-06-21
 *
 * AXIOM Design Director protokolü. Tez: "Sessiz lüks bir tesettür lookbook'unu
 * karıştırmak gibi." Display Fraunces × gövde Mulish. Signature: altın hairline +
 * clip-path görsel reveal. RTL-safe logical properties. WCAG AA+.
 */

/* ============ PHASE 4 — TOKEN MİMARİSİ ============ */
:root {
  /* — Renk anlatısı (60/30/10) — */
  --c-bg:        #F7F2EA;   /* fildişi (dominant 60) */
  --c-bg-deep:   #EFE7DA;
  --c-surface:   #FFFFFF;
  --c-ink:       #211C18;   /* mürekkep metin (30) */
  --c-ink-soft:  #5A5048;
  --c-muted:     #756A5E;   /* AA: fildişi üzerinde ~4.7:1 */
  --c-line:      #E2D8C8;   /* ince çizgi/kenar */
  --c-accent:    #6E1423;   /* bordo (10, az kullanılır) */
  --c-accent-deep:#560E1B;
  --c-rose:      #D8B7AE;   /* pudra (ikincil) */
  --c-rose-soft: #EFDED8;
  --c-gold:      #B08A3E;   /* altın hairline/çerçeve (dekoratif) */
  --c-gold-ink:  #806223;   /* metin için koyu altın (ivory üzerinde ~5.1:1, AA) */
  --c-gold-soft: #D8C49A;
  --c-success:   #2C6E54;
  --c-danger:    #9B2226;
  --c-focus:     #B08A3E;

  /* — Tipografi — */
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Mulish", system-ui, -apple-system, "Segoe UI", sans-serif;
  --text-xs: .75rem;  --text-sm: .875rem; --text-md: 1rem;
  --text-lg: 1.1875rem; --text-xl: 1.5rem; --text-2xl: 2.1rem;
  --text-3xl: clamp(2.4rem, 6vw, 3.6rem);
  --text-hero: clamp(2.8rem, 9vw, 6rem);
  --leading-tight: 1.08; --leading-snug: 1.28; --leading-normal: 1.65;
  --tracking-tight: -.02em; --tracking-wide: .04em; --tracking-wider: .18em;
  --weight-normal: 400; --weight-medium: 500; --weight-semibold: 600; --weight-bold: 700;

  /* — Boşluk (8 tabanı) — */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px; --sp-5: 24px;
  --sp-6: 32px; --sp-7: 48px; --sp-8: 64px; --sp-9: 96px; --sp-10: 128px;
  --maxw: 1240px; --maxw-prose: 64ch;

  /* — Derinlik — */
  --radius-sm: 4px; --radius-md: 10px; --radius-lg: 20px; --radius-pill: 999px;
  --shadow-sm: 0 1px 3px rgba(33,28,24,.05);
  --shadow-md: 0 12px 30px -12px rgba(33,28,24,.18);
  --shadow-lg: 0 30px 60px -20px rgba(33,28,24,.25);

  /* — Hareket (lüks/ağırbaşlı) — */
  --dur-fast: 200ms; --dur-normal: 420ms; --dur-slow: 720ms; --dur-cinematic: 1100ms;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-expo: cubic-bezier(.16,1,.3,1);
}

/* ============ RESET / BASE ============ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: var(--weight-normal);
  line-height: var(--leading-normal);
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: var(--weight-semibold);
  line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); margin: 0; color: var(--c-ink); }
p { margin: 0 0 1em; }
a { color: inherit; text-decoration: none; }
img, picture, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; }
ul { margin: 0; padding: 0; list-style: none; }

::selection { background: var(--c-rose); color: var(--c-ink); }
:focus-visible { outline: 2px solid var(--c-focus); outline-offset: 3px; border-radius: 2px; }

/* — Atmosfer: ince kâğıt greni (PHASE 6) — */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============ DÜZEN YARDIMCILARI ============ */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--sp-5); }
.section { padding-block: var(--sp-9); position: relative; z-index: 2; }
.eyebrow { font-family: var(--font-body); font-size: var(--text-xs); font-weight: var(--weight-bold);
  text-transform: uppercase; letter-spacing: var(--tracking-wider); color: var(--c-gold-ink); }
.section-index { font-family: var(--font-display); font-size: clamp(3rem, 10vw, 7rem);
  line-height: 1; color: var(--c-bg-deep); font-weight: var(--weight-semibold); user-select: none; }

/* — Signature: altın hairline — */
.hairline { height: 1px; background: linear-gradient(90deg, transparent, var(--c-gold), transparent); border: 0; }
.hairline--short { width: 56px; height: 2px; background: var(--c-gold); border: 0; border-radius: 2px; }

/* ============ PHASE 5 — BİLEŞENLER ============ */

/* — Buton — */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  min-height: 50px; padding-inline: var(--sp-6);
  font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-sm);
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: #fff; background: var(--c-accent);
  border: 1px solid var(--c-accent); border-radius: var(--radius-pill);
  transition: background var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.btn:hover { background: var(--c-accent-deep); border-color: var(--c-accent-deep); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0); }
.btn--ghost { background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.btn--ghost:hover { background: var(--c-ink); color: var(--c-bg); }
.btn--gold { background: var(--c-gold); border-color: var(--c-gold); color: #2a1f08; }
.btn--block { display: flex; width: 100%; }
.btn[disabled] { opacity: .5; pointer-events: none; }

/* — Bağlantı alt çizgi animasyonu — */
.link-u { position: relative; }
.link-u::after { content: ""; position: absolute; inset-inline: 0; inset-block-end: -3px; height: 1px;
  background: currentColor; transform: scaleX(0); transform-origin: inline-start; transition: transform var(--dur-normal) var(--ease); }
.link-u:hover::after { transform: scaleX(1); }

/* — Ürün kartı (signature reveal) — */
.p-card { display: block; position: relative; }
.p-card__media { position: relative; overflow: hidden; border-radius: var(--radius-md);
  background: var(--c-bg-deep); aspect-ratio: 3 / 4; }
.p-card__media img { width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-expo), filter var(--dur-slow) var(--ease); }
.p-card:hover .p-card__media img { transform: scale(1.05); }
.p-card__media::after { content: ""; position: absolute; inset: 0; border: 1px solid transparent;
  border-radius: var(--radius-md); transition: border-color var(--dur-normal) var(--ease); }
.p-card:hover .p-card__media::after { border-color: var(--c-gold-soft); }
.p-card__fav { position: absolute; inset-block-start: var(--sp-3); inset-inline-end: var(--sp-3);
  width: 40px; height: 40px; display: grid; place-items: center; border-radius: 50%;
  background: rgba(255,255,255,.85); color: var(--c-ink); backdrop-filter: blur(4px); }
.p-card__tag { position: absolute; inset-block-start: var(--sp-3); inset-inline-start: var(--sp-3);
  background: var(--c-accent); color: #fff; font-size: var(--text-xs); font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-wide); padding: 4px 12px; border-radius: var(--radius-pill); }
.p-card__body { padding-block: var(--sp-3); }
.p-card__name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: var(--weight-medium);
  line-height: var(--leading-snug); margin-block-end: 4px; }
.p-card__cat { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--c-muted); }
.p-card__price { font-family: var(--font-display); font-size: var(--text-lg); color: var(--c-accent); margin-block-start: var(--sp-2); }
.p-card__price del { color: var(--c-muted); font-size: var(--text-sm); margin-inline-start: var(--sp-2); }
.p-card__swatches { display: flex; gap: 5px; margin-block-start: var(--sp-2); }
.p-card__swatches span { width: 14px; height: 14px; border-radius: 50%; border: 1px solid rgba(0,0,0,.12); }

/* — Ürün grid — */
.p-grid { display: grid; gap: var(--sp-5) var(--sp-4); grid-template-columns: repeat(2, 1fr); }
@media (min-width: 720px) { .p-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-7) var(--sp-5); } }
@media (min-width: 1040px) { .p-grid { grid-template-columns: repeat(4, 1fr); } }

/* — Renk/beden seçici (ürün detay) — */
.swatch-row { display: flex; flex-wrap: wrap; gap: var(--sp-3); }
.swatch { width: 38px; height: 38px; border-radius: 50%; border: 2px solid var(--c-line);
  position: relative; cursor: pointer; transition: transform var(--dur-fast) var(--ease); }
.swatch:hover { transform: scale(1.08); }
.swatch[aria-pressed="true"] { border-color: var(--c-gold); box-shadow: 0 0 0 2px var(--c-bg), 0 0 0 4px var(--c-gold); }
.size-row { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.size {
  min-width: 50px; min-height: 50px; padding-inline: var(--sp-3); display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--c-line); border-radius: var(--radius-sm); background: var(--c-surface);
  font-weight: var(--weight-semibold); transition: all var(--dur-fast) var(--ease);
}
.size:hover { border-color: var(--c-ink); }
.size[aria-pressed="true"] { background: var(--c-ink); color: var(--c-bg); border-color: var(--c-ink); }
.size[disabled] { opacity: .35; text-decoration: line-through; pointer-events: none; }

/* — Rozet — */
.badge { display: inline-flex; align-items: center; gap: 6px; font-size: var(--text-xs);
  font-weight: var(--weight-bold); letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.badge--stock { color: var(--c-success); }
.badge--out { color: var(--c-danger); }

/* ============ PHASE 7 — GİRİŞ ANİMASYONLARI ============ */
@keyframes fadeUp { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
@keyframes clipReveal { from { clip-path: inset(0 0 100% 0); } to { clip-path: inset(0 0 0 0); } }
.reveal { opacity: 0; }
.reveal.in { animation: fadeUp var(--dur-slow) var(--ease-expo) forwards; }
.reveal-clip.in img { animation: clipReveal var(--dur-cinematic) var(--ease-expo) forwards; }
[data-stagger] > * { opacity: 0; }
[data-stagger].in > * { animation: fadeUp var(--dur-slow) var(--ease-expo) forwards; }

/* ============ HEADER / NAV ============ */
.site-head { position: sticky; inset-block-start: 0; z-index: 40;
  background: color-mix(in srgb, var(--c-bg) 88%, transparent); backdrop-filter: blur(10px);
  border-block-end: 1px solid var(--c-line); }
.site-head__bar { display: flex; align-items: center; gap: var(--sp-4); min-height: 70px; }
.brand-mark { font-family: var(--font-display); font-weight: var(--weight-semibold); font-size: var(--text-xl);
  color: var(--c-accent); letter-spacing: var(--tracking-tight); white-space: nowrap; }
.site-nav { display: none; gap: var(--sp-6); margin-inline: auto; }
.site-nav a { font-size: var(--text-sm); font-weight: var(--weight-semibold); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--c-ink-soft); }
.site-nav a:hover { color: var(--c-accent); }
.head-actions { display: flex; align-items: center; gap: var(--sp-2); margin-inline-start: auto; }
.icon-link { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 50%; color: var(--c-ink);
  position: relative; transition: background var(--dur-fast) var(--ease); }
.icon-link:hover { background: var(--c-bg-deep); }
.icon-link svg { width: 22px; height: 22px; }
.icon-link .count { position: absolute; inset-block-start: 6px; inset-inline-end: 4px; min-width: 18px; height: 18px;
  padding-inline: 4px; background: var(--c-accent); color: #fff; font-size: 11px; font-weight: 700; border-radius: 999px;
  display: grid; place-items: center; }
.head-burger { display: grid; }
@media (min-width: 900px) { .site-nav { display: flex; } .head-burger { display: none; } }

/* — Mobil menü çekmecesi — */
.m-drawer { position: fixed; inset: 0; z-index: 60; visibility: hidden; }
.m-drawer.open { visibility: visible; }
.m-drawer__scrim { position: absolute; inset: 0; background: rgba(33,28,24,.45); opacity: 0; transition: opacity var(--dur-normal) var(--ease); }
.m-drawer.open .m-drawer__scrim { opacity: 1; }
.m-drawer__panel { position: absolute; inset-block: 0; inset-inline-start: 0; width: 80%; max-width: 340px;
  background: var(--c-bg); padding: var(--sp-6); transform: translateX(-102%); transition: transform var(--dur-normal) var(--ease-expo); overflow-y: auto; }
.m-drawer.open .m-drawer__panel { transform: none; }
.m-drawer__panel a { display: block; padding-block: var(--sp-3); font-family: var(--font-display); font-size: var(--text-lg);
  border-block-end: 1px solid var(--c-line); }

/* ============ HERO ============ */
.hero { position: relative; z-index: 2; padding-block: var(--sp-9) var(--sp-8); }
.hero__grid { display: grid; gap: var(--sp-6); align-items: center; }
.hero__title { font-size: var(--text-hero); font-weight: var(--weight-semibold); letter-spacing: var(--tracking-tight); }
.hero__title em { font-style: italic; color: var(--c-accent); }
.hero__lead { font-size: var(--text-lg); color: var(--c-ink-soft); max-width: 46ch; margin-block: var(--sp-4) var(--sp-6); }
.hero__media { position: relative; border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4 / 5; background: var(--c-rose-soft); }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__frame { position: absolute; inset: 14px; border: 1px solid var(--c-gold); border-radius: var(--radius-lg); pointer-events: none; mix-blend-mode: overlay; }
@media (min-width: 880px) { .hero__grid { grid-template-columns: 1.05fr .95fr; gap: var(--sp-8); } }

/* ============ BÖLÜM BAŞLIĞI ============ */
.head-row { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--sp-4); margin-block-end: var(--sp-6); }
.head-row h2 { font-size: var(--text-3xl); }

/* ============ KATEGORİ BENTO ============ */
.bento { display: grid; gap: var(--sp-3); grid-template-columns: repeat(2, 1fr); }
.bento__cell { position: relative; overflow: hidden; border-radius: var(--radius-md); min-height: 200px;
  display: flex; align-items: flex-end; padding: var(--sp-5); color: #fff; background: var(--c-ink); isolation: isolate; }
.bento__cell img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-expo); }
.bento__cell::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, transparent 30%, rgba(20,15,12,.75)); }
.bento__cell:hover img { transform: scale(1.06); }
.bento__cell h3 { color: #fff; font-size: var(--text-xl); }
.bento__cell .c { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; opacity: .85; }
@media (min-width: 760px) {
  .bento { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; }
  .bento__cell--big { grid-column: span 2; grid-row: span 2; }
}

/* ============ MARKA MANİFESTOSU ============ */
.manifesto { text-align: center; max-width: 56ch; margin-inline: auto; }
.manifesto p { font-family: var(--font-display); font-size: clamp(1.3rem, 3.4vw, 2rem); line-height: 1.4; color: var(--c-ink); font-style: italic; }

/* ============ ÜRÜN DETAY ============ */
.pdp { display: grid; gap: var(--sp-6); padding-block: var(--sp-7); }
.pdp__gallery { display: grid; gap: var(--sp-3); }
.pdp__main { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 3 / 4; background: var(--c-bg-deep); }
.pdp__main img { width: 100%; height: 100%; object-fit: cover; }
.pdp__thumbs { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.pdp__thumbs button { width: 64px; height: 80px; border-radius: var(--radius-sm); overflow: hidden; border: 2px solid transparent; padding: 0; background: var(--c-bg-deep); }
.pdp__thumbs button[aria-pressed="true"] { border-color: var(--c-gold); }
.pdp__thumbs img { width: 100%; height: 100%; object-fit: cover; }
.pdp__name { font-size: var(--text-3xl); margin-block: var(--sp-2) var(--sp-3); }
.pdp__price { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--c-accent); }
.pdp__price del { color: var(--c-muted); font-size: var(--text-lg); margin-inline-start: var(--sp-3); }
.pdp__opt-label { font-size: var(--text-sm); font-weight: var(--weight-bold); text-transform: uppercase;
  letter-spacing: var(--tracking-wide); color: var(--c-muted); margin-block: var(--sp-5) var(--sp-3); }
.pdp__desc { color: var(--c-ink-soft); max-width: var(--maxw-prose); margin-block-start: var(--sp-6); }
.pdp__meta { display: flex; gap: var(--sp-5); flex-wrap: wrap; margin-block-start: var(--sp-5); font-size: var(--text-sm); color: var(--c-muted); }
@media (min-width: 880px) { .pdp { grid-template-columns: 1.1fr .9fr; align-items: start; gap: var(--sp-8); }
  .pdp__gallery { grid-template-columns: 72px 1fr; } .pdp__thumbs { flex-direction: column; } }

/* ============ BREADCRUMB ============ */
.crumbs { display: flex; flex-wrap: wrap; gap: var(--sp-2); font-size: var(--text-sm); color: var(--c-muted); padding-block: var(--sp-5) 0; }
.crumbs a:hover { color: var(--c-accent); }
.crumbs span { color: var(--c-line); }

/* ============ BANNER / BÜLTEN / ZENGİN METİN (bölümler) ============ */
.banner { position: relative; min-height: 320px; display: grid; place-items: center; text-align: center;
  color: #fff; background: var(--c-ink); background-size: cover; background-position: center;
  padding: var(--sp-8) var(--sp-5); }
.section.wrap .banner { border-radius: var(--radius-lg); overflow: hidden; }
.banner__inner { max-width: 54ch; position: relative; z-index: 2; }
.banner__title { color: #fff; font-size: var(--text-3xl); }
.banner__text { color: rgba(255,255,255,.9); margin-block: var(--sp-3) var(--sp-5); }

.newsletter { text-align: center; max-width: 56ch; margin-inline: auto; }
.newsletter__title { font-size: var(--text-2xl); }
.newsletter__desc { color: var(--c-ink-soft); margin-block: var(--sp-3) var(--sp-5); }
.newsletter__form { display: flex; gap: var(--sp-2); max-width: 460px; margin-inline: auto; flex-wrap: wrap; }
.newsletter__form input { flex: 1; min-width: 220px; min-height: 50px; padding-inline: var(--sp-4);
  border: 1px solid var(--c-line); border-radius: var(--radius-pill); background: var(--c-surface); color: var(--c-ink); }
.newsletter__ok { color: var(--c-success); font-weight: var(--weight-semibold); }

.richtext h2 { font-size: var(--text-2xl); margin-block: var(--sp-5) var(--sp-3); }
.richtext h3 { font-size: var(--text-xl); margin-block: var(--sp-4) var(--sp-2); }
.richtext p { margin-block-end: 1em; line-height: var(--leading-normal); }
.richtext a { color: var(--c-accent); text-decoration: underline; }
.richtext ul, .richtext ol { margin: 0 0 1em; padding-inline-start: 1.4em; }
.richtext li { margin-block-end: .4em; }

/* ============ FOOTER ============ */
.site-foot { background: var(--c-ink); color: var(--c-bg); margin-block-start: var(--sp-9); position: relative; z-index: 2; }
.site-foot__grid { display: grid; gap: var(--sp-6); padding-block: var(--sp-8); grid-template-columns: 1fr; }
.site-foot h4 { color: var(--c-bg); font-size: var(--text-md); margin-block-end: var(--sp-3); }
.site-foot a { color: color-mix(in srgb, var(--c-bg) 75%, transparent); font-size: var(--text-sm); display: block; padding-block: 5px; }
.site-foot a:hover { color: var(--c-gold-soft); }
.site-foot__brand .brand-mark { color: var(--c-bg); font-size: var(--text-2xl); }
.site-foot__bottom { border-block-start: 1px solid rgba(247,242,234,.12); padding-block: var(--sp-5);
  font-size: var(--text-xs); color: color-mix(in srgb, var(--c-bg) 60%, transparent); text-align: center; }
@media (min-width: 760px) { .site-foot__grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--sp-7); } }

/* ============ BOŞ DURUM ============ */
.empty { text-align: center; padding-block: var(--sp-9); color: var(--c-muted); }
.empty h2 { font-size: var(--text-2xl); color: var(--c-ink); margin-block-end: var(--sp-3); }

/* ============ SEPET / ÖDEME / SİPARİŞ ============ */
.card-plain { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius-md); padding: var(--sp-5); }
.cart-flash { background: var(--c-rose-soft); color: var(--c-ink); padding: var(--sp-3) var(--sp-4); border-radius: var(--radius-sm); margin-block-end: var(--sp-4); font-size: var(--text-sm); }

.cart-layout { display: grid; gap: var(--sp-6); }
.cart-items { display: grid; gap: var(--sp-3); }
.cart-row { display: grid; grid-template-columns: 84px 1fr auto; gap: var(--sp-4); align-items: center;
  padding: var(--sp-3); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius-md); }
.cart-thumb img { width: 84px; height: 112px; object-fit: cover; border-radius: var(--radius-sm); background: var(--c-bg-deep); }
.cart-name { font-family: var(--font-display); font-size: var(--text-md); color: var(--c-ink); }
.cart-combo { font-size: var(--text-xs); color: var(--c-muted); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-block: 2px; }
.cart-unit { font-size: var(--text-sm); color: var(--c-ink-soft); }
.cart-controls { display: flex; flex-direction: column; align-items: flex-end; gap: var(--sp-2); }
.qty-form input { width: 70px; min-height: 40px; text-align: center; }
.cart-line { font-family: var(--font-display); color: var(--c-accent); font-weight: var(--weight-semibold); }
.cart-remove { background: none; border: 0; color: var(--c-muted); font-size: var(--text-sm); text-decoration: underline; cursor: pointer; padding: 0; }
.cart-remove:hover { color: var(--c-danger); }

.cart-summary, .checkout-summary { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius-md);
  padding: var(--sp-5); align-self: start; position: sticky; inset-block-start: 90px; }
.sum-row { display: flex; justify-content: space-between; align-items: baseline; padding-block: var(--sp-2); color: var(--c-ink-soft); }
.sum-total { font-size: var(--text-lg); color: var(--c-ink); }
.sum-total strong { font-family: var(--font-display); color: var(--c-accent); }

.checkout-layout { display: grid; gap: var(--sp-6); align-items: start; }
.co-item { display: flex; justify-content: space-between; gap: var(--sp-3); padding-block: var(--sp-2); border-block-end: 1px solid var(--c-line); font-size: var(--text-sm); }
.co-item:last-of-type { border-block-end: 0; }
.co-item small { color: var(--c-muted); }

.order-check { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; margin-inline: auto;
  margin-block-end: var(--sp-4); background: var(--c-success); color: #fff; }

@media (min-width: 860px) {
  .cart-layout { grid-template-columns: 1fr 340px; }
  .checkout-layout { grid-template-columns: 1.4fr .9fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .reveal, [data-stagger] > * { opacity: 1 !important; }
}
