/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/.pnpm/next@15.5.15_react-dom@19.2.5_react@19.2.5__react@19.2.5/node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/.pnpm/next@15.5.15_react-dom@19.2.5_react@19.2.5__react@19.2.5/node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./app/globals.css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* ============================================================
   ESZTI88 — globális stílusok
   Tokenek a brand design systemből (colors_and_type.css), majd
   alap reset + production komponens-osztályok.
   ============================================================ */

:root {
  /* ---- Brand core ---- */
  --e88-magenta: #ff19d6;
  --e88-magenta-hi: #ff5ce4;
  --e88-pink: #ff3da0;
  --e88-red: #fb1b17;
  --e88-violet: #7c5cff;
  --e88-periwinkle: #9186fb;
  --e88-blue: #4b5bff;

  --e88-gradient: linear-gradient(100deg, #4b5bff 0%, #7c5cff 26%, #dc00c1 58%, #ff19d6 76%, #fb1b17 100%);
  --e88-gradient-soft: linear-gradient(100deg, rgba(75,91,255,.16) 0%, rgba(220,0,193,.18) 58%, rgba(251,27,23,.16) 100%);

  /* ---- Neutrals (deep plum darks) ---- */
  --ink-950: #07040c;
  --ink-900: #0d0815;
  --ink-850: #140d1f;
  --ink-800: #1b1328;
  --ink-700: #251a35;
  --ink-600: #342445;
  --ink-500: #4a3760;

  /* ---- Foreground ---- */
  --fg-1: #f5f0fb;
  --fg-2: #b9aecb;
  --fg-3: #847596;
  --fg-on-accent: #0a0410;

  /* ---- Semantic ---- */
  --ok: #34e0a1;
  --warn: #ffb648;
  --danger: #fb1b17;

  /* ---- Type families ---- */
  --font-display: "Rubik Dirt", system-ui, sans-serif;
  --font-heading: "Poppins", system-ui, sans-serif;
  --font-body: "Poppins", system-ui, sans-serif;
  --font-mono: "Poppins", system-ui, sans-serif;

  /* ---- Type scale ---- */
  --t-display: 400 clamp(3rem, 7.5vw, 7rem) / 1.02 var(--font-display);
  --t-h1: 700 clamp(2rem, 4vw, 3.5rem) / 1.08 var(--font-heading);
  --t-h2: 700 clamp(1.6rem, 2.8vw, 2.5rem) / 1.12 var(--font-heading);
  --t-h3: 600 1.375rem/1.25 var(--font-heading);
  --t-lead: 400 clamp(1.05rem, 1.4vw, 1.375rem) / 1.55 var(--font-body);
  --t-body: 400 1rem/1.65 var(--font-body);
  --t-small: 400 0.875rem/1.5 var(--font-body);
  --t-eyebrow: 600 0.75rem/1 var(--font-mono);
  --t-price: 600 1.125rem/1 var(--font-mono);

  /* ---- Radii ---- */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;
  --r-pill: 999px;

  /* ---- Spacing (4px base) ---- */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;
  --sp-9: 96px; --sp-10: 128px;

  /* ---- Elevation / glow ---- */
  --shadow-1: 0 1px 2px rgba(0,0,0,.4);
  --shadow-2: 0 8px 24px rgba(0,0,0,.45);
  --shadow-3: 0 24px 60px rgba(0,0,0,.55);
  --glow-magenta: 0 0 0 1px rgba(255,25,214,.35), 0 8px 40px rgba(255,25,214,.35);

  /* ---- Motion ---- */
  --ease: cubic-bezier(.2,.7,.2,1);
  --dur: 220ms;
}

/* ============================================================ Reset / base */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  background: var(--ink-950);
  color: var(--fg-1);
  font: var(--t-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}
h1, h2, h3, h4 { margin: 0; }
h1 { font: var(--t-h1); letter-spacing: -0.01em; }
h2 { font: var(--t-h2); letter-spacing: -0.01em; }
h3 { font: var(--t-h3); }
p { margin: 0 0 1em; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; }
ul { margin: 0; padding: 0; list-style: none; }
:focus-visible { outline: 2px solid var(--e88-magenta); outline-offset: 2px; }

/* ============================================================ Helpers */
.display { font: var(--t-display); letter-spacing: 0; }
.lead { font: var(--t-lead); color: var(--fg-2); }
.eyebrow {
  font: var(--t-eyebrow);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--e88-magenta);
}
.price { font: var(--t-price); }
.grad-text {
  background: var(--e88-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.label-mono {
  font: 700 11px/1 var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--fg-2);
}
.muted { color: var(--fg-3); }
.container { max-width: 1280px; margin: 0 auto; padding-left: clamp(20px,5vw,56px); padding-right: clamp(20px,5vw,56px); }
.section { padding-top: var(--sp-9); padding-bottom: var(--sp-9); }
.stack { display: flex; flex-direction: column; }
.row { display: flex; align-items: center; }
.spread { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); }

