/* ============================================================
   GAVEPORTAL – Portal CSS v4
   LOGIN  = neutral, generic, platform-only branding
   APP    = company-branded via CSS custom properties
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Neutrals – fixed, never change */
  --bg:        #F3F3F1;
  --white:     #FFFFFF;
  --text:      #111218;
  --text-2:    #6B6B78;
  --text-3:    #9B9BA8;
  --border:    #E4E4EC;
  --success:   #1E7A4E;
  --success-bg:#E8F5EE;
  --danger:    #DC2626;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 6px rgba(0,0,0,.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.06);
  --r-sm: 8px; --r-md: 14px; --r-lg: 22px;
  --font: 'Inter', system-ui, -apple-system, sans-serif;
  --t: 0.18s ease;

  /* Brand palette – set by JS after login, reset on logout */
  --accent:       #1A3A5C;
  --accent-h:     #122A44;
  --accent-light: #EDF1F7;
  --accent-mid:   #C5D3E8;
  --on-accent:    #ffffff;
}

html { font-size: 16px; -webkit-font-smoothing: antialiased; }
body { font-family: var(--font); background: var(--bg); color: var(--text); min-height: 100vh; line-height: 1.6; }
#app  { min-height: 100vh; }

.fade-in { animation: fadeIn .3s ease both; }
@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

/* ── Shared form elements ─────────────────────────────────── */
.input-group { display:flex; flex-direction:column; gap:6px; }
.input-group label {
  font-size:.82rem; font-weight:600; color:var(--text-2);
  text-transform:uppercase; letter-spacing:.06em;
}
.input-field {
  padding:14px 16px; border:1.5px solid var(--border); border-radius:var(--r-sm);
  font-family:var(--font); font-size:1rem; color:var(--text);
  background:var(--white); outline:none;
  transition:border-color var(--t), box-shadow var(--t);
}
.input-field:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent);
}
.field-error { color:var(--danger); font-size:.85rem; min-height:20px; margin-top:4px; }

