/* ============================================================
   SWEETDEALS.CO.NZ — DESIGN SYSTEM v2
   Full dark mode on every component
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800;900&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600&display=swap');

/* ── TOKENS ────────────────────────────────────────────────── */
:root {
  --forest:      #1A4D1A; --grove:  #2E7D32; --fern:  #4CAF50;
  --lime:        #8BC34A; --mint:   #C8E6C9;
  --gold:        #FFB300; --gold-lt:#FFD54F; --gold-dk:#E65100;
  --cherry:      #E53935; --candy:  #FF6D00; --teal:  #00897B;
  --snow:        #FAFCF8; --parchment:#F2F5EE; --mist:#E8EDDF;
  --ink:         #1C2B1E; --slate:  #3D4F41; --stone: #7A8C7D;
  --cloud:       #B8C9BC; --white:  #FFFFFF;
  --space-xs:4px; --space-sm:8px; --space-md:16px;
  --space-lg:24px; --space-xl:40px; --space-2xl:64px;
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:100px;
  --shadow-sm:0 2px 8px rgba(26,77,26,.08);
  --shadow-md:0 6px 24px rgba(26,77,26,.12);
  --shadow-lg:0 16px 48px rgba(26,77,26,.18);
  --shadow-gold:0 8px 32px rgba(255,179,0,.30);
  --shadow-card:0 4px 16px rgba(26,77,26,.10);
  --ease:cubic-bezier(.4,0,.2,1); --ease-b:cubic-bezier(.34,1.56,.64,1);
  --t-fast:.15s; --t-med:.25s; --t-slow:.4s;
  /* Semantic surface tokens — these flip in dark mode */
  --bg:          var(--snow);
  --bg-alt:      var(--parchment);
  --bg-card:     var(--white);
  --bg-input:    var(--white);
  --border:      var(--mist);
  --text:        var(--ink);
  --text-muted:  var(--stone);
  --text-sub:    var(--slate);
}

[data-theme="dark"] {
  --bg:          #0f1a10;
  --bg-alt:      #151f16;
  --bg-card:     #1a2b1b;
  --bg-input:    #1e2e1f;
  --border:      #2a3c2d;
  --text:        #e8f0e9;
  --text-muted:  #7a9c7d;
  --text-sub:    #a8b9aa;
  --snow:        #0f1a10;
  --parchment:   #151f16;
  --mist:        #2a3c2d;
  --ink:         #e8f0e9;
  --slate:       #a8b9aa;
  --stone:       #6b7e6d;
  --white:       #1a2b1b;
  --shadow-sm:   0 2px 8px rgba(0,0,0,.35);
  --shadow-md:   0 6px 24px rgba(0,0,0,.45);
  --shadow-lg:   0 16px 48px rgba(0,0,0,.55);
  --shadow-card: 0 4px 16px rgba(0,0,0,.4);
}