/* ============================================================ Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font: 600 14px/1 var(--font-body);
  padding: 15px 26px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  cursor: pointer; white-space: nowrap; letter-spacing: .005em;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease),
    background var(--dur) var(--ease), box-shadow var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn:active { transform: scale(.97); }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn-sm { font-size: 12px; padding: 10px 16px; }
.btn-block { width: 100%; }

.btn-primary { background: var(--e88-violet); color: #fff; }
.btn-primary:hover:not(:disabled) { background: #9176ff; transform: translateY(-1px); }
/* A brand-skill szerint az elsődleges gomb TÖMÖR violet, fehér szöveg, glow és
   szivárvány-gradiens NÉLKÜL. A .btn-grad korábban gradiens volt; most a .btn-primary
   aliasa, hogy a visszamaradt használatok is helyesen jelenjenek meg. Új kódban
   használj .btn-primary-t. (A gradienst csak felületeken tartjuk meg: marquee, hero, e-mail.) */
.btn-grad { background: var(--e88-violet); color: #fff; }
.btn-grad:hover:not(:disabled) { background: #9176ff; transform: translateY(-1px); }
.btn-light { background: var(--fg-1); color: var(--ink-950); }
.btn-light:hover:not(:disabled) { background: #fff; transform: translateY(-1px); }
.btn-outline { background: transparent; border-color: var(--ink-500); color: var(--fg-1); }
.btn-outline:hover:not(:disabled) { border-color: var(--fg-2); background: rgba(255,25,214,.06); }
.btn-ghost { background: transparent; color: var(--fg-2); }
.btn-ghost:hover:not(:disabled) { color: var(--fg-1); }
.btn-danger { background: transparent; border-color: rgba(251,27,23,.5); color: #ff6b67; }
.btn-danger:hover:not(:disabled) { background: rgba(251,27,23,.12); border-color: var(--e88-red); }

/* ============================================================ Badges / chips */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font: 700 10px/1 var(--font-mono);
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--fg-on-accent);
  background: var(--e88-magenta);
  padding: 6px 9px; border-radius: var(--r-pill);
}
.badge-red { background: var(--e88-red); color: #fff; }
.badge-muted { background: var(--ink-700); color: var(--fg-2); }
.badge-warn { background: var(--warn); color: var(--ink-950); }
.badge-ok { background: var(--ok); color: var(--ink-950); }
.badge-info { background: var(--e88-blue); color: #fff; }

/* ============================================================ Nav / chrome */
.site-header { position: -webkit-sticky; position: sticky; top: 0; z-index: 40; }
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px clamp(20px,5vw,56px);
  background: rgba(7,4,12,.78);
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ink-700);
}
.nav-brand { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.nav-brand img { height: 26px; }
.nav-wordmark { font: 800 20px/1 var(--font-heading); letter-spacing: .04em; }
.nav-links { display: flex; gap: 30px; font: 600 13px/1 var(--font-body); }
.nav-links a { color: var(--fg-2); transition: color var(--dur) var(--ease); }
.nav-links a:hover, .nav-links a.active { color: var(--fg-1); }
.nav-actions { display: flex; gap: 20px; align-items: center; }
.nav-icon-btn { position: relative; cursor: pointer; display: inline-flex; color: var(--fg-1); background: none; border: 0; padding: 0; }
.cart-count {
  position: absolute; top: -8px; right: -10px;
  background: var(--e88-magenta); color: var(--fg-on-accent);
  font: 700 10px/1 var(--font-mono);
  min-width: 16px; height: 16px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center; padding: 0 4px;
}
@media (max-width: 760px) { .nav-links { display: none; } }

.marquee {
  background: var(--e88-gradient); padding: 12px 0; overflow: hidden; white-space: nowrap;
  text-align: center; font: 700 13px/1 var(--font-mono); letter-spacing: .18em; color: #fff;
}

/* ============================================================ Footer */
.footer { background: var(--ink-950); border-top: 1px solid var(--ink-700); padding: var(--sp-9) clamp(20px,5vw,56px) var(--sp-6); }
.footer-grid { display: flex; flex-wrap: wrap; gap: 48px; justify-content: space-between; max-width: 1280px; margin: 0 auto; }
.footer-col-title { font: 700 11px/1 var(--font-mono); text-transform: uppercase; letter-spacing: .14em; color: var(--fg-2); margin-bottom: 16px; }
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a { color: var(--fg-3); font: var(--t-small); }
.footer-links a:hover { color: var(--fg-1); }
.footer-bottom { max-width: 1280px; margin: 48px auto 0; padding-top: 20px; border-top: 1px solid var(--ink-700); display: flex; justify-content: space-between; font: 400 11px/1 var(--font-mono); color: var(--fg-3); letter-spacing: .06em; text-transform: uppercase; }

/* ============================================================ Product art / cards */
.product-art { position: relative; width: 100%; height: 100%; overflow: hidden; }
.product-art .halftone {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.20) 1px, transparent 1.3px);
  background-size: 11px 11px;
  -webkit-mask-image: linear-gradient(95deg, #000 0%, transparent 58%);
  mask-image: linear-gradient(95deg, #000 0%, transparent 58%);
}
.product-art .mark { position: absolute; right: 6%; bottom: 8%; width: 52%; opacity: .9; filter: drop-shadow(0 6px 24px rgba(0,0,0,.4)); }
.product-art img.photo { width: 100%; height: 100%; object-fit: cover; }

.product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); grid-gap: var(--sp-5); gap: var(--sp-5); }
.product-card {
  position: relative; display: block;
  background: var(--ink-850); border: 1px solid var(--ink-600);
  border-radius: var(--r-lg); overflow: hidden; cursor: pointer;
  transition: transform var(--dur) var(--ease), box-shadow 260ms var(--ease);
}
.product-card:hover { transform: translateY(-4px); box-shadow: 0 0 0 1px rgba(124,92,255,.45), 0 0 34px 9px rgba(124,92,255,.42); }
.product-card .art-wrap { position: relative; aspect-ratio: 4/5; }
.product-card .art-wrap > * { transition: filter var(--dur) var(--ease); }
.product-card:hover .art-wrap > * { filter: brightness(1.08); }
.product-card .card-tag { position: absolute; top: 12px; left: 12px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; max-width: calc(100% - 24px); }
.product-card .card-body { padding: 16px; }
.product-card .card-name { font: 600 16px/1.2 var(--font-heading); }
.product-card .card-meta { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; }
.product-card.sold-out { opacity: .62; }

/* ============================================================ Hero */
.hero {
  position: relative; overflow: hidden; min-height: min(80vh, 660px);
  display: flex; align-items: center;
  background: radial-gradient(120% 130% at 80% 22%, #ff19d6 0%, #7c2bb0 30%, #2a1140 58%, #07040c 100%);
}
.hero .halftone {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.22) 1.1px, transparent 1.4px);
  background-size: 13px 13px;
  -webkit-mask-image: linear-gradient(98deg, #000 0%, transparent 52%);
  mask-image: linear-gradient(98deg, #000 0%, transparent 52%);
}
.hero-wrap {
  position: relative; z-index: 2; padding: 0 clamp(20px,5vw,56px);
  max-width: 1280px; margin: 0 auto; width: 100%;
  display: grid; grid-template-columns: 1.05fr 0.95fr; align-items: center; grid-gap: 40px; gap: 40px;
}
.hero h1 { max-width: 13ch; margin: 16px 0 0; }
.hero .lead { margin: 20px 0 0; max-width: 460px; color: rgba(245,240,251,.86); }
/* A hero magenta washán a magenta eyebrow beleolvadna — fehéren marad olvasható. */
.hero .eyebrow { color: #fff; }
.hero-cta { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.hero-img { display: flex; align-items: center; justify-content: center; }
.hero-img img { width: min(470px, 94%); filter: drop-shadow(0 24px 70px rgba(255,25,214,.4)); }
@media (max-width: 880px) { .hero-wrap { grid-template-columns: 1fr; } .hero-img { display: none; } }

/* ============================================================ Product detail */
.pdp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); grid-gap: var(--sp-7); gap: var(--sp-7); align-items: start; }
.pdp-gallery { display: flex; flex-direction: column; gap: 14px; }
.pdp-main-img { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--ink-600); aspect-ratio: 4/5; }
.pdp-thumbs { display: grid; grid-template-columns: repeat(3, 1fr); grid-gap: 14px; gap: 14px; }
.pdp-thumb { border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--ink-600); aspect-ratio: 1/1; }
.pdp-info { position: -webkit-sticky; position: sticky; top: 100px; }
.pdp-price { font: 700 22px/1 var(--font-mono); margin-top: 14px; }
.back-link { display: inline-flex; align-items: center; gap: 6px; color: var(--fg-3); font: var(--t-small); cursor: pointer; margin-bottom: var(--sp-5); }
.back-link:hover { color: var(--fg-1); }
.trust-row { display: flex; gap: 18px; margin-top: 22px; flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: 8px; color: var(--fg-3); font: var(--t-small); }

