/* minarimart — styles (extracted from index.html inline)
   Critical tokens & base reset остаются в <style> head для FCP.
   Ниже — всё остальное: layout, components, views, modals. */

/* RULE-CSS-08: каскад через @layer.
   Decl-порядок: reset → tokens → base → layout → components → utilities.
   Inline-стили в <style> head не привязаны к layer и бьют любые слои (critical CSS). */
@layer reset, tokens, base, layout, components, utilities;

@layer reset {
  /* RULE-CSS-08 reset layer: всё что должно быть применено в первую очередь, низкая specificity */
  /* (фактическое содержимое перенесено внутрь components для совместимости с существующим каскадом;
     отдельный layer-блок зарезервирован для будущей миграции — IMP-30 partial) */
}

@layer components {

/* <picture> wrapper прозрачен в layout, чтобы <img> наследовал flex/grid-родителя */
picture { display: contents; }

/* RULE-MBL-03/04: убирает 300ms tap delay + системный flash на mobile */
body { -webkit-tap-highlight-color: transparent; }
.btn, .icon-btn, .chip, .method-card, .card-add, .card-fav, .card,
.qty-btn, .spice-btn, .slot, .toggle-pill, .mob-nav-link, .mob-hamburger,
.close-btn, .mob-nav-close, .auth-close, .info-close, [role="button"] {
  touch-action: manipulation;
}

/* RULE-MBL-07: input font-size ≥ 16px на mobile предотвращает iOS zoom */
@media (max-width: 640px) {
  .input, .search-inp, textarea, select { font-size: 16px; }
}

/* RULE-FRM-06: :user-invalid срабатывает только после взаимодействия (vs :invalid сразу) */
.input:user-invalid { border-color: var(--gochujang); }
.input:user-invalid:focus { border-color: var(--gochujang-2); }

/* RULE-FRM-08: textarea растёт по содержимому (Baseline 2024+) */
textarea { field-sizing: content; min-block-size: 2lh; }

/* RULE-FNT-07/CSS-07: табличные цифры для цен (выравнивание в столбцах) */
.card-price, .cart-item-price, .op-item-price, .total-preview,
.summary-row .v, .order-row .total, .hp-price {
  font-feature-settings: "tnum" 1, "lnum" 1;
}

body{font-size:15px;line-height:1.55}
.container{max-width:1320px;margin:0 auto;padding:0 24px}

/* HEADER */
.site-header{position:sticky;top:0;z-index:var(--z-header);background:var(--cream-alpha-88);backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--ink-alpha-08)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:60px}
.logo{font-size:18px;display:inline-flex;align-items:baseline;gap:2px;cursor:pointer}
/* RULE-A11-07 + RULE-HTM-04: <button class="logo"> reset под inline-flex логотип */
button.logo{background:transparent;border:0;padding:0;color:inherit;font:inherit;line-height:inherit;text-align:left}
.logo svg{margin-right:4px}
.logo .ko{font-family:var(--font-display);font-weight:700;color:var(--gochujang);margin-right:6px;font-size:20px}
.nav-links{display:flex;gap:28px;font-size:13px;color:var(--ink-alpha-65)}
/* RULE-A11-07: nav-links мигрированы с <a data-route> на <button data-route>; стили — на оба тега */
.nav-links a,.nav-links button{transition:color .15s;cursor:pointer;background:transparent;border:0;padding:0;color:inherit;font:inherit;line-height:inherit}
.nav-links a:hover,.nav-links a.active,.nav-links button:hover,.nav-links button.active{color:var(--ink)}
.header-actions{display:flex;align-items:center;gap:6px}
.icon-btn{width:38px;height:38px;border-radius:var(--r-button);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-alpha-65);transition:background .15s,color .15s;position:relative}
.icon-btn:hover{background:var(--ink-alpha-06);color:var(--ink)}
.icon-btn svg{width:18px;height:18px}
.badge-count{position:absolute;top:3px;right:3px;min-width:16px;height:16px;padding:0 4px;background:var(--gochujang);color:var(--cream);border-radius:var(--r-button);font-size:10px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums;transform:scale(0);transition:transform .2s var(--ease-out)}
.badge-count.show{transform:scale(1)}
.badge-count.bump{animation:bump .4s var(--ease-out)}
@keyframes bump{0%{transform:scale(1)}30%{transform:scale(1.4)}100%{transform:scale(1)}}
.status-pill{display:inline-flex;align-items:center;gap:6px;padding:0 12px;height:32px;border-radius:20px;font-size:12px;font-variant-numeric:tabular-nums;color:var(--ink-alpha-65);background:var(--minari-alpha-10);border:1px solid var(--minari-alpha-22)}
@media(max-width:900px){.status-pill{display:none}}
.status-pill .ring{width:7px;height:7px;border-radius:var(--r-circle);background:var(--minari);box-shadow:0 0 0 3px var(--minari-alpha-22);animation:pulse 2s ease-in-out infinite}
.status-pill.closed{color:var(--ink-alpha-55);background:var(--ink-alpha-04);border-color:var(--ink-alpha-10)}
.status-pill.closed .ring{background:var(--ink-alpha-35);box-shadow:none;animation:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@media(max-width:900px){.nav-links{display:none}}
/* ── mobile nav ─────────────────────────────────────────────────── */
.mob-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;min-width:44px;flex-shrink:0;border-radius:var(--r-button);padding:0 10px;background:none;border:none;cursor:pointer;transition:background .15s}
.mob-hamburger:hover{background:var(--ink-alpha-06)}
.mob-hamburger span{display:block;height:1.5px;background:var(--ink);border-radius:2px;transition:transform .25s var(--ease-out),opacity .2s}
.mob-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.mob-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.mob-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(max-width:900px){.mob-hamburger{display:flex}}
#mob-nav-overlay{position:fixed;inset:0;background:var(--ink-alpha-45);backdrop-filter:blur(4px);z-index:var(--z-mobnav-overlay);opacity:0;pointer-events:none;transition:opacity .25s}
#mob-nav-overlay.open{opacity:1;pointer-events:all}
#mob-nav{position:fixed;top:0;right:0;width:min(300px,85vw);height:100dvh;background:var(--cream);z-index:var(--z-mobnav);transform:translateX(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}
#mob-nav.open{transform:translateX(0)}
.mob-nav-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--ink-alpha-08)}
.mob-nav-head .logo{display:flex;align-items:center;gap:6px}
.mob-nav-close{width:32px;height:32px;border-radius:var(--r-circle);background:var(--ink-alpha-06);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.mob-nav-close:hover{background:var(--ink-alpha-10)}
.mob-nav-links{flex:1;padding:12px 12px 0;display:flex;flex-direction:column;gap:2px}
.mob-nav-link{display:flex;align-items:center;gap:12px;padding:12px 12px;min-height:44px;border-radius:10px;font-size:15px;font-weight:500;color:var(--ink-alpha-65);transition:background .15s,color .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}
.mob-nav-link:hover,.mob-nav-link.active{background:var(--ink-alpha-06);color:var(--ink)}
.mob-nav-link svg{width:18px;height:18px;flex-shrink:0;opacity:.55}
.mob-nav-link.active svg{opacity:1}
.mob-nav-foot{padding:20px;border-top:1px solid var(--ink-alpha-08);font-size:12px;color:var(--ink-alpha-65)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 18px;font-size:13px;font-weight:500;border-radius:var(--r-button);transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;white-space:nowrap;cursor:pointer;border:none;font-family:inherit;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}
.btn-primary{background:var(--ink);color:var(--cream);font-weight:600;letter-spacing:-0.01em}
.btn-primary:hover{background:var(--walnut)}
.btn-primary:active{transform:scale(0.98)}
.btn-accent{background:var(--gochujang-2);color:var(--cream);font-weight:600;letter-spacing:-0.01em}
.btn-accent:hover{background:var(--gochujang-3)}
.btn-ghost{background:transparent;border:1px solid var(--ink-alpha-20);color:var(--ink)}
.btn-ghost:hover{background:var(--ink-alpha-06);border-color:var(--ink-alpha-35)}
.btn-sm{height:32px;padding:0 12px;font-size:12px;border-radius:var(--r-input)}
.btn-lg{height:52px;padding:0 24px;font-size:14px;border-radius:10px}
.btn-block{width:100%}
/* focus-ring: двухслойный (cream разделитель + ink контраст) — WCAG 1.4.11 ≥3:1 на любом фоне; transparent outline = fallback для Windows HCM */
.btn:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px var(--cream),0 0 0 4px var(--ink)}

