/* TratoDirect — editorial-utilitarian Guatemalan e-commerce */

/* ───── reset */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: transparent; }
input, select, textarea { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; cursor: pointer; }
img, svg { display: block; max-width: 100%; }

/* ───── tokens */
:root {
  --td-paper: oklch(0.965 0.012 80);
  --td-ink:   oklch(0.18 0.012 60);
  --td-primary: oklch(0.50 0.10 170);
  --td-accent:  oklch(0.55 0.16 28);
  --td-line:    oklch(0.85 0.012 80);
  --td-panel:   oklch(0.93 0.014 80);
  --td-density: 1;

  --td-display: "Bricolage Grotesque", ui-sans-serif, system-ui;
  --td-body: "Geist", ui-sans-serif, system-ui;
  --td-mono: "Geist Mono", ui-monospace, "SFMono-Regular", monospace;
  --td-italic: "Instrument Serif", "Times New Roman", serif;

  --td-rad: 4px;

  --td-pad-section: calc(64px * var(--td-density));
  --td-pad-block:   calc(28px * var(--td-density));
}

html, body { background: var(--td-paper); color: var(--td-ink); font-family: var(--td-body); font-size: 16px; line-height: 1.5; -webkit-font-smoothing: antialiased; }

.td-root { min-height: 100vh; }

/* ───── helpers */
.mono { font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 500; }
.dim { opacity: 0.55; }
.small { font-size: 10px; }
.serif-i { font-family: var(--td-italic); font-style: italic; font-weight: 400; letter-spacing: -0.01em; }
.center { text-align: center; }
.hide-sm { display: inline; }
@media (max-width: 700px) { .hide-sm { display: none; } }

.td-container { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 700px) { .td-container { padding: 0 20px; } }

/* ───── nav */
.td-nav { position: sticky; top: 0; z-index: 50; background: color-mix(in oklch, var(--td-paper) 92%, transparent); backdrop-filter: blur(8px); border-bottom: 1px solid var(--td-line); }
.td-nav__inner { display: flex; align-items: center; gap: 28px; padding: 22px 32px; }
.td-nav__brand { display: inline-flex; align-items: center; }
.td-wordmark { display: inline-flex; align-items: baseline; gap: 6px; font-family: var(--td-display); font-weight: 800; letter-spacing: -0.045em; line-height: 1; }
.td-wordmark__t { color: var(--td-ink); }
.td-wordmark__d { color: var(--td-primary); }
.td-wordmark__d .serif-i { font-size: 1.05em; }
.td-wordmark__tld { font-size: 11px; opacity: 0.4; align-self: flex-end; padding-bottom: 4px; letter-spacing: 0.02em; }
.td-wordmark--sm  { font-size: 20px; }
.td-wordmark--md  { font-size: 28px; }
.td-wordmark--nav { font-size: 52px; }
.td-wordmark--lg  { font-size: 48px; }
.td-nav__links { display: flex; gap: 24px; margin-left: 12px; flex: 1; }
.td-nav__links a { font-size: 14px; opacity: 0.7; transition: opacity 0.2s; }
.td-nav__links a:hover, .td-nav__links a.is-active { opacity: 1; }
.td-nav__links a.is-active { text-decoration: underline; text-underline-offset: 6px; text-decoration-thickness: 1px; }
.td-nav__right { display: flex; align-items: center; gap: 14px; }
.td-nav__login { font-size: 14px; opacity: 0.7; }
.td-nav__login:hover { opacity: 1; }
.td-cart { display: inline-flex; align-items: center; gap: 10px; padding: 10px 14px; border: 1px solid var(--td-ink); border-radius: 999px; font-size: 13px; }
.td-cart:hover { background: var(--td-ink); color: var(--td-paper); }
.td-cart__count { font-size: 10px; padding: 2px 6px; background: var(--td-primary); color: var(--td-paper); border-radius: 999px; }
@media (max-width: 900px) { .td-nav__links { display: none; } .td-nav__login { display: none; } }

/* country selector */
.td-country { position: relative; }
.td-country__btn { display: inline-flex; align-items: center; gap: 8px; padding: 8px 10px; border: 1px solid var(--td-line); border-radius: 999px; font-size: 12px; transition: border-color 0.15s; }
.td-country__btn:hover { border-color: var(--td-ink); }
.td-country__btn svg:last-child { opacity: 0.5; }
.td-country__pop { position: absolute; right: 0; top: calc(100% + 8px); min-width: 240px; background: var(--td-paper); border: 1px solid var(--td-line); box-shadow: 0 12px 32px -8px color-mix(in oklch, var(--td-ink) 18%, transparent); padding: 12px; display: flex; flex-direction: column; gap: 4px; z-index: 60; }
.td-country__pop-h { padding: 4px 8px 10px; border-bottom: 1px solid var(--td-line); margin-bottom: 4px; }
.td-country__opt { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; padding: 10px 12px; cursor: pointer; transition: background 0.15s; border-radius: var(--td-rad); text-align: left; }
.td-country__opt:hover:not(.is-disabled) { background: var(--td-panel); }
.td-country__opt.is-active { background: var(--td-panel); }
.td-country__opt.is-disabled { opacity: 0.5; cursor: not-allowed; }
.td-country__name { font-weight: 500; }
.td-country__tag { font-size: 10px; }

/* ───── hero */
.td-hero { padding-top: 20px; padding-bottom: 20px; }
.td-hero__meta { display: flex; gap: 24px; flex-wrap: wrap; padding-bottom: 16px; border-bottom: 1px solid var(--td-line); }
.td-hero__h { font-family: var(--td-display); font-weight: 800; font-size: clamp(56px, 11vw, 152px); line-height: 0.88; letter-spacing: -0.045em; margin: 16px 0 0; display: flex; flex-direction: column; }
.td-hero__line1 { opacity: 0.35; }
.td-hero__line2 { color: var(--td-ink); }
.td-hero__line3 { color: var(--td-primary); display: flex; align-items: baseline; gap: 0.05em; margin-top: 0.10em; }
.td-hero__line3 .serif-i { font-size: 1.05em; line-height: 0.90; color: var(--td-primary); }
.td-hero__period { color: var(--td-accent); }

.td-hero__split { display: grid; grid-template-columns: 1fr 200px; gap: 40px; align-items: end; padding: 0 0 18px; margin-top: -8px; border-bottom: 1px solid var(--td-line); }

/* textcol wrapper — transparent in A mode, becomes left column in B mode */
.td-hero__textcol { display: contents; }

/* ───── HERO LAYOUT B — text on the left, vitrina on the right (compact) */
.td-hero--split { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.95fr); column-gap: 48px; align-items: start; }
.td-hero--split .td-hero__meta    { grid-column: 1; grid-row: 1; }
.td-hero--split .td-hero__textcol { display: flex; flex-direction: column; grid-column: 1; grid-row: 2; gap: 16px; }
.td-hero--split .td-hero__h       { margin-top: 8px; font-size: clamp(46px, 7vw, 104px); }
.td-hero--split .td-hero__split   { padding-bottom: 0; border-bottom: none; margin-top: 0; grid-template-columns: 1fr; }
.td-hero--split .td-hero__seal    { display: none; }
.td-hero--split .td-feature       { grid-column: 2; grid-row: 1 / span 2; align-self: start; padding-top: 0; }
.td-hero--split .td-feature__topbar { padding-top: 0; padding-bottom: 8px; margin-bottom: 12px; gap: 8px; }
.td-hero--split .td-feature__pager  { gap: 10px; }
.td-hero--split .td-feature__arrow  { width: 28px; height: 28px; font-size: 12px; }
.td-hero--split .td-feature__grid { grid-template-columns: 1fr; gap: 14px; }
.td-hero--split .td-feature__img img { aspect-ratio: 16/10; }
.td-hero--split .td-feature__h    { font-size: clamp(20px, 2.1vw, 26px); }
.td-hero--split .td-feature__sub  { font-size: 13px; }
.td-hero--split .td-feature__pitch{ font-size: 13px; }
.td-hero--split .td-feature__cta  { flex-direction: column; align-items: stretch; gap: 8px; }

/* B-mode extra content stack: mini pillars + catalog CTA, fills leftover left-col vertical space */
.td-hero__bcol-extra { display: flex; flex-direction: column; gap: 18px; margin-top: 8px; padding-top: 18px; border-top: 1px solid var(--td-line); }
.td-hero__bpillars { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.td-hero__bpillars li { display: flex; flex-direction: column; gap: 4px; }
.td-hero__bpillars li .mono { font-size: 11px; opacity: 0.5; }
.td-hero__bpillars li b { font-family: var(--td-display); font-size: 15px; font-weight: 600; line-height: 1.2; letter-spacing: -0.005em; }
.td-hero__bpillars li span:last-child { font-size: 12px; line-height: 1.45; opacity: 0.72; text-wrap: pretty; }
.td-hero__bcta { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding-top: 10px; }
.td-hero__bcta .mono { font-size: 11px; opacity: 0.6; }
.td-hero__bdeal { display: flex; flex-direction: column; gap: 10px; padding-top: 18px; border-top: 1px solid var(--td-line); }
.td-hero__bdeal-h { font-family: var(--td-display); font-size: clamp(22px, 2.4vw, 32px); font-weight: 600; letter-spacing: -0.015em; line-height: 1.1; margin: 4px 0 0; text-wrap: pretty; }
.td-hero__bdeal-p { font-size: 14px; line-height: 1.55; opacity: 0.78; margin: 4px 0 6px; max-width: 60ch; }
.td-hero__bdeal-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: 8px; font-size: 14px; line-height: 1.4; }
.td-hero__bdeal-list li { display: grid; grid-template-columns: 30px 1fr; gap: 8px; align-items: baseline; }
.td-hero__bdeal-list li > span:first-child { font-size: 11px; opacity: 0.5; font-family: var(--td-mono); letter-spacing: 0.05em; }
.td-hero__bdeal-list li > span:last-child { opacity: 0.92; text-wrap: pretty; }
@media (max-width: 900px) {
  .td-hero--split { grid-template-columns: 1fr; }
  .td-hero--split .td-hero__meta { grid-column: 1; grid-row: auto; }
  .td-hero--split .td-hero__textcol { grid-column: 1; grid-row: auto; }
  .td-hero--split .td-feature { grid-column: 1; grid-row: auto; }
  .td-hero__bpillars { grid-template-columns: 1fr; }
  .td-hero__bcta { flex-direction: column; align-items: stretch; }
}
.td-hero__lede { max-width: 56ch; font-size: clamp(17px, 1.4vw, 21px); line-height: 1.5; text-wrap: pretty; margin: 0; }
.td-hero__lede em { font-family: var(--td-italic); font-size: 1.05em; }
.td-hero__seal { display: flex; justify-content: flex-end; color: var(--td-ink); }
@media (max-width: 800px) { .td-hero__split { grid-template-columns: 1fr; } .td-hero__seal { justify-content: flex-start; } }

/* ───── feature (rotating) */
.td-feature { padding-top: 16px; }
.td-feature__topbar { display: flex; align-items: center; gap: 14px; padding: 12px 0 12px; border-bottom: 1px solid var(--td-line); margin-bottom: 16px; flex-wrap: wrap; }
.td-feature__count { font-size: 11px; letter-spacing: 0.08em; }
.td-feature__pager { display: flex; align-items: center; gap: 14px; margin-left: auto; }
.td-feature__arrow { width: 36px; height: 36px; border: 1px solid var(--td-ink); border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; font-size: 14px; transition: background 0.15s, color 0.15s; }
.td-feature__arrow:hover { background: var(--td-ink); color: var(--td-paper); }
.td-feature__pause { width: 36px; height: 36px; padding: 0; margin-left: 4px; }
.td-feature__pause[aria-pressed="true"] { background: var(--td-ink); color: var(--td-paper); }
.td-feature__dots { display: flex; gap: 8px; }
.td-feature__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--td-line); transition: background 0.2s, transform 0.2s; }
.td-feature__dot.is-active { background: var(--td-ink); transform: scale(1.3); }
.td-feature__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; animation: td-fade 0.4s ease; }
@keyframes td-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.td-feature__img { position: relative; cursor: pointer; }
.td-feature__img .td-img--photo img { object-fit: contain; padding: 0; background: transparent; }
.td-feature__tag { display: inline-flex; align-items: center; background: var(--td-ink); color: var(--td-paper); padding: 5px 10px; font-size: 10px; letter-spacing: 0.12em; line-height: 1; }
.td-feature__sale { display: inline-flex; align-items: center; gap: 8px; padding: 5px 10px; font-size: 10px; letter-spacing: 0.1em; line-height: 1; color: var(--td-paper); }
.td-feature__sale--orange { background: #FF6515; }
.td-feature__sale--jade   { background: var(--td-primary); }
.td-feature__sale-save { font-size: 9px; opacity: 0.92; letter-spacing: 0.04em; }
.td-feature__body { display: flex; flex-direction: column; gap: 16px; padding-top: 8px; }
.td-feature__h { font-family: var(--td-display); font-size: clamp(38px, 4.5vw, 64px); font-weight: 700; letter-spacing: -0.03em; line-height: 1; margin: 4px 0 0; }
.td-feature__sub { font-size: 18px; opacity: 0.7; margin: 0; }
.td-feature__pitch { font-size: 17px; line-height: 1.55; max-width: 50ch; margin: 8px 0 16px; padding: 16px 0; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); }
.td-feature__row { display: flex; gap: 48px; padding: 8px 0; }
.td-feature__row > div { display: flex; flex-direction: column; gap: 6px; }
.td-feature__cta { display: flex; gap: 12px; flex-wrap: wrap; padding-top: 16px; }
@media (max-width: 800px) { .td-feature__grid { grid-template-columns: 1fr; gap: 32px; } }

/* ───── price */
.td-price { display: inline-flex; align-items: baseline; gap: 4px; font-family: var(--td-display); }
.td-price__cur { font-size: 18px; opacity: 0.6; }
.td-price__num { font-size: 32px; font-weight: 700; letter-spacing: -0.02em; }
.td-price--lg .td-price__num { font-size: 56px; }
.td-price--lg .td-price__cur { font-size: 24px; }
.td-price__cmp { font-family: var(--td-mono); font-size: 12px; opacity: 0.5; text-decoration: line-through; margin-left: 8px; align-self: center; }

/* ───── stock */
.td-stock { display: inline-flex; align-items: center; gap: 8px; }
.td-stock__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--td-primary); box-shadow: 0 0 0 4px color-mix(in oklch, var(--td-primary) 18%, transparent); }

/* ───── eta stamp */
.td-stamp { display: inline-flex; align-items: center; gap: 10px; padding: 10px 14px; border: 1.5px dashed var(--td-ink); align-self: flex-start; }
.td-stamp__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--td-accent); animation: td-pulse 2s ease-in-out infinite; }
@keyframes td-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ───── btn */
.td-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 22px; border-radius: 999px; font-weight: 500; font-size: 14px; transition: transform 0.15s, background 0.2s, color 0.2s; line-height: 1; }
.td-btn:hover { transform: translateY(-1px); }
.td-btn:active { transform: translateY(0); }
.td-btn--solid { background: var(--td-ink); color: var(--td-paper); }
.td-btn--solid:hover { background: var(--td-primary); }
.td-btn--ghost { background: transparent; color: var(--td-ink); border: 1px solid var(--td-ink); }
.td-btn--ghost:hover { background: var(--td-ink); color: var(--td-paper); }
.td-btn--lg { padding: 18px 28px; font-size: 15px; }
.td-btn--full { width: 100%; }
.td-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ───── product image placeholder */
.td-img { position: relative; background: var(--td-panel); overflow: hidden; }
.td-img--photo { background: var(--td-panel); }
.td-img--photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.td-img--primary { background: color-mix(in oklch, var(--td-primary) 18%, var(--td-panel)); color: color-mix(in oklch, var(--td-primary) 70%, var(--td-ink)); }
.td-img--neutral { color: color-mix(in oklch, var(--td-ink) 30%, transparent); }
.td-img--copper { background: color-mix(in oklch, oklch(0.62 0.10 50) 26%, var(--td-panel)); color: color-mix(in oklch, oklch(0.45 0.10 45) 70%, var(--td-ink)); }
.td-img--lilac { background: color-mix(in oklch, oklch(0.70 0.07 310) 30%, var(--td-panel)); color: color-mix(in oklch, oklch(0.42 0.10 305) 70%, var(--td-ink)); }
.td-img__pattern { position: absolute; inset: 0; width: 100%; height: 100%; }
.td-img__cap { position: absolute; left: 16px; bottom: 14px; right: 16px; display: flex; flex-direction: column; gap: 4px; color: var(--td-ink); mix-blend-mode: multiply; }