/* selectors */
.size-row { display: flex; gap: 10px; flex-wrap: wrap; }
.size-chip {
  min-width: 46px; height: 46px; padding: 0 14px; border-radius: var(--r-sm);
  border: 1px solid var(--ink-500); background: var(--ink-850); color: var(--fg-1);
  font: 600 13px/1 var(--font-body); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--dur) var(--ease);
}
.size-chip.on { border-color: var(--e88-magenta); background: rgba(255,25,214,.12); }
.size-chip:disabled { opacity: .35; cursor: not-allowed; text-decoration: line-through; }
.color-row { display: flex; gap: 12px; flex-wrap: wrap; }
.color-dot {
  width: 30px; height: 30px; border-radius: 999px; cursor: pointer;
  border: 2px solid var(--ink-600); padding: 0;
  transition: box-shadow var(--dur) var(--ease);
}
.color-dot.on { border-color: var(--fg-1); box-shadow: 0 0 0 3px var(--ink-900), 0 0 0 4px var(--e88-magenta); }
.qty {
  display: inline-flex; align-items: center; border: 1px solid var(--ink-600);
  border-radius: var(--r-pill); overflow: hidden;
}
.qty button { background: var(--ink-850); border: 0; color: var(--fg-1); width: 44px; height: 44px; font-size: 18px; cursor: pointer; }
.qty button:disabled { opacity: .4; cursor: not-allowed; }
.qty span { width: 44px; text-align: center; font: 600 15px/1 var(--font-body); }