/* VIEWS */
.view{display:none}
.view.active{display:block}

/* HERO */
.hero{padding:56px 0 40px;position:relative}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:48px;align-items:start}
.hero-grid > *{min-width:0}
@media(max-width:900px){.hero{padding:28px 0 24px}.hero-grid{grid-template-columns:1fr;gap:28px}}
.hero-kicker{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-alpha-65);font-weight:600;display:flex;align-items:center;gap:10px;margin-bottom:28px}
.hero-kicker .sep{width:16px;height:1px;background:var(--ink-alpha-20)}
.hero-title{font-family:var(--font-display);font-weight:700;font-size:clamp(52px,8.5vw,116px);line-height:.9;letter-spacing:-0.045em;margin:0 0 32px;color:var(--ink);overflow-wrap:break-word;word-break:break-word}
.hero-title .accent{color:var(--minari-2);font-weight:300;font-style:italic}
.hero-title .k{font-weight:300;display:inline-block;transform:translateY(-0.04em)}
.hero-title--xl{font-size:clamp(44px,7vw,88px)}
.hero-title--xxl{font-size:clamp(40px,7vw,92px);margin-bottom:36px;max-width:14ch}
.hero-sub{font-size:16px;line-height:1.6;color:var(--ink-alpha-65);max-width:440px;margin:0 0 32px}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap}

.hero-panel{background:var(--ink);color:var(--cream);border-radius:18px;padding:24px;position:relative;overflow:hidden;display:flex;flex-direction:column;align-self:start}
.hero-panel::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 100% 0%, var(--gochujang-alpha-28), transparent 50%),radial-gradient(circle at 0% 100%, var(--minari-alpha-22), transparent 60%);pointer-events:none}
.hero-panel > *{position:relative;z-index:var(--z-raise)}
.hp-featured{background:var(--cream-alpha-04);border:1px solid var(--cream-alpha-08);border-radius:var(--r-card);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:border-color .2s,transform .3s cubic-bezier(.16,1,.3,1);padding:0;text-align:left;color:inherit;font:inherit;width:100%}
.hp-featured:hover{border-color:var(--gochujang-alpha-40);transform:translateY(-2px)}
.hp-featured-label{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 0}
.hp-badge{font-size:10px;text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--gochujang);background:var(--gochujang-alpha-14);padding:5px 9px;border-radius:4px}
.hp-price{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--brass);letter-spacing:-.02em}
.hp-featured-img{margin:10px 14px 0;border-radius:10px;overflow:hidden;background:var(--ink-3);flex-shrink:0}
.hp-featured-img img{width:100%;height:auto;aspect-ratio:5/3;object-fit:cover;display:block}
.hp-featured-meta{padding:14px 16px 16px}
.hp-title{font-family:var(--font-display);font-weight:700;font-size:22px;line-height:1.15;letter-spacing:-.02em;margin:0 0 6px;color:var(--cream)}
.hp-desc{font-size:12px;line-height:1.55;color:var(--cream-alpha-55);margin:0 0 10px}
.hp-tags{display:flex;flex-wrap:wrap;gap:6px}
.hp-tag{font-size:10px;font-weight:500;letter-spacing:.02em;padding:3px 8px;border:1px solid var(--cream-alpha-12);border-radius:3px;color:var(--cream-alpha-55)}
.hp-tag-spicy{color:var(--spice-light);border-color:var(--spice-light-alpha-30);background:var(--gochujang-alpha-10)}










/* MARQUEE */
.marquee{border-top:1px solid var(--ink-alpha-08);border-bottom:1px solid var(--ink-alpha-08);padding:12px 0;overflow:hidden;background:var(--ink-alpha-04)}
.marquee-track{display:flex;width:max-content;animation:marq 46s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-alpha-65);padding:0 24px;display:inline-flex;align-items:center;gap:16px;white-space:nowrap;font-weight:500}
.marquee-item .sep{color:var(--gochujang);opacity:.6}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION */
.section{padding:72px 0;border-top:1px solid var(--ink-alpha-08)}
.section--top-tight{border-top:none;padding-top:48px}
.section--no-divider{border-top:none}
.section-band-top{padding:48px 0 0}
@media(max-width:900px){.section{padding:48px 0}}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px}
@media(max-width:700px){.section-head{flex-direction:column;align-items:flex-start}}
.section-kicker{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-alpha-65);font-weight:600;margin:0 0 12px}
.section-title{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,5vw,56px);line-height:1;letter-spacing:-0.035em;margin:0}
.section-title .lite{font-weight:300;color:var(--ink-alpha-55);font-style:italic}

/* FILTERS */
.filter-row{display:flex;align-items:center;gap:16px;padding:14px 0;margin-bottom:20px;position:sticky;top:60px;z-index:var(--z-sticky);background:var(--cream-alpha-94);backdrop-filter:blur(10px);border-bottom:1px solid var(--ink-alpha-06)}
.filter-chips{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;position:relative;mask-image:linear-gradient(90deg,var(--black-pure) 0,var(--black-pure) calc(100% - 32px),transparent 100%);-webkit-mask-image:linear-gradient(90deg,var(--black-pure) 0,var(--black-pure) calc(100% - 32px),transparent 100%)}
.filter-chips::-webkit-scrollbar{display:none}
.chip{height:34px;padding:0 14px;border:1px solid var(--ink-alpha-10);border-radius:20px;background:transparent;font-size:12px;font-weight:500;color:var(--ink-alpha-55);white-space:nowrap;display:inline-flex;align-items:center;gap:6px;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;cursor:pointer;font-family:inherit}
.chip:hover{border-color:var(--ink-alpha-25);color:var(--ink)}
.chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.chip .count{opacity:.5;font-variant-numeric:tabular-nums}
.filter-extras{display:flex;gap:8px;align-items:center;flex-shrink:0}
.filter-extras select{height:34px;padding:0 28px 0 12px;border:1px solid var(--ink-alpha-10);border-radius:20px;background:transparent;color:var(--ink);font-size:12px;font-family:inherit;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='10'%20height='10'%20viewBox='0%200%2010%2010'%3E%3Cpath%20d='M2%204l3%203%203-3'%20stroke='%231A0E06'%20stroke-width='1.2'%20fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer}
.toggle-pill{height:34px;padding:0 14px;border:1px solid var(--ink-alpha-10);border-radius:20px;font-size:12px;font-weight:500;color:var(--ink-alpha-55);display:inline-flex;align-items:center;gap:8px;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;cursor:pointer;background:transparent;font-family:inherit}
.toggle-pill.on{background:var(--minari-alpha-12);border-color:var(--minari-alpha-40);color:var(--minari-2)}
@media(max-width:700px){.filter-extras{display:none}}