/* ── RESET ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden;
  transition:background var(--t-med) var(--ease), color var(--t-med) var(--ease);
}
img{max-width:100%;height:auto;display:block;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;font-family:inherit;}
input,textarea,select{font-family:inherit;}

/* ── LAYOUT ────────────────────────────────────────────────── */
.container       {max-width:1140px;margin:0 auto;padding:0 var(--space-lg);}
.container-wide  {max-width:1400px;margin:0 auto;padding:0 var(--space-lg);}
.container-narrow{max-width:720px;margin:0 auto;padding:0 var(--space-lg);}
.section    {padding:var(--space-2xl) 0;}
.section-sm {padding:var(--space-xl) 0;}
.section-bg {background:var(--bg-alt);}
.section-dark{background:linear-gradient(135deg,var(--forest),#1e6020);color:#fff;}

/* ── TYPOGRAPHY ────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:'Nunito',sans-serif;line-height:1.2;color:var(--text);}
.display-title{font-family:'Fredoka One',cursive;font-size:clamp(28px,4vw,42px);color:var(--forest);}
.section-title{font-family:'Fredoka One',cursive;font-size:clamp(24px,3vw,36px);color:var(--forest);
  margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm);}
[data-theme="dark"] .display-title,
[data-theme="dark"] .section-title{color:var(--gold-lt);}
.section-sub{color:var(--text-muted);font-size:15px;margin-bottom:var(--space-xl);}

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);
  padding:13px 24px;border-radius:var(--r-pill);font-family:'DM Sans',sans-serif;
  font-weight:800;font-size:14.5px;letter-spacing:.1px;border:none;cursor:pointer;
  transition:all var(--t-med) var(--ease);white-space:nowrap;position:relative;overflow:hidden;
  -webkit-tap-highlight-color:transparent;
}
.btn::after{content:'';position:absolute;inset:0;background:#fff;opacity:0;transition:opacity var(--t-fast);}
.btn:hover::after{opacity:.12;}
.btn:active{transform:scale(.97);}
.btn-gold{background:var(--gold);color:var(--forest);box-shadow:var(--shadow-gold);}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px);}
.btn-forest{background:var(--forest);color:#fff;box-shadow:var(--shadow-md);}
.btn-forest:hover{background:var(--grove);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--forest);border:2px solid var(--forest);}
.btn-outline:hover{background:var(--forest);color:#fff;}
[data-theme="dark"] .btn-outline{color:var(--gold-lt);border-color:var(--gold-lt);}
[data-theme="dark"] .btn-outline:hover{background:var(--gold-lt);color:var(--forest);}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.3);backdrop-filter:blur(8px);}
.btn-ghost:hover{background:rgba(255,255,255,.22);}
.btn-danger{background:var(--cherry);color:#fff;}
.btn-danger:hover{background:#c62828;}
.btn-sm{padding:8px 16px;font-size:13px;}
.btn-lg{padding:16px 32px;font-size:17px;}
.btn-xl{padding:20px 40px;font-size:18px;}
.btn-full{width:100%;}
@keyframes pulse-ring{
  0%{box-shadow:0 0 0 0 rgba(255,179,0,.5),var(--shadow-gold);}
  70%{box-shadow:0 0 0 14px rgba(255,179,0,0),var(--shadow-gold);}
  100%{box-shadow:0 0 0 0 rgba(255,179,0,0),var(--shadow-gold);}
}
.btn-pulse{animation:pulse-ring 2.2s ease-in-out infinite;}

/* ── BADGES ────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;padding:3px 10px;
  border-radius:var(--r-pill);font-family:'Nunito',sans-serif;
  font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;
}
.badge-hot{background:var(--candy);color:#fff;}
.badge-new{background:var(--teal);color:#fff;}
.badge-expiring{background:var(--cherry);color:#fff;}
.badge-coupon{background:var(--forest);color:var(--gold-lt);}
.badge-cashback{background:var(--lime);color:var(--forest);}
.badge-freebie{background:var(--teal);color:#fff;}
.badge-verified{background:var(--mint);color:var(--forest);}
.badge-featured{background:var(--gold);color:var(--forest);}
.badge-sale{background:var(--cherry);color:#fff;}

/* ── DEAL CARD ─────────────────────────────────────────────── */
.deal-card{
  background:var(--bg-card);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-card);border:1.5px solid transparent;
  transition:transform var(--t-med) var(--ease),box-shadow var(--t-med),border-color var(--t-med);
  display:flex;flex-direction:column;position:relative;
}
.deal-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold);}
.deal-card.deal-expired{opacity:.55;}
.deal-card__img-link{display:block;}
.deal-card__img{
  position:relative;height:160px;
  background:linear-gradient(135deg,#e8f5e9,#f1f8e9);overflow:hidden;flex-shrink:0;
}
[data-theme="dark"] .deal-card__img{background:linear-gradient(135deg,#1a2e1a,#1e341e);}
.deal-card__badge{position:absolute;top:10px;left:10px;z-index:2;}
.deal-card__image{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit;}
.deal-card__emoji{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:56px;transition:transform var(--t-slow) var(--ease-b);
}
.deal-card:hover .deal-card__emoji{transform:scale(1.1);}
.deal-card__saving{
  position:absolute;top:10px;right:10px;background:var(--cherry);color:#fff;
  font-family:'Fredoka One',cursive;font-size:17px;min-width:50px;height:50px;
  border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  line-height:1;box-shadow:0 4px 12px rgba(229,57,53,.4);z-index:2;
}
.deal-card__saving span{font-family:'DM Sans';font-size:9px;font-weight:600;opacity:.9;}
.deal-card__body{padding:var(--space-md);display:flex;flex-direction:column;flex:1;gap:8px;}
.deal-card__store{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;}
.deal-card__title{
  font-family:'Nunito',sans-serif;font-weight:700;font-size:15px;color:var(--text);
  line-height:1.35;flex:1;display:block;
}
.deal-card__title:hover{color:var(--grove);}
[data-theme="dark"] .deal-card__title:hover{color:var(--gold-lt);}
.deal-card__price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;}
.price-now{font-family:'Fredoka One',cursive;font-size:24px;color:var(--grove);}
[data-theme="dark"] .price-now{color:var(--fern);}
.price-was{font-size:14px;color:var(--text-muted);text-decoration:line-through;}
.price-save{font-family:'Nunito',sans-serif;font-weight:700;font-size:11px;
  background:var(--lime);color:var(--forest);padding:2px 8px;border-radius:var(--r-pill);}
.deal-card__timer{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--cherry);}
.deal-card__timer.urgent{animation:urgency 1s ease-in-out infinite;}
@keyframes urgency{0%,100%{color:var(--cherry);}50%{color:var(--candy);}}
.deal-card__social{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);}
.deal-card__trust{text-align:center;font-size:10px;color:var(--text-muted);}