/* ============================================================ Cart drawer */
.drawer-root { position: fixed; inset: 0; z-index: 60; }
.drawer-root.closed { pointer-events: none; }
.drawer-scrim { position: absolute; inset: 0; background: rgba(7,4,12,.6); opacity: 0; transition: opacity var(--dur) var(--ease); }
.drawer-root.open .drawer-scrim { opacity: 1; -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
.drawer {
  position: absolute; top: 0; right: 0; height: 100%; width: min(420px, 92vw);
  background: var(--ink-900); border-left: 1px solid var(--ink-700);
  transform: translateX(100%); transition: transform var(--dur) var(--ease);
  display: flex; flex-direction: column;
}
.drawer-root.open .drawer { transform: translateX(0); }
.drawer-head { display: flex; justify-content: space-between; align-items: center; padding: 20px 24px; border-bottom: 1px solid var(--ink-700); }
.drawer-title { font: 700 16px/1 var(--font-heading); letter-spacing: .01em; }
.drawer-body { flex: 1 1; overflow-y: auto; padding: 8px 24px; }
.drawer-empty { color: var(--fg-3); font: var(--t-body); padding: 40px 0; text-align: center; }
.cart-line { display: flex; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--ink-700); }
.cart-line .thumb { width: 64px; height: 80px; border-radius: var(--r-md); overflow: hidden; flex-shrink: 0; border: 1px solid var(--ink-600); }
.cart-line .name { font: 600 14px/1.2 var(--font-heading); }
.cart-line .sub { font: var(--t-small); color: var(--fg-3); margin-top: 4px; }
.cart-line .li-price { font: 700 13px/1 var(--font-mono); margin-top: 8px; }
.icon-btn { background: none; border: 0; color: var(--fg-3); cursor: pointer; display: inline-flex; padding: 0; }
.icon-btn:hover { color: var(--fg-1); }
.drawer-foot { padding: 24px; border-top: 1px solid var(--ink-700); }
.drawer-subtotal { display: flex; justify-content: space-between; margin-bottom: 16px; font: var(--t-body); }
.drawer-subtotal .amt { font: 700 16px/1 var(--font-mono); }