/* CARDS */
.cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
@media(max-width:1024px){.cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.cards-grid{grid-template-columns:minmax(0,1fr)}}

.card{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;overflow:hidden;transition:transform .25s var(--ease-out),border-color .2s,box-shadow .25s;display:flex;flex-direction:column;cursor:pointer;position:relative}
.card:hover{transform:translateY(-4px);border-color:var(--ink-alpha-20);box-shadow:var(--shadow-md)}
.card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.card:hover .card-img img{transform:scale(1.04)}
.card-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:4px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;padding:4px 8px;border-radius:4px;background:var(--cream-alpha-95);color:var(--ink);backdrop-filter:blur(4px)}
.pill.minari{background:var(--minari-alpha-95);color:var(--ink)}
.pill.gochujang{background:var(--gochujang-2);color:var(--white-pure)}
.pill.brass{background:var(--brass-alpha-95);color:var(--ink)}
.card-fav{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:var(--r-circle);background:var(--cream-alpha-92);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-alpha-45);transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;backdrop-filter:blur(4px);border:none;cursor:pointer}
.card-fav:hover{color:var(--gochujang);transform:scale(1.08)}
.card-fav.active{color:var(--gochujang);background:var(--white-pure)}
.card-fav svg{width:16px;height:16px}

.card-body{padding:16px;flex:1;display:flex;flex-direction:column}
.card-top{display:flex;justify-content:space-between;gap:12px;align-items:baseline;margin-bottom:6px;min-width:0}
.card-title{font-family:var(--font-display);font-weight:700;font-size:18px;line-height:1.2;letter-spacing:-0.02em;color:var(--ink);margin:0;flex:1}
.card-price{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--walnut);font-variant-numeric:tabular-nums;flex-shrink:0}
.card-desc{font-size:12.5px;line-height:1.5;color:var(--ink-alpha-65);margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;gap:10px}
.card-meta-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.card-cta-row{display:flex;align-items:center;gap:12px}
.btn--with-icon{display:flex;align-items:center;justify-content:center;gap:8px}
.info-consent{display:flex;gap:8px;align-items:flex-start;font-size:12px;line-height:1.5;color:var(--ink-alpha-80);margin:8px 0}
.info-consent input[type=checkbox]{margin-top:3px;flex-shrink:0}
.info-consent a,.info-consent button{text-decoration:underline;background:transparent;border:0;padding:0;color:inherit;font:inherit;line-height:inherit;cursor:pointer}
.info-consent button:focus-visible{outline:2px solid var(--minari);outline-offset:2px;border-radius:2px}
.success-cta-row{display:flex;gap:10px;justify-content:center;margin-top:28px;flex-wrap:wrap}
.spice-meter{display:inline-flex;align-items:center;gap:3px}
.spice-meter .dot{width:6px;height:6px;border-radius:var(--r-circle);background:transparent;border:1.5px solid var(--ink-alpha-25)}
.spice-meter .dot.on{background:var(--gochujang);border-color:var(--gochujang);box-shadow:0 0 0 2px var(--gochujang-alpha-12)}
.mini-tag{font-size:10px;color:var(--ink-alpha-65);font-weight:500;padding:2px 7px;border:1px solid var(--ink-alpha-10);border-radius:3px;font-variant-numeric:tabular-nums}
.mini-tag.vegan{color:var(--minari-3);border-color:var(--minari-alpha-45)}
.card-add{width:34px;height:34px;border-radius:var(--r-circle);background:var(--ink);color:var(--cream);display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;flex-shrink:0;border:none;cursor:pointer}
.card-add:hover{background:var(--gochujang);transform:rotate(90deg)}
.card-add svg{width:14px;height:14px}


.card-featured{grid-column:1/-1;display:grid;grid-template-columns:1.1fr 1fr;gap:0}
.card-featured .card-img{aspect-ratio:16/10}
.card-featured .card-body{padding:28px 32px}
.card-featured .card-title{font-size:28px;margin-bottom:10px}
.card-featured .card-desc{-webkit-line-clamp:3;font-size:14px;margin-bottom:18px}
.card-featured .card-price{font-size:22px;white-space:nowrap}
@media(max-width:768px){.card-featured{grid-template-columns:1fr}.card-featured .card-body{padding:20px}}

/* STORY STRIP */
.story-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;border-radius:14px;overflow:hidden;border:1px solid var(--ink-alpha-08)}
@media(max-width:900px){.story-strip{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
@media(max-width:520px){.story-strip{grid-template-columns:minmax(0,1fr)}}
.story-card{padding:28px;background:var(--white-pure);border-right:1px solid var(--ink-alpha-08);position:relative;overflow:hidden}
.story-card--lg{padding:36px 28px}
.story-card:last-child{border-right:none}
@media(max-width:900px){.story-card:nth-child(2){border-right:none}.story-card:nth-child(1),.story-card:nth-child(2){border-bottom:1px solid var(--ink-alpha-08)}}
.story-num{font-family:var(--font-display);font-weight:800;font-size:60px;line-height:1;letter-spacing:-0.04em;color:var(--ink-alpha-45);margin-bottom:18px}
.story-title{font-family:var(--font-display);font-weight:700;font-size:19px;line-height:1.2;letter-spacing:-0.02em;margin:0 0 10px}
.story-body{font-size:13px;color:var(--ink-alpha-65);line-height:1.6;margin:0}


/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:32px}
@media(max-width:900px){.testimonials-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.testimonials-grid{grid-template-columns:minmax(0,1fr)}}
.testimonial-card{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:var(--r-card);padding:24px;display:flex;flex-direction:column;gap:18px}
.testimonial-head{display:flex;align-items:center;gap:14px}
.testimonial-avatar{width:64px;height:64px;border-radius:var(--r-circle);background:var(--minari);color:var(--cream);font-size:22px;font-weight:700;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-0.02em}
.testimonial-avatar--walnut{background:var(--walnut)}
.testimonial-avatar--gochujang{background:var(--gochujang);color:var(--cream)}
.testimonial-meta{display:flex;flex-direction:column;gap:6px;min-width:0}
.testimonial-name{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--ink);letter-spacing:-0.01em;line-height:1.2}
.testimonial-stars{display:inline-flex;gap:2px;color:var(--brass)}
.testimonial-stars svg{width:14px;height:14px;display:block}
.testimonial-stars .star-empty{color:var(--ink-alpha-20)}
.testimonial-quote{margin:0;font-size:14px;line-height:1.6;color:var(--ink-alpha-80);font-style:normal;border-left:2px solid var(--ink-alpha-08);padding-left:14px}


/* TWO-COL CONTENT */
.two-col{display:grid;grid-template-columns:5fr 7fr;gap:48px;align-items:start}
@media(max-width:900px){.two-col{grid-template-columns:1fr;gap:28px}}
.address-card{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:20px 16px}
.address-card .full{grid-column:1/-1}
.address-label{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-alpha-65);margin-bottom:8px;font-weight:600}
.address-val{font-size:15px;color:var(--ink);font-weight:500;line-height:1.45}
.address-val.mono{font-family:var(--font-mono);font-size:13px}
.map-ph{aspect-ratio:4/3;border-radius:14px;overflow:hidden;position:relative;background:linear-gradient(135deg,var(--cream-3),var(--cream-4));border:1px solid var(--ink-alpha-08)}
.map-ph svg{position:absolute;inset:0;width:100%;height:100%}
.map-skeleton{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--ink-alpha-35);font-size:13px;font-weight:500;letter-spacing:.01em;background:var(--cream-2);pointer-events:none;z-index:var(--z-base)}