/* ───── seal */
.td-seal { color: var(--td-ink); }

/* ───── pillars */
.td-pillars { padding: 40px 0; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); margin-top: 24px; }
.td-pillars__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; }
.td-pillar { display: flex; flex-direction: column; gap: 14px; }
.td-pillar__n { font-size: 11px; opacity: 0.4; padding-bottom: 16px; border-bottom: 1px solid var(--td-line); }
.td-pillar__h { font-family: var(--td-display); font-size: 30px; line-height: 1.05; letter-spacing: -0.02em; font-weight: 600; margin: 0; }
.td-pillar__p { font-size: 16px; line-height: 1.55; opacity: 0.75; margin: 0; max-width: 36ch; text-wrap: pretty; }
@media (max-width: 800px) { .td-pillars__grid { grid-template-columns: 1fr; gap: 32px; } }

/* ───── section heads */
.td-h1 { font-family: var(--td-display); font-size: clamp(48px, 7vw, 88px); font-weight: 800; letter-spacing: -0.035em; line-height: 1; margin: 12px 0 0; }
.td-h2 { font-family: var(--td-display); font-size: clamp(36px, 5vw, 60px); font-weight: 700; letter-spacing: -0.03em; line-height: 1.05; margin: 8px 0 0; }
.td-page__head { padding: 28px 0; display: flex; flex-direction: column; gap: 4px; border-bottom: 1px solid var(--td-line); margin-bottom: 32px; }
.td-page__sub { font-size: 17px; opacity: 0.7; max-width: 64ch; margin: 16px 0 0; }

/* ───── catalog */
.td-cat { padding: var(--td-pad-section) 0; }
.td-cat__head { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: end; padding-bottom: 32px; border-bottom: 1px solid var(--td-line); }
.td-cat__sub { font-size: 18px; opacity: 0.7; max-width: 40ch; margin: 0; }
.td-cat__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding-top: 48px; }
@media (max-width: 1000px) { .td-cat__grid { grid-template-columns: repeat(2, 1fr); } .td-cat__head { grid-template-columns: 1fr; gap: 16px; } }
@media (max-width: 540px)  { .td-cat__grid { grid-template-columns: 1fr; } }
.td-card { cursor: pointer; display: flex; flex-direction: column; gap: 16px; transition: transform 0.2s; }
.td-card:hover { transform: translateY(-4px); }
.td-card__body { display: flex; flex-direction: column; gap: 4px; }
.td-card__h { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; margin: 4px 0; }
.td-card__sub { font-size: 13px; opacity: 0.7; line-height: 1.4; margin: 0 0 8px; }
.td-card__row { display: flex; justify-content: space-between; align-items: baseline; padding-top: 10px; border-top: 1px solid var(--td-line); }
.td-card__price { font-family: var(--td-display); font-size: 22px; font-weight: 700; }

/* ───── promise */
.td-promise { background: var(--td-ink); color: var(--td-paper); padding: 40px 0; }
.td-promise__grid { display: grid; grid-template-columns: 1fr 320px; gap: 48px; align-items: center; }
.td-promise__copy h2 { color: var(--td-paper); }
.td-promise__copy h2 .serif-i { color: color-mix(in oklch, var(--td-primary) 60%, var(--td-paper)); }
.td-promise__copy p { font-size: 17px; line-height: 1.55; opacity: 0.75; max-width: 56ch; margin: 24px 0; }
.td-promise__list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px 32px; }
.td-promise__list li { padding: 16px 0; border-top: 1px solid color-mix(in oklch, var(--td-paper) 18%, transparent); display: flex; gap: 14px; align-items: baseline; font-size: 16px; }
.td-promise__list .mono { opacity: 0.5; }
.td-promise__seal { display: flex; justify-content: center; color: var(--td-paper); }
@media (max-width: 900px) { .td-promise__grid { grid-template-columns: 1fr; } .td-promise__list { grid-template-columns: 1fr; } }

/* ───── PDP */
.td-pdp { padding: 16px 0 var(--td-pad-section); }
.td-crumb { padding: 8px 0 16px; opacity: 0.6; }
.td-crumb a:hover { opacity: 1; }
.td-pdp__grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; padding: 24px 0; }
.td-pdp__main { width: 100%; }
.td-pdp__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding-top: 8px; }
.td-pdp__thumb { aspect-ratio: 1/1; background: var(--td-panel); display: flex; align-items: center; justify-content: center; cursor: pointer; border: 1px solid transparent; overflow: hidden; padding: 0; transition: border-color 0.15s; }
.td-pdp__thumb.is-active { border-color: var(--td-ink); }
.td-pdp__thumb:hover { border-color: color-mix(in oklch, var(--td-ink) 50%, transparent); }
.td-pdp__thumb--img img { width: 100%; height: 100%; object-fit: cover; }
.td-pdp__info { display: flex; flex-direction: column; gap: 18px; }
.td-pdp__meta { display: flex; gap: 12px; }
.td-pdp__h { font-family: var(--td-display); font-size: clamp(36px, 4.5vw, 56px); font-weight: 700; letter-spacing: -0.03em; line-height: 1; margin: 8px 0 0; }
.td-pdp__sub { font-size: 19px; opacity: 0.7; margin: 0; }
.td-pdp__pricerow { display: flex; align-items: center; gap: 16px; padding: 16px 0; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); }
.td-pdp__save { background: var(--td-accent); color: var(--td-paper); padding: 6px 10px; }
.td-pdp__pitch { font-size: 17px; line-height: 1.55; }
.td-pdp__promise { display: flex; flex-direction: column; gap: 8px; padding: 16px 0; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); }
.td-pdp__qty { display: flex; flex-direction: column; gap: 8px; padding-top: 4px; }
.td-pdp__qty label { display: block; }
.td-qty { display: inline-flex; align-items: center; gap: 12px; border: 1px solid var(--td-ink); border-radius: 999px; padding: 6px 12px; align-self: flex-start; }
.td-qty button { padding: 4px 8px; font-size: 18px; }
.td-qty span { min-width: 24px; text-align: center; }
.td-qty--sm { padding: 4px 10px; font-size: 12px; }
.td-pdp__cta { display: flex; flex-direction: column; gap: 10px; padding-top: 12px; }
.td-pdp__trust { list-style: none; padding: 16px 0 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; opacity: 0.7; border-top: 1px solid var(--td-line); }
.td-pdp__trust .mono { opacity: 0.5; margin-right: 8px; }
@media (max-width: 900px) { .td-pdp__grid { grid-template-columns: 1fr; gap: 32px; } }

.td-pdp__details { padding-top: var(--td-pad-block); border-top: 1px solid var(--td-line); margin-top: 24px; }
.td-tabs { display: flex; gap: 32px; border-bottom: 1px solid var(--td-line); }
.td-tab { padding: 16px 0; font-size: 14px; opacity: 0.55; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.td-tab.is-active { opacity: 1; border-color: var(--td-ink); }
.td-tab__panel { padding: 32px 0; }
.td-bullets { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px 48px; max-width: 800px; }
.td-bullets li { display: flex; gap: 16px; font-size: 16px; line-height: 1.5; padding: 12px 0; border-top: 1px solid var(--td-line); }
.td-bullets .mono { opacity: 0.4; flex-shrink: 0; }
.td-tab__ship { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.td-tab__ship h4 { margin: 0 0 8px; opacity: 0.5; }
.td-tab__ship p { font-size: 15px; line-height: 1.5; margin: 0; }
@media (max-width: 700px) { .td-bullets { grid-template-columns: 1fr; } .td-tab__ship { grid-template-columns: 1fr 1fr; } }

/* ───── cart */
.td-cart { /* nav button reused above */ }
.td-cart__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 36px; padding-bottom: var(--td-pad-section); }
.td-cart__lines { display: flex; flex-direction: column; }
.td-line { display: grid; grid-template-columns: 120px 1fr auto; gap: 20px; padding: 16px 0; border-top: 1px solid var(--td-line); align-items: center; }
.td-line__img { cursor: pointer; }
.td-line__info { display: flex; flex-direction: column; gap: 4px; }
.td-line__h { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin: 4px 0 0; }
.td-line__sub { font-size: 13px; opacity: 0.65; margin: 0 0 12px; }
.td-line__row { display: flex; align-items: center; gap: 16px; }
.td-line__rm { font-size: 11px; opacity: 0.5; }
.td-line__rm:hover { opacity: 1; color: var(--td-accent); }
.td-line__price { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.td-line__price .td-price__num { font-family: var(--td-display); font-size: 22px; font-weight: 700; }

.td-empty { padding-top: var(--td-pad-section); padding-bottom: var(--td-pad-section); text-align: center; display: flex; flex-direction: column; gap: 16px; align-items: center; }

.td-summary { background: var(--td-panel); padding: 24px; display: flex; flex-direction: column; gap: 14px; align-self: start; }
.td-summary--sticky { position: sticky; top: 100px; }
.td-summary h3 { margin: 0 0 8px; opacity: 0.5; }
.td-summary__row { display: flex; justify-content: space-between; font-size: 15px; padding: 6px 0; }
.td-summary__row em { opacity: 0.7; }
.td-summary__hint { padding: 4px 0; }
.td-summary__total { display: flex; justify-content: space-between; align-items: baseline; padding: 16px 0 8px; border-top: 1px solid var(--td-line); font-family: var(--td-display); font-size: 24px; font-weight: 700; margin-top: 8px; }
.td-summary__total strong { font-size: 32px; }
.td-summary__safe { padding-top: 4px; text-align: center; }
.td-summary hr { border: 0; border-top: 1px solid var(--td-line); margin: 12px 0; }

@media (max-width: 900px) { .td-cart__grid { grid-template-columns: 1fr; } .td-line { grid-template-columns: 80px 1fr; } .td-line__price { grid-column: span 2; align-items: flex-start; } }

/* ───── mini line */
.td-mini { display: grid; grid-template-columns: 56px 1fr auto; gap: 12px; align-items: center; padding: 8px 0; }
.td-mini__img { width: 56px; }
.td-mini__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-mini__h { font-family: var(--td-display); font-size: 15px; font-weight: 600; line-height: 1.2; }

/* ───── checkout */
.td-checkout__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 36px; padding-bottom: var(--td-pad-section); }
.td-form { display: flex; flex-direction: column; gap: 24px; }
.td-form fieldset { border: 1px solid var(--td-line); padding: 20px; display: flex; flex-direction: column; gap: 14px; margin: 0; }
.td-form legend { padding: 0 8px; opacity: 0.6; }
.td-field { display: flex; flex-direction: column; gap: 6px; }
.td-field label { font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; opacity: 0.55; }
.td-field input, .td-field select { padding: 12px 14px; border: 1px solid var(--td-line); background: var(--td-paper); border-radius: var(--td-rad); font-size: 15px; outline: none; }
.td-field input:focus, .td-field select:focus { border-color: var(--td-ink); }
.td-field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.td-field--row > div { display: flex; flex-direction: column; gap: 6px; }

.td-pay { display: flex; flex-direction: column; gap: 8px; }
.td-pay__opt { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; padding: 14px 16px; border: 1px solid var(--td-line); cursor: pointer; transition: border-color 0.15s, background 0.15s; }
.td-pay__opt.is-active { border-color: var(--td-ink); background: var(--td-panel); }
.td-pay__opt input { accent-color: var(--td-ink); }
.td-pay__l { font-weight: 500; }

.td-card-form { display: flex; flex-direction: column; gap: 12px; padding: 16px 0 0; }

@media (max-width: 900px) { .td-checkout__grid { grid-template-columns: 1fr; } }

/* ───── thanks */
.td-thanks { padding: var(--td-pad-section) 0; }
.td-thanks__inner { display: flex; flex-direction: column; align-items: center; gap: 16px; text-align: center; max-width: 720px; margin: 0 auto; }
.td-thanks__lede { font-size: 18px; line-height: 1.55; opacity: 0.75; max-width: 56ch; margin: 8px 0; }
.td-thanks__cta { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; padding-top: 16px; }

/* ───── tracking */
.td-track__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; padding-bottom: 48px; }
.td-timeline { display: flex; flex-direction: column; }
.td-step { display: grid; grid-template-columns: 32px 1fr; gap: 18px; }
.td-step__rail { display: flex; flex-direction: column; align-items: center; padding-top: 4px; }
.td-step__dot { width: 14px; height: 14px; border-radius: 50%; border: 2px solid var(--td-line); background: var(--td-paper); flex-shrink: 0; }
.td-step.is-done .td-step__dot { background: var(--td-primary); border-color: var(--td-primary); }
.td-step.is-current .td-step__dot { background: var(--td-accent); border-color: var(--td-accent); box-shadow: 0 0 0 6px color-mix(in oklch, var(--td-accent) 22%, transparent); animation: td-pulse 2s ease-in-out infinite; }
.td-step__line { flex: 1; width: 2px; background: var(--td-line); margin: 4px 0 -2px; }
.td-step.is-done .td-step__line { background: var(--td-primary); }
.td-step__body { padding: 0 0 18px; display: flex; flex-direction: column; gap: 2px; }
.td-step__h { font-family: var(--td-display); font-size: 20px; font-weight: 600; letter-spacing: -0.02em; margin: 2px 0; line-height: 1.15; }
.td-step__note { padding: 12px 14px; background: var(--td-panel); margin: 10px 0 0; font-size: 14px; line-height: 1.5; }

.td-side__card { background: var(--td-panel); padding: 24px; margin-bottom: 16px; display: flex; flex-direction: column; gap: 8px; }
.td-side__card h3 { margin: 0 0 8px; opacity: 0.5; }
.td-side__card--seal { align-items: center; text-align: center; padding: 32px 24px; }
.td-side__card--seal p { font-size: 15px; line-height: 1.5; max-width: 32ch; margin: 8px 0 0; }
.td-side__link { display: block; padding: 6px 0; }

@media (max-width: 900px) { .td-track__grid { grid-template-columns: 1fr; } }

/* ───── carrier meta strip */
.td-carrier { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--td-line); border: 1px solid var(--td-line); margin-bottom: 28px; }
.td-carrier__cell { background: var(--td-paper); padding: 16px 20px; display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.td-carrier__cell strong { font-family: var(--td-display); font-size: 19px; letter-spacing: -0.01em; }
.td-carrier__cell .td-stock__dot { display: inline-block; vertical-align: middle; margin-right: 6px; }
.td-step__meta { display: flex; gap: 6px; flex-wrap: wrap; }
@media (max-width: 800px) { .td-carrier { grid-template-columns: 1fr 1fr; } }

/* ───── how tracking works */
.td-howtrack { padding: 48px 0 0; border-top: 1px solid var(--td-line); margin-top: 16px; }
.td-howtrack__head { max-width: 800px; margin-bottom: 24px; }
.td-howtrack__sub { font-size: 17px; line-height: 1.55; opacity: 0.75; margin: 16px 0 0; text-wrap: pretty; }
.td-howtrack__flow { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr; gap: 16px; align-items: stretch; padding: 32px 0; }
.td-stage { background: var(--td-panel); padding: 20px; display: flex; flex-direction: column; gap: 8px; }
.td-stage__h { font-family: var(--td-display); font-size: 19px; font-weight: 700; letter-spacing: -0.01em; margin: 4px 0; }
.td-stage__p { font-size: 13px; line-height: 1.5; opacity: 0.8; margin: 0; }
.td-howtrack__arrow { font-size: 20px; opacity: 0.4; align-self: center; }
@media (max-width: 1000px) {
  .td-howtrack__flow { grid-template-columns: 1fr; }
  .td-howtrack__arrow { transform: rotate(90deg); justify-self: center; }
}
.td-howtrack__matrix { border: 1px solid var(--td-line); margin-top: 24px; }
.td-matrix__head, .td-matrix__row { display: grid; grid-template-columns: 1.4fr 1fr 1.2fr 2fr; gap: 24px; padding: 14px 20px; align-items: center; }
.td-matrix__head { background: var(--td-panel); border-bottom: 1px solid var(--td-line); }
.td-matrix__head .mono { opacity: 0.5; }
.td-matrix__row + .td-matrix__row { border-top: 1px solid var(--td-line); }
.td-matrix__row strong { font-family: var(--td-display); font-size: 16px; }
.td-howtrack__foot { padding: 24px 0; max-width: 60ch; }
@media (max-width: 800px) {
  .td-matrix__head { display: none; }
  .td-matrix__row { grid-template-columns: 1fr; gap: 4px; padding: 16px 20px; }
}

/* ───── about */
.td-about { padding-bottom: 56px; }
.td-about__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; padding: 16px 0 24px; }
.td-about__lede { font-size: 22px; line-height: 1.45; text-wrap: pretty; margin: 0 0 16px; }
.td-about__col p { font-size: 16px; line-height: 1.6; margin: 0 0 14px; opacity: 0.85; }
.td-about__col h3 { margin: 0 0 12px; opacity: 0.5; }
.td-about__seal { display: flex; justify-content: center; padding: 32px 0 0; border-top: 1px solid var(--td-line); }
@media (max-width: 900px) { .td-about__grid { grid-template-columns: 1fr; } }