/* Shared buttons */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border:none; border-radius:var(--r-sm);
  font-family:var(--font); font-size:.9rem; font-weight:600; cursor:pointer;
  transition:all var(--t); text-decoration:none; white-space:nowrap;
}
.btn:active { transform:scale(.98); }
.btn:disabled { opacity:.42; cursor:not-allowed; transform:none !important; }
.btn--full  { width:100%; }
.btn--large { padding:15px 28px; font-size:.95rem; }
.btn--primary {
  background:var(--accent); color:var(--on-accent);
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.btn--primary:hover:not(:disabled) {
  background:var(--accent-h);
  box-shadow:0 4px 14px rgba(0,0,0,.2);
  transform:translateY(-1px);
}
.btn--secondary {
  background:var(--white); color:var(--accent);
  border:1.5px solid var(--accent-mid);
}
.btn--secondary:hover { background:var(--accent-light); }
.btn--ghost { background:transparent; color:var(--text-2); }
.btn--ghost:hover { color:var(--text); background:rgba(0,0,0,.04); }
.btn-arrow { transition:transform var(--t); }
.btn:hover .btn-arrow { transform:translateX(3px); }


/* ══════════════════════════════════════════════════════════
   LOGIN PAGE
   — Clean, neutral, only platform logo, no company colors
   ══════════════════════════════════════════════════════════ */

.lp {
  min-height:100vh;
  background:linear-gradient(160deg, #EEECEA 0%, #F6F6F4 60%, #ECEAE8 100%);
  display:flex; align-items:center; justify-content:center;
  padding:24px;
}

.lp__card {
  background:var(--white);
  border-radius:var(--r-lg);
  box-shadow:0 24px 64px rgba(0,0,0,.10), 0 4px 16px rgba(0,0,0,.06);
  width:100%; max-width:400px;
  overflow:hidden;
}

/* Platform logo header */
.lp__top {
  background:#F8F8F7;
  border-bottom:1px solid var(--border);
  padding:26px 32px;
  display:flex; align-items:center; justify-content:center;
}
.lp__platform-logo {
  height:34px; max-width:200px; object-fit:contain;
  display:block;
}

/* Form body */
.lp__body {
  padding:32px; display:flex; flex-direction:column; gap:16px;
}
.lp__title {
  font-size:1.5rem; font-weight:700; letter-spacing:-.03em;
  color:var(--text); line-height:1.2;
}
.lp__sub { color:var(--text-2); font-size:.92rem; line-height:1.65; margin-top:-4px; }

.lp__field-wrap { position:relative; }
.lp__input-icon {
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  color:var(--text-3); pointer-events:none;
  display:flex; align-items:center;
}
.lp__input {
  width:100%; padding:14px 16px 14px 44px;
  border:1.5px solid var(--border); border-radius:var(--r-sm);
  font-family:var(--font); font-size:1rem; color:var(--text);
  background:var(--white); outline:none;
  transition:border-color var(--t), box-shadow var(--t);
}
.lp__input:focus {
  border-color:#111218;
  box-shadow:0 0 0 3px rgba(17,18,24,.08);
}
.lp__input--error { border-color:var(--danger) !important; }
.lp__input--error:focus { box-shadow:0 0 0 3px rgba(220,38,38,.1) !important; }

@keyframes shake {
  0%,100%{transform:translateX(0)}
  20%    {transform:translateX(-7px)}
  40%    {transform:translateX(7px)}
  60%    {transform:translateX(-4px)}
  80%    {transform:translateX(4px)}
}
.lp__input--shake { animation:shake .42s ease; }

.lp__error { color:var(--danger); font-size:.85rem; min-height:18px; margin-top:6px; }

/* Login CTA – neutral dark, never uses brand color */
.lp__btn {
  width:100%; padding:15px 24px;
  background:#111218; color:#fff; border:none; border-radius:var(--r-sm);
  font-family:var(--font); font-size:.95rem; font-weight:600;
  display:flex; align-items:center; justify-content:center; gap:10px;
  cursor:pointer; transition:all var(--t);
  box-shadow:0 2px 8px rgba(0,0,0,.22);
}
.lp__btn:hover:not(:disabled) {
  background:#1e1f2b;
  box-shadow:0 6px 20px rgba(0,0,0,.28);
  transform:translateY(-1px);
}
.lp__btn:active { transform:scale(.98); }
.lp__btn:disabled { opacity:.45; cursor:not-allowed; transform:none; }
.lp__btn-arrow { transition:transform var(--t); flex-shrink:0; }
.lp__btn:hover .lp__btn-arrow { transform:translateX(4px); }

/* Footer */
.lp__footer {
  padding:14px 32px; border-top:1px solid var(--border);
  background:#FAFAF9; text-align:center;
  font-size:.76rem; color:var(--text-3);
  display:flex; align-items:center; justify-content:center; gap:6px;
}


/* ══════════════════════════════════════════════════════════
   APP – NAV BAR  (white, thin, sticky, always visible)
   ══════════════════════════════════════════════════════════ */

.nav {
  position:sticky; top:0; z-index:200;
  background:var(--white);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 4px rgba(0,0,0,.05);
}
.nav__inner {
  max-width:1160px; margin:0 auto; padding:0 24px; height:58px;
  display:flex; justify-content:space-between; align-items:center;
}
.nav__brand { display:flex; align-items:center; }
.nav__logo-img {
  height:28px; max-width:130px; object-fit:contain;
}
.nav__logo-text {
  font-size:.9rem; font-weight:700; color:var(--text); letter-spacing:-.01em;
}
.nav__right { display:flex; align-items:center; gap:14px; }
.nav__user  { font-size:.85rem; color:var(--text-2); }
.nav__logout {
  padding:6px 14px; background:transparent;
  border:1.5px solid var(--border); border-radius:var(--r-sm);
  font-family:var(--font); font-size:.82rem; font-weight:600; color:var(--text-2);
  cursor:pointer; transition:all var(--t);
}
.nav__logout:hover { border-color:var(--text); color:var(--text); background:var(--bg); }


/* ══════════════════════════════════════════════════════════
   APP – COMPANY HERO  (branded area, shown after login)
   ══════════════════════════════════════════════════════════ */

.hero {
  background:var(--accent);
  padding:52px 24px 48px;
  position:relative;
  overflow:hidden;
}
/* Subtle texture: diagonal overlay */
.hero::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg,
    rgba(255,255,255,.06) 0%,
    rgba(255,255,255,0)   50%,
    rgba(0,0,0,.06)       100%);
  pointer-events:none;
}