/* ── CODE BOX ──────────────────────────────────────────────── */
.code-box{
  display:flex;align-items:center;justify-content:space-between;
  border:2px dashed var(--gold);border-radius:var(--r-sm);padding:9px 12px;
  background:rgba(255,179,0,.08);cursor:pointer;
  transition:all var(--t-fast);user-select:none;
}
[data-theme="dark"] .code-box{background:rgba(255,179,0,.06);}
.code-box:hover{border-color:var(--grove);background:rgba(46,125,50,.08);}
.code-box.copied{border-style:solid;border-color:var(--grove);background:rgba(46,125,50,.1);}
.code-box__text{font-family:'Courier New',monospace;font-weight:700;font-size:14px;
  color:var(--forest);letter-spacing:2px;}
[data-theme="dark"] .code-box__text{color:var(--gold-lt);}
.code-box__action{font-family:'Nunito',sans-serif;font-weight:700;font-size:11px;
  color:var(--grove);flex-shrink:0;}
[data-theme="dark"] .code-box__action{color:var(--fern);}

/* ── COUNTDOWN ─────────────────────────────────────────────── */
.countdown{display:flex;align-items:center;gap:5px;}
.countdown__unit{
  background:var(--forest);color:#fff;border-radius:var(--r-sm);
  padding:4px 8px;text-align:center;min-width:38px;
  transition:background var(--t-fast);
}
.countdown__unit.urgent{background:var(--cherry);}
.countdown__num{font-family:'Fredoka One',cursive;font-size:16px;line-height:1;display:block;}
.countdown__label{font-size:9px;opacity:.7;text-transform:uppercase;letter-spacing:.3px;}
.countdown__sep{color:var(--cherry);font-weight:700;font-size:16px;}

/* ── TRUST BAR ─────────────────────────────────────────────── */
.trust-bar{background:var(--bg-card);border-bottom:1px solid var(--border);}
.trust-bar__inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;padding:12px 0;}
.trust-item{display:flex;align-items:center;gap:6px;padding:6px 20px;
  font-size:13px;font-weight:600;color:var(--text-sub);border-right:1px solid var(--border);}
.trust-item:last-child{border-right:none;}
.trust-item__icon{font-size:14px;}

/* ── ANNOUNCE BAR ──────────────────────────────────────────── */
.announce-bar{background:var(--gold);color:var(--forest);padding:10px var(--space-lg);
  text-align:center;font-family:'Nunito',sans-serif;font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;gap:var(--space-md);position:relative;}
.announce-bar__close{position:absolute;right:var(--space-md);top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.1);border:none;width:26px;height:26px;border-radius:50%;cursor:pointer;
  font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--forest);
  transition:background var(--t-fast);}
.announce-bar__close:hover{background:rgba(0,0,0,.2);}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.5);opacity:.6;}}
.announce-bar__pulse{width:8px;height:8px;background:var(--cherry);border-radius:50%;animation:pulse 1.5s infinite;flex-shrink:0;}

/* ── CATEGORY CARD ─────────────────────────────────────────── */
.cat-card{
  background:var(--bg-card);border-radius:var(--r-lg);padding:28px 16px;
  text-align:center;cursor:pointer;border:2px solid transparent;
  box-shadow:var(--shadow-sm);display:block;color:inherit;
  transition:all var(--t-med) var(--ease);
}
.cat-card:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:var(--shadow-gold);}
.cat-card__icon{font-size:40px;margin-bottom:12px;display:block;transition:transform var(--t-slow) var(--ease-b);}
.cat-card:hover .cat-card__icon{transform:scale(1.15);}
.cat-card__name{font-family:'Nunito',sans-serif;font-weight:700;font-size:14px;color:var(--forest);margin-bottom:4px;}
[data-theme="dark"] .cat-card__name{color:var(--gold-lt);}
.cat-card__count{font-size:12px;color:var(--text-muted);}