/* FOOTER */
.site-footer{border-top:1px solid var(--ink-alpha-08);padding:72px 0 32px;background:var(--ink-alpha-04)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-grid > *{min-width:0}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr;gap:24px;margin-bottom:32px}}
.footer-brand-title{font-family:var(--font-display);font-size:36px;font-weight:700;letter-spacing:-0.03em;line-height:1;margin:0 0 16px;display:flex;align-items:center;gap:10px;color:var(--walnut)}
.footer-brand-title .ko{color:var(--gochujang)}
.footer-bottom-right{display:flex;align-items:center;gap:16px}
.footer-brand-text{font-size:13px;color:var(--ink-alpha-65);line-height:1.6;max-width:320px}
.footer-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-alpha-65);margin:0 0 18px;font-weight:600}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:10px}
/* RULE-A11-07: footer-col мигрирован с <a data-route|data-info> на <button>; стили — на оба */
.footer-col a,.footer-col button{font-size:13px;color:var(--ink-alpha-65);transition:color .15s;cursor:pointer;background:transparent;border:0;padding:0;font:inherit;text-align:left;line-height:inherit}
.footer-col a:hover,.footer-col button:hover{color:var(--ink)}
.footer-bottom{border-top:1px solid var(--ink-alpha-08);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:12px;color:var(--ink-alpha-65)}

/* OVERLAY / DRAWERS */
.overlay{position:fixed;inset:0;z-index:var(--z-overlay);background:var(--ink-alpha-55);opacity:0;pointer-events:none;transition:opacity .22s;backdrop-filter:blur(3px)}
.overlay.open{opacity:1;pointer-events:auto}
/* Native <dialog> drawer (RULE-HTM-05): override default centering, slide-from-right animation */
.drawer{position:fixed;top:0;right:0;bottom:0;left:auto;margin:0;width:100%;max-width:460px;height:100dvh;max-height:100dvh;background:var(--cream);color:var(--ink);border:none;padding:0;z-index:var(--z-drawer);transform:translateX(100%);transition:transform .32s var(--ease-out);display:flex;flex-direction:column;box-shadow:-20px 0 60px -20px var(--ink-alpha-25)}
.drawer[open]{transform:translateX(0)}
.drawer::backdrop{background:var(--ink-alpha-55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.drawer:not([open]){display:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid var(--ink-alpha-08);flex-shrink:0}
.drawer-title{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-0.025em;margin:0}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px}
.drawer-foot{padding:16px 24px calc(16px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--ink-alpha-08);background:var(--cream);flex-shrink:0}
.close-btn{width:36px;height:36px;border-radius:var(--r-button);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-alpha-55);transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;cursor:pointer;border:none;background:none}
.close-btn:hover{background:var(--ink-alpha-06);color:var(--ink)}
.close-btn svg{width:18px;height:18px}

/* PRODUCT DRAWER (wider) */
.drawer-product{max-width:560px}
.product-hero{aspect-ratio:4/3;border-radius:var(--r-card);overflow:hidden;margin-bottom:20px;position:relative;background:var(--cream-2)}
.product-hero img{width:100%;height:100%;object-fit:cover}
.product-hero .card-badges{left:14px;top:14px}
.product-hero .card-fav{top:14px;right:14px}
.product-title{font-family:var(--font-display);font-weight:700;font-size:28px;line-height:1.1;letter-spacing:-0.03em;margin:0 0 6px}
.product-ko{font-family:var(--font-display);font-weight:300;color:var(--gochujang);font-size:16px;margin-bottom:14px;letter-spacing:-0.02em}
.product-desc{font-size:14px;line-height:1.6;color:var(--ink-alpha-65);margin:0 0 22px}
.product-section{border-top:1px solid var(--ink-alpha-08);padding:18px 0}
.product-section h5{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-alpha-45);margin:0 0 12px;font-weight:600}
.ing-list{display:flex;flex-wrap:wrap;gap:6px}
.ing-chip{font-size:12px;color:var(--ink-alpha-55);padding:4px 10px;border:1px solid var(--ink-alpha-10);border-radius:20px;background:var(--white-pure)}
.macro-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.macro{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:var(--r-button);padding:10px 12px;text-align:left}
.macro .lbl{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-alpha-35);margin-bottom:4px;font-weight:600}
.macro .val{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.option-group{display:flex;flex-direction:column;gap:8px}
.option-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid var(--ink-alpha-10);border-radius:var(--r-button);background:var(--white-pure);cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s}
.option-row:hover{border-color:var(--ink-alpha-25)}
.option-row input{position:absolute;opacity:0;pointer-events:none}
.option-row.checked{background:var(--ink-alpha-04);border-color:var(--ink)}
.option-row .chk{width:18px;height:18px;border-radius:var(--r-circle);border:1.5px solid var(--ink-alpha-25);flex-shrink:0;display:grid;place-items:center}
.option-row.checked .chk{border-color:var(--ink);background:var(--ink)}
.option-row.checked .chk::after{content:'';width:6px;height:6px;border-radius:var(--r-circle);background:var(--cream)}
.option-row .name{font-size:13px;font-weight:500;flex:1;margin:0 12px}
.option-row .add-price{font-size:12px;color:var(--ink-alpha-65);font-variant-numeric:tabular-nums}

.spice-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.spice-btn{padding:10px;border:1px solid var(--ink-alpha-10);border-radius:var(--r-button);background:var(--white-pure);font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;text-align:center}
.spice-btn:hover{border-color:var(--ink-alpha-25)}
.spice-btn.active{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.spice-btn.active .sp-dot{background:var(--cream)}
.spice-btn .sp-dots{display:flex;justify-content:center;gap:3px;margin-bottom:6px}
.spice-btn .sp-dot{width:5px;height:5px;border-radius:var(--r-circle);background:var(--ink-alpha-14)}
.spice-btn .sp-dot.on{background:var(--gochujang)}
.spice-btn.active .sp-dot.on{background:var(--gochujang)}
.spice-btn .sp-label{font-size:11px;font-weight:500}

.qty-row{display:flex;align-items:center;justify-content:space-between}
.qty-ctrl{display:flex;align-items:center;gap:2px;background:var(--white-pure);border:1px solid var(--ink-alpha-10);border-radius:var(--r-button);padding:2px}
.qty-btn{width:32px;height:32px;border-radius:var(--r-input);display:inline-flex;align-items:center;justify-content:center;color:var(--ink);transition:background .15s;cursor:pointer;border:none;background:none;font-family:inherit}
.qty-btn:hover{background:var(--ink-alpha-06)}
.qty-val{min-width:28px;text-align:center;font-family:var(--font-display);font-weight:700;font-size:16px;font-variant-numeric:tabular-nums}
.qty-label{font-size:12px;color:var(--ink-alpha-65);text-transform:uppercase;letter-spacing:.1em;font-weight:600}

.add-to-cart-row{display:flex;align-items:center;gap:12px}
.total-preview{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;margin-right:auto}

/* CART */
.cart-empty{text-align:center;padding:40px 20px;color:var(--ink-alpha-65)}
.cart-empty-icon{width:64px;height:64px;margin:0 auto 20px;border-radius:var(--r-circle);background:var(--ink-alpha-06);display:grid;place-items:center;color:var(--ink-alpha-35)}
.cart-empty h3{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--ink);margin:0 0 8px;letter-spacing:-0.02em}
.cart-empty p{font-size:13px;margin:0 0 20px}