.hero__inner {
  max-width:680px; margin:0 auto;
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:12px;
  text-align:center;
}

/* Company logo in hero */
.hero__logo-wrap {
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.25);
  border-radius:var(--r-md);
  padding:12px 24px;
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:4px;
}
.hero__logo-img {
  max-height:48px; max-width:160px; object-fit:contain;
  display:block;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.12));
}
.hero__company-name {
  font-size:1rem; font-weight:700;
  color:var(--on-accent); opacity:.9;
  letter-spacing:.02em; text-transform:uppercase;
}

.hero__greeting {
  font-size:2rem; font-weight:700; letter-spacing:-.03em; line-height:1.2;
  color:var(--on-accent);
}
.hero__msg {
  font-size:1rem; line-height:1.65;
  color:var(--on-accent); opacity:.82;
  max-width:480px;
}
.hero__badges {
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
  margin-top:6px;
}
.hero__badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 16px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.22);
  border-radius:99px;
  font-size:.85rem; font-weight:500;
  color:var(--on-accent);
}


/* ══════════════════════════════════════════════════════════
   GIFTS SCREEN
   ══════════════════════════════════════════════════════════ */

.gifts-wrap { max-width:1160px; margin:0 auto; padding:32px 24px 0; }
.gifts-pad  { height:96px; }

.price-tabs { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.price-tab {
  padding:7px 16px; border:1.5px solid var(--border); border-radius:99px;
  background:var(--white); font-size:.84rem; font-weight:600;
  cursor:pointer; transition:all var(--t); color:var(--text-2);
}
.price-tab:hover  { border-color:var(--accent); color:var(--accent); }
.price-tab.active { background:var(--accent); color:var(--on-accent); border-color:var(--accent); }

.gifts-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:20px;
}

.gift-card {
  background:var(--white); border-radius:var(--r-md); overflow:hidden;
  box-shadow:var(--shadow-sm); cursor:pointer;
  border:2px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, border-color var(--t);
  display:flex; flex-direction:column;
}
.gift-card:hover {
  transform:translateY(-4px);
  box-shadow:0 12px 28px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.05);
}
.gift-card--selected {
  border-color:var(--accent);
  box-shadow:0 0 0 4px var(--accent-light), var(--shadow-md);
}
.gift-card__img {
  position:relative;
  /* Aspect-ratio keeps all product thumbnails uniform regardless of image */
  aspect-ratio: 4 / 3;
  height:auto;
  background:var(--accent-light);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.gift-card__img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .35s ease;
}
.gift-card:hover .gift-card__img img { transform:scale(1.04); }
.gift-card__icon    { font-size:3rem; }
.gift-card__check {
  position:absolute; top:10px; right:10px;
  width:30px; height:30px; border-radius:50%;
  background:var(--accent); color:var(--on-accent);
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-sm);
  z-index:2;
}
.gift-card__body { padding:16px; display:flex; flex-direction:column; flex:1; }
.gift-card__name { font-size:.95rem; font-weight:600; margin-bottom:6px; line-height:1.35; }
.gift-card__desc {
  font-size:.82rem; color:var(--text-2); line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden; margin-bottom:8px;
}
.gift-card__price {
  display:inline-block; background:var(--accent-light); color:var(--accent);
  padding:3px 10px; border-radius:99px; font-size:.78rem; font-weight:600;
}
.no-gifts { color:var(--text-2); padding:48px 0; text-align:center; }

