/* ============================================================
   AMEX REFERRAL — APP STYLES
   All colours reference --theme-* variables set by theme files.
   Import a theme file first, then this file.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; font-size: 16px; }
body  {
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif;
  background: var(--theme-page-bg);
  color: var(--theme-tile-name);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  transition: background 0.3s ease, color 0.3s ease;
}
img  { max-width: 100%; height: auto; display: block; }
a    { text-decoration: none; }
ul   { list-style: none; }

/* ── Container ── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
@media (max-width: 480px) { .container { padding: 0 16px; } }

/* ============================================================
   CONTROL BAR (theme + layout switcher)
   ============================================================ */
.control-bar {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 500;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
.control-bar__toggle {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--theme-accent);
  border: none;
  color: #fff;
  font-size: 1.3rem;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.3s, transform 0.2s;
  font-family: inherit;
}
.control-bar__toggle:hover { transform: scale(1.08); }

.control-panel {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.22);
  padding: 20px;
  width: 260px;
  display: none;
  flex-direction: column;
  gap: 18px;
  border: 1px solid rgba(0,0,0,0.08);
}
.control-panel.open { display: flex; }

.cp-section-label {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #999;
  margin-bottom: 8px;
}

/* Theme swatches */
.theme-swatches {
  display: flex;
  gap: 10px;
}
.theme-swatch {
  flex: 1;
  border: 2px solid transparent;
  border-radius: 8px;
  padding: 8px 6px;
  background: none;
  cursor: pointer;
  font-family: inherit;
  font-size: .72rem;
  font-weight: 600;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  transition: border-color 0.2s, box-shadow 0.2s;
  color: #333;
}
.theme-swatch:hover    { border-color: #ccc; }
.theme-swatch.active   { border-color: var(--theme-accent, #016FD0); box-shadow: 0 0 0 2px var(--theme-accent, #016FD0); }
.swatch-dot {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,0.1);
}
.swatch-dot--classic { background: linear-gradient(135deg, #016FD0, #001E50); }
.swatch-dot--dark    { background: linear-gradient(135deg, #001030, #B8A460); }
.swatch-dot--gold    { background: linear-gradient(135deg, #2C1E0F, #B8A460); }

/* Layout options */
.layout-opts { display: flex; flex-direction: column; gap: 6px; }
.layout-opt {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 8px;
  border: 1.5px solid #E0E0E0;
  background: none;
  cursor: pointer;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 500;
  color: #333;
  transition: border-color 0.2s, background 0.2s;
  text-align: left;
}
.layout-opt:hover  { border-color: #aaa; background: #F5F5F5; }
.layout-opt.active { border-color: var(--theme-accent, #016FD0); background: #EBF5FB; color: var(--theme-accent, #016FD0); font-weight: 700; }
.layout-opt__icon  { font-size: 1rem; width: 22px; text-align: center; flex-shrink: 0; }

/* ============================================================
   NAV
   ============================================================ */
.app-nav {
  background: var(--theme-nav-bg);
  position: sticky; top: 0; z-index: 200;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
  transition: background 0.3s;
}
.app-nav__inner {
  max-width: 1280px; margin: 0 auto;
  padding: 0 24px; height: 64px;
  display: flex; align-items: center;
  justify-content: space-between; gap: 24px;
  position: relative;
}
.app-nav__eyebrow {
  position: absolute; left: 50%; transform: translateX(-50%);
  font-size: .95rem; font-weight: 800; letter-spacing: -.01em;
  color: var(--theme-nav-text);
  white-space: nowrap; pointer-events: none;
}
.app-nav__brand {
  display: flex; align-items: center; gap: 12px;
  color: var(--theme-nav-text);
  font-weight: 800; font-size: .95rem;
  letter-spacing: -.01em; flex-shrink: 0;
}
.app-nav__icon {
  width: 38px; height: 38px;
  background: var(--theme-nav-icon-bg);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: .75rem;
  color: var(--theme-nav-icon-text);
  letter-spacing: -.04em; flex-shrink: 0;
}
.app-nav__links { display: flex; gap: 6px; list-style: none; }
.app-nav__links a {
  color: rgba(255,255,255,0.88);
  font-size: .84rem; font-weight: 500;
  padding: 6px 12px; border-radius: 6px;
  transition: all 0.2s;
}
.app-nav__links a:hover { background: rgba(255,255,255,0.15); color: #fff; }
.app-nav__right { display: flex; gap: 10px; align-items: center; }
.app-nav__login { color: rgba(255,255,255,0.88); font-size: .84rem; font-weight: 500; transition: all 0.2s; }
.app-nav__login:hover { color: #fff; }
@media (max-width: 768px) { .app-nav__links { display: none; } .app-nav__brand span { display: none; } }

/* ============================================================
   HERO
   ============================================================ */
.app-hero {
  background: var(--theme-feat-bg);
  color: var(--theme-hero-text);
  padding: 16px 24px 14px;
  text-align: center;
  transition: background 0.3s;
}
.app-hero h1 { font-size: clamp(1.05rem, 2.5vw, 1.5rem); font-weight: 800; letter-spacing: -.02em; line-height: 1.2; margin-bottom: 6px; }
.app-hero p  { font-size: clamp(.78rem, 1.5vw, .875rem); opacity: .85; max-width: 520px; margin: 0 auto; line-height: 1.5; }
/* Dark theme hero decoration */
.app-hero__eyebrow {
  font-size: .64rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--theme-feat-sub);
  margin-bottom: 6px;
}
.app-hero__divider { width: 32px; height: 2px; background: var(--theme-accent); margin: 10px auto 0; border-radius: 2px; }

/* ── Trust strip ── */
.trust-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px 24px;
  padding: 12px 24px;
  background: var(--theme-filter-bg);
  border-bottom: 1px solid var(--theme-filter-bd);
  transition: background 0.3s, border-color 0.3s;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--theme-tab-text);
  white-space: nowrap;
}
.trust-icon { font-size: .95rem; line-height: 1; }
.trust-sep  { color: var(--theme-tab-bd); font-size: .9rem; }
@media (max-width: 640px) { .trust-sep { display: none; } .trust-strip { gap: 8px; } }

/* ============================================================
   FILTER BAR
   ============================================================ */
.app-filter-bar {
  background: var(--theme-filter-bg);
  border-bottom: 1px solid var(--theme-filter-bd);
  padding: 14px 24px;
  transition: background 0.3s, border-color 0.3s;
  position: sticky;
  top: 64px;
  z-index: 190;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.app-filter-bar__inner {
  max-width: 1280px; margin: 0 auto;
  display: flex; gap: 8px; flex-wrap: wrap; justify-content: center;
}
.filter-tab {
  padding: 7px 17px; border-radius: 100px;
  border: 1.5px solid var(--theme-tab-bd);
  background: var(--theme-tab-bg);
  color: var(--theme-tab-text);
  font-size: .825rem; font-weight: 500;
  font-family: inherit; cursor: pointer;
  transition: all 0.2s; white-space: nowrap;
}
.filter-tab:hover  { border-color: var(--theme-tab-hov-bd); color: var(--theme-tab-hov-text); }
.filter-tab.active { background: var(--theme-tab-act-bg); border-color: var(--theme-tab-act-bd); color: var(--theme-tab-act-text); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-block; padding: 11px 22px; border-radius: 4px;
  font-family: inherit; font-size: .825rem; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase; text-align: center;
  cursor: pointer; border: 2px solid transparent;
  transition: all 0.22s; line-height: 1.2; text-decoration: none !important;
}
.btn-pri {
  background: var(--theme-btn-pri-bg);
  color:      var(--theme-btn-pri-text);
  border-color: var(--theme-btn-pri-bd);
}
.btn-pri:hover { background: var(--theme-btn-pri-hbg); border-color: var(--theme-btn-pri-hbg); color: #fff; }
.btn-out {
  background: transparent;
  color:      var(--theme-btn-out-text);
  border-color: var(--theme-btn-out-bd);
}
.btn-out:hover { background: var(--theme-btn-out-hbg); color: var(--theme-btn-out-htxt); border-color: var(--theme-btn-out-hbg); }

/* ============================================================
   BADGES
   ============================================================ */
.badge {
  display: inline-block; padding: 3px 9px; border-radius: 3px;
  font-size: .67rem; font-weight: 800; letter-spacing: .08em;
  text-transform: uppercase; line-height: 1.5; white-space: nowrap;
}
.badge-gold   { background: #B8A460; color: #fff; }
.badge-blue   { background: #016FD0; color: #fff; }
.badge-green  { background: #2E7D32; color: #fff; }
.badge-purple { background: #6B2D8B; color: #fff; }

/* ============================================================
   APPLY BUTTON + TRUST TEXT
   ============================================================ */
.apply-wrap {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
}
.btn--apply {
  font-size: .95rem;
  padding: 13px 22px;
  border-radius: 6px;
  letter-spacing: .01em;
  text-transform: none;
  font-weight: 700;
  width: 100%;
  text-align: center;
}
.apply-secure {
  text-align: center;
  font-size: .78rem;
  color: var(--theme-apr);
  opacity: 0.85;
}
@media (max-width: 640px) { .apply-secure { font-size: .82rem; } }

/* ============================================================
   CARD ART
   ============================================================ */
/* Real Amex card photo */
.card-art-img {
  display: block;
  border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,0.28);
  flex-shrink: 0;
  object-fit: contain;
  background: transparent;
}
.card-art-img--sm { width: 140px; height: 88px; }
.card-art-img--md { width: 200px; height: 126px; }
.card-art-img--lg { width: 260px; height: 164px; }

/* CSS gradient fallback (used when no cardImageUrl) */
.card-art {
  border-radius: 10px; position: relative;
  box-shadow: 0 8px 28px rgba(0,0,0,0.28);
  overflow: hidden; flex-shrink: 0;
}
.card-art::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 30%, rgba(255,255,255,0.18) 0%, transparent 60%);
  pointer-events: none;
}
.ca-chip { position: absolute; top: 22%; left: 9%; width: 14%; height: 18%; background: linear-gradient(135deg, #D4AF37 0%, #F5D97C 50%, #B8860B 100%); border-radius: 3px; }
.ca-number { position: absolute; bottom: 28%; left: 9%; font-size: .45em; letter-spacing: .16em; font-family: 'Courier New', monospace; opacity: .75; }
.ca-holder { position: absolute; bottom: 14%; left: 9%; font-size: .4em; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; opacity: .88; }
.ca-logo   { position: absolute; top: 16%; right: 9%; font-size: .55em; font-weight: 900; letter-spacing: .06em; opacity: .92; }
.ca-holo   { position: absolute; bottom: 12%; right: 9%; width: 12%; padding-bottom: 12%; border-radius: 50%; background: conic-gradient(from 0deg, #ff6b6b, #ffd93d, #6bff6b, #6bffff, #6b6bff, #ff6bff, #ff6b6b); opacity: .55; }

/* ============================================================
   SHARED TILE ELEMENTS
   ============================================================ */
.offer-box {
  background: var(--theme-offer-bg);
  border-left: 3px solid var(--theme-offer-bd);
  padding: 11px 13px;
  border-radius: 0 6px 6px 0;
  transition: background 0.3s, border-color 0.3s;
}
.offer-headline { font-weight: 700; font-size: .9rem; color: var(--theme-offer-head); line-height: 1.3; }
.offer-sub      { font-weight: 600; font-size: .82rem; color: var(--theme-offer-sub); margin-top: 3px; }
.offer-detail   { font-size: .74rem; color: var(--theme-offer-detail); margin-top: 5px; line-height: 1.45; }

/* ── Offer Comparison Banner ─────────────────────────────────── */
.offer-compare {
  margin: 10px 0 4px;
  border: 1.5px solid #a5d6a7;
  border-radius: 8px;
  overflow: hidden;
  font-size: .8rem;
}
.offer-compare__header {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #2E7D32;
  background: #e8f5e9;
  border-bottom: 1px solid #a5d6a7;
  padding: 6px 10px;
  margin: 0;
}
.offer-compare__row {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 7px 10px;
}
.offer-compare__row--direct {
  background: #fff8f8;
  border-bottom: 1px solid #f0c0c0;
}
.offer-compare__row--referral {
  background: #f0faf0;
}
.offer-compare__label {
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
  font-size: .75rem;
  padding-top: 1px;
  width: 100px;
}
.offer-compare__row--direct .offer-compare__label  { color: #c62828; }
.offer-compare__row--referral .offer-compare__label { color: #2E7D32; }
.offer-compare__val {
  line-height: 1.35;
  color: #444;
}
.offer-compare__row--direct .offer-compare__val {
  text-decoration: line-through;
  color: #999;
}
.offer-compare__val--better {
  font-weight: 700;
  color: #1b5e20;
}
.offer-compare__cta {
  font-size: .7rem;
  color: #2E7D32;
  font-weight: 600;
  padding: 5px 10px 6px;
  background: #e8f5e9;
  margin: 0;
  text-align: center;
}

.benefits { display: flex; flex-direction: column; gap: 5px; }
.benefits li { display: flex; gap: 8px; align-items: flex-start; font-size: .82rem; color: var(--theme-benefit-text); }
.benefits li::before { content: '✓'; color: var(--theme-benefit-tick); font-weight: 800; flex-shrink: 0; line-height: 1.55; }
.benefits__more { font-size: .75rem !important; color: var(--theme-accent) !important; font-weight: 600; font-style: italic; }
.benefits__more::before { content: '' !important; display: none; }

.pill {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--theme-pill-bg); color: var(--theme-pill-text);
  border-radius: 100px; padding: 3px 10px;
  font-size: .72rem; font-weight: 600; line-height: 1.4;
}
.pill::before { content: '✓'; font-weight: 800; }

.fee-row { font-size: .78rem; color: var(--theme-meta-text); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.fee-row strong { color: var(--theme-meta-strong); }
.fee-row--paid strong { color: #c62828; font-weight: 800; }
.fee-free { background: #2E7D32; color: #fff; font-size: .62rem; font-weight: 700; padding: 2px 6px; border-radius: 3px; letter-spacing: .05em; text-transform: uppercase; }
.fee-high-tag { background: #c62828; color: #fff; font-size: .6rem; font-weight: 700; padding: 2px 6px; border-radius: 3px; letter-spacing: .05em; text-transform: uppercase; }
.offer-expiry {
  display: block;
  width: 100%;
  padding: 7px 16px;
  background: #F5A623;
  color: #1a1a1a;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  text-align: left;
  margin: 0;
  /* Angled right tab like Amex ribbon */
  clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 50%, calc(100% - 16px) 100%, 0 100%);
  padding-right: 32px;
}
.apr-text { font-size: .72rem; color: var(--theme-apr); line-height: 1.4; }
.eligibility { background: var(--theme-elig-bg); border: 1px solid var(--theme-elig-bd); border-radius: 6px; padding: 8px 11px; font-size: .71rem; color: var(--theme-elig-text); line-height: 1.45; }
.no-link-warn { font-size: .76rem; color: var(--theme-no-link-text); background: var(--theme-no-link-bg); border: 1px solid var(--theme-no-link-bd); padding: 7px 11px; border-radius: 6px; font-weight: 600; }
.section-title { font-size: 1.3rem; font-weight: 800; color: var(--theme-section-title); letter-spacing: -.02em; margin-bottom: 4px; }
.section-sub   { font-size: .88rem; color: var(--theme-section-sub); margin-bottom: 24px; }

/* ============================================================
   LAYOUT: GRID (3-col)
   ============================================================ */
#layout-root.layout-grid .cards-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media (max-width: 1024px) { #layout-root.layout-grid .cards-wrap { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px)  { #layout-root.layout-grid .cards-wrap { grid-template-columns: 1fr; } }

.grid-tile {
  background: var(--theme-tile-bg);
  border-radius: 12px; border: 1px solid var(--theme-tile-bd);
  overflow: hidden; display: flex; flex-direction: column;
  transition: box-shadow 0.22s, transform 0.22s, border-color 0.22s, background 0.3s;
}
.grid-tile:hover { box-shadow: 0 8px 36px rgba(0,0,0,0.18); transform: translateY(-3px); border-color: var(--theme-tile-bd-h); }

.grid-tile__head {
  background: var(--theme-tile-head-bg);
  padding: 22px 18px 16px; border-bottom: 1px solid var(--theme-tile-bd);
  display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center;
}
.grid-tile__name { font-size: .92rem; font-weight: 700; line-height: 1.3; color: var(--theme-tile-name); }
.grid-tile__body { padding: 16px 18px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
.grid-tile__meta { border-top: 1px solid var(--theme-tile-bd); padding-top: 10px; display: flex; flex-direction: column; gap: 5px; }
.grid-tile__foot {
  display: flex; gap: 8px; padding: 13px 18px;
  border-top: 1px solid var(--theme-tile-bd);
  background: var(--theme-tile-foot-bg);
}
.grid-tile__foot .btn { flex: 1; padding: 9px 8px; font-size: .76rem; }

/* ============================================================
   LAYOUT: HERO + GRID
   ============================================================ */
.feat-hero {
  background: var(--theme-feat-bg);
  padding: 48px 24px 52px;
  transition: background 0.3s;
}
.feat-hero__inner {
  max-width: 960px; margin: 0 auto;
  display: grid; grid-template-columns: auto 1fr;
  gap: 48px; align-items: center;
}
.feat-hero__art { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.feat-hero__info { color: var(--theme-feat-text); }
.feat-hero__eyebrow { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--theme-feat-sub); margin-bottom: 8px; }
.feat-hero__name { font-size: clamp(1.3rem, 3vw, 1.9rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.2; margin-bottom: 16px; }
.feat-hero__offer-head { font-size: clamp(.95rem, 2vw, 1.3rem); font-weight: 700; color: var(--theme-feat-offer); line-height: 1.3; margin-bottom: 5px; }
.feat-hero__offer-sub  { font-size: .95rem; font-weight: 600; color: var(--theme-feat-sub); margin-bottom: 8px; }
.feat-hero__offer-det  { font-size: .8rem; color: var(--theme-feat-sub); line-height: 1.5; margin-bottom: 18px; }
.feat-hero__bens       { list-style: none; display: flex; flex-direction: column; gap: 7px; margin-bottom: 24px; }
.feat-hero__bens li    { display: flex; gap: 9px; font-size: .86rem; color: var(--theme-feat-text); align-items: flex-start; }
.feat-hero__bens li::before { content: '✓'; color: var(--theme-feat-tick); font-weight: 800; flex-shrink: 0; line-height: 1.5; }
.feat-hero__actions    { display: flex; gap: 12px; flex-wrap: wrap; }
.feat-hero__elig       { margin-top: 12px; font-size: .7rem; color: var(--theme-feat-sub); line-height: 1.5; opacity: .8; }
.btn-feat-pri  { background: #fff; color: var(--theme-nav-bg); border-color: #fff; }
.btn-feat-pri:hover { background: rgba(255,255,255,0.9); }
.btn-feat-out  { background: transparent; color: #fff; border-color: rgba(255,255,255,0.6); }
.btn-feat-out:hover { background: rgba(255,255,255,0.12); border-color: #fff; color: #fff; }
@media (max-width: 720px) {
  .feat-hero__inner { grid-template-columns: 1fr; text-align: center; gap: 24px; }
  .feat-hero__bens li { text-align: left; }
  .feat-hero__actions { justify-content: center; }
}

#layout-root.layout-hero .browse-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
@media (max-width: 1024px) { #layout-root.layout-hero .browse-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px)  { #layout-root.layout-hero .browse-grid { grid-template-columns: 1fr; } }

/* hero layout uses same grid-tile styles but smaller */
#layout-root.layout-hero .grid-tile__head { padding: 14px 14px 12px; }
#layout-root.layout-hero .grid-tile__body { padding: 13px 14px; gap: 10px; }
#layout-root.layout-hero .grid-tile__foot { padding: 11px 14px; }
#layout-root.layout-hero .grid-tile__name { font-size: .86rem; }

/* ============================================================
   LAYOUT: MAGAZINE
   ============================================================ */
#layout-root.layout-magazine .mag-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
}
@media (max-width: 900px)  { #layout-root.layout-magazine .mag-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px)  { #layout-root.layout-magazine .mag-grid { grid-template-columns: 1fr; } }

.mag-featured {
  grid-column: 1 / -1;
  background: var(--theme-tile-bg); border: 1px solid var(--theme-tile-bd);
  border-radius: 14px; overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
  transition: box-shadow 0.22s, background 0.3s;
}
.mag-featured:hover { box-shadow: 0 10px 40px rgba(0,0,0,0.18); }
.mag-feat-visual {
  background: var(--theme-feat-bg); padding: 40px 32px;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 20px; text-align: center;
}
.mag-feat-label { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--theme-feat-sub); }
.mag-feat-tag   { font-size: clamp(.95rem, 2vw, 1.25rem); font-weight: 800; color: var(--theme-feat-text); letter-spacing: -.02em; line-height: 1.2; }
.mag-feat-info  { padding: 32px; display: flex; flex-direction: column; gap: 16px; justify-content: center; }
.mag-feat-name  { font-size: 1rem; font-weight: 800; letter-spacing: -.02em; color: var(--theme-tile-name); line-height: 1.25; }
.mag-feat-actions { display: flex; gap: 12px; }
.mag-feat-apr   { font-size: .7rem; color: var(--theme-apr); margin-top: -8px; }
@media (max-width: 860px) { .mag-featured { grid-template-columns: 1fr; } .mag-feat-visual { padding: 24px; } .mag-feat-info { padding: 22px; } }

.mag-divider {
  grid-column: 1 / -1; display: flex; align-items: center; gap: 14px; margin: 6px 0;
}
.mag-divider span { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--theme-section-sub); white-space: nowrap; }
.mag-divider::before, .mag-divider::after { content: ''; flex: 1; height: 1px; background: var(--theme-divider); }

/* ============================================================
   LAYOUT: LIST
   ============================================================ */
#layout-root.layout-list .list-wrap { display: flex; flex-direction: column; gap: 14px; max-width: 960px; margin: 0 auto; }

.list-card {
  background: var(--theme-tile-bg); border: 1px solid var(--theme-tile-bd);
  border-radius: 10px; overflow: hidden;
  transition: box-shadow 0.22s, transform 0.22s, border-color 0.22s, background 0.3s;
}
.list-card:hover { box-shadow: 0 4px 22px rgba(0,0,0,0.15); transform: translateX(2px); border-color: var(--theme-tile-bd-h); }

.list-card__row { display: grid; grid-template-columns: 160px 1fr auto; align-items: stretch; }
.list-card__art {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 9px; padding: 18px 14px;
  border-right: 1px solid var(--theme-tile-bd);
  background: var(--theme-tile-head-bg); text-align: center; min-height: 130px;
}
.list-card__info { padding: 16px 20px; display: flex; flex-direction: column; gap: 9px; min-width: 0; }
.list-card__name { font-size: .95rem; font-weight: 700; line-height: 1.25; color: var(--theme-tile-name); }
.list-card__offer-head { font-size: .88rem; font-weight: 700; color: var(--theme-offer-head); line-height: 1.3; }
.list-card__offer-det  { font-size: .74rem; color: var(--theme-offer-detail); line-height: 1.4; }
.list-card__pills { display: flex; flex-wrap: wrap; gap: 5px; }
.list-card__action {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 9px; padding: 18px 18px;
  border-left: 1px solid var(--theme-tile-bd);
  background: var(--theme-tile-foot-bg); min-width: 145px; text-align: center;
}
.list-card__fee { font-size: .76rem; color: var(--theme-meta-text); }
.list-card__fee strong { color: var(--theme-meta-strong); display: block; font-size: .8rem; }
.list-card__action .btn { width: 100%; font-size: .76rem; padding: 8px 12px; }

.list-card__toggle {
  display: flex; align-items: center; gap: 7px; width: 100%; padding: 8px 20px;
  background: none; border: none; border-top: 1px solid var(--theme-tile-bd);
  font-size: .76rem; font-weight: 600; color: var(--theme-toggle-text);
  cursor: pointer; font-family: inherit; transition: background 0.2s;
}
.list-card__toggle:hover { background: var(--theme-toggle-hbg); }
.list-card__toggle .chev { transition: transform 0.25s; }
.list-card__toggle.open .chev { transform: rotate(180deg); }

.list-card__expand { display: none; border-top: 1px solid var(--theme-tile-bd); }
.list-card__expand-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding: 16px 20px; }
.list-card__expand-title { font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--theme-expand-title); margin-bottom: 8px; }

@media (max-width: 640px) {
  .list-card__row { grid-template-columns: 1fr; }
  .list-card__art { flex-direction: row; border-right: none; border-bottom: 1px solid var(--theme-tile-bd); padding: 12px 14px; min-height: auto; justify-content: flex-start; }
  .list-card__action { flex-direction: row; border-left: none; border-top: 1px solid var(--theme-tile-bd); min-width: auto; justify-content: space-between; padding: 12px 14px; }
  .list-card__action .btn { width: auto; }
  .list-card__expand-inner { grid-template-columns: 1fr; }
}

/* ============================================================
   SECTION WRAPPER
   ============================================================ */
.app-section { padding: 40px 0 72px; }

/* ============================================================
   ERROR / FALLBACK
   ============================================================ */
.cards-error-msg {
  text-align: center; padding: 64px 24px;
  color: var(--theme-meta-text, #6B6B6B);
  font-size: 1rem; line-height: 1.6;
}

/* ============================================================
   FOOTER
   ============================================================ */
.app-footer {
  background: var(--theme-footer-bg); color: var(--theme-footer-text);
  margin-top: 40px; padding: 40px 24px 28px;
  transition: background 0.3s;
}
.app-footer__inner { max-width: 1280px; margin: 0 auto; }
.app-footer__logo  { font-weight: 900; font-size: 1rem; color: var(--theme-footer-logo); letter-spacing: -.02em; margin-bottom: 14px; }
.app-footer__links { display: flex; flex-wrap: wrap; gap: 8px 20px; margin-bottom: 22px; }
.app-footer__links a { color: var(--theme-footer-link); font-size: .76rem; transition: color 0.2s; }
.app-footer__links a:hover { color: #fff; }
.app-footer__disc  { font-size: .7rem; line-height: 1.65; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 18px; }
.app-footer__copy  { margin-top: 14px; font-size: .7rem; color: rgba(255,255,255,0.35); }