/* ───── footer */
.td-foot { background: var(--td-ink); color: var(--td-paper); margin-top: 0; }
.td-foot__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 36px; padding: 48px 32px; }
.td-foot__pitch { max-width: 36ch; opacity: 0.7; line-height: 1.5; margin: 16px 0 0; }
.td-foot__grid h4 { margin: 0 0 16px; opacity: 0.5; }
.td-foot__grid a { display: block; padding: 4px 0; opacity: 0.75; font-size: 14px; }
.td-foot__grid a:hover { opacity: 1; }
.td-foot__grid .td-wordmark__t, .td-foot__grid .td-wordmark__d { color: var(--td-paper); }
.td-foot__bar { display: flex; justify-content: space-between; padding: 24px 32px; border-top: 1px solid color-mix(in oklch, var(--td-paper) 16%, transparent); flex-wrap: wrap; gap: 16px; opacity: 0.5; }
@media (max-width: 800px) { .td-foot__grid { grid-template-columns: 1fr 1fr; } }

/* ───── density */
.td-density-compact .td-page__head { padding: 24px 0; margin-bottom: 32px; }
.td-density-compact .td-feature, .td-density-compact .td-cat__grid, .td-density-compact .td-cat__head { padding-top: 32px; }


/* ═══════════════════════════════════════════════════ teaser row (home) */
.td-teaser { padding-top: 48px; padding-bottom: 36px; }
.td-teaser__head { display: flex; justify-content: space-between; align-items: end; gap: 32px; padding-bottom: 32px; border-bottom: 1px solid var(--td-line); flex-wrap: wrap; }
.td-teaser__head--solo { border-bottom: 0; padding-bottom: 0; align-items: end; }
.td-teaser__head--solo > div { max-width: 56ch; display: flex; flex-direction: column; gap: 8px; }
.td-teaser__sub { font-size: 16px; line-height: 1.55; opacity: 0.7; margin: 8px 0 0; text-wrap: pretty; }
.td-teaser__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; padding-top: 32px; }

/* ═══════════════════════════════════════════════════ quick card */
.td-qcard { display: flex; flex-direction: column; background: var(--td-paper); border: 1px solid var(--td-line); transition: transform 0.2s, border-color 0.2s; }
.td-qcard:hover { transform: translateY(-4px); border-color: var(--td-ink); }
.td-qcard__img { position: relative; cursor: pointer; }
.td-qcard__img:hover .td-qcard__quick { opacity: 1; transform: translateY(0); }
.td-qcard__tabrow { display: flex; padding: 10px 12px 0; }
.td-qcard__tab { display: inline-flex; align-items: center; background: var(--td-ink); color: var(--td-paper); padding: 5px 10px; font-size: 10px; letter-spacing: 0.12em; line-height: 1; }
.td-qcard__sale { color: var(--td-paper); padding: 8px 14px; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.td-qcard__sale--orange { background: #FF6515; }
.td-qcard__sale--jade   { background: var(--td-primary); }
.td-qcard__sale-save { opacity: 0.85; font-weight: 500; text-transform: none; letter-spacing: 0.04em; }
.td-qcard__quick { position: absolute; bottom: 12px; right: 12px; background: var(--td-paper); border: 1px solid var(--td-ink); padding: 8px 12px; border-radius: 999px; opacity: 0; transform: translateY(8px); transition: opacity 0.2s, transform 0.2s, background 0.2s; }
.td-qcard__quick:hover { background: var(--td-ink); color: var(--td-paper); }
.td-qcard__body { display: flex; flex-direction: column; gap: 6px; padding: 20px; }
.td-qcard__h { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; margin: 4px 0 0; cursor: pointer; }
.td-qcard__sub { font-size: 13px; opacity: 0.7; line-height: 1.4; margin: 0 0 8px; }
.td-qcard__row { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 0; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); margin-bottom: 12px; }
.td-qcard__cta { display: flex; gap: 8px; flex-wrap: wrap; }
.td-qcard__cta .td-btn { flex: 1; min-width: 120px; }

/* ═══════════════════════════════════════════════════ catalog page */
.td-catalog { padding-bottom: 56px; }
.td-catalog__bar { display: flex; justify-content: space-between; align-items: center; gap: 24px; padding: 12px 0; border-bottom: 1px solid var(--td-line); flex-wrap: wrap; margin-bottom: 24px; }
.td-catalog__filters { display: flex; gap: 8px; flex-wrap: wrap; }
.td-chip { padding: 8px 14px; border: 1px solid var(--td-line); border-radius: 999px; font-size: 11px; transition: all 0.15s; cursor: pointer; }
.td-chip:hover { border-color: var(--td-ink); }
.td-chip.is-active { background: var(--td-ink); color: var(--td-paper); border-color: var(--td-ink); }
.td-catalog__sort { display: flex; align-items: center; gap: 12px; }
.td-catalog__sort select { padding: 8px 12px; border: 1px solid var(--td-line); background: var(--td-paper); border-radius: var(--td-rad); font-size: 13px; }
.td-catalog__view { display: flex; gap: 4px; border: 1px solid var(--td-line); padding: 2px; border-radius: var(--td-rad); }
.td-catalog__view button { padding: 6px 8px; opacity: 0.4; transition: opacity 0.15s, background 0.15s; }
.td-catalog__view button.is-active { background: var(--td-panel); opacity: 1; }
.td-catalog__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }
.td-catalog__list { display: flex; flex-direction: column; gap: 0; }
.td-listrow { display: grid; grid-template-columns: 160px 1fr 200px; gap: 32px; padding: 24px 0; border-top: 1px solid var(--td-line); align-items: start; }
.td-listrow:last-child { border-bottom: 1px solid var(--td-line); }
.td-listrow__img { cursor: pointer; width: 160px; }
.td-listrow__body { display: flex; flex-direction: column; gap: 6px; }
.td-listrow__h { font-family: var(--td-display); font-size: 26px; font-weight: 700; letter-spacing: -0.02em; margin: 4px 0; cursor: pointer; }
.td-listrow__sub { font-size: 15px; opacity: 0.7; margin: 0; }
.td-listrow__pitch { font-size: 14px; line-height: 1.5; margin: 8px 0; max-width: 60ch; }
.td-listrow__cta { display: flex; flex-direction: column; gap: 8px; align-items: stretch; text-align: right; }
.td-listrow__cta .td-price { justify-content: flex-end; }
@media (max-width: 800px) { .td-listrow { grid-template-columns: 1fr; } .td-listrow__cta { text-align: left; align-items: start; } }