/* Sticky bottom CTA bar */
.gifts-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:100;
  background:rgba(255,255,255,.94); backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
  padding:14px 24px;
  display:flex; align-items:center; justify-content:center;
}
.btn--cta {
  min-width:320px; padding:15px 28px;
  background:var(--accent); color:var(--on-accent);
  border:none; border-radius:var(--r-sm);
  font-family:var(--font); font-size:.95rem; font-weight:600;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  cursor:pointer; transition:all var(--t);
  box-shadow:0 2px 10px rgba(0,0,0,.15);
}
.btn--cta:hover:not(:disabled) {
  background:var(--accent-h);
  box-shadow:0 6px 20px rgba(0,0,0,.2);
  transform:translateY(-1px);
}
.btn--cta-disabled {
  background:var(--border); color:var(--text-3);
  cursor:not-allowed; box-shadow:none;
}
.btn--cta strong { font-weight:700; }


/* ══════════════════════════════════════════════════════════
   INNER SCREENS  (email, confirm – centered cards)
   ══════════════════════════════════════════════════════════ */

.inner-screen {
  min-height:calc(100vh - 58px);
  display:flex; align-items:center; justify-content:center;
  padding:32px 24px;
  background:var(--bg);
}
.inner-card {
  background:var(--white); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  padding:40px; width:100%; max-width:480px;
}
.inner-card--confirm { max-width:520px; text-align:center; }

.summary-gift {
  display:flex; align-items:center; gap:16px;
  background:var(--accent-light); border-radius:var(--r-md);
  padding:16px 20px; margin-bottom:24px;
}
.summary-img  { width:64px; height:64px; border-radius:var(--r-sm); object-fit:cover; }
.summary-icon { font-size:2.5rem; }
.summary-info { display:flex; flex-direction:column; gap:4px; }
.summary-label { font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--text-2); }
.summary-name  { font-weight:600; font-size:1rem; }
.summary-price {
  display:inline-block; background:var(--accent); color:var(--on-accent);
  padding:2px 10px; border-radius:99px; font-size:.78rem; font-weight:600; margin-top:2px;
}
.divider { height:1px; background:var(--border); margin-bottom:24px; }
.inner-heading { font-size:1.35rem; font-weight:700; letter-spacing:-.02em; margin-bottom:6px; }
.inner-sub     { color:var(--text-2); font-size:.9rem; line-height:1.6; }