/* ============================================================ Forms */
.field { margin-bottom: var(--sp-4); }
.field label { display: block; font: 700 11px/1 var(--font-mono); text-transform: uppercase; letter-spacing: .14em; color: var(--fg-2); margin-bottom: 8px; }
.input, .textarea, .select {
  width: 100%; background: var(--ink-850); color: var(--fg-1);
  border: 1px solid var(--ink-600); border-radius: var(--r-md);
  padding: 12px 14px; font: var(--t-body);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.input:focus, .textarea:focus, .select:focus { outline: none; border-color: var(--e88-magenta); box-shadow: 0 0 0 3px rgba(255,25,214,.18); }
.textarea { min-height: 96px; resize: vertical; }
/* Dátum/idő mezők naptár-ikonja: a sötét háttéren alapból láthatatlan — fehérre invertáljuk. */
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(1.8);
  opacity: .85;
  cursor: pointer;
}
input[type="datetime-local"]::-webkit-calendar-picker-indicator:hover,
input[type="date"]::-webkit-calendar-picker-indicator:hover,
input[type="time"]::-webkit-calendar-picker-indicator:hover { opacity: 1; }
.field .hint { font: var(--t-small); color: var(--fg-3); margin-top: 6px; }
.field .err { font: var(--t-small); color: #ff6b67; margin-top: 6px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; grid-gap: var(--sp-4); gap: var(--sp-4); }
@media (max-width: 620px) { .form-grid { grid-template-columns: 1fr; } }

.alert { border-radius: var(--r-md); padding: 12px 14px; font: var(--t-small); margin-bottom: var(--sp-4); }
.alert-err { background: rgba(251,27,23,.12); border: 1px solid rgba(251,27,23,.4); color: #ff8a87; }
.alert-ok { background: rgba(52,224,161,.12); border: 1px solid rgba(52,224,161,.4); color: var(--ok); }
.alert-warn { background: rgba(255,182,72,.12); border: 1px solid rgba(255,182,72,.4); color: var(--warn); }

/* ============================================================ Generic surface / card */
.surface { background: var(--ink-850); border: 1px solid var(--ink-600); border-radius: var(--r-lg); padding: var(--sp-5); }

/* ============================================================ Admin */
.admin-shell { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; }
.admin-side { background: var(--ink-900); border-right: 1px solid var(--ink-700); padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-2); position: -webkit-sticky; position: sticky; top: 0; height: 100vh; }
.admin-side .brand { display: flex; align-items: center; gap: 10px; margin-bottom: var(--sp-5); color: inherit; text-decoration: none; }
a.brand { transition: opacity var(--dur) var(--ease); }
a.brand:hover { opacity: .82; }
.admin-side .brand img { height: 22px; }
.admin-side .brand span { font: 800 17px/1 var(--font-heading); letter-spacing: .04em; }
.admin-nav-link { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--r-md); color: var(--fg-2); font: 600 14px/1 var(--font-body); transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.admin-nav-link:hover { background: var(--ink-800); color: var(--fg-1); }
.admin-nav-link.active { background: rgba(255,25,214,.12); color: var(--fg-1); }
.admin-main { padding: var(--sp-6) clamp(20px,4vw,48px); max-width: 1100px; }
.admin-head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); margin-bottom: var(--sp-6); flex-wrap: wrap; }
.admin-logout { margin-top: auto; }
@media (max-width: 760px) { .admin-shell { grid-template-columns: 1fr; } .admin-side { position: static; height: auto; flex-direction: row; flex-wrap: wrap; align-items: center; } .admin-logout { margin-top: 0; } }