.td-catalog__soon { padding-top: 48px; border-top: 1px solid var(--td-line); margin-top: 32px; }
.td-catalog__soon-head { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.td-catalog__soon-sub { font-size: 16px; opacity: 0.7; max-width: 64ch; margin: 0 0 20px; }
.td-catalog__soon-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.td-soon { padding: 20px; border: 1px dashed var(--td-line); display: flex; flex-direction: column; gap: 4px; opacity: 0.7; }
.td-soon__h { font-family: var(--td-display); font-size: 18px; font-weight: 600; margin: 6px 0 2px; }
.td-soon__p { font-size: 13px; margin: 0; }

/* ═══════════════════════════════════════════════════ couriers public list */
.td-couriers { padding: 48px 0 0; border-top: 1px solid var(--td-line); margin-top: 32px; }
.td-couriers__head { max-width: 700px; margin-bottom: 24px; }
.td-couriers__sub { font-size: 16px; line-height: 1.55; opacity: 0.75; margin: 12px 0 0; text-wrap: pretty; }
.td-couriers__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.td-courier { padding: 20px; border: 1px solid var(--td-line); display: flex; flex-direction: column; gap: 14px; background: var(--td-paper); }
.td-courier.is-soon { opacity: 0.6; background: var(--td-panel); }
.td-courier__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.td-courier__head strong { font-family: var(--td-display); font-size: 18px; }
.td-courier__meta { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.td-courier__meta li { display: flex; justify-content: space-between; font-size: 13px; padding: 6px 0; border-top: 1px solid var(--td-line); }
.td-courier__meta li:first-child { border-top: 0; padding-top: 0; }
.td-couriers__foot { padding: 24px 0; max-width: 60ch; }

/* pill */
.td-pill { display: inline-flex; align-items: center; padding: 4px 10px; border-radius: 999px; font-family: var(--td-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; }
.td-pill--ok   { background: color-mix(in oklch, var(--td-primary) 18%, var(--td-panel)); color: color-mix(in oklch, var(--td-primary) 65%, var(--td-ink)); }
.td-pill--warn { background: color-mix(in oklch, var(--td-accent) 18%, var(--td-panel));  color: color-mix(in oklch, var(--td-accent) 65%, var(--td-ink)); }
.td-pill--info { background: var(--td-panel); color: var(--td-ink); border: 1px solid var(--td-line); }
.td-pill--done { background: var(--td-ink); color: var(--td-paper); }

/* ═══════════════════════════════════════════════════ customer login */
.td-login { min-height: 100vh; background: var(--td-paper); display: flex; align-items: center; justify-content: center; padding: 48px 20px; }
.td-login__wrap { width: 100%; max-width: 480px; display: flex; flex-direction: column; gap: 16px; }
.td-login__home { font-size: 13px; opacity: 0.6; align-self: flex-start; }
.td-login__home:hover { opacity: 1; }
.td-login__card { background: var(--td-paper); border: 1px solid var(--td-line); padding: 40px; display: flex; flex-direction: column; gap: 20px; }
.td-login__head { display: flex; flex-direction: column; gap: 12px; padding-bottom: 8px; }
.td-login__lede { font-size: 14px; line-height: 1.5; opacity: 0.75; margin: 0; }
.td-login__tabs { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--td-line); padding: 4px; gap: 4px; border-radius: var(--td-rad); }
.td-login__tab { padding: 10px; font-size: 13px; border-radius: 2px; transition: background 0.15s; }
.td-login__tab.is-active { background: var(--td-ink); color: var(--td-paper); }
.td-login__form { display: flex; flex-direction: column; gap: 14px; }
.td-field__row { display: flex; justify-content: space-between; align-items: baseline; }
.td-login__sep { display: flex; align-items: center; gap: 16px; margin: 8px 0; }
.td-login__sep::before, .td-login__sep::after { content: ""; flex: 1; height: 1px; background: var(--td-line); }
.td-login__wa { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 14px; border: 1px solid var(--td-line); border-radius: var(--td-rad); font-size: 14px; transition: all 0.15s; color: #25D366; }
.td-login__wa:hover { background: #25D366; color: white; border-color: #25D366; }
.td-login__wa svg { width: 20px; height: 20px; }
.td-login__guest { text-align: center; margin: 4px 0 0; font-size: 13px; }
.td-login__guest a { opacity: 0.6; }
.td-login__guest a:hover { opacity: 1; }
.td-login__terms { text-align: center; padding: 8px 16px; line-height: 1.5; }

/* ═══════════════════════════════════════════════════ admin login */
.td-adminlogin { min-height: 100vh; background: var(--td-ink); color: var(--td-paper); display: flex; align-items: center; justify-content: center; padding: 48px 20px; font-family: var(--td-body); }
.td-adminlogin__wrap { width: 100%; max-width: 440px; display: flex; flex-direction: column; gap: 20px; }
.td-adminlogin__head { display: flex; flex-direction: column; gap: 10px; padding-bottom: 16px; border-bottom: 1px solid color-mix(in oklch, var(--td-paper) 20%, transparent); }
.td-adminlogin__h { font-family: var(--td-display); font-size: 38px; font-weight: 800; letter-spacing: -0.03em; margin: 0; color: var(--td-paper); }
.td-adminlogin__sub { margin: 0; opacity: 0.6; }
.td-adminlogin__form { display: flex; flex-direction: column; gap: 14px; }
.td-adminlogin__form .td-field input { background: color-mix(in oklch, var(--td-paper) 8%, transparent); border-color: color-mix(in oklch, var(--td-paper) 20%, transparent); color: var(--td-paper); }
.td-adminlogin__form .td-field input::placeholder { color: color-mix(in oklch, var(--td-paper) 40%, transparent); }
.td-adminlogin__form .td-field input:focus { border-color: var(--td-paper); }
.td-adminlogin__form .td-field label { color: color-mix(in oklch, var(--td-paper) 60%, transparent); }
.td-adminlogin__form .td-btn--solid { background: var(--td-paper); color: var(--td-ink); }
.td-adminlogin__form .td-btn--solid:hover { background: var(--td-primary); color: var(--td-paper); }
.td-adminlogin__form .center { color: color-mix(in oklch, var(--td-paper) 50%, transparent); }
.td-adminlogin__back { font-size: 11px; align-self: flex-start; padding: 16px 0 0; cursor: pointer; opacity: 0.5; }
.td-adminlogin__back:hover { opacity: 1; }

/* ═══════════════════════════════════════════════════ admin dashboard */
.td-admin { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; background: var(--td-paper); }
.td-admin__side { background: var(--td-ink); color: var(--td-paper); padding: 22px 18px; display: flex; flex-direction: column; gap: 22px; min-width: 0; }
.td-admin__brand { display: flex; flex-direction: column; gap: 8px; padding-bottom: 16px; border-bottom: 1px solid color-mix(in oklch, var(--td-paper) 16%, transparent); }
.td-admin__brand .td-wordmark { font-size: 22px; }
.td-admin__brand .td-wordmark__t, .td-admin__brand .td-wordmark__d { color: var(--td-paper); }
.td-admin__brand .td-wordmark__d { color: color-mix(in oklch, var(--td-primary) 70%, var(--td-paper)); }
.td-admin__brand .td-wordmark__tld { font-size: 9px; padding-bottom: 2px; }
.td-admin__role { display: inline-flex; align-items: center; gap: 6px; font-family: var(--td-mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.7; }
.td-admin__role-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--td-primary); }
.td-admin__role--t1 .td-admin__role-dot { background: oklch(0.70 0.10 240); }
.td-admin__role--t2 .td-admin__role-dot { background: var(--td-primary); }
.td-admin__role--t3 .td-admin__role-dot { background: oklch(0.72 0.13 75); }   /* amber */
.td-admin__role--t4 .td-admin__role-dot { background: var(--td-accent); }       /* red */
.td-admin__nav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.td-admin__nav-item { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px; border-radius: var(--td-rad); font-size: 14px; text-align: left; transition: background 0.15s; }
.td-admin__nav-item:hover { background: color-mix(in oklch, var(--td-paper) 6%, transparent); }
.td-admin__nav-item.is-active { background: color-mix(in oklch, var(--td-paper) 10%, transparent); }
.td-admin__nav-item .mono { opacity: 0.5; font-size: 11px; }
.td-admin__user { display: flex; align-items: center; gap: 10px; padding: 12px 0; border-top: 1px solid color-mix(in oklch, var(--td-paper) 16%, transparent); }
.td-admin__user > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-admin__user strong { font-size: 12px; }
.td-admin__avatar { width: 36px; height: 36px; background: var(--td-primary); display: flex; align-items: center; justify-content: center; border-radius: 999px; flex-shrink: 0; font-size: 11px; }
.td-admin__exit { font-size: 10px; cursor: pointer; opacity: 0.4; }
.td-admin__exit:hover { opacity: 1; }
.td-admin__main { padding: 24px 32px 64px; max-width: 100%; overflow: hidden; }
.td-admin__top { display: flex; justify-content: space-between; align-items: end; gap: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--td-line); margin-bottom: 24px; flex-wrap: wrap; }
.td-admin__top > div:first-child { display: flex; flex-direction: column; gap: 4px; }
.td-admin__h { font-family: var(--td-display); font-size: 36px; font-weight: 700; letter-spacing: -0.025em; margin: 0; }
.td-admin__top-r { display: flex; align-items: center; gap: 16px; }
.td-admin__search { padding: 10px 14px; border: 1px solid var(--td-line); border-radius: 999px; min-width: 280px; font-size: 13px; background: var(--td-paper); }
.td-admin__body { display: flex; flex-direction: column; gap: 24px; }
.td-admin__intro { font-size: 15px; line-height: 1.55; opacity: 0.75; max-width: 72ch; margin: 0; }
.td-admin__foot { padding-top: 16px; }

.td-admin__stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.td-admin__stat { background: var(--td-panel); padding: 20px; display: flex; flex-direction: column; gap: 6px; }
.td-admin__stat-v { font-family: var(--td-display); font-size: 38px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
@media (max-width: 900px) { .td-admin__stats { grid-template-columns: repeat(2, 1fr); } }

.td-admin__split { display: grid; grid-template-columns: 1.4fr 1fr; gap: 24px; }
@media (max-width: 1100px) { .td-admin__split { grid-template-columns: 1fr; } }
.td-admin__panel { background: var(--td-paper); border: 1px solid var(--td-line); overflow: hidden; }
.td-admin__panel > header { display: flex; justify-content: space-between; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--td-line); background: var(--td-panel); }
.td-admin__panel > header h3 { font-family: var(--td-display); font-size: 18px; font-weight: 700; margin: 0; }
.td-admin__placeholder { padding: 64px 32px; text-align: center; }
.td-admin__placeholder h3 { font-family: var(--td-display); font-size: 24px; margin: 0 0 8px; }
.td-admin__placeholder p { opacity: 0.6; margin: 0; }

.td-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.td-table th, .td-table td { padding: 12px 20px; text-align: left; }
.td-table thead th { font-family: var(--td-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; opacity: 0.55; font-weight: 500; border-bottom: 1px solid var(--td-line); background: var(--td-panel); }
.td-table tbody tr { border-bottom: 1px solid var(--td-line); }
.td-table tbody tr:last-child { border-bottom: 0; }
.td-table tbody tr:hover { background: color-mix(in oklch, var(--td-panel) 50%, transparent); }

.td-health { list-style: none; padding: 0; margin: 0; }
.td-health li { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; padding: 12px 20px; border-bottom: 1px solid var(--td-line); font-size: 13px; }
.td-health li:last-child { border-bottom: 0; }
.td-health__dot { width: 8px; height: 8px; border-radius: 50%; }
.td-health__dot--ok   { background: var(--td-primary); box-shadow: 0 0 0 3px color-mix(in oklch, var(--td-primary) 22%, transparent); }
.td-health__dot--soon { background: var(--td-line); }
.td-health__dot--warn { background: var(--td-accent); box-shadow: 0 0 0 3px color-mix(in oklch, var(--td-accent) 22%, transparent); }

.td-pipeline { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr; gap: 12px; align-items: stretch; padding: 8px 0; }
.td-pipeline__arrow { font-size: 20px; opacity: 0.4; align-self: center; }
@media (max-width: 1200px) { .td-pipeline { grid-template-columns: 1fr; } .td-pipeline__arrow { transform: rotate(90deg); justify-self: center; } }
.td-stage { background: var(--td-panel); padding: 16px; display: flex; flex-direction: column; gap: 6px; }
.td-stage__h { font-family: var(--td-display); font-size: 17px; font-weight: 700; letter-spacing: -0.01em; margin: 4px 0; }
.td-stage__p { font-size: 12px; line-height: 1.5; opacity: 0.8; margin: 0; }

@media (max-width: 900px) {
  .td-admin { grid-template-columns: 1fr; }
  .td-admin__side { flex-direction: row; flex-wrap: wrap; gap: 12px; }
  .td-admin__nav { flex-direction: row; flex-wrap: wrap; flex: 1; }
}


/* ═══════════════════════════════════════════════════ admin · tabs */
.td-admin__tabs { display: flex; gap: 0; border-bottom: 1px solid var(--td-line); margin-bottom: 0; flex-wrap: wrap; }
.td-admin__tab { padding: 14px 20px; font-size: 13px; opacity: 0.55; border-bottom: 2px solid transparent; margin-bottom: -1px; display: inline-flex; gap: 8px; align-items: center; }
.td-admin__tab.is-active { opacity: 1; border-color: var(--td-ink); }
.td-admin__tab .mono { font-size: 10px; opacity: 0.55; }

/* admin · clickable order row */
.td-table tbody tr.is-clickable { cursor: pointer; }
.td-table tbody tr.is-clickable:hover { background: color-mix(in oklch, var(--td-primary) 6%, var(--td-panel)); }
.td-table .td-table__more { width: 24px; text-align: right; opacity: 0.4; }

/* ═══════════════════════════════════════════════════ admin · drawer (right side) */
.td-drawer { position: fixed; inset: 0; z-index: 80; display: flex; justify-content: flex-end; }
.td-drawer__veil { position: absolute; inset: 0; background: color-mix(in oklch, var(--td-ink) 50%, transparent); backdrop-filter: blur(2px); animation: td-fade 0.18s ease; }
.td-drawer__panel { position: relative; width: min(960px, 92vw); height: 100vh; background: var(--td-paper); display: flex; flex-direction: column; box-shadow: -16px 0 48px -16px color-mix(in oklch, var(--td-ink) 36%, transparent); animation: td-slide 0.22s ease; overflow: hidden; }
.td-drawer__panel--wide { width: min(1100px, 96vw); }
@keyframes td-slide { from { transform: translateX(32px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.td-drawer__head { display: flex; justify-content: space-between; align-items: center; padding: 18px 28px; border-bottom: 1px solid var(--td-line); background: var(--td-panel); flex-shrink: 0; }
.td-drawer__head h2 { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin: 0; }
.td-drawer__head-r { display: flex; align-items: center; gap: 16px; }
.td-drawer__close { width: 36px; height: 36px; border-radius: 999px; border: 1px solid var(--td-line); display: inline-flex; align-items: center; justify-content: center; transition: background 0.15s, color 0.15s; }
.td-drawer__close:hover { background: var(--td-ink); color: var(--td-paper); border-color: var(--td-ink); }
.td-drawer__body { flex: 1; overflow-y: auto; padding: 28px 28px 96px; display: flex; flex-direction: column; gap: 24px; }
.td-drawer__foot { padding: 16px 28px; border-top: 1px solid var(--td-line); background: var(--td-panel); display: flex; gap: 12px; justify-content: space-between; align-items: center; flex-shrink: 0; }

/* order detail */
.td-od__top { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: start; padding-bottom: 20px; border-bottom: 1px solid var(--td-line); }
.td-od__num { font-family: var(--td-display); font-size: 32px; font-weight: 700; letter-spacing: -0.02em; margin: 4px 0; }
.td-od__meta { display: flex; flex-wrap: wrap; gap: 6px 16px; font-size: 13px; opacity: 0.75; }
.td-od__meta strong { font-weight: 500; opacity: 1; }
.td-od__topr { display: flex; flex-direction: column; gap: 8px; align-items: flex-end; }

.td-od__grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 24px; }
@media (max-width: 900px) { .td-od__grid { grid-template-columns: 1fr; } }
.td-od__col { display: flex; flex-direction: column; gap: 18px; }
.td-od__card { border: 1px solid var(--td-line); padding: 18px 20px; display: flex; flex-direction: column; gap: 12px; background: var(--td-paper); }
.td-od__card-h { display: flex; justify-content: space-between; align-items: baseline; }
.td-od__card-h h3 { font-family: var(--td-display); font-size: 17px; margin: 0; font-weight: 700; }
.td-od__card-h .mono { font-size: 10px; opacity: 0.55; }
.td-od__kv { display: grid; grid-template-columns: 1fr 1.4fr; gap: 6px 16px; font-size: 13px; }
.td-od__kv > dt { opacity: 0.55; font-family: var(--td-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; align-self: center; }
.td-od__kv > dd { margin: 0; }
.td-od__kv > dd.mono { font-size: 12px; }

.td-od__items { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; }
.td-od__items li { display: grid; grid-template-columns: 40px 1fr auto; gap: 14px; padding: 10px 0; border-bottom: 1px dashed var(--td-line); align-items: center; }
.td-od__items li:last-child { border-bottom: 0; }
.td-od__items li b { display: block; font-family: var(--td-display); font-size: 15px; }
.td-od__qty { width: 40px; height: 40px; background: var(--td-panel); display: flex; align-items: center; justify-content: center; font-family: var(--td-mono); font-size: 12px; }
.td-od__totals { display: flex; flex-direction: column; gap: 4px; padding-top: 8px; border-top: 1px solid var(--td-line); }
.td-od__totals > div { display: flex; justify-content: space-between; font-size: 13px; padding: 4px 0; }
.td-od__totals > div:last-child { font-family: var(--td-display); font-size: 18px; font-weight: 700; padding-top: 10px; border-top: 1px solid var(--td-line); }

/* GPS / map placeholder */
.td-od__map { aspect-ratio: 5/3; position: relative; background:
  repeating-linear-gradient(35deg, color-mix(in oklch, var(--td-primary) 8%, var(--td-panel)) 0 1px, transparent 1px 16px),
  repeating-linear-gradient(-55deg, color-mix(in oklch, var(--td-primary) 8%, var(--td-panel)) 0 1px, transparent 1px 16px),
  var(--td-panel);
  overflow: hidden; border: 1px solid var(--td-line); }
.td-od__pin { position: absolute; left: 62%; top: 48%; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 6px; }
.td-od__pin-dot { width: 16px; height: 16px; border-radius: 50%; background: var(--td-accent); box-shadow: 0 0 0 8px color-mix(in oklch, var(--td-accent) 22%, transparent); animation: td-pulse 2s ease-in-out infinite; }
.td-od__pin-l { font-family: var(--td-mono); font-size: 10px; background: var(--td-ink); color: var(--td-paper); padding: 3px 6px; }
.td-od__dest { position: absolute; left: 22%; top: 72%; display: flex; flex-direction: column; align-items: center; gap: 6px; opacity: 0.5; }
.td-od__dest-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--td-ink); }
.td-od__path { position: absolute; left: 22%; top: 72%; width: 40%; height: 2px; background: linear-gradient(90deg, var(--td-ink) 0, transparent 100%); transform-origin: left; transform: rotate(-22deg); opacity: 0.4; }
.td-od__mapinfo { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--td-line); margin-top: 1px; }
.td-od__mapinfo > div { background: var(--td-paper); padding: 10px 12px; display: flex; flex-direction: column; gap: 2px; }
.td-od__mapinfo span { font-family: var(--td-mono); font-size: 9px; opacity: 0.55; letter-spacing: 0.06em; text-transform: uppercase; }
.td-od__mapinfo strong { font-family: var(--td-display); font-size: 16px; font-weight: 700; }

/* raw event log */
.td-od__events { width: 100%; border-collapse: collapse; font-size: 12px; }
.td-od__events th, .td-od__events td { padding: 8px 10px; text-align: left; vertical-align: top; }
.td-od__events thead th { font-family: var(--td-mono); font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase; opacity: 0.55; font-weight: 500; border-bottom: 1px solid var(--td-line); }
.td-od__events tbody tr { border-bottom: 1px dashed var(--td-line); }
.td-od__events tbody tr:last-child { border-bottom: 0; }
.td-od__events .mono { font-size: 11px; }

/* JSON payload viewer */
.td-od__json { background: oklch(0.16 0.012 60); color: oklch(0.96 0.008 80); padding: 14px 16px; font-family: var(--td-mono); font-size: 11px; line-height: 1.7; overflow-x: auto; white-space: pre; border-radius: 2px; }
.td-od__json .k { color: oklch(0.75 0.10 200); }
.td-od__json .s { color: oklch(0.80 0.12 130); }
.td-od__json .n { color: oklch(0.82 0.12 80); }

.td-od__driver { display: grid; grid-template-columns: 56px 1fr; gap: 14px; align-items: center; padding: 12px 0; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); }
.td-od__avatar { width: 56px; height: 56px; border-radius: 999px; background: color-mix(in oklch, var(--td-primary) 18%, var(--td-panel)); display: inline-flex; align-items: center; justify-content: center; font-family: var(--td-display); font-weight: 700; font-size: 22px; color: color-mix(in oklch, var(--td-primary) 70%, var(--td-ink)); }
.td-od__driverbody { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-od__driverbody strong { font-family: var(--td-display); font-size: 16px; }

/* small timeline (reuse pattern) inside drawer */
.td-od__tl { display: flex; flex-direction: column; }
.td-od__tl .td-step__body { padding-bottom: 18px; }
.td-od__tl .td-step__h { font-size: 16px; }

/* ═══════════════════════════════════════════════════ product editor */
.td-pe__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 32px; }
@media (max-width: 900px) { .td-pe__grid { grid-template-columns: 1fr; } }
.td-pe__media { display: flex; flex-direction: column; gap: 12px; }
.td-pe__hero { aspect-ratio: 1/1; }
.td-pe__upload { border: 1.5px dashed var(--td-line); display: flex; flex-direction: column; gap: 4px; align-items: center; justify-content: center; padding: 24px; text-align: center; cursor: pointer; transition: border-color 0.15s, background 0.15s; }
.td-pe__upload:hover { border-color: var(--td-ink); background: var(--td-panel); }
.td-pe__upload b { font-family: var(--td-display); font-size: 16px; }
.td-pe__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.td-pe__thumb { aspect-ratio: 1/1; background: var(--td-panel); display: flex; align-items: center; justify-content: center; font-family: var(--td-mono); font-size: 9px; opacity: 0.6; border: 1px dashed var(--td-line); }
.td-pe__form { display: flex; flex-direction: column; gap: 18px; }
.td-pe__form fieldset { border: 1px solid var(--td-line); padding: 18px 20px; display: flex; flex-direction: column; gap: 14px; margin: 0; }
.td-pe__form legend { padding: 0 8px; font-family: var(--td-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; opacity: 0.55; }
.td-pe__list { display: flex; flex-direction: column; gap: 8px; }
.td-pe__list-row { display: grid; grid-template-columns: 24px 1fr 28px; gap: 10px; align-items: center; }
.td-pe__list-row .mono { opacity: 0.5; font-size: 10px; }
.td-pe__list-row input { padding: 10px 12px; border: 1px solid var(--td-line); background: var(--td-paper); border-radius: var(--td-rad); font-size: 14px; outline: none; }
.td-pe__list-row input:focus { border-color: var(--td-ink); }
.td-pe__list-row button { font-size: 14px; opacity: 0.4; }
.td-pe__list-row button:hover { opacity: 1; color: var(--td-accent); }
.td-pe__add { font-family: var(--td-mono); font-size: 10px; align-self: flex-start; padding: 6px 0; opacity: 0.55; }
.td-pe__add:hover { opacity: 1; }
.td-pe__tones { display: flex; gap: 8px; flex-wrap: wrap; }
.td-pe__tone { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border: 1px solid var(--td-line); border-radius: 999px; font-size: 12px; transition: border-color 0.15s, background 0.15s; cursor: pointer; }
.td-pe__tone.is-active { border-color: var(--td-ink); background: var(--td-panel); }
.td-pe__sw { width: 14px; height: 14px; border-radius: 50%; border: 1px solid var(--td-line); }
.td-pe__sw--primary { background: var(--td-primary); }
.td-pe__sw--neutral { background: var(--td-ink); }
.td-pe__sw--copper  { background: oklch(0.62 0.10 50); }
.td-pe__sw--lilac   { background: oklch(0.70 0.07 310); }

/* ═══════════════════════════════════════════════════ admin · infraestructura */
.td-infra { display: flex; flex-direction: column; gap: 32px; }
.td-infra__hero { display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; padding: 24px 28px; background: var(--td-ink); color: var(--td-paper); }
@media (max-width: 1000px) { .td-infra__hero { grid-template-columns: 1fr; } }
.td-infra__hero h2 { font-family: var(--td-display); font-size: 30px; font-weight: 700; letter-spacing: -0.025em; margin: 8px 0; color: var(--td-paper); }
.td-infra__hero p { font-size: 14px; line-height: 1.55; opacity: 0.75; max-width: 60ch; margin: 4px 0; }
.td-infra__cost { display: flex; flex-direction: column; gap: 4px; padding: 16px 20px; border: 1px solid color-mix(in oklch, var(--td-paper) 16%, transparent); align-self: start; }
.td-infra__cost-v { font-family: var(--td-display); font-size: 38px; font-weight: 700; letter-spacing: -0.02em; }
.td-infra__cost-n { font-size: 12px; opacity: 0.65; line-height: 1.5; }

.td-infra__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 16px; }
.td-infra__card { border: 1px solid var(--td-line); padding: 20px; display: flex; flex-direction: column; gap: 10px; background: var(--td-paper); }
.td-infra__card-h { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.td-infra__label { font-family: var(--td-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; opacity: 0.55; }
.td-infra__rec { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin: 0; }
.td-infra__why { font-size: 13px; line-height: 1.55; margin: 0; opacity: 0.85; }
.td-infra__alts { display: flex; flex-direction: column; gap: 4px; padding-top: 8px; margin-top: 4px; border-top: 1px dashed var(--td-line); }
.td-infra__alts span { font-family: var(--td-mono); font-size: 9px; opacity: 0.55; letter-spacing: 0.06em; text-transform: uppercase; }
.td-infra__alts li { list-style: none; font-size: 12px; opacity: 0.7; padding: 2px 0; }
.td-infra__cost-line { display: flex; justify-content: space-between; padding-top: 10px; margin-top: 4px; border-top: 1px solid var(--td-line); font-size: 12px; }
.td-infra__cost-line .mono { opacity: 0.55; }

.td-infra__flow { display: flex; flex-direction: column; gap: 4px; padding: 24px; background: var(--td-panel); }
.td-infra__flow h3 { font-family: var(--td-display); font-size: 20px; font-weight: 700; margin: 0 0 16px; }
.td-infra__step { display: grid; grid-template-columns: 36px 1fr auto 1fr; gap: 16px; padding: 10px 0; border-top: 1px solid var(--td-line); align-items: center; }
.td-infra__step:first-of-type { border-top: 0; }
.td-infra__step .mono { opacity: 0.5; font-size: 10px; }
.td-infra__step-from, .td-infra__step-to { font-family: var(--td-display); font-size: 15px; font-weight: 600; }
.td-infra__step-arr { opacity: 0.4; font-family: var(--td-mono); }
.td-infra__step-what { font-size: 12px; opacity: 0.7; grid-column: 2 / -1; margin-top: -4px; }
@media (max-width: 800px) { .td-infra__step { grid-template-columns: 32px 1fr; } .td-infra__step-arr, .td-infra__step-to { display: none; } }


/* ═══════════════════════════════════════════════════ admin · login role picker */
.td-adminlogin__err { color: var(--td-accent); padding: 10px 12px; background: color-mix(in oklch, var(--td-accent) 8%, transparent); border-left: 3px solid var(--td-accent); margin: -4px 0 4px; line-height: 1.4; }

.td-adminlogin__demo { margin-top: 24px; padding-top: 20px; border-top: 1px dashed color-mix(in oklch, var(--td-paper) 18%, transparent); }
.td-adminlogin__demo-toggle { background: transparent; border: none; color: color-mix(in oklch, var(--td-paper) 55%, transparent); cursor: pointer; padding: 0; letter-spacing: 0.1em; font-size: 11px; }
.td-adminlogin__demo-toggle:hover { color: color-mix(in oklch, var(--td-paper) 80%, transparent); }
.td-adminlogin__demo-grid { display: flex; flex-direction: column; gap: 4px; margin-top: 12px; }
.td-adminlogin__demo-row { display: grid; grid-template-columns: 28px 1fr; column-gap: 12px; row-gap: 4px; align-items: start; padding: 10px 12px; border: 1px solid color-mix(in oklch, var(--td-paper) 14%, transparent); background: transparent; color: var(--td-paper); text-align: left; cursor: pointer; transition: border-color 0.15s, background 0.15s; }
.td-adminlogin__demo-row:hover { border-color: color-mix(in oklch, var(--td-paper) 38%, transparent); background: color-mix(in oklch, var(--td-paper) 5%, transparent); }
.td-adminlogin__demo-row.is-active { border-color: var(--td-primary); background: color-mix(in oklch, var(--td-primary) 10%, transparent); }
.td-adminlogin__demo-row > span:first-child { font-size: 11px; letter-spacing: 0.08em; opacity: 0.6; align-self: center; }
.td-adminlogin__demo-row > div { display: flex; flex-direction: column; gap: 2px; }
.td-adminlogin__demo-row > div b { font-family: var(--td-display); font-size: 14px; font-weight: 600; }
.td-adminlogin__demo-desc { grid-column: 2; font-size: 11px; line-height: 1.45; color: color-mix(in oklch, var(--td-paper) 55%, transparent); margin-top: 2px; }
.td-adminlogin__demo-foot { margin: 8px 0 0; opacity: 0.55; line-height: 1.5; }

/* admin · role switch (demo, in sidebar) */
.td-admin__roleswitch { display: flex; flex-direction: column; gap: 6px; padding-top: 12px; border-top: 1px solid color-mix(in oklch, var(--td-paper) 12%, transparent); }
.td-admin__roleswitch-btns { display: flex; gap: 4px; }
.td-admin__roleswitch-btn { flex: 1; padding: 6px 8px; border: 1px solid color-mix(in oklch, var(--td-paper) 16%, transparent); border-radius: var(--td-rad); font-family: var(--td-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--td-paper); opacity: 0.6; transition: all 0.15s; }
.td-admin__roleswitch-btn:hover { opacity: 1; }
.td-admin__roleswitch-btn.is-active { background: var(--td-paper); color: var(--td-ink); opacity: 1; }

/* admin · tier-1 note */
.td-admin__tier-note { padding: 10px 14px; background: color-mix(in oklch, oklch(0.70 0.10 240) 14%, var(--td-panel)); border-left: 3px solid oklch(0.55 0.12 240); border-radius: 2px; }

/* admin · clickable stat */
.td-admin__stat.is-clickable { cursor: pointer; transition: background 0.15s, transform 0.15s; position: relative; }
.td-admin__stat.is-clickable:hover { background: color-mix(in oklch, var(--td-accent) 10%, var(--td-panel)); transform: translateY(-2px); }
.td-admin__stat-cta { display: block; padding-top: 6px; color: var(--td-accent); opacity: 0; transition: opacity 0.15s; }
.td-admin__stat.is-clickable:hover .td-admin__stat-cta { opacity: 1; }

/* admin · critical stock list */
.td-critical { list-style: none; padding: 0; margin: 0; }
.td-critical__row { display: grid; grid-template-columns: 56px 1fr auto; gap: 14px; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--td-line); cursor: pointer; transition: background 0.15s; }
.td-critical__row:last-child { border-bottom: 0; }
.td-critical__row:hover { background: color-mix(in oklch, var(--td-accent) 6%, var(--td-panel)); }
.td-critical__img { width: 56px; aspect-ratio: 1/1; }
.td-critical__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-critical__body b { font-family: var(--td-display); font-size: 14px; font-weight: 600; }
.td-critical__cta { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }

/* admin · inventory actions */
.td-inv__actions { display: flex; gap: 4px; justify-content: flex-end; }
.td-inv__act { padding: 6px 10px; border: 1px solid var(--td-line); border-radius: 2px; font-family: var(--td-mono); font-size: 9px; letter-spacing: 0.06em; transition: all 0.15s; white-space: nowrap; }
.td-inv__act:hover { border-color: var(--td-ink); }
.td-inv__act--solid { background: var(--td-ink); color: var(--td-paper); border-color: var(--td-ink); }
.td-inv__act--solid:hover { background: var(--td-accent); border-color: var(--td-accent); }

/* admin · inline-editable cells */
.td-inv .td-inv__col-num { text-align: right; }
.td-inv td:has(> .td-inv__cell), .td-inv td:has(> .td-inv__edit) { text-align: right; }
.td-inv__cell { display: inline-flex; align-items: baseline; gap: 6px; padding: 4px 6px; border-radius: 2px; cursor: text; transition: background 0.12s; }
.td-inv__cell:hover { background: color-mix(in oklch, var(--td-primary) 12%, var(--td-panel)); outline: 1px dashed color-mix(in oklch, var(--td-primary) 50%, transparent); }
.td-inv__cell .td-inv__pen { font-size: 9px; opacity: 0; transition: opacity 0.12s; }
.td-inv__cell:hover .td-inv__pen { opacity: 0.55; }
.td-inv__edit { width: 90px; padding: 4px 8px; border: 1px solid var(--td-ink); border-radius: 2px; background: var(--td-paper); font-family: var(--td-mono); font-size: 12px; text-align: right; outline: none; box-shadow: 0 0 0 3px color-mix(in oklch, var(--td-primary) 22%, transparent); }
.td-inv__edit::-webkit-inner-spin-button { opacity: 0.4; }
.td-inv__reset { margin-left: 4px; padding: 2px 6px; border-radius: 999px; font-family: var(--td-mono); font-size: 10px; background: color-mix(in oklch, var(--td-accent) 14%, var(--td-panel)); color: color-mix(in oklch, var(--td-accent) 70%, var(--td-ink)); transition: background 0.12s; cursor: pointer; }
.td-inv__reset:hover { background: var(--td-accent); color: var(--td-paper); }
.td-inv__margin { display: inline-block; padding: 2px 6px; border-radius: 2px; }
.td-inv td { vertical-align: middle; }

/* admin · trend color cues (used in tables + history) */
.td-up, .td-down, .td-warn { font-weight: 500; }
.td-up   { color: color-mix(in oklch, var(--td-primary) 70%, var(--td-ink)); }
.td-down { color: color-mix(in oklch, var(--td-accent) 70%, var(--td-ink)); }
.td-warn { color: oklch(0.55 0.12 65); }


/* ═══════════════════════════════════════════════════ admin · re-abastecer drawer */
.td-ro__supplier { display: grid; grid-template-columns: 1fr auto; gap: 24px; padding: 18px 20px; background: var(--td-ink); color: var(--td-paper); border-radius: 2px; align-items: start; }
.td-ro__supplier-l { display: flex; flex-direction: column; gap: 6px; }
.td-ro__supplier-l .mono.dim { color: color-mix(in oklch, var(--td-paper) 55%, transparent); }
.td-ro__supplier-h { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin: 2px 0; color: var(--td-paper); }
.td-ro__supplier-meta { display: flex; flex-wrap: wrap; gap: 6px 16px; font-size: 13px; opacity: 0.85; }
.td-ro__supplier-meta b { font-weight: 500; }
.td-ro__supplier-note { font-size: 13px; line-height: 1.5; margin: 6px 0 0; padding-top: 10px; border-top: 1px solid color-mix(in oklch, var(--td-paper) 18%, transparent); opacity: 0.8; max-width: 64ch; text-wrap: pretty; }
.td-ro__supplier-r { display: flex; flex-direction: column; gap: 8px; align-items: stretch; min-width: 220px; }
.td-ro__supplier-r .td-btn--solid { background: var(--td-paper); color: var(--td-ink); }
.td-ro__supplier-r .td-btn--solid:hover { background: var(--td-primary); color: var(--td-paper); }
.td-ro__supplier-r .td-btn--ghost { color: var(--td-paper); border-color: color-mix(in oklch, var(--td-paper) 30%, transparent); }
.td-ro__supplier-r .td-btn--ghost:hover { background: var(--td-paper); color: var(--td-ink); }
.td-ro__supplier-r .mono.dim { color: color-mix(in oklch, var(--td-paper) 55%, transparent); text-align: center; padding: 2px 0; }
.td-ro__platform { padding-top: 4px; }
@media (max-width: 800px) { .td-ro__supplier { grid-template-columns: 1fr; } .td-ro__supplier-r { min-width: 0; } }

.td-ro__calc { display: flex; flex-direction: column; gap: 16px; border: 1px solid var(--td-line); padding: 18px 20px; background: var(--td-paper); }
.td-ro__calc-head { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--td-line); }
.td-ro__calc-head h3 { font-family: var(--td-display); font-size: 19px; font-weight: 700; margin: 0; }

.td-ro__inputs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 700px) { .td-ro__inputs { grid-template-columns: 1fr 1fr; } }
.td-ro__input { display: flex; flex-direction: column; gap: 4px; padding: 12px 14px; background: var(--td-panel); border-radius: 2px; }
.td-ro__input input { padding: 6px 0; background: transparent; border: 0; border-bottom: 1px solid var(--td-line); font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; outline: none; }
.td-ro__input input:focus { border-bottom-color: var(--td-ink); }
.td-ro__input strong { font-family: var(--td-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; padding: 6px 0; border-bottom: 1px solid transparent; }
.td-ro__input--read { background: color-mix(in oklch, var(--td-panel) 60%, transparent); }

.td-ro__breakdown { display: flex; flex-direction: column; gap: 8px; }
.td-ro__breakdown h4 { margin: 0 0 6px; opacity: 0.55; }
.td-ro__bd { display: flex; flex-direction: column; }
.td-ro__row { display: grid; grid-template-columns: 1.4fr auto 1.4fr; gap: 16px; padding: 8px 0; border-top: 1px dashed var(--td-line); align-items: baseline; font-size: 13px; }
.td-ro__row:first-child { border-top: 0; }
.td-ro__row.is-bold { font-family: var(--td-display); font-size: 17px; font-weight: 700; padding: 12px 0 6px; border-top: 1px solid var(--td-ink); }
.td-ro__row.is-bold .mono { font-family: var(--td-display); font-size: 22px; font-weight: 800; }
.td-ro__row.is-muted { opacity: 0.6; }
.td-ro__row .mono.dim { font-size: 11px; }
.td-ro__row .mono:nth-child(2) { text-align: right; }
@media (max-width: 700px) { .td-ro__row { grid-template-columns: 1fr auto; } .td-ro__row > span:last-child { grid-column: 1 / -1; padding-left: 0; } }

.td-ro__totals { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--td-line); border: 1px solid var(--td-line); }
.td-ro__total { background: var(--td-paper); padding: 14px 16px; display: flex; flex-direction: column; gap: 4px; }
.td-ro__total strong { font-family: var(--td-display); font-size: 26px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.td-ro__total--rec { background: color-mix(in oklch, var(--td-primary) 12%, var(--td-panel)); }
.td-ro__total--rec strong { color: color-mix(in oklch, var(--td-primary) 65%, var(--td-ink)); }
@media (max-width: 800px) { .td-ro__totals { grid-template-columns: 1fr 1fr; } }

.td-ro__history { display: flex; flex-direction: column; gap: 8px; padding: 18px 0 0; }
.td-ro__history h3 { font-family: var(--td-display); font-size: 19px; font-weight: 700; margin: 0 0 8px; }
.td-ro__current { background: color-mix(in oklch, var(--td-primary) 10%, var(--td-panel)); }
.td-ro__current td { border-top: 2px solid var(--td-primary); }
.td-ro__velocity { padding-top: 8px; }


/* ═══════════════════════════════════════════════════ admin · working image uploader */
.td-up-gal { display: flex; flex-direction: column; gap: 8px; }
.td-up-gal__row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.td-up { position: relative; aspect-ratio: 1/1; border: 1.5px dashed var(--td-line); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 16px; text-align: center; cursor: pointer; transition: border-color 0.15s, background 0.15s; overflow: hidden; }
.td-up:hover { border-color: var(--td-ink); background: var(--td-panel); }
.td-up.is-drag { border-color: var(--td-primary); border-style: solid; background: color-mix(in oklch, var(--td-primary) 8%, var(--td-panel)); }
.td-up.has-img { border-style: solid; padding: 0; border-color: var(--td-line); }
.td-up.has-img:hover { border-color: var(--td-ink); }
.td-up.is-busy { opacity: 0.6; pointer-events: none; }
.td-up img { width: 100%; height: 100%; object-fit: cover; }
.td-up__icon { font-family: var(--td-mono); font-size: 22px; opacity: 0.4; }
.td-up b { font-family: var(--td-display); font-size: 14px; font-weight: 600; }
.td-up__rm { position: absolute; top: 6px; right: 6px; padding: 4px 8px; background: color-mix(in oklch, var(--td-ink) 70%, transparent); color: var(--td-paper); font-size: 9px; letter-spacing: 0.06em; border-radius: 2px; opacity: 0; transition: opacity 0.15s; }
.td-up:hover .td-up__rm { opacity: 1; }
.td-up__name { position: absolute; bottom: 6px; left: 6px; right: 6px; padding: 3px 6px; background: color-mix(in oklch, var(--td-paper) 80%, transparent); border-radius: 2px; font-size: 9px; opacity: 0; transition: opacity 0.15s; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; }
.td-up:hover .td-up__name { opacity: 1; }
.td-up-gal > .td-up:first-child { aspect-ratio: 1/1; min-height: 280px; }
.td-up-gal__row .td-up { min-height: 0; }

/* admin · AI helper button on legend */
.td-pe__ai { float: right; padding: 4px 10px; background: var(--td-ink); color: var(--td-paper); border-radius: 999px; font-size: 10px; font-family: var(--td-mono); letter-spacing: 0.05em; transition: background 0.15s; }
.td-pe__ai:hover { background: var(--td-primary); }


/* ═══════════════════════════════════════════════════════════════════
   GT ADDRESS · carrier routing preview
   ═══════════════════════════════════════════════════════════════════ */
.td-gtaddr { display: flex; flex-direction: column; gap: 14px; }
.td-gtaddr .td-field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.td-gtaddr textarea { padding: 12px 14px; border: 1px solid var(--td-line); background: var(--td-paper); border-radius: var(--td-rad); font-size: 15px; outline: none; resize: vertical; font-family: inherit; line-height: 1.45; }
.td-gtaddr textarea:focus { border-color: var(--td-ink); }
.td-gtaddr__chk { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; line-height: 1.45; cursor: pointer; padding: 4px 0; }
.td-gtaddr__chk input { margin-top: 3px; accent-color: var(--td-ink); flex-shrink: 0; }

/* carrier-routing preview block */
.td-gtroute { border: 1.5px dashed var(--td-ink); padding: 16px 18px; display: flex; flex-direction: column; gap: 12px; margin-top: 4px; background: color-mix(in oklch, var(--td-paper) 92%, var(--td-primary) 8%); }
.td-gtroute__head { display: flex; justify-content: space-between; align-items: center; gap: 16px; cursor: pointer; }
.td-gtroute__head > div { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.td-gtroute__pick { font-family: var(--td-display); font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.td-gtroute__pick .serif-i { color: var(--td-primary); font-size: 1.05em; }
.td-gtroute__toggle { padding: 6px 10px; border: 1px solid var(--td-ink); border-radius: 999px; font-size: 10px; transition: background 0.15s, color 0.15s; flex-shrink: 0; background: var(--td-paper); }
.td-gtroute__toggle:hover { background: var(--td-ink); color: var(--td-paper); }
.td-gtroute__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.td-gtroute__row { display: grid; grid-template-columns: 24px 1fr auto; gap: 14px; align-items: center; padding: 12px 0; border-top: 1px solid color-mix(in oklch, var(--td-ink) 14%, transparent); }
.td-gtroute__row--no { opacity: 0.45; }
.td-gtroute__row--soon { opacity: 0.65; }
.td-gtroute__cmain { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-gtroute__cmain strong { font-family: var(--td-display); font-size: 15px; }
.td-gtroute__note { font-size: 11px; }
.td-pill--off { background: var(--td-panel); color: color-mix(in oklch, var(--td-ink) 50%, transparent); border: 1px dashed var(--td-line); }
.td-gtroute--compact { padding: 12px 14px; }
.td-gtroute--compact .td-gtroute__pick { font-size: 15px; }

/* ═══════════════════════════════════════════════════════════════════
   REGISTRATION · multi-step
   ═══════════════════════════════════════════════════════════════════ */
.td-login__card--reg { max-width: 560px; width: min(100%, 560px); padding: 36px 36px 32px; }
.td-login__wrap:has(.td-login__card--reg) { max-width: 560px; }

.td-reg__h { font-family: var(--td-display); font-size: 32px; font-weight: 700; letter-spacing: -0.025em; line-height: 1.05; margin: 4px 0 0; }
.td-reg__lede { font-size: 14px; line-height: 1.5; margin: 0; opacity: 0.85; text-wrap: pretty; }

.td-reg__rail { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin: 4px 0 8px; }
.td-reg__pip { display: flex; flex-direction: column; gap: 4px; padding: 8px 10px 6px; border-top: 2px solid var(--td-line); opacity: 0.4; transition: opacity 0.2s, border-color 0.2s; min-width: 0; }
.td-reg__pip-l { font-size: 11px; line-height: 1.2; }
.td-reg__pip.is-active { opacity: 1; border-color: var(--td-ink); }
.td-reg__pip.is-done { opacity: 1; border-color: var(--td-primary); }
.td-reg__pip.is-done .mono::before { content: "✓ "; color: var(--td-primary); }

.td-reg__cta { display: flex; gap: 10px; align-items: center; padding-top: 4px; }
.td-reg__cta--col { flex-direction: column; align-items: stretch; }
.td-reg__cta > button:first-child { flex-shrink: 0; }

.td-reg__addr { gap: 12px; }

/* OTP cells */
.td-otp { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 8px; padding: 8px 0; }
.td-otp__cell { min-width: 0; padding: 16px 0; text-align: center; font-family: var(--td-mono); font-size: 22px; font-weight: 500; border: 1px solid var(--td-line); border-radius: var(--td-rad); background: var(--td-paper); outline: none; transition: border-color 0.15s, background 0.15s; }
.td-otp__cell:focus { border-color: var(--td-ink); background: color-mix(in oklch, var(--td-primary) 6%, var(--td-paper)); }

/* register done state */
.td-reg__done { display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 8px 0; text-align: center; }
.td-reg__done-h { font-family: var(--td-display); font-size: 30px; font-weight: 700; letter-spacing: -0.025em; margin: 8px 0 0; line-height: 1.05; }
.td-reg__done-list { list-style: none; padding: 0; margin: 8px 0 12px; display: flex; flex-direction: column; gap: 8px; text-align: left; width: 100%; }
.td-reg__done-list li { display: grid; grid-template-columns: 32px 1fr; gap: 10px; padding: 10px 0; border-top: 1px solid var(--td-line); font-size: 14px; line-height: 1.45; }
.td-reg__done-list li:last-child { border-bottom: 1px solid var(--td-line); }

/* sign-in alts row */
.td-login__alts { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.td-login__alt { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 12px; border: 1px solid var(--td-line); border-radius: var(--td-rad); font-size: 13px; transition: background 0.15s, border-color 0.15s; }
.td-login__alt:hover { border-color: var(--td-ink); background: var(--td-panel); }
.td-login__alt--wa { color: #25D366; }
.td-login__alt--wa:hover { background: #25D366; color: white; border-color: #25D366; }

/* new-here CTA */
.td-login__newhere { display: flex; flex-direction: column; gap: 6px; padding: 14px 16px; border: 1px dashed var(--td-line); border-radius: var(--td-rad); text-align: center; margin-top: 4px; background: color-mix(in oklch, var(--td-panel) 50%, var(--td-paper)); }
.td-login__newhere-cta { font-family: var(--td-display); font-size: 16px; font-weight: 600; letter-spacing: -0.01em; padding: 4px 0; transition: color 0.15s; }
.td-login__newhere-cta:hover { color: var(--td-primary); }

@media (max-width: 540px) {
  .td-otp { gap: 6px; }
  .td-otp__cell { font-size: 18px; padding: 12px 0; }
  .td-reg__rail { grid-template-columns: repeat(2, 1fr); }
  .td-login__card--reg { padding: 28px 22px; }
}

/* ═══════════════════════════════════════════════════════════════════
   SUPPORT · FAB + chat widget
   ═══════════════════════════════════════════════════════════════════ */
.td-fab { position: fixed; right: 24px; bottom: 24px; z-index: 70; display: inline-flex; align-items: center; gap: 10px; padding: 14px 20px 14px 16px; background: var(--td-ink); color: var(--td-paper); border-radius: 999px; box-shadow: 0 16px 32px -12px color-mix(in oklch, var(--td-ink) 50%, transparent), 0 4px 12px -2px color-mix(in oklch, var(--td-ink) 30%, transparent); transition: transform 0.18s, background 0.2s; font-size: 14px; font-weight: 500; }
.td-fab:hover { transform: translateY(-2px); background: var(--td-primary); }
.td-fab__label { line-height: 1; }
.td-fab__pulse { position: absolute; right: 14px; top: 14px; width: 8px; height: 8px; border-radius: 50%; background: var(--td-primary); box-shadow: 0 0 0 0 color-mix(in oklch, var(--td-primary) 60%, transparent); animation: td-fabpulse 2.2s ease-out infinite; }
@keyframes td-fabpulse {
  0% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--td-primary) 60%, transparent); }
  70% { box-shadow: 0 0 0 12px color-mix(in oklch, var(--td-primary) 0%, transparent); }
  100% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--td-primary) 0%, transparent); }
}
.td-fab__badge { position: absolute; right: -4px; top: -4px; min-width: 18px; height: 18px; padding: 0 5px; background: var(--td-accent); color: var(--td-paper); border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; font-size: 9px; }

/* fab hint bubble */
.td-fab__hint { position: fixed; right: 24px; bottom: 86px; z-index: 70; background: var(--td-paper); border: 1px solid var(--td-ink); padding: 14px 36px 14px 16px; max-width: 280px; box-shadow: 0 12px 28px -10px color-mix(in oklch, var(--td-ink) 40%, transparent); display: flex; flex-direction: column; gap: 2px; cursor: pointer; animation: td-fab-hint-in 0.4s ease 1.2s both; }
.td-fab__hint strong { font-family: var(--td-display); font-size: 15px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.25; }
.td-fab__hint strong .serif-i { color: var(--td-primary); }
.td-fab__hint-x { position: absolute; top: 6px; right: 8px; width: 22px; height: 22px; font-size: 16px; line-height: 1; opacity: 0.5; }
.td-fab__hint-x:hover { opacity: 1; }
@keyframes td-fab-hint-in { from { opacity: 0; transform: translateY(8px) scale(0.96); } to { opacity: 1; transform: translateY(0) scale(1); } }
.td-fab__hint::after { content: ""; position: absolute; right: 24px; bottom: -8px; width: 14px; height: 14px; background: var(--td-paper); border-right: 1px solid var(--td-ink); border-bottom: 1px solid var(--td-ink); transform: rotate(45deg); }

/* support panel */
.td-fab-panel { position: fixed; right: 24px; bottom: 24px; z-index: 75; width: min(400px, calc(100vw - 32px)); height: min(620px, calc(100vh - 48px)); background: var(--td-paper); border: 1px solid var(--td-ink); box-shadow: 0 24px 48px -16px color-mix(in oklch, var(--td-ink) 50%, transparent), 0 8px 16px -4px color-mix(in oklch, var(--td-ink) 30%, transparent); display: flex; flex-direction: column; animation: td-fab-panel-in 0.22s ease; overflow: hidden; }
@keyframes td-fab-panel-in { from { opacity: 0; transform: translateY(16px) scale(0.96); transform-origin: bottom right; } to { opacity: 1; transform: translateY(0) scale(1); } }
.td-fab-panel__head { background: var(--td-ink); color: var(--td-paper); padding: 16px 18px; display: flex; justify-content: space-between; align-items: start; gap: 12px; flex-shrink: 0; }
.td-fab-panel__head > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-fab-panel__head .mono { color: color-mix(in oklch, var(--td-paper) 60%, transparent); }
.td-fab-panel__h { font-family: var(--td-display); font-size: 18px; font-weight: 700; letter-spacing: -0.015em; line-height: 1.15; }
.td-fab-panel__actions { display: flex; gap: 4px; }
.td-fab-panel__close, .td-fab-panel__back { width: 28px; height: 28px; border-radius: 999px; border: 1px solid color-mix(in oklch, var(--td-paper) 30%, transparent); color: var(--td-paper); display: inline-flex; align-items: center; justify-content: center; font-size: 16px; line-height: 1; transition: background 0.15s, color 0.15s; flex-shrink: 0; }
.td-fab-panel__close:hover, .td-fab-panel__back:hover { background: var(--td-paper); color: var(--td-ink); }
.td-fab-panel__body { flex: 1; overflow-y: auto; padding: 16px 18px; }
.td-fab-panel__body--chat { padding: 0; display: flex; flex-direction: column; overflow: hidden; }
.td-fab-panel__foot { padding: 10px 18px; border-top: 1px solid var(--td-line); background: var(--td-panel); text-align: center; flex-shrink: 0; line-height: 1.4; }

/* menu */
.td-fab-menu { display: flex; flex-direction: column; gap: 10px; }
.td-fab-menu__opt { display: grid; grid-template-columns: 40px 1fr auto; gap: 14px; align-items: center; padding: 14px 16px; border: 1px solid var(--td-line); transition: border-color 0.15s, background 0.15s; cursor: pointer; text-align: left; color: inherit; background: var(--td-paper); }
.td-fab-menu__opt:hover { border-color: var(--td-ink); background: var(--td-panel); }
.td-fab-menu__opt--wa:hover { border-color: #25D366; background: color-mix(in oklch, oklch(0.78 0.13 150) 12%, var(--td-paper)); }
.td-fab-menu__icon { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; background: var(--td-panel); border-radius: var(--td-rad); flex-shrink: 0; }
.td-fab-menu__opt--wa .td-fab-menu__icon { background: #25D366; color: white; }
.td-fab-menu__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.td-fab-menu__body strong { font-family: var(--td-display); font-size: 15px; font-weight: 600; letter-spacing: -0.01em; }
.td-fab-menu__arrow { font-size: 16px; opacity: 0.4; transition: transform 0.15s, opacity 0.15s; }
.td-fab-menu__opt:hover .td-fab-menu__arrow { opacity: 1; transform: translateX(2px); }
.td-fab-menu__quick { padding-top: 8px; display: flex; flex-direction: column; gap: 6px; }
.td-fab-menu__qs { display: flex; flex-wrap: wrap; gap: 6px; }
.td-fab-menu__qs button { padding: 6px 12px; border: 1px solid var(--td-line); border-radius: 999px; font-size: 12px; transition: background 0.15s, border-color 0.15s; }
.td-fab-menu__qs button:hover { border-color: var(--td-ink); background: var(--td-panel); }

/* chat */
.td-chat__meta { display: flex; justify-content: space-between; align-items: center; padding: 12px 18px; border-bottom: 1px solid var(--td-line); background: var(--td-panel); flex-shrink: 0; }
.td-chat__agent { display: flex; align-items: center; gap: 10px; }
.td-chat__agent strong { font-family: var(--td-display); font-size: 14px; display: block; }
.td-chat__avatar { width: 32px; height: 32px; border-radius: 999px; background: var(--td-primary); color: var(--td-paper); display: inline-flex; align-items: center; justify-content: center; font-family: var(--td-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.05em; flex-shrink: 0; }
.td-chat__dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--td-primary); vertical-align: middle; margin-right: 4px; box-shadow: 0 0 0 3px color-mix(in oklch, var(--td-primary) 22%, transparent); }
.td-chat__esc { font-size: 9px; padding: 5px 8px; border: 1px solid var(--td-line); border-radius: 999px; transition: border-color 0.15s, background 0.15s; }
.td-chat__esc:hover { border-color: var(--td-ink); background: var(--td-paper); }

.td-chat__thread { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 12px; }
.td-chat__msg { display: flex; flex-direction: column; gap: 4px; max-width: 84%; }
.td-chat__msg--agent { align-self: flex-start; }
.td-chat__msg--user { align-self: flex-end; align-items: flex-end; }
.td-chat__bubble { padding: 10px 14px; font-size: 14px; line-height: 1.45; border-radius: 14px; word-wrap: break-word; }
.td-chat__msg--agent .td-chat__bubble { background: var(--td-panel); border-bottom-left-radius: 4px; }
.td-chat__msg--user  .td-chat__bubble { background: var(--td-ink); color: var(--td-paper); border-bottom-right-radius: 4px; }
.td-chat__bubble--typing { display: inline-flex; gap: 4px; padding: 14px; align-items: center; }
.td-chat__bubble--typing span { width: 6px; height: 6px; border-radius: 50%; background: color-mix(in oklch, var(--td-ink) 40%, transparent); animation: td-chat-bounce 1.2s ease-in-out infinite; }
.td-chat__bubble--typing span:nth-child(2) { animation-delay: 0.15s; }
.td-chat__bubble--typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes td-chat-bounce { 0%, 60%, 100% { transform: translateY(0); opacity: 0.4; } 30% { transform: translateY(-4px); opacity: 1; } }

.td-chat__form { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 12px 14px; border-top: 1px solid var(--td-line); background: var(--td-paper); flex-shrink: 0; }
.td-chat__form input { padding: 10px 14px; border: 1px solid var(--td-line); border-radius: 999px; font-size: 14px; outline: none; background: var(--td-paper); }
.td-chat__form input:focus { border-color: var(--td-ink); }
.td-chat__form button { width: 40px; height: 40px; border-radius: 999px; background: var(--td-ink); color: var(--td-paper); display: inline-flex; align-items: center; justify-content: center; transition: background 0.15s, transform 0.1s; }
.td-chat__form button:not(:disabled):hover { background: var(--td-primary); }
.td-chat__form button:disabled { opacity: 0.3; cursor: not-allowed; }

/* message form */
.td-msgform { display: flex; flex-direction: column; gap: 12px; }
.td-msgform .td-field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.td-msgform textarea { padding: 12px 14px; border: 1px solid var(--td-line); background: var(--td-paper); border-radius: var(--td-rad); font-size: 14px; outline: none; resize: vertical; font-family: inherit; line-height: 1.45; }
.td-msgform textarea:focus { border-color: var(--td-ink); }
.td-msgsent { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 24px 8px; text-align: center; }
.td-msgsent h3 { font-family: var(--td-display); font-size: 24px; font-weight: 700; letter-spacing: -0.02em; margin: 4px 0 0; }
.td-msgsent p { font-size: 14px; line-height: 1.5; max-width: 30ch; margin: 0; opacity: 0.85; }

/* ═══════════════════════════════════════════════════════════════════
   CONTACTO page
   ═══════════════════════════════════════════════════════════════════ */
.td-contact { padding-bottom: 56px; }
.td-contact__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; padding-bottom: 36px; border-bottom: 1px solid var(--td-line); }
@media (max-width: 900px) { .td-contact__grid { grid-template-columns: 1fr; } }
.td-contact__card { display: flex; flex-direction: column; gap: 12px; padding: 28px; border: 1px solid var(--td-line); background: var(--td-paper); text-align: left; transition: transform 0.18s, border-color 0.18s; cursor: pointer; color: inherit; }
.td-contact__card:hover { transform: translateY(-4px); border-color: var(--td-ink); }
.td-contact__card--wa:hover { border-color: #25D366; background: color-mix(in oklch, oklch(0.78 0.13 150) 6%, var(--td-paper)); }
.td-contact__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 8px 0 12px; border-bottom: 1px solid var(--td-line); }
.td-contact__head strong { font-family: var(--td-display); font-size: 28px; font-weight: 700; letter-spacing: -0.025em; }
.td-contact__card p { font-size: 14px; line-height: 1.5; margin: 0; opacity: 0.85; text-wrap: pretty; min-height: 4.5em; }
.td-contact__addr { font-size: 13px; padding: 4px 0; opacity: 0.85; }
.td-contact__cta { padding-top: 8px; border-top: 1px solid var(--td-line); font-size: 11px; opacity: 0.7; transition: opacity 0.15s; }
.td-contact__card:hover .td-contact__cta { opacity: 1; }

.td-contact__faq { padding: 40px 0 24px; }
.td-contact__faq-head { max-width: 700px; margin-bottom: 20px; display: flex; flex-direction: column; gap: 8px; }
.td-contact__faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--td-line); }
@media (max-width: 700px) { .td-contact__faq-grid { grid-template-columns: 1fr; } }
.td-faq { display: flex; flex-direction: column; gap: 12px; padding: 20px 4px; text-align: left; border-bottom: 1px solid var(--td-line); background: transparent; transition: padding 0.18s; }
.td-faq:nth-child(odd) { border-right: 1px solid var(--td-line); padding-right: 24px; }
.td-faq:nth-child(even) { padding-left: 24px; }
@media (max-width: 700px) { .td-faq:nth-child(odd) { border-right: 0; padding-right: 4px; } .td-faq:nth-child(even) { padding-left: 4px; } }
.td-faq__q { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.td-faq__q strong { font-family: var(--td-display); font-size: 19px; font-weight: 600; letter-spacing: -0.015em; line-height: 1.2; }
.td-faq__tog { width: 28px; height: 28px; border-radius: 999px; border: 1px solid var(--td-line); display: inline-flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; transition: background 0.15s, color 0.15s; }
.td-faq.is-open .td-faq__tog { background: var(--td-ink); color: var(--td-paper); border-color: var(--td-ink); }
.td-faq__a { font-size: 15px; line-height: 1.55; margin: 0; opacity: 0.85; text-wrap: pretty; max-width: 60ch; }

.td-contact__bodega { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; padding: var(--td-pad-section) 0 0; border-top: 1px solid var(--td-line); align-items: start; }
@media (max-width: 900px) { .td-contact__bodega { grid-template-columns: 1fr; gap: 32px; } }
.td-contact__bodega-l { display: flex; flex-direction: column; gap: 12px; }
.td-contact__bodega-l p { font-size: 16px; line-height: 1.55; opacity: 0.85; margin: 0; max-width: 40ch; }
.td-contact__bodega-list { list-style: none; padding: 0; margin: 16px 0 0; display: flex; flex-direction: column; }
.td-contact__bodega-list li { display: grid; grid-template-columns: 120px 1fr; gap: 16px; padding: 12px 0; border-top: 1px solid var(--td-line); font-size: 15px; }
.td-contact__bodega-list li:last-child { border-bottom: 1px solid var(--td-line); }
.td-contact__bodega-r { position: relative; }
.td-contact__map { position: relative; aspect-ratio: 4/3; background: var(--td-panel); border: 1px solid var(--td-line); overflow: hidden; color: color-mix(in oklch, var(--td-ink) 40%, transparent); }
.td-contact__pin { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); padding: 16px 20px; background: var(--td-ink); color: var(--td-paper); display: flex; flex-direction: column; gap: 4px; align-items: flex-start; min-width: 200px; }
.td-contact__pin strong { font-family: var(--td-display); font-size: 18px; letter-spacing: -0.01em; }
.td-contact__pin .mono { color: color-mix(in oklch, var(--td-paper) 70%, transparent); }
.td-contact__pin::after { content: ""; position: absolute; bottom: -10px; left: 24px; width: 14px; height: 14px; background: var(--td-ink); transform: rotate(45deg); }
.td-contact__map-tag { position: absolute; bottom: 12px; right: 16px; }