/* ── FILTER BAR ────────────────────────────────────────────── */
.filter-bar{
  background:var(--bg-card);border-radius:var(--r-lg);padding:16px var(--space-lg);
  margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);
  display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap;
}
.filter-tabs{display:flex;gap:6px;flex-wrap:wrap;}
.filter-tab{
  padding:7px 16px;border-radius:var(--r-pill);font-family:'Nunito',sans-serif;
  font-weight:700;font-size:13px;cursor:pointer;border:1.5px solid var(--border);
  color:var(--text-sub);background:var(--bg-alt);transition:all var(--t-fast);
}
.filter-tab:hover,.filter-tab.active{background:var(--forest);color:#fff;border-color:var(--forest);}
.filter-select{
  border:1.5px solid var(--border);border-radius:var(--r-sm);padding:8px 32px 8px 14px;
  font-family:'Nunito',sans-serif;font-weight:600;font-size:13px;
  color:var(--text-sub);background:var(--bg-card);cursor:pointer;outline:none;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%237A8C7D' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
}
.filter-select:focus{border-color:var(--gold);}
.filter-sort{margin-left:auto;}

/* ── GRIDS ─────────────────────────────────────────────────── */
.deals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);}
.deals-grid-3{grid-template-columns:repeat(3,1fr);}
.category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-md);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md);}

/* ── SKELETON ──────────────────────────────────────────────── */
@keyframes shimmer{0%{background-position:-600px 0;}100%{background-position:600px 0;}}
.skeleton-block{
  background:linear-gradient(90deg,var(--border) 25%,var(--bg-alt) 50%,var(--border) 75%);
  background-size:1200px 100%;animation:shimmer 2s infinite linear;border-radius:var(--r-sm);
}

/* ── MODAL / POPUP ─────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  z-index:1000;display:flex;align-items:center;justify-content:center;
  padding:var(--space-lg);opacity:0;pointer-events:none;transition:opacity var(--t-med);
}
.modal-overlay.active{opacity:1;pointer-events:all;}
.modal{
  background:var(--bg-card);border-radius:var(--r-xl);max-width:480px;width:100%;
  overflow:hidden;transform:scale(.9) translateY(24px);
  transition:transform .35s var(--ease-b);box-shadow:0 32px 80px rgba(0,0,0,.35);
  border:1px solid var(--border);
}
.modal-overlay.active .modal{transform:scale(1) translateY(0);}
.modal__header{
  background:linear-gradient(135deg,var(--forest),var(--grove));
  padding:var(--space-xl) var(--space-xl) var(--space-lg);text-align:center;position:relative;
}
.modal__close{
  position:absolute;top:14px;right:14px;width:32px;height:32px;
  background:rgba(255,255,255,.15);border:none;border-radius:50%;color:#fff;
  font-size:16px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--t-fast);
}
.modal__close:hover{background:rgba(255,255,255,.25);}
.modal__body{padding:var(--space-xl);}

/* ── TOAST ─────────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:var(--space-lg);right:var(--space-lg);
  z-index:2000;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none;}
.toast{
  background:var(--forest);color:#fff;padding:12px var(--space-lg);
  border-radius:var(--r-md);font-family:'Nunito',sans-serif;font-weight:700;font-size:14px;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-sm);
  transform:translateX(120%);transition:transform .35s var(--ease-b);pointer-events:all;
}
[data-theme="dark"] .toast{background:#1a3d1b;border:1px solid var(--border);}
.toast.show{transform:translateX(0);}
.toast.success{border-left:4px solid var(--gold);}
.toast.error{border-left:4px solid var(--cherry);}

/* ── STICKY MOBILE BAR ─────────────────────────────────────── */
.sticky-bar{
  position:fixed;bottom:0;left:0;right:0;background:var(--forest);
  padding:12px var(--space-lg) calc(12px + env(safe-area-inset-bottom));
  z-index:90;display:none;align-items:center;gap:var(--space-md);
  box-shadow:0 -4px 24px rgba(0,0,0,.25);
}
@media(max-width:768px){.sticky-bar{display:flex;}}
.sticky-bar__deal{flex:1;color:#fff;}
.sticky-bar__name{font-family:'Nunito';font-weight:800;font-size:14px;}
.sticky-bar__save{font-size:12px;color:var(--gold-lt);}

/* ── FORMS ─────────────────────────────────────────────────── */
.form-group{margin-bottom:var(--space-md);}
.form-label{display:block;font-family:'Nunito',sans-serif;font-weight:700;font-size:14px;
  color:var(--text);margin-bottom:6px;}
.form-input,.form-textarea,.form-select{
  width:100%;border:2px solid var(--border);border-radius:var(--r-md);
  padding:12px 16px;font-size:15px;color:var(--text);background:var(--bg-input);
  outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form-input:focus,.form-textarea:focus,.form-select:focus{
  border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,179,0,.15);
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted);}
.form-textarea{resize:vertical;min-height:100px;}
.form-select{appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%237A8C7D' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;}
.form-error{font-size:12px;color:var(--cherry);margin-top:4px;display:none;}
.form-input.invalid{border-color:var(--cherry);}
.form-input.invalid + .form-error{display:block;}

/* ── SEARCH BAR ────────────────────────────────────────────── */
.search-bar{display:flex;background:var(--bg-card);border-radius:var(--r-pill);overflow:hidden;
  box-shadow:var(--shadow-lg);border:2px solid transparent;transition:border-color var(--t-fast);}
.search-bar:focus-within{border-color:var(--gold);}
.search-bar input{flex:1;border:none;outline:none;padding:16px var(--space-lg);
  font-size:15px;background:transparent;color:var(--text);}
.search-bar input::placeholder{color:var(--text-muted);}
.search-bar button{background:var(--gold);border:none;padding:0 var(--space-lg);
  font-family:'Nunito',sans-serif;font-weight:800;font-size:14px;color:var(--forest);
  transition:background var(--t-fast);white-space:nowrap;}
.search-bar button:hover{background:var(--gold-lt);}

/* Search dropdown */
.search-results-dropdown{
  position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:320px;
  background:var(--bg-card);border-radius:var(--r-md);box-shadow:var(--shadow-lg);
  z-index:200;display:none;overflow:hidden;border:1px solid var(--border);
}
.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;
  border-bottom:1px solid var(--border);color:var(--text);transition:background var(--t-fast);}