/* tables */
.table { width: 100%; border-collapse: collapse; }
.table th { text-align: left; font: 700 11px/1 var(--font-mono); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); padding: 12px 14px; border-bottom: 1px solid var(--ink-700); }
.table td { padding: 14px; border-bottom: 1px solid var(--ink-700); font: var(--t-small); color: var(--fg-1); vertical-align: middle; }
.table tr:hover td { background: var(--ink-850); }
.table a.row-link { color: var(--e88-magenta-hi); font-weight: 600; }
.table a.row-link-icon { display: inline-flex; align-items: center; }
.table a.row-link-icon:hover { color: #fff; }

.kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); grid-gap: var(--sp-4); gap: var(--sp-4); margin-bottom: var(--sp-6); }
.kpi { background: var(--ink-850); border: 1px solid var(--ink-600); border-radius: var(--r-lg); padding: var(--sp-5); }
.kpi .k-label { font: 700 11px/1 var(--font-mono); text-transform: uppercase; letter-spacing: .12em; color: var(--fg-3); }
.kpi .k-value { font: 700 28px/1 var(--font-heading); margin-top: 10px; }

.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--sp-5); background: radial-gradient(120% 120% at 80% 10%, #2a1140 0%, #07040c 60%); }
.login-card { width: 100%; max-width: 380px; background: var(--ink-900); border: 1px solid var(--ink-700); border-radius: var(--r-lg); padding: var(--sp-7); }

/* Admin sorrendezés — drag & drop */
.reorder-row.dragging { opacity: .4; }
.reorder-row.drag-over td { box-shadow: inset 0 2px 0 0 var(--e88-magenta); }
.drag-handle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: var(--r-sm);
  color: var(--fg-3); cursor: -webkit-grab; cursor: grab; background: transparent; border: 0;
}
.drag-handle:hover { color: var(--fg-1); background: var(--ink-800); }
.drag-handle:active { cursor: -webkit-grabbing; cursor: grabbing; }

.variant-row { display: grid; grid-template-columns: 1fr 1fr 90px 40px; grid-gap: 10px; gap: 10px; align-items: end; margin-bottom: 10px; }
@media (max-width: 620px) { .variant-row { grid-template-columns: 1fr 1fr; } }

.empty-state { text-align: center; padding: var(--sp-9) var(--sp-5); color: var(--fg-3); }