/* tracking · order support card additions */
.td-side__cardp { font-size: 14px; line-height: 1.5; margin: 0 0 4px; opacity: 0.85; }
.td-side__altrow { display: flex; gap: 16px; padding-top: 8px; border-top: 1px solid var(--td-line); margin-top: 4px; flex-wrap: wrap; }
.td-side__altrow .td-side__link { padding: 0; opacity: 0.55; }
.td-side__altrow .td-side__link:hover { opacity: 1; }

/* small-screen support adjustments */
@media (max-width: 540px) {
  .td-fab { right: 16px; bottom: 16px; padding: 12px 16px 12px 14px; font-size: 13px; }
  .td-fab__label { display: none; }
  .td-fab__hint { right: 16px; bottom: 72px; max-width: 220px; }
  .td-fab-panel { right: 8px; bottom: 8px; left: 8px; width: auto; height: calc(100vh - 16px); }
}

/* ═══════════════════════════════════════════════════ footnote / disclaimer */
.td-foot-ast { color: var(--td-accent); font-family: var(--td-mono); font-size: 0.55em; vertical-align: super; line-height: 0; margin-left: 2px; text-decoration: none; transition: opacity 0.15s; font-weight: 600; }
.td-foot-ast:hover { opacity: 0.7; }
.td-foot__legal { padding: 28px 32px 20px; border-top: 1px solid color-mix(in oklch, var(--td-paper) 12%, transparent); }
.td-foot__legal-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; max-width: 92ch; }
.td-foot__legal-list li { display: grid; grid-template-columns: 24px 1fr; gap: 12px; font-size: 11px; line-height: 1.65; letter-spacing: 0.02em; text-transform: none; color: color-mix(in oklch, var(--td-paper) 55%, transparent); scroll-margin-top: 80px; transition: color 0.15s; }
.td-foot__legal-list li:target { color: color-mix(in oklch, var(--td-paper) 85%, transparent); }
.td-foot__legal-list li:target .td-foot__legal-n { color: var(--td-accent); }
.td-foot__legal-list strong { color: color-mix(in oklch, var(--td-paper) 75%, transparent); font-weight: 600; letter-spacing: 0.06em; }
.td-foot__legal-n { color: var(--td-accent); font-family: var(--td-mono); font-size: 12px; line-height: 1; padding-top: 1px; font-weight: 600; }
@media (max-width: 700px) { .td-foot__legal { padding: 20px 20px 16px; } }