/* Confirm specifics */
.confirm-check {
  width:64px; height:64px; border-radius:50%;
  background:var(--success-bg); color:var(--success);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
}
.confirm-heading { font-size:1.7rem; font-weight:700; letter-spacing:-.03em; margin-bottom:8px; }
.confirm-sub     { color:var(--text-2); margin-bottom:28px; }
.confirm-gift-box {
  display:flex; align-items:center; gap:16px; text-align:left;
  background:var(--accent-light); border-radius:var(--r-md);
  padding:16px 20px; margin-bottom:20px;
}
.confirm-gift-img  { width:72px; height:72px; border-radius:var(--r-sm); object-fit:cover; }
.confirm-gift-icon { font-size:2.5rem; }
.confirm-gift-info { display:flex; flex-direction:column; gap:4px; }
.confirm-gift-label{ font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--text-2); }
.confirm-gift-name { font-weight:600; font-size:1rem; }
.confirm-gift-price{
  display:inline-block; background:var(--accent); color:var(--on-accent);
  padding:2px 10px; border-radius:99px; font-size:.78rem; font-weight:600;
}
.confirm-email-note {
  color:var(--text-2); font-size:.88rem; margin-bottom:24px;
  background:var(--bg); padding:10px 16px; border-radius:var(--r-sm);
}
.confirm-cta-card {
  background:linear-gradient(135deg, #0d2338 0%, #1A3A5C 100%);
  border-radius:var(--r-md); padding:28px; color:#fff;
  margin-bottom:8px; text-align:left;
}
.confirm-cta-title { font-size:1rem; font-weight:700; margin-bottom:6px; }
.confirm-cta-sub   { font-size:.88rem; opacity:.75; margin-bottom:20px; line-height:1.55; }
.confirm-cta-actions { display:flex; gap:10px; flex-wrap:wrap; }


/* ══════════════════════════════════════════════════════════
   PRODUCT DETAIL  (.pd)
   ══════════════════════════════════════════════════════════ */

.pd { background:var(--bg); min-height:calc(100vh - 58px); padding-bottom:64px; }
.pd__inner { max-width:1080px; margin:0 auto; padding:28px 28px; }

/* Back link */
.pd__back {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; margin-bottom:28px;
  background:transparent; border:none; cursor:pointer;
  font-family:var(--font); font-size:.88rem; font-weight:600;
  color:var(--text-2); border-radius:var(--r-sm);
  transition:all var(--t);
}
.pd__back:hover { color:var(--text); background:rgba(0,0,0,.05); transform:translateX(-2px); }
.pd__back svg   { flex-shrink:0; transition:transform var(--t); }
.pd__back:hover svg { transform:translateX(-3px); }

/* Two-column layout */
.pd__layout {
  display:grid;
  grid-template-columns:54% 1fr;
  gap:52px;
  align-items:start;
}

/* ── Gallery ──────────────────────────────────────────────── */
.pd__gallery { position:sticky; top:74px; }

.pd__main-img-wrap {
  position:relative; border-radius:var(--r-lg);
  overflow:hidden; background:var(--white);
  box-shadow:var(--shadow-md);
  aspect-ratio:1/1;
  cursor:zoom-in;
}
.pd__main-img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:opacity .18s ease, transform .5s ease;
}
.pd__main-img:hover { transform:scale(1.03); }
.pd__main-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-size:6rem; background:var(--accent-light);
}

/* Arrow buttons */
.pd__arr {
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,.9); backdrop-filter:blur(8px);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 2px 12px rgba(0,0,0,.14);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--text);
  transition:all var(--t); z-index:5;
}
.pd__arr--prev { left:14px; }
.pd__arr--next { right:14px; }
.pd__arr:hover {
  background:var(--white);
  box-shadow:0 4px 18px rgba(0,0,0,.2);
  transform:translateY(-50%) scale(1.08);
}

/* Dot indicators */
.pd__dots {
  position:absolute; bottom:16px; left:50%; transform:translateX(-50%);
  display:flex; gap:7px; z-index:5;
}
.pd__dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.5);
  cursor:pointer; transition:all var(--t); border:none; padding:0;
}
.pd__dot--active { background:var(--white); transform:scale(1.4); }
.pd__dot:hover:not(.pd__dot--active) { background:rgba(255,255,255,.8); }

/* Image counter badge */
.pd__img-counter {
  position:absolute; bottom:14px; right:14px;
  background:rgba(0,0,0,.52); color:#fff;
  font-size:.72rem; font-weight:600;
  padding:3px 9px; border-radius:99px;
  z-index:5; pointer-events:none;
  backdrop-filter:blur(4px);
}