.cart-item{display:grid;grid-template-columns:68px 1fr auto;gap:14px;padding:14px 0;border-bottom:1px solid var(--ink-alpha-06)}
.cart-item:last-child{border-bottom:none}
.cart-item-img{width:68px;height:68px;border-radius:10px;overflow:hidden;background:var(--cream-2)}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-body{min-width:0}
.cart-item-name{font-family:var(--font-display);font-weight:700;font-size:14px;line-height:1.25;letter-spacing:-0.015em;margin:0 0 4px}
.cart-item-meta{font-size:11px;color:var(--ink-alpha-65);line-height:1.5}
.cart-item-meta span{margin-right:8px}
.cart-item-bot{display:flex;justify-content:space-between;align-items:center;margin-top:6px;gap:8px}
.cart-item-price{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--brass);font-variant-numeric:tabular-nums}
.cart-item-remove{font-size:11px;color:var(--ink-alpha-45);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;text-decoration-thickness:.5px;text-underline-offset:2px;transition:color .15s;font-family:inherit}
.cart-item-remove:hover{color:var(--gochujang)}
.cart-item-aside{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;gap:8px}
.qty-ctrl-sm{display:inline-flex;background:var(--white-pure);border:1px solid var(--ink-alpha-10);border-radius:var(--r-input);padding:1px}
.qty-ctrl-sm button{width:26px;height:26px;border:none;background:none;cursor:pointer;color:var(--ink);font-family:inherit}
.qty-ctrl-sm button:hover{background:var(--ink-alpha-06);border-radius:4px}
.qty-ctrl-sm .v{display:inline-flex;align-items:center;justify-content:center;min-width:24px;font-family:var(--font-display);font-weight:700;font-size:13px;font-variant-numeric:tabular-nums}

.summary{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:10px;padding:16px;margin-top:16px}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--ink-alpha-65)}
.summary-row.strong{padding-top:14px;margin-top:6px;border-top:1px solid var(--ink-alpha-08);font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-0.02em;color:var(--ink);font-variant-numeric:tabular-nums}
.summary-row.discount{color:var(--minari-2)}
.summary-row .v{font-variant-numeric:tabular-nums;font-weight:500;color:var(--ink)}
.summary-row.strong .v{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--ink)}
#cart-foot .summary{margin-top:12px}
#go-checkout{margin-top:14px}
#clr-promo{margin-left:8px;background:none;border:none;color:inherit;cursor:pointer;text-decoration:underline;font-size:11px}
#clr-promo:hover{color:var(--gochujang)}
#clr-promo:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:4px}

.promo-row{display:flex;gap:8px;margin-top:12px}
.input{height:40px;padding:0 14px;border:1px solid var(--ink-alpha-14);border-radius:var(--r-button);background:var(--white-pure);font-family:inherit;font-size:13px;color:var(--ink);width:100%;transition:border-color .15s}
.input:focus{border-color:var(--ink);outline:none}
.input:focus-visible{outline:2px solid var(--minari);outline-offset:2px;border-color:var(--ink)}
.input.err{border-color:var(--gochujang)}
.input[readonly]{opacity:.6}

.weight-meter{background:var(--minari-alpha-08);border:1px solid var(--minari-alpha-20);border-radius:10px;padding:12px 14px;margin-top:14px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--minari-2)}
.weight-meter b{font-family:var(--font-display);font-weight:700;font-size:16px;font-variant-numeric:tabular-nums;color:var(--ink);letter-spacing:-0.02em}

/* CHECKOUT */
.checkout-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:start}
@media(max-width:900px){.checkout-grid{grid-template-columns:1fr}}
.stepper{display:flex;gap:10px;margin-bottom:28px;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-alpha-35);font-weight:500}
.step.active{color:var(--ink)}
.step.done{color:var(--minari-2)}
.step .n{width:24px;height:24px;border-radius:var(--r-circle);background:var(--ink-alpha-08);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:12px;color:var(--ink-alpha-45)}
.step.active .n{background:var(--ink);color:var(--cream)}
.step.done .n{background:var(--minari);color:var(--cream)}
.step .sep{width:28px;height:1px;background:var(--ink-alpha-14)}
.step.done + .step .sep{background:var(--minari)}
.step-sep{flex:0 0 28px;height:1px;background:var(--ink-alpha-14);align-self:center}
.step.done + .step-sep{background:var(--minari)}

.card-block{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:22px;margin-bottom:14px}
.card-block h3{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em;margin:0 0 16px}
.label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-alpha-45);margin-bottom:6px;font-weight:600}
.field{margin-bottom:14px}
.field.err .input{border-color:var(--gochujang)}
.field .err-msg{display:none;color:var(--gochujang);font-size:11px;margin-top:5px}
.field.err .err-msg{display:block}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.grid-2{grid-template-columns:1fr}}

.method-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.method-grid{grid-template-columns:1fr}}
.method-card{padding:16px;border:1.5px solid var(--ink-alpha-10);border-radius:10px;cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;position:relative;background:var(--white-pure)}
.method-card:hover{border-color:var(--ink-alpha-25)}
.method-card.active{border-color:var(--ink);background:var(--ink-alpha-04)}
.method-card h4,.method-card-title{display:block;font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:-0.015em;margin:0 0 4px}
.method-card p,.method-card-text{display:block;font-size:12px;color:var(--ink-alpha-55);margin:0;line-height:1.5}
.method-card .chk{position:absolute;top:12px;right:12px;width:18px;height:18px;border-radius:var(--r-circle);border:1.5px solid var(--ink-alpha-20);display:grid;place-items:center}
.method-card.active .chk{border-color:var(--ink);background:var(--ink)}
.method-card.active .chk::after{content:'';width:6px;height:6px;border-radius:var(--r-circle);background:var(--cream)}
/* RULE-HTM-04: settings preferences — <button aria-pressed>, не <label>+radio (см. checkout-вариант ниже).
   Button-reset, чтобы UA-стиль не ломал общий .method-card layout; text-align:left под левое выравнивание (RULE-CSS-01). */
.method-card--toggle{font:inherit;color:inherit;text-align:left;width:100%;appearance:none;-webkit-appearance:none}