/* ═══════════════════════════════════════════════════ admin · public visibility flags */
.td-visflag { margin-bottom: 8px; }
.td-visflag__body { padding: 18px 20px; display: flex; flex-direction: column; gap: 18px; }
.td-visflag__row { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; padding-bottom: 18px; border-bottom: 1px solid var(--td-line); }
.td-visflag__row:last-child { padding-bottom: 0; border-bottom: none; }
.td-visflag__row--col { flex-direction: column; gap: 16px; align-items: stretch; }
.td-visflag__l { display: flex; flex-direction: column; gap: 4px; max-width: 60ch; }
.td-visflag__l strong { font-family: var(--td-display); font-size: 17px; font-weight: 600; }
.td-visflag__detail { font-size: 13px; opacity: 0.75; margin-top: 4px; line-height: 1.5; }
.td-visflag__off { color: var(--td-accent); }
.td-toggle { width: 48px; height: 28px; background: var(--td-line); border-radius: 999px; padding: 3px; display: inline-flex; align-items: center; transition: background 0.18s; flex-shrink: 0; cursor: pointer; border: none; }
.td-toggle.is-on { background: var(--td-primary); }
.td-toggle__knob { width: 22px; height: 22px; background: var(--td-paper); border-radius: 50%; transition: transform 0.18s; box-shadow: 0 1px 3px color-mix(in oklch, var(--td-ink) 30%, transparent); }
.td-toggle.is-on .td-toggle__knob { transform: translateX(20px); }