/* Thumbnails */
.pd-thumbs { display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pd-thumb {
  width:74px; height:74px; border-radius:var(--r-sm);
  overflow:hidden; cursor:pointer;
  border:2.5px solid transparent;
  transition:all var(--t); background:var(--white);
  flex-shrink:0; padding:0;
  box-shadow:var(--shadow-sm);
}
.pd-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.pd-thumb--active { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-light); }
.pd-thumb:hover:not(.pd-thumb--active) {
  border-color:var(--accent-mid);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

/* ── Info panel ───────────────────────────────────────────── */
.pd__info { padding-top:4px; }

.pd__category {
  font-size:.76rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--accent); margin-bottom:10px;
}
.pd__name {
  font-size:2.1rem; font-weight:700;
  letter-spacing:-.04em; line-height:1.2;
  color:var(--text); margin-bottom:18px;
}
.pd__price-wrap {
  display:flex; align-items:center; gap:12px;
  margin-bottom:26px; flex-wrap:wrap;
  padding-bottom:24px; border-bottom:1px solid var(--border);
}
.pd__price { font-size:1.6rem; font-weight:800; color:var(--accent); letter-spacing:-.03em; }
.pd__price-sub { font-size:.84rem; color:var(--text-2); line-height:1.4; }

.pd__desc-wrap { margin-bottom:28px; }
.pd__desc-heading {
  font-size:.76rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--text-3); margin-bottom:12px;
}
.pd__desc {
  font-size:.95rem; color:var(--text-2);
  line-height:1.8; white-space:pre-wrap;
}

/* CTA block */
.pd__actions {
  display:flex; flex-direction:column; gap:10px;
  padding-top:20px; border-top:1px solid var(--border);
}
.pd__select-btn {
  width:100%; padding:17px 24px;
  background:var(--accent); color:var(--on-accent);
  border:none; border-radius:var(--r-sm);
  font-family:var(--font); font-size:1rem; font-weight:700;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  cursor:pointer; transition:all var(--t);
  box-shadow:0 4px 18px rgba(0,0,0,.16);
}
.pd__select-btn:hover:not(.pd__select-btn--selected) {
  background:var(--accent-h);
  box-shadow:0 8px 28px rgba(0,0,0,.22);
  transform:translateY(-2px);
}
.pd__select-btn:active { transform:scale(.98); }
.pd__select-btn .btn-arrow { transition:transform var(--t); }
.pd__select-btn:hover:not(.pd__select-btn--selected) .btn-arrow { transform:translateX(3px); }
.pd__select-btn--selected {
  background:var(--success) !important;
  color:#fff !important;
  box-shadow:0 4px 16px rgba(30,122,78,.28) !important;
  cursor:default;
}
.pd__compare-btn {
  width:100%; padding:13px 24px;
  background:transparent; border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  font-family:var(--font); font-size:.88rem; font-weight:600;
  color:var(--text-2); cursor:pointer; transition:all var(--t);
}
.pd__compare-btn:hover { border-color:var(--text-2); color:var(--text); background:rgba(0,0,0,.03); }

.pd__next-btn {
  width:100%; padding:13px 24px;
  background:var(--white); color:var(--accent);
  border:1.5px solid var(--accent-mid); border-radius:var(--r-sm);
  font-family:var(--font); font-size:.88rem; font-weight:600;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  cursor:pointer; transition:all var(--t);
}
.pd__next-btn:hover { background:var(--accent-light); border-color:var(--accent); }
.pd__next-btn .btn-arrow { transition:transform var(--t); }
.pd__next-btn:hover .btn-arrow { transform:translateX(3px); }

/* ── Gift card "Se mere" label ────────────────────────────── */
.gift-card__cta {
  display:block; font-size:.78rem; font-weight:600;
  color:var(--accent); margin-top:8px;
  transition:color var(--t);
}
.gift-card:hover .gift-card__cta { color:var(--accent-h); }
.gift-card--selected .gift-card__cta { color:var(--success); }

/* ── Lightbox ─────────────────────────────────────────────── */
@keyframes lbIn { from { opacity:0; } to { opacity:1; } }