.slot-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
@media(max-width:520px){.slot-picker{grid-template-columns:repeat(3,1fr)}}
.slot{padding:10px 8px;border:1px solid var(--ink-alpha-10);border-radius:var(--r-button);background:var(--white-pure);font-family:inherit;cursor:pointer;font-size:12px;font-weight:500;color:var(--ink);text-align:center;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;font-variant-numeric:tabular-nums}
.slot:hover{border-color:var(--ink-alpha-25)}
.slot.active{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.slot.soon{position:relative}
.slot.soon::after{content:'';position:absolute;top:4px;right:4px;width:5px;height:5px;border-radius:var(--r-circle);background:var(--minari)}
.slot-day-note{font-size:12px;color:var(--ink-alpha-45);margin:0 0 10px}

.order-preview{position:sticky;top:80px;background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:20px}
.op-title{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.02em;margin:0 0 14px;display:flex;justify-content:space-between;align-items:baseline}
.op-title .ct{font-size:11px;color:var(--ink-alpha-45);font-weight:500;text-transform:uppercase;letter-spacing:.1em}
.op-items{max-height:240px;overflow-y:auto;margin:0 -6px 10px;padding:0 6px}
.op-item{display:flex;gap:10px;padding:8px 0;font-size:12px;border-bottom:1px solid var(--ink-alpha-06)}
.op-item:last-child{border-bottom:none}
.op-item-thumb{width:40px;height:40px;border-radius:var(--r-button);overflow:hidden;flex-shrink:0;background:var(--cream-2)}
.op-item-thumb img{width:100%;height:100%;object-fit:cover}
.op-item-body{flex:1;min-width:0}
.op-item-name{font-weight:600;color:var(--ink);margin-bottom:2px;font-family:var(--font-display);font-size:13px;letter-spacing:-0.015em;line-height:1.2}
.op-item-meta{color:var(--ink-alpha-45);font-size:11px}
.op-item-price{font-variant-numeric:tabular-nums;color:var(--ink);font-weight:600;font-family:var(--font-display);font-size:13px;flex-shrink:0}

/* SUCCESS */
.success-wrap{max-width:560px;margin:0 auto;padding:60px 24px;text-align:center}
.success-icon{width:88px;height:88px;border-radius:var(--r-circle);background:var(--minari);display:grid;place-items:center;margin:0 auto 24px;color:var(--cream)}
.success-icon svg{width:40px;height:40px}
.success-title{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,5vw,48px);line-height:1.05;letter-spacing:-0.035em;margin:0 0 14px}
.success-title .accent{color:var(--minari);font-weight:300;font-style:italic}
.success-sub{font-size:15px;color:var(--ink-alpha-55);line-height:1.6;margin:0 0 32px}
.format-intro{font-size:15px;line-height:1.7;color:var(--ink-alpha-65);margin:24px 0 28px;max-width:460px}
.story-lede{font-size:16px;line-height:1.7;color:var(--ink-alpha-55);max-width:680px}
.legal-note{font-size:11px;color:var(--ink-alpha-45);line-height:1.5;margin:12px 0 0;text-align:center}
.legal-note a,.legal-note button{text-decoration:underline;background:transparent;border:0;padding:0;color:inherit;font:inherit;line-height:inherit;cursor:pointer}
.legal-note button:focus-visible{outline:2px solid var(--minari);outline-offset:2px;border-radius:2px}
.drawer-title-count{font-weight:300;color:var(--ink-alpha-45);font-size:14px;margin-left:8px}
.order-card{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:24px;text-align:left;margin-bottom:24px}
.order-card .row{display:flex;justify-content:space-between;font-size:13px;padding:8px 0}
.order-card .row .l{color:var(--ink-alpha-65)}
.order-card .row .v{font-weight:500;font-variant-numeric:tabular-nums}
.order-card .row.big{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-0.02em;border-top:1px solid var(--ink-alpha-08);margin-top:8px;padding-top:14px}
.order-card .order-id{font-family:var(--font-mono)}
.order-card [data-copy-id]{margin-left:8px;height:22px;padding:0 8px;font-size:11px}
.track-bar{background:var(--ink-alpha-04);border-radius:10px;padding:18px 20px;margin-top:16px}
.track-steps{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.track-step{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;gap:8px;font-size:11px;color:var(--ink-alpha-35);font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.track-step .dot{width:10px;height:10px;border-radius:var(--r-circle);background:var(--ink-alpha-14);transition:background .3s,transform .3s}
.track-step.active .dot{background:var(--gochujang);animation:pulse 1.4s ease-in-out infinite;box-shadow:0 0 0 4px var(--gochujang-alpha-15)}
.track-step.done .dot{background:var(--minari)}
.track-step.active,.track-step.done{color:var(--ink)}


/* ACCOUNT */
.account-grid{display:grid;grid-template-columns:280px 1fr;gap:28px;align-items:start}
@media(max-width:768px){.account-grid{grid-template-columns:1fr}}
.side-nav{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:8px}
.side-nav button{width:100%;padding:12px 14px;border:none;background:none;text-align:left;border-radius:var(--r-button);font-family:inherit;font-size:13px;color:var(--ink-alpha-65);display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s}
.side-nav button:hover{background:var(--ink-alpha-04);color:var(--ink)}
.side-nav button.active{background:var(--ink);color:var(--cream)}
.side-nav svg{width:16px;height:16px}
.acct-head{margin-bottom:24px}
.acct-head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4vw,40px);line-height:1.05;letter-spacing:-0.03em;margin:0 0 8px}
.acct-head p{color:var(--ink-alpha-55);font-size:14px;margin:0}

.order-row{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:var(--r-card);padding:18px;margin-bottom:10px;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}
@media(max-width:640px){.order-row{grid-template-columns:1fr;gap:10px}}
.order-row .id{font-family:var(--font-mono);font-size:12px;color:var(--ink-alpha-45);letter-spacing:.02em;margin-top:6px}
.order-row .meta{font-size:12px;color:var(--ink-alpha-55);margin-top:2px}
.order-row .items-preview{font-size:13px;color:var(--ink)}
.order-row .items-preview b{font-family:var(--font-display);font-weight:700;letter-spacing:-0.015em}
.order-row .right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
@media(max-width:640px){.order-row .right{align-items:flex-start}}
.order-row .total{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.status-chip{display:inline-flex;align-items:center;gap:5px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;padding:4px 8px;border-radius:4px}
.status-chip .dot{width:5px;height:5px;border-radius:var(--r-circle)}
.status-chip.cooking{background:var(--gochujang-alpha-12);color:var(--gochujang-2)}
.status-chip.cooking .dot{background:var(--gochujang);animation:pulse 1.4s ease-in-out infinite}
.status-chip.ready{background:var(--minari-alpha-18);color:var(--minari-2)}
.status-chip.ready .dot{background:var(--minari)}

.empty-state{text-align:center;padding:64px 20px;border:1px dashed var(--ink-alpha-14);border-radius:14px;background:var(--ink-alpha-04);grid-column:1/-1}
.empty-state h3{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-0.02em;margin:0 0 8px}
.empty-state p{color:var(--ink-alpha-55);font-size:13px;margin:0 0 20px}

/* TOAST */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(40px);background:var(--ink);color:var(--cream);padding:14px 20px;border-radius:10px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;opacity:0;pointer-events:none;transition:transform .25s var(--ease-out),opacity .25s var(--ease-out);z-index:var(--z-toast);box-shadow:var(--shadow-lg);max-width:calc(100% - 48px)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .dot{width:8px;height:8px;border-radius:var(--r-circle);background:var(--minari);flex-shrink:0}

/* MOBILE BOTTOM BAR */
.mobile-bottom{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-mobile-bar);padding:12px 16px calc(12px + env(safe-area-inset-bottom,0px));background:var(--ink);color:var(--cream);display:none;transform:translateY(100%);transition:transform .25s;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 -12px 30px -8px var(--ink-alpha-25)}
.mobile-bottom.show{transform:translateY(0)}
@media(max-width:640px){.mobile-bottom{display:flex}}
.mobile-bottom .cnt{font-size:12px;color:var(--cream-alpha-65)}
.mobile-bottom .amt{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease-out),transform .55s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}