/* ============================================================ Visszaszámláló (countdown) */
.countdown { display: inline-flex; gap: 8px; flex-wrap: wrap; }
.countdown-unit {
  display: flex; flex-direction: column; align-items: center;
  min-width: 56px; padding: 10px 8px;
  background: var(--ink-850); border: 1px solid var(--ink-600); border-radius: var(--r-md);
}
.countdown-num { font: 700 22px/1 var(--font-mono); color: var(--fg-1); }
.countdown-lbl { font: 700 9px/1 var(--font-mono); text-transform: uppercase; letter-spacing: .12em; color: var(--fg-3); margin-top: 6px; }
.countdown-sm .countdown-unit { min-width: 0; padding: 5px 7px; border-radius: var(--r-sm); }
.countdown-sm .countdown-num { font-size: 14px; }
.countdown-sm .countdown-lbl { font-size: 8px; margin-top: 3px; }
/* Sürgető változat: rendelési határidő (amber), vizuálisan elüt a "hamarosan" visszaszámlálótól. */
.countdown.urgent .countdown-unit { background: rgba(255,182,72,.08); border-color: rgba(255,182,72,.45); }
.countdown.urgent .countdown-num { color: var(--warn); }

/* "Hamarosan" termékkártya: alapból teljesen leszürkítve (feketefehér kép), visszaszámlálóval. */
.product-card.coming-soon .art-wrap > *:not(.card-countdown):not(.card-tag) { filter: grayscale(1) brightness(.72); }
/* Hover: a termékkép 50%-os színezést kap; a glow viszont feketefehér (semleges, szürke) marad. */
.product-card.coming-soon:hover {
  box-shadow: 0 0 0 1px rgba(210,210,220,.45), 0 0 34px 9px rgba(185,185,195,.34);
}
.product-card.coming-soon:hover .art-wrap > *:not(.card-countdown):not(.card-tag) { filter: grayscale(.5) brightness(.9); }
.card-countdown {
  position: absolute; left: 12px; right: 12px; bottom: 12px; z-index: 2;
  display: flex; justify-content: center;
}

/* ============================================================ Admin színválasztó (RGB) */
.color-input {
  width: 46px; height: 40px; padding: 3px;
  background: var(--ink-850); border: 1px solid var(--ink-600); border-radius: var(--r-md);
  cursor: pointer;
}
.color-input::-webkit-color-swatch-wrapper { padding: 0; }
.color-input::-webkit-color-swatch { border: none; border-radius: var(--r-sm); }
.color-input::-moz-color-swatch { border: none; border-radius: var(--r-sm); }
/* Variánssor "nincs készleten" checkbox-szal: méret · szín · swatch · checkbox · törlés */
.variant-row.has-color { grid-template-columns: 1fr 1fr 46px auto 40px; }
@media (max-width: 620px) { .variant-row.has-color { grid-template-columns: 1fr 1fr; } }

/* Színválasztó: sorban csak a swatch-gomb; a hex mező a felugró popoverben. */
.color-field { position: relative; }
.color-swatch {
  width: 46px; height: 40px; cursor: pointer;
  border: 1px solid var(--ink-600); border-radius: var(--r-md);
}
.color-pop {
  position: absolute; z-index: 20; top: calc(100% + 6px); left: 0;
  display: flex; align-items: center; gap: 8px; padding: 10px;
  background: var(--ink-850); border: 1px solid var(--ink-600); border-radius: var(--r-md);
  box-shadow: 0 12px 30px rgba(0,0,0,.45);
}
.color-pop .hex-input { width: 104px; flex: none; padding: 10px; font-family: var(--font-mono); text-transform: lowercase; }
.check-inline { display: inline-flex; align-items: center; gap: 8px; font: var(--t-small); color: var(--fg-2); white-space: nowrap; cursor: pointer; }

/* ============================================================ "Értesítést kérek" űrlap */
.notify-form { display: flex; gap: 10px; flex-wrap: wrap; align-items: stretch; margin-top: var(--sp-5); }
.notify-form .input { flex: 1 1; min-width: 200px; }