/* discount band slider */
.td-band { display: grid; grid-template-columns: 1fr 80px; gap: 14px; align-items: center; max-width: 540px; }
.td-band input[type="range"] { width: 100%; accent-color: var(--td-primary); grid-column: 1; }
.td-band__marks { grid-column: 1; display: flex; justify-content: space-between; font-size: 10px; opacity: 0.5; margin-top: -6px; }
.td-band__v { grid-column: 2; grid-row: 1 / span 2; font-family: var(--td-display); font-size: 32px; font-weight: 700; color: var(--td-primary); text-align: right; }

/* ═══════════════════════════════════════════════════ admin · ops cost panel (T4 legal) */
.td-opscost__intro { margin: 0 0 16px; max-width: 72ch; }
.td-opscost__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 20px; }
@media (max-width: 900px) { .td-opscost__grid { grid-template-columns: 1fr; } }
.td-opscost__card { display: flex; flex-direction: column; gap: 6px; padding: 14px 16px; background: var(--td-panel); border: 1px solid var(--td-line); }
.td-opscost__card > span:first-child { font-size: 10px; letter-spacing: 0.06em; }
.td-opscost__inp { font-family: var(--td-display); font-size: 26px; font-weight: 700; letter-spacing: -0.015em; padding: 4px 0; border: none; border-bottom: 2px solid var(--td-ink); background: transparent; color: var(--td-ink); width: 100%; margin: 2px 0 4px; }
.td-opscost__inp:focus { outline: none; border-bottom-color: var(--td-primary); }

.td-opscost__mix { display: flex; flex-direction: column; gap: 10px; padding: 16px; background: color-mix(in oklch, var(--td-ink) 4%, var(--td-paper)); border: 1px solid var(--td-line); }
.td-opscost__mixhead { display: flex; flex-direction: column; gap: 4px; margin-bottom: 4px; }
.td-opscost__mixhead strong { font-family: var(--td-display); font-size: 16px; font-weight: 600; }
.td-opscost__bar { display: flex; height: 32px; background: var(--td-paper); border: 1px solid var(--td-line); overflow: hidden; }
.td-opscost__bar-urb { display: flex; align-items: center; padding: 0 10px; background: oklch(0.50 0.14 220); color: var(--td-paper); transition: width 0.2s; min-width: 60px; }
.td-opscost__bar-dept { display: flex; align-items: center; padding: 0 10px; background: oklch(0.55 0.16 28); color: var(--td-paper); transition: width 0.2s; min-width: 60px; justify-content: flex-end; }
.td-opscost__bar span { font-size: 11px; white-space: nowrap; }
.td-opscost__slider { width: 100%; accent-color: var(--td-primary); }
.td-opscost__readout { padding-top: 4px; border-top: 1px solid var(--td-line); }

/* ═══════════════════════════════════════════════════ admin · inventory wide table */
.td-inv__scroll { overflow-x: auto; margin: 0 -2px; }
.td-inv__scroll table { min-width: 100%; }
.td-inv__th2 { display: flex; flex-direction: column; gap: 1px; line-height: 1.1; align-items: flex-end; }
.td-inv__th2 .small { font-size: 9px; }

/* ═══════════════════════════════════════════════════ admin · product editor cost summary */
.td-pe__costsum { display: grid; grid-template-columns: repeat(7, 1fr); gap: 10px; padding: 14px; margin-top: 8px; background: color-mix(in oklch, var(--td-ink) 4%, var(--td-paper)); border: 1px solid var(--td-line); }
@media (max-width: 900px) { .td-pe__costsum { grid-template-columns: repeat(3, 1fr); } }
.td-pe__costsum > div { display: flex; flex-direction: column; gap: 3px; }
.td-pe__costsum > div > span { font-size: 9px; letter-spacing: 0.05em; }
.td-pe__costsum > div > strong { font-family: var(--td-display); font-size: 17px; font-weight: 600; letter-spacing: -0.01em; }

/* layout A/B picker */
.td-layout-b__tag { font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.1em; background: var(--td-primary); color: var(--td-paper); padding: 3px 8px; margin-left: 6px; }
.td-layout-b__picker { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: 540px; }
.td-layout-b__opt { display: flex; flex-direction: column; gap: 10px; padding: 14px; border: 1px solid var(--td-line); background: var(--td-paper); cursor: pointer; transition: border-color 0.15s, background 0.15s; text-align: left; }
.td-layout-b__opt:hover { border-color: color-mix(in oklch, var(--td-ink) 40%, var(--td-line)); }
.td-layout-b__opt.is-active { border-color: var(--td-primary); background: color-mix(in oklch, var(--td-primary) 6%, var(--td-paper)); }
.td-layout-b__opt strong { font-size: 11px; letter-spacing: 0.1em; }
.td-layout-b__thumb { background: var(--td-panel); padding: 14px; display: flex; flex-direction: column; gap: 8px; aspect-ratio: 16/9; border: 1px solid var(--td-line); }
.td-layout-b__t { background: var(--td-line); border-radius: 2px; }
.td-layout-b__t--wide { height: 8px; width: 75%; }
.td-layout-b__t--meta { height: 4px; width: 40%; }
.td-layout-b__t--vit { height: 38px; width: 100%; background: color-mix(in oklch, var(--td-primary) 25%, var(--td-line)); margin-top: auto; }
.td-layout-b__t-split { display: grid; grid-template-columns: 1.1fr 1fr; gap: 10px; flex: 1; }
.td-layout-b__t--left { width: 90%; height: 100%; }
.td-layout-b__t--right { width: 100%; height: 100%; background: color-mix(in oklch, var(--td-primary) 25%, var(--td-line)); }
.td-layout-b__opt.is-active .td-layout-b__t--vit,
.td-layout-b__opt.is-active .td-layout-b__t--right { background: var(--td-primary); }

/* discount banner color picker */
.td-discol__picker { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: 540px; }
.td-discol__opt { display: flex; flex-direction: column; gap: 10px; padding: 14px; border: 1px solid var(--td-line); background: var(--td-paper); cursor: pointer; transition: border-color 0.15s, background 0.15s; text-align: left; }
.td-discol__opt:hover { border-color: color-mix(in oklch, var(--td-ink) 40%, var(--td-line)); }
.td-discol__opt.is-active { border-color: var(--td-ink); background: color-mix(in oklch, var(--td-ink) 4%, var(--td-paper)); }
.td-discol__opt strong { font-size: 11px; letter-spacing: 0.1em; }
.td-discol__sw { display: inline-flex; align-items: center; justify-content: center; padding: 10px 14px; color: var(--td-paper); font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.1em; text-align: center; }

/* ═══════════════════════════════════════════════════ admin · analítica */
.td-anly__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; margin-bottom: 24px; }
.td-anly__periods { display: flex; gap: 4px; flex-shrink: 0; background: var(--td-panel); padding: 4px; border: 1px solid var(--td-line); }
.td-anly__period { padding: 8px 14px; font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.08em; border: none; background: transparent; cursor: pointer; color: var(--td-ink); opacity: 0.55; transition: opacity 0.15s, background 0.15s; }
.td-anly__period:hover { opacity: 0.85; }
.td-anly__period.is-active { background: var(--td-ink); color: var(--td-paper); opacity: 1; }
.td-anly__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.td-anly__list li { display: flex; flex-direction: column; gap: 4px; padding: 12px 14px; background: var(--td-panel); border-left: 3px solid var(--td-accent); }
.td-anly__list li strong { font-family: var(--td-display); font-size: 16px; font-weight: 600; }
.td-anly__hint { font-size: 12px; opacity: 0.7; margin-top: 2px; }
.td-admin__panel:has(.td-anly__list) .td-anly__list li { border-left-color: var(--td-accent); }
section.td-admin__panel header h3:has(+ * .td-up), .td-admin__panel:nth-of-type(2) .td-anly__list li { border-left-color: var(--td-primary); }