.search-result-item:last-child{border-bottom:none;}
.search-result-item:hover{background:var(--bg-alt);}
.search-result-emoji{font-size:22px;flex-shrink:0;}
.search-result-info{flex:1;min-width:0;}
.search-result-title{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.search-result-meta{font-size:12px;color:var(--text-muted);}
.search-result-price{font-family:'Fredoka One',cursive;color:var(--grove);flex-shrink:0;}
[data-theme="dark"] .search-result-price{color:var(--fern);}
.search-no-results{padding:20px;text-align:center;color:var(--text-muted);font-size:14px;}

/* ── SCROLL REVEAL ─────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ── PAGINATION ────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:var(--space-xl);}

/* ── UTILITY ───────────────────────────────────────────────── */
.text-center{text-align:center;} .text-right{text-align:right;}
.text-gold{color:var(--gold);} .text-forest{color:var(--forest);}
.text-cherry{color:var(--cherry);} .text-muted{color:var(--text-muted);}
.font-bold{font-weight:700;} .font-black{font-weight:900;}
.mt-sm{margin-top:var(--space-sm);} .mt-md{margin-top:var(--space-md);}
.mt-lg{margin-top:var(--space-lg);} .mb-md{margin-bottom:var(--space-md);}
.flex{display:flex;} .flex-center{display:flex;align-items:center;justify-content:center;}
.flex-between{display:flex;align-items:center;justify-content:space-between;}
.gap-sm{gap:var(--space-sm);} .gap-md{gap:var(--space-md);}
.hidden{display:none!important;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:1024px){
  .deals-grid{grid-template-columns:repeat(3,1fr);}
  .category-grid{grid-template-columns:repeat(4,1fr);}
}
@media(max-width:768px){
  .deals-grid,.deals-grid-3{grid-template-columns:repeat(2,1fr);}
  .category-grid{grid-template-columns:repeat(3,1fr);}
  .blog-grid{grid-template-columns:1fr;}
  .trust-item{border-right:none;border-bottom:1px solid var(--border);}
  .section-header{flex-direction:column;align-items:flex-start;}
  :root{--space-2xl:48px;--space-xl:32px;}
}
@media(max-width:480px){
  .deals-grid,.deals-grid-3{grid-template-columns:1fr;}
  .category-grid{grid-template-columns:repeat(2,1fr);}
  .btn-lg{padding:14px 24px;font-size:16px;}
  .container{padding:0 16px;}
}