/* AUTH MODAL */
.auth-overlay{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;background:var(--ink-alpha-55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .25s var(--ease-out);overflow-y:auto;padding:20px 16px}
.auth-overlay.open{opacity:1;pointer-events:all}
.auth-modal{background:var(--cream);border-radius:22px;padding:40px 36px 36px;width:100%;max-width:400px;flex-shrink:0;position:relative;transform:translateY(24px) scale(0.97);transition:transform .3s var(--ease-out);box-shadow:0 32px 80px -12px var(--ink-alpha-25)}
.auth-overlay.open .auth-modal{transform:none}
@media(max-width:480px){.auth-modal{margin:0;padding:28px 20px 24px;border-radius:18px}}
.auth-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:var(--r-circle);display:inline-flex;align-items:center;justify-content:center;background:var(--ink-alpha-06);color:var(--ink-alpha-45);transition:background .15s,color .15s,border-color .15s,transform .15s,opacity .15s;border:none;cursor:pointer}
.auth-close:hover{background:var(--ink-alpha-10);color:var(--ink)}
.auth-close svg{width:12px;height:12px}
.auth-logo-mark{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--gochujang);letter-spacing:.02em;margin-bottom:22px;display:flex;align-items:center;gap:6px}
.auth-logo-mark span{color:var(--ink-alpha-35);font-weight:400}
.auth-h{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:-0.03em;margin:0 0 8px;color:var(--ink)}
.auth-sub{font-size:13px;color:var(--ink-alpha-65);margin:0 0 28px;line-height:1.55}
.auth-step{display:none}
.auth-step.active{display:block}
/* admin: needs override of host */
#tg-btn-wrap{margin:8px 0;display:flex;justify-content:center;min-height:52px;align-items:center}
#tg-btn-wrap iframe{border-radius:var(--r-button)!important} /* VALIDATOR-SKIP: RULE-CSS-02: Telegram OAuth iframe injects inline style attributes runtime, override requires !important */
#tg-btn-wrap.consent-locked{opacity:.45;pointer-events:none;transition:opacity .2s var(--ease-out)} /* RULE-AUTH-04: Telegram-флоу залочен, пока #auth-agree не отмечен */
.auth-agree{display:flex;align-items:flex-start;gap:8px;margin-top:16px;cursor:pointer;font-size:11px;color:var(--ink-alpha-65);line-height:1.5}
.auth-agree input[type=checkbox]{margin-top:2px;accent-color:var(--gochujang);flex-shrink:0}
.auth-agree a,.auth-agree button{text-decoration:underline;color:var(--ink-alpha-80);background:transparent;border:0;padding:0;font:inherit;line-height:inherit;cursor:pointer}
.auth-agree button:focus-visible{outline:2px solid var(--minari);outline-offset:2px;border-radius:2px}






.err-shake{animation:err-shake .35s ease}
@keyframes err-shake{0%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}100%{transform:translateX(0)}}
/* header avatar */
.acct-avatar{width:28px;height:28px;border-radius:var(--r-circle);background:var(--minari);color:var(--cream);font-size:11px;font-weight:700;font-family:var(--font-display);display:inline-flex;align-items:center;justify-content:center;letter-spacing:.02em}
/* profile panel logout */
.profile-user-card{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:20px 20px 16px;margin-bottom:16px;display:flex;align-items:center;gap:16px}
.profile-avatar-lg{width:52px;height:52px;border-radius:var(--r-circle);background:var(--minari);color:var(--cream);font-size:20px;font-weight:700;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.profile-user-info{flex:1;min-width:0}
.profile-user-info .uname{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em;margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-user-info .uphone{font-size:12px;color:var(--ink-alpha-65);font-family:var(--font-mono)}





/* home extras */
.promise-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
@media(max-width:768px){.promise-grid{grid-template-columns:minmax(0,1fr)}}
.promise{background:var(--white-pure);border:1px solid var(--ink-alpha-08);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:14px}
.promise .ico{width:40px;height:40px;border-radius:10px;background:var(--gochujang-alpha-10);display:grid;place-items:center;color:var(--gochujang)}
.promise .ico--minari{background:var(--minari-alpha-12);color:var(--minari-2)}
.promise .ico--brass{background:var(--brass-alpha-18);color:var(--brass-2)}
.promise .ico svg{width:20px;height:20px}
.promise h3{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em;margin:0}
.promise p{font-size:13px;color:var(--ink-alpha-65);line-height:1.55;margin:0}

/* search overlay + mission view */
/* SEARCH OVERLAY */
.search-overlay{position:fixed;inset:0;z-index:var(--z-modal);background:var(--ink-alpha-55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;padding:80px 20px 20px;opacity:0;pointer-events:none;transition:opacity .2s}
.search-overlay.open{opacity:1;pointer-events:auto}
.search-box{width:100%;max-width:560px;background:var(--white-pure);border-radius:14px;overflow:hidden;box-shadow:0 24px 60px -10px var(--ink-alpha-25);transform:translateY(-12px);transition:transform .25s cubic-bezier(.16,1,.3,1)}
.search-overlay.open .search-box{transform:translateY(0)}
.search-input-wrap{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--ink-alpha-08)}
.search-input-wrap svg{flex-shrink:0;color:var(--ink-alpha-35)}
.search-inp{flex:1;border:none;font-family:var(--font-body);font-size:16px;color:var(--ink);background:transparent;line-height:1}
.search-inp:focus{outline:none}
.search-inp:focus-visible{outline:2px solid var(--minari);outline-offset:2px;border-radius:4px}
.search-inp::placeholder{color:var(--ink-alpha-25)}
.search-clear{width:24px;height:24px;border-radius:var(--r-circle);background:var(--ink-alpha-08);color:var(--ink-alpha-45);font-size:16px;line-height:1;display:none;align-items:center;justify-content:center;cursor:pointer;border:none;flex-shrink:0}
.search-clear.show{display:inline-flex}
.search-results{max-height:400px;overflow-y:auto;overscroll-behavior:contain}
.search-result{display:flex;align-items:center;gap:14px;padding:12px 18px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--ink-alpha-06)}
.search-result:last-child{border-bottom:none}
.search-result:hover,.search-result.focused{background:var(--ink-alpha-04)}
.search-result-thumb{width:44px;height:44px;border-radius:var(--r-button);overflow:hidden;flex-shrink:0;background:var(--cream-2)}
.search-result-thumb img{width:100%;height:100%;object-fit:cover}
.search-result-body{flex:1;min-width:0}
.search-result-name{font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:-0.015em;color:var(--ink);margin-bottom:2px}
.search-result-meta{font-size:12px;color:var(--ink-alpha-65)}
.search-result-price{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--brass);flex-shrink:0;font-variant-numeric:tabular-nums}
.search-empty{padding:32px 18px;text-align:center;color:var(--ink-alpha-45);font-size:13px}
.search-hints{display:flex;gap:16px;padding:10px 18px;border-top:1px solid var(--ink-alpha-06);background:var(--ink-alpha-04)}
.search-hints span{font-size:11px;color:var(--ink-alpha-35)}
@media(max-width:520px){.search-hints{display:none}}
mark{background:var(--gochujang-alpha-15);color:var(--gochujang);border-radius:2px;padding:0 1px}
/* ── mission view ─────────────────────────────────────────────── */
.mission-lede{font-size:17px;line-height:1.7;color:var(--ink-alpha-65);max-width:680px;margin:0 0 20px}
.mission-lede-strong{font-family:var(--font-display);font-weight:500;font-size:21px;line-height:1.5;letter-spacing:-0.015em;color:var(--ink);max-width:680px;margin:28px 0 0}

.mission-section-title{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-0.03em;margin:12px 0 0;max-width:18ch;color:var(--ink)}
.manifest-list{display:flex;flex-direction:column;border-top:1px solid var(--ink-alpha-10)}
.manifest-item{display:grid;grid-template-columns:120px 1fr;gap:48px;padding:40px 0;border-bottom:1px solid var(--ink-alpha-10);align-items:start}
.manifest-num{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--gochujang);letter-spacing:.1em;padding-top:6px}
.manifest-body h3{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,2.6vw,30px);line-height:1.2;letter-spacing:-0.02em;color:var(--ink);margin:0 0 14px;max-width:28ch}
.manifest-body p{font-size:16px;line-height:1.7;color:var(--ink-alpha-65);margin:0;max-width:62ch}
@media(max-width:700px){
  .manifest-item{grid-template-columns:1fr;gap:12px;padding:32px 0}
  .manifest-num{padding-top:0}
  .manifest-body h3{font-size:22px}
  .manifest-body p{font-size:15px}
}
.mission-closing{background:var(--cream-2);border-top:1px solid var(--ink-alpha-08)}
.mission-closing-lede{font-family:var(--font-display);font-weight:500;font-size:clamp(26px,3.2vw,40px);line-height:1.3;letter-spacing:-0.025em;color:var(--ink);margin:0 0 28px;max-width:22ch}
.mission-closing-lede .em{color:var(--minari);font-style:italic;font-weight:400}
.mission-closing-body{font-size:17px;line-height:1.7;color:var(--ink-alpha-65);margin:0 0 18px;max-width:62ch}
.mission-join{border-top:1px solid var(--ink-alpha-10);padding-top:32px;margin-top:16px;display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between}
.mission-join-text{font-family:var(--font-display);font-weight:600;font-size:clamp(22px,2.4vw,28px);letter-spacing:-0.02em;margin:0;max-width:26ch;line-height:1.3}
.mission-join-text .em{color:var(--minari)}