/* ═══════════════════════════════════════════════════ admin · charts + trend badge */
.td-trend { display: inline-flex; align-items: center; gap: 4px; padding: 3px 7px; border-radius: 999px; font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.04em; font-weight: 500; line-height: 1; vertical-align: middle; }
.td-trend--sm { padding: 2px 5px; font-size: 10px; gap: 3px; }
.td-trend--lg { padding: 4px 9px; font-size: 12px; gap: 5px; }
.td-trend svg { flex-shrink: 0; }

.td-spark { display: block; max-width: 100%; }

.td-kpi { display: flex; flex-direction: column; gap: 6px; padding: 18px 20px 16px; background: var(--td-panel); position: relative; }
.td-kpi__h { display: flex; justify-content: space-between; align-items: center; gap: 8px; min-height: 18px; }
.td-kpi__v { font-family: var(--td-display); font-size: 38px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; margin: 2px 0 0; }
.td-kpi__sub { line-height: 1.3; }
.td-kpi__spark { margin-top: 10px; height: 48px; color: var(--td-ink); display: flex; align-items: flex-end; }
.td-kpi__spark svg { width: 100%; height: 100%; }
.td-kpi__spark--compact { height: 36px; margin-top: 8px; }
.td-kpi--mini { padding: 14px 16px; }
.td-kpi--mini strong { font-family: var(--td-display); font-size: 26px; font-weight: 700; letter-spacing: -0.02em; }

.td-kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
@media (max-width: 1100px) { .td-kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .td-kpi-grid { grid-template-columns: 1fr; } }

.td-kpi-secondary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding: 16px 20px; background: color-mix(in oklch, var(--td-ink) 4%, var(--td-paper)); border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); margin-bottom: 24px; }
.td-kpi-secondary > div { display: flex; flex-direction: column; gap: 2px; }
.td-kpi-secondary strong { font-family: var(--td-display); font-size: 22px; font-weight: 600; letter-spacing: -0.015em; }

/* funnel bars */
.td-funnel { display: flex; flex-direction: column; gap: 8px; padding: 4px 0; }
.td-funnel--compact { gap: 4px; padding: 0; }
.td-funnel__row { display: grid; grid-template-columns: 64px 1fr 48px; gap: 8px; align-items: center; }
.td-funnel--compact .td-funnel__row { grid-template-columns: 52px 1fr 40px; }
.td-funnel__lbl { font-size: 10px; }
.td-funnel__track { background: color-mix(in oklch, var(--td-ink) 5%, var(--td-paper)); height: 22px; position: relative; overflow: hidden; }
.td-funnel--compact .td-funnel__track { height: 14px; }
.td-funnel__fill { height: 100%; min-width: 32px; display: flex; align-items: center; padding: 0 8px; transition: width 0.3s ease; }
.td-funnel__val { color: var(--td-paper); font-size: 11px; font-weight: 500; white-space: nowrap; }
.td-funnel--compact .td-funnel__val { font-size: 9px; padding-left: 2px; }
.td-funnel__pct { text-align: right; font-size: 10px; }

.td-anly__funkv { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--td-line); }
.td-anly__funkv > div { display: flex; flex-direction: column; gap: 4px; }
.td-anly__funkv dt { font-size: 10px; margin: 0; }
.td-anly__funkv dd { margin: 0; display: flex; align-items: center; gap: 8px; }
.td-anly__funkv dd strong { font-family: var(--td-display); font-size: 22px; font-weight: 600; letter-spacing: -0.015em; }

/* ranked bars */
.td-ranked { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.td-ranked li { display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: flex-start; }
.td-ranked__n { font-size: 10px; padding-top: 4px; opacity: 0.5; }
.td-ranked__body { display: flex; flex-direction: column; gap: 4px; }
.td-ranked__row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.td-ranked__row strong { font-family: var(--td-display); font-size: 14px; font-weight: 600; }
.td-ranked__track { height: 6px; background: color-mix(in oklch, var(--td-ink) 5%, var(--td-paper)); overflow: hidden; }
.td-ranked__fill { height: 100%; transition: width 0.3s ease; }

/* line + stack charts */
.td-line, .td-stack { color: var(--td-ink); display: block; margin-top: 8px; }
.td-anly__chart { margin-bottom: 24px; }
.td-anly__legend { display: flex; gap: 16px; flex-wrap: wrap; }
.td-anly__legend-item { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; }
.td-anly__legend-sw { width: 10px; height: 10px; border-radius: 2px; }

/* 3-up row */
.td-anly__row3 { display: grid; grid-template-columns: 1.1fr 1fr 1.2fr; gap: 16px; margin-bottom: 24px; }
@media (max-width: 1200px) { .td-anly__row3 { grid-template-columns: 1fr; } }

/* warn / ok icons */
.td-anly__icon { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; font-size: 11px; font-weight: 700; margin-right: 8px; vertical-align: -3px; }
.td-anly__icon--warn { background: oklch(0.66 0.18 28); color: var(--td-paper); }
.td-anly__icon--ok   { background: oklch(0.55 0.14 150); color: var(--td-paper); }

/* analysis cards (flagged/winners) */
.td-anly__cards { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.td-anly__card { padding: 14px; background: var(--td-panel); border-left: 3px solid var(--td-accent); display: flex; flex-direction: column; gap: 10px; cursor: pointer; transition: background 0.15s, transform 0.15s; }
.td-anly__card:hover { background: color-mix(in oklch, var(--td-accent) 8%, var(--td-panel)); transform: translateX(2px); }
.td-anly__card--ok { border-left-color: oklch(0.55 0.14 150); }
.td-anly__card--ok:hover { background: color-mix(in oklch, oklch(0.55 0.14 150) 8%, var(--td-panel)); }
.td-anly__card-h { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.td-anly__card-h strong { font-family: var(--td-display); font-size: 15px; font-weight: 600; }

/* table cells */
.td-anly__table td { vertical-align: middle; }
.td-anly__minifun { display: flex; flex-direction: column; gap: 2px; width: 140px; }
.td-anly__minifun-bar { height: 5px; transition: width 0.2s; min-width: 6px; }
.td-anly__convcell { display: flex; align-items: center; gap: 8px; }
.td-anly__sparkcell { display: flex; align-items: center; gap: 10px; }

/* heatmap */
.td-heat { display: flex; flex-direction: column; gap: 3px; font-family: var(--td-mono); }
.td-heat__cols { display: grid; grid-template-columns: 32px repeat(24, 1fr); gap: 2px; padding-left: 0; }
.td-heat__cols span { font-size: 9px; opacity: 0.4; grid-column: span 1; }
.td-heat__col-l { grid-column: span 6 !important; }
.td-heat__row { display: grid; grid-template-columns: 32px repeat(24, 1fr); gap: 2px; align-items: center; }
.td-heat__row-l { font-size: 9px; opacity: 0.5; }
.td-heat__cell { display: block; width: 100%; }
.td-anly__heatfoot { margin-top: 10px; }

/* focus grid in drawer */
.td-anly__focusgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
@media (max-width: 700px) { .td-anly__focusgrid { grid-template-columns: repeat(2, 1fr); } }

/* bar cell */
.td-barcell { display: flex; flex-direction: column; gap: 3px; min-width: 80px; }
.td-barcell__track { height: 4px; background: color-mix(in oklch, var(--td-ink) 5%, var(--td-paper)); overflow: hidden; }
.td-barcell__fill { height: 100%; transition: width 0.2s; }

/* ═══════════════════════════════════════════════════ admin · analítica · tabs */
.td-anly__tabs { display: inline-flex; gap: 2px; background: var(--td-panel); border: 1px solid var(--td-line); padding: 4px; margin-bottom: 20px; }
.td-anly__tab { padding: 9px 18px; font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; border: none; background: transparent; color: var(--td-ink); opacity: 0.55; cursor: pointer; transition: background 0.15s, opacity 0.15s; }
.td-anly__tab:hover { opacity: 0.85; }
.td-anly__tab.is-active { background: var(--td-ink); color: var(--td-paper); opacity: 1; }

/* ═══════════════════════════════════════════════════ admin · geografía */
.td-geo { display: flex; flex-direction: column; }
.td-geo__intro-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; margin-bottom: 22px; }
.td-geo__intro-row code { font-size: 12px; background: var(--td-panel); padding: 1px 6px; }
.td-geo__metric { display: inline-flex; gap: 4px; flex-shrink: 0; background: var(--td-panel); padding: 4px; border: 1px solid var(--td-line); }
.td-geo__metric-btn { padding: 8px 14px; font-family: var(--td-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; border: none; background: transparent; color: var(--td-ink); opacity: 0.55; cursor: pointer; transition: background 0.15s, opacity 0.15s; }
.td-geo__metric-btn:hover { opacity: 0.85; }
.td-geo__metric-btn.is-active { background: var(--td-ink); color: var(--td-paper); opacity: 1; }

.td-geo__hero { display: grid; grid-template-columns: 1.55fr 1fr; gap: 16px; margin-bottom: 24px; }
@media (max-width: 1100px) { .td-geo__hero { grid-template-columns: 1fr; } }
.td-geo__mappanel { min-width: 0; }
.td-geo__mapwrap { display: flex; flex-direction: column; gap: 14px; }
.td-geo__map { width: 100%; height: auto; }
.td-geo__tile rect { transition: stroke 0.15s; }
.td-geo__tile:hover rect { stroke: var(--td-ink); stroke-width: 2; }
.td-geo__scale { display: flex; align-items: center; gap: 10px; }
.td-geo__scale-ramp { flex: 1; height: 8px; background: linear-gradient(90deg, oklch(0.95 0.012 235), oklch(0.35 0.142 235)); }
.td-geo__rankpanel { min-width: 0; display: flex; flex-direction: column; }
.td-geo__rankscroll { max-height: 520px; overflow-y: auto; padding-right: 6px; margin-right: -6px; }

.td-geo__legend { display: flex; gap: 16px; flex-wrap: wrap; }
.td-geo__legend-item { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; }
.td-geo__mdot { width: 10px; height: 10px; border-radius: 2px; flex-shrink: 0; }

.td-geo__matrix-scroll { overflow-x: auto; }
.td-geo__matrix { width: 100%; }
.td-geo__matrix th { vertical-align: bottom; }
.td-geo__mcol { min-width: 92px; }
.td-geo__mcol .td-geo__mdot { display: inline-block; margin-bottom: 4px; }
.td-geo__mname { display: block; font-family: var(--td-display); font-size: 12px; font-weight: 600; line-height: 1.2; text-transform: none; letter-spacing: 0; }
.td-geo__cell { text-align: center; transition: background 0.2s; }
.td-geo__cell .mono { font-size: 11px; }
.td-geo__total { text-align: right; font-weight: 600; }

.td-geo__drawer2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 760px) { .td-geo__drawer2 { grid-template-columns: 1fr; } }
.td-geo__carriers { display: flex; flex-direction: column; gap: 12px; }
.td-geo__carrier-row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 4px; }
.td-geo__carrier-row strong { font-family: var(--td-display); font-size: 14px; font-weight: 600; }

/* ═══════════════════════════════════════════════════ admin · reorder · alternates */
.td-ro__alts { padding: 24px 28px; border-top: 1px solid var(--td-line); border-bottom: 1px solid var(--td-line); background: var(--td-panel); }
.td-ro__alts-head { display: flex; flex-direction: column; gap: 4px; margin-bottom: 18px; max-width: 80ch; }
.td-ro__alts-head h3 { margin: 0; font-family: var(--td-display); font-size: 20px; font-weight: 600; letter-spacing: -0.01em; }
.td-ro__alts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.td-ro__alt { display: flex; flex-direction: column; gap: 8px; background: var(--td-paper); border: 1px solid var(--td-line); padding: 16px; }
.td-ro__alt-h { display: flex; justify-content: space-between; align-items: center; }
.td-ro__alt-name { margin: 0; font-family: var(--td-display); font-size: 15px; font-weight: 600; line-height: 1.25; }
.td-ro__alt-meta { display: flex; flex-direction: column; gap: 2px; }
.td-ro__alt-kv { display: grid; grid-template-columns: auto 1fr; gap: 4px 12px; margin: 4px 0; font-size: 12px; }
.td-ro__alt-kv dt { opacity: 0.55; font-family: var(--td-mono); text-transform: uppercase; font-size: 10px; letter-spacing: 0.08em; align-self: center; }
.td-ro__alt-kv dd { margin: 0; font-family: var(--td-mono); }
.td-ro__alt-note { font-size: 12px; line-height: 1.5; opacity: 0.75; margin: 0; flex: 1; }
.td-ro__alt-link { font-size: 11px; letter-spacing: 0.08em; padding: 8px 10px; background: var(--td-ink); color: var(--td-paper); text-align: center; text-decoration: none; transition: opacity 0.15s; }
.td-ro__alt-link:hover { opacity: 0.85; }
@media (max-width: 1100px) { .td-ro__alts-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 700px)  { .td-ro__alts-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════ mobile polish */
@media (max-width: 700px) {
  :root { --td-pad-section: 56px; --td-pad-block: 28px; }

  /* nav — drop to mobile scale */
  .td-nav__inner { padding: 14px 20px; gap: 12px; }
  .td-wordmark--nav { font-size: 32px; }
  .td-wordmark__tld { font-size: 9px; padding-bottom: 2px; }
  .td-nav__right { gap: 8px; margin-left: auto; }
  .td-country__btn { padding: 7px 9px; font-size: 11px; }
  .td-cart { padding: 8px 12px; font-size: 12px; }

  /* hero — tighten everything */
  .td-hero { padding-top: 24px; padding-bottom: 16px; }
  .td-hero__meta { gap: 12px 18px; padding-bottom: 14px; font-size: 10px; }
  .td-hero__h { font-size: clamp(48px, 15vw, 88px); margin: 14px 0 0; line-height: 0.92; letter-spacing: -0.04em; }
  .td-hero__split { padding: 20px 0 22px; gap: 24px; }
  .td-hero__lede { font-size: 16px; }
  .td-hero__seal svg { width: 110px; height: auto; }

  /* feature topbar / grid */
  .td-feature { padding-top: 24px; }
  .td-feature__topbar { padding: 10px 0; margin-bottom: 16px; gap: 10px; }
  .td-feature__pager { gap: 10px; margin-left: 0; width: 100%; justify-content: space-between; }
  .td-feature__arrow, .td-feature__pause { width: 32px; height: 32px; }
  .td-feature__grid { gap: 24px; }
  .td-feature__h { font-size: clamp(30px, 8vw, 44px); }
  .td-feature__sub { font-size: 15px; }
  .td-feature__pitch { font-size: 15px; padding: 12px 0; margin: 6px 0 12px; }
  .td-feature__row { gap: 28px; padding: 4px 0; flex-wrap: wrap; }
  .td-feature__cta { padding-top: 12px; }
  .td-feature__cta .td-btn { flex: 1; min-width: 0; }

  /* pillars */
  .td-pillars { padding: 40px 0; margin-top: 24px; }
  .td-pillars__grid { gap: 24px; }
  .td-pillar__h { font-size: 24px; }
  .td-pillar__p { font-size: 15px; }
  .td-pillar__n { padding-bottom: 10px; }

  /* teaser */
  .td-teaser { padding-top: 40px; padding-bottom: 40px; }
  .td-teaser__head--solo > div { gap: 4px; }
  .td-teaser__sub { font-size: 15px; }

  /* promise */
  .td-promise { padding: 48px 0; }
  .td-promise__grid { gap: 32px; }
  .td-promise__list { gap: 4px 16px; }
  .td-promise__list li { padding: 12px 0; font-size: 15px; }
  .td-promise__seal svg { width: 180px; height: auto; }

  /* price */
  .td-price__num { font-size: 26px; }
  .td-price--lg .td-price__num { font-size: 42px; }

  /* sections that use sticky nav offsets */
  .td-summary--sticky { position: static; }

  /* generic */
  .td-h1 { font-size: clamp(40px, 10vw, 60px); }
  .td-h2 { font-size: clamp(28px, 7vw, 40px); }
  .td-page__head { padding: 24px 0; margin-bottom: 28px; }

  /* footer */
  .td-foot__grid { padding: 48px 20px; gap: 28px; }
  .td-foot__bar { padding: 18px 20px; font-size: 11px; }
}