.pd-lightbox {
  position:fixed; inset:0; z-index:1000;
  background:rgba(6,6,10,.92);
  backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
  cursor:zoom-out;
  /* Hidden by default via opacity/pointer-events */
  opacity:0; pointer-events:none;
  transition:opacity .22s ease;
}
.pd-lightbox--open {
  opacity:1; pointer-events:auto;
}
.pd-lb__img {
  max-width:90vw; max-height:88vh;
  object-fit:contain; border-radius:var(--r-md);
  box-shadow:0 32px 80px rgba(0,0,0,.55);
  cursor:default;
  animation:lbIn .28s ease;
}
.pd-lb__close {
  position:fixed; top:18px; right:18px;
  width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);
  color:#fff; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background var(--t); z-index:1002;
}
.pd-lb__close:hover { background:rgba(255,255,255,.22); }
.pd-lb__arr {
  position:fixed; top:50%; transform:translateY(-50%);
  width:54px; height:54px; border-radius:50%;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);
  color:#fff; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background var(--t); z-index:1002;
}
.pd-lb__arr:hover { background:rgba(255,255,255,.22); }
.pd-lb__arr--prev { left:16px; }
.pd-lb__arr--next { right:16px; }


/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */

@media (max-width: 860px) {
  /* Product detail collapses to single column */
  .pd__layout { grid-template-columns:1fr; gap:28px; }
  .pd__gallery { position:static; }
  .pd__name    { font-size:1.6rem; }
  .pd__price   { font-size:1.35rem; }

  /* Sticky action bar pinned to bottom */
  .pd__actions {
    position:fixed; bottom:0; left:0; right:0;
    flex-direction:row; flex-wrap:wrap;
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(18px);
    border-top:1px solid var(--border);
    padding:12px 20px 16px;
    z-index:50; gap:8px;
    box-shadow:0 -4px 24px rgba(0,0,0,.08);
  }
  .pd__select-btn  { flex:1 1 auto; min-width:0; padding:15px 16px; }
  .pd__compare-btn { flex:0 0 auto; padding:15px 18px; }
  .pd__next-btn    { flex:1 1 auto; min-width:0; }
  .pd { padding-bottom:100px; }
  .pd__inner { padding:16px; }
  .pd__back  { margin-bottom:16px; }
}

@media (max-width: 640px) {
  /* Login */
  .lp { padding:16px; align-items:flex-start; padding-top:40px; }
  .lp__card { border-radius:var(--r-md); }
  .lp__top  { padding:20px 24px; }
  .lp__body { padding:24px; }
  .lp__footer { padding:12px 24px; }

  /* Nav */
  .nav__inner { padding:0 16px; }
  .nav__user  { display:none; }

  /* Hero */
  .hero { padding:36px 20px 32px; }
  .hero__greeting { font-size:1.55rem; }
  .hero__badges   { flex-direction:column; align-items:center; }

  /* Gifts */
  .gifts-wrap { padding:20px 16px 0; }
  .gifts-grid { grid-template-columns:repeat(auto-fill, minmax(155px, 1fr)); gap:12px; }
  .gift-card__img { aspect-ratio: 1 / 1; }
  .gift-card__body { padding:12px 12px 14px; }
  .gifts-bar { padding:12px 16px; }
  .btn--cta { min-width:0; width:100%; }

  /* Inner screens */
  .inner-card { padding:24px 20px; }
  .inner-screen { padding:20px 16px; align-items:flex-start; padding-top:32px; }
  .confirm-heading { font-size:1.4rem; }
  .confirm-cta-actions { flex-direction:column; }
  .confirm-cta-actions .btn { justify-content:center; }

  /* Product detail */
  .pd__name      { font-size:1.35rem; }
  .pd-thumbs     { gap:7px; }
  .pd-thumb      { width:58px; height:58px; }
  .pd-lb__arr    { width:44px; height:44px; }
  .pd-lb__arr--prev { left:8px; }
  .pd-lb__arr--next { right:8px; }
}