/* info modal */
/* Native <dialog> info-modal (RULE-HTM-05): override default + ::backdrop */
.info-modal{position:fixed;inset:0;z-index:var(--z-toast);border:none;padding:20px;background:transparent;color:var(--ink);max-width:none;max-height:none;width:100%;height:100%;margin:0;align-items:center;justify-content:center}
.info-modal[open]{display:flex;animation:fadeIn .2s}
.info-modal:not([open]){display:none}
.info-modal::backdrop{background:var(--ink-alpha-45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.info-panel{position:relative;background:var(--cream);max-width:560px;width:100%;max-height:85vh;overflow-y:auto;border-radius:var(--r-modal);padding:40px;box-shadow:0 30px 80px -20px var(--shadow-deep)}
.info-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:var(--r-circle);background:var(--ink-alpha-06);color:var(--ink);font-size:18px;cursor:pointer}
.info-close:hover{background:var(--ink-alpha-10)}
.info-body h2{font-family:var(--font-display);font-weight:700;font-size:32px;line-height:1.1;letter-spacing:-.03em;margin:0 0 8px}
.info-body .info-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--gochujang);font-weight:600;margin-bottom:8px}
.info-body p{font-size:14px;line-height:1.65;color:var(--ink-alpha-65);margin:0 0 16px}
.info-body ul{margin:0 0 20px;padding:0;list-style:none}
.info-body ul li{font-size:13px;line-height:1.6;color:var(--ink-alpha-65);padding:10px 0;border-bottom:1px solid var(--ink-alpha-06);display:flex;gap:10px}
.info-body ul li::before{content:'·';color:var(--minari);font-weight:bold}
.info-body .info-form{display:grid;gap:10px;margin-top:20px}
.info-body .info-form input,.info-body .info-form textarea,.info-body .info-form select{padding:10px 12px;border:1px solid var(--ink-alpha-10);border-radius:var(--r-button);font-size:13px;font-family:inherit;background:var(--white-pure)}
.info-body .info-form button{padding:12px;background:var(--ink);color:var(--cream);border-radius:var(--r-button);font-size:13px;font-weight:600;margin-top:4px;cursor:pointer}
.info-body .info-form button:hover{background:var(--walnut)}
.info-body .info-success{background:var(--minari-alpha-10);border:1px solid var(--minari-alpha-30);color:var(--minari-2);padding:14px;border-radius:var(--r-button);font-size:13px;text-align:center;margin-top:14px}

/* Print styles — readable single-column page, hide UI chrome */
@media print {
  .site-header, .mobile-bottom, #mob-nav, #mob-nav-overlay,
  .marquee, .drawer, .auth-overlay, .info-modal,
  #search-overlay, #adm-panel, #adm-overlay, #adm-fab, #adm-login-overlay,
  .skip-link, .icon-btn, .mob-hamburger, .card-add, .card-fav,
  /* VALIDATOR-SKIP: RULE-CSS-02: print stylesheet must override min-height/display from media-narrower screens */
  .btn, .adm-login-trigger { display: none !important; }
  body { background: var(--white-pure); color: var(--black-pure); font-size: 12pt; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  a { color: var(--black-pure); text-decoration: underline; }
  .container { max-width: none; padding: 0 12mm; }
  picture, img { break-inside: avoid; max-width: 100%; }
  h1, h2, h3 { break-after: avoid; }
}

  /* FOCUS PARITY — keyboard ring для всех hover-bearing интерактивов (RULE-A11-02, WCAG 2.4.7) */
  .nav-links a:focus-visible,
  .nav-links button:focus-visible,
  .footer-col a:focus-visible,
  .footer-col button:focus-visible,
  button.logo:focus-visible { outline: 2px solid var(--minari); outline-offset: 2px; border-radius: 2px; }
  .icon-btn:focus-visible,
  .mob-hamburger:focus-visible,
  .mob-nav-close:focus-visible,
  .close-btn:focus-visible,
  .auth-close:focus-visible,
  .info-close:focus-visible { outline: 2px solid var(--ink); outline-offset: 2px; }
  .mob-nav-link:focus-visible { outline: 2px solid var(--minari); outline-offset: -2px; }
  .hp-featured:focus-visible,
  .card:focus-visible { outline: 2px solid var(--minari); outline-offset: 3px; }
  .chip:focus-visible { outline: 2px solid var(--ink); outline-offset: 2px; }
  .card-fav:focus-visible,
  .card-add:focus-visible { outline: 2px solid var(--ink); outline-offset: 2px; border-radius: 6px; }
  .option-row:focus-visible,
  .method-card:has(:focus-visible),
  .method-card--toggle:focus-visible,
  .slot:focus-visible,
  .spice-btn:focus-visible { outline: 2px solid var(--minari); outline-offset: 2px; }
  .qty-btn:focus-visible,
  .qty-ctrl-sm button:focus-visible,
  .cart-item-remove:focus-visible { outline: 2px solid var(--ink); outline-offset: 2px; border-radius: 4px; }
  .side-nav button:focus-visible { outline: 2px solid var(--minari); outline-offset: -2px; }
  .search-result:focus-visible { outline: 2px solid var(--minari); outline-offset: -2px; }
  .info-body .info-form button:focus-visible { outline: 2px solid transparent; outline-offset: 2px; box-shadow: 0 0 0 2px var(--cream), 0 0 0 4px var(--ink); }

} /* @layer components */

@layer utilities {
  /* RULE-CSS-08 utilities layer: высокий приоритет, поверх components */
  /* Текущие utility-rules (.reveal, .err-shake, @media print) пока в components — будут мигрированы IMP-30 deep */

  /* Spacing — каркас для inline-style migration (Stage 4 hygiene burst) */
  .mb-8{margin-bottom:8px}
  .mb-16{margin-bottom:16px}
  .mb-20{margin-bottom:20px}
  .mb-24{margin-bottom:24px}
  .mb-28{margin-bottom:28px}
  .mb-40{margin-bottom:40px}
  .mt-8{margin-top:8px}
  .mt-16{margin-top:16px}

  /* Inline link унаследует цвет родителя — заменяет style="color:inherit;text-decoration:none" */
  .link-inherit{color:inherit;text-decoration:none}

  /* Узкая колонка для текстовых блоков */
  .col--narrow{max-width:820px}

  /* RULE-HTM-12 + RULE-A11-07: screen-reader-only паттерн.
     .sr-only — текст уходит за viewport, но остаётся в a11y tree (live regions, описания).
     .vis-hidden — то же + focusable: для скрытых radio внутри <label class="method-card">.
     НЕ использовать display:none / visibility:hidden — они выкидывают и из a11y tree, и из tab-flow. */
  .sr-only,
  .vis-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}
}