/* ============================================================ Markdown WYSIWYG editor */
.md-editor { display: grid; grid-template-columns: 1fr 1fr; grid-gap: var(--sp-4); gap: var(--sp-4); align-items: start; }
@media (max-width: 820px) { .md-editor { grid-template-columns: 1fr; } }
.md-pane-label { font: 700 11px/1 var(--font-mono); text-transform: uppercase; letter-spacing: .14em; color: var(--fg-3); margin-bottom: 8px; }
.md-toolbar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.md-tool-btn {
  font: 600 12px/1 var(--font-body); padding: 8px 11px; border-radius: var(--r-sm);
  border: 1px solid var(--ink-600); background: var(--ink-850); color: var(--fg-1); cursor: pointer;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.md-tool-btn:hover { border-color: var(--fg-2); background: var(--ink-800); }
.md-editor .textarea { min-height: 320px; font-family: var(--font-mono); font-size: 14px; line-height: 1.6; }
.md-preview {
  background: var(--ink-850); border: 1px solid var(--ink-600); border-radius: var(--r-md);
  padding: 16px 18px; min-height: 320px; overflow: auto;
}

/* Renderelt markdown (publikus oldal + preview) */
.prose { color: var(--fg-2); font: var(--t-body); max-width: 70ch; }
.prose > *:first-child { margin-top: 0; }
.prose h1, .prose h2, .prose h3 { color: var(--fg-1); margin: 1.5em 0 .5em; line-height: 1.2; }
.prose h1 { font: 700 1.75rem/1.2 var(--font-heading); }
.prose h2 { font: 700 1.375rem/1.25 var(--font-heading); }
.prose h3 { font: 600 1.125rem/1.3 var(--font-heading); }
.prose p { margin: 0 0 1em; }
.prose a { color: var(--e88-magenta-hi); text-decoration: underline; }
.prose a:hover { color: var(--e88-magenta); }
.prose strong { color: var(--fg-1); font-weight: 700; }
.prose em { font-style: italic; }
.prose ul, .prose ol { margin: 0 0 1em; padding-left: 1.4em; }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose li { margin: .3em 0; }

/* ============================================================ Hero — fix pozíciójú lapozó + szövegek */
.hero-pager {
  position: absolute; bottom: 24px; left: 0; right: 0; z-index: 3;
  display: flex; gap: 9px; justify-content: center;
}
.hero-pager button {
  width: 9px; height: 9px; padding: 0; border: 0; cursor: pointer;
  border-radius: var(--r-pill); background: rgba(245, 240, 251, .32);
  transition: width var(--dur) var(--ease), background var(--dur) var(--ease);
}
.hero-pager button.on { width: 28px; background: var(--fg-1); }
/* Fix szövegterület: a dia-váltáskor a tartalom ne ugráltassa az elrendezést. */
.hero-copy { position: relative; min-height: 300px; display: flex; flex-direction: column; justify-content: center; }
@media (max-width: 880px) { .hero-copy { min-height: 0; } }

/* ============================================================ Képfeltöltés */
.img-upload { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.img-upload-preview {
  width: 56px; height: 56px; flex-shrink: 0;
  border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--ink-600);
  background: var(--ink-900);
}
.img-upload-preview img { width: 100%; height: 100%; object-fit: cover; }

/* ============================================================ Média könyvtár (admin) */
.media-toolbar { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; margin-bottom: var(--sp-5); }
.media-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); grid-gap: var(--sp-4); gap: var(--sp-4); }
.media-card {
  position: relative; background: var(--ink-850); border: 1px solid var(--ink-600);
  border-radius: var(--r-md); overflow: hidden;
}
.media-card.selected { border-color: var(--e88-magenta); box-shadow: 0 0 0 2px rgba(255,25,214,.25); }
.media-thumb { aspect-ratio: 1 / 1; background: var(--ink-900); display: block; }
.media-thumb img { width: 100%; height: 100%; object-fit: cover; }
.media-check { position: absolute; top: 8px; left: 8px; z-index: 2; width: 20px; height: 20px; cursor: pointer; }
.media-status { position: absolute; top: 8px; right: 8px; z-index: 2; }
.media-meta { padding: 8px 10px; }
.media-meta .media-name { font: var(--t-small); color: var(--fg-1); word-break: break-all; }
.media-meta .media-sub { font: 400 11px/1.4 var(--font-mono); color: var(--fg-3); margin-top: 4px; }

