:root{
  --espresso:#2A2018;
  --espresso-soft:#6f6256;
  --cream:#FBF6EE;
  --cream-2:#F3E9DA;
  --cream-3:#ecdfca;
  --terracotta:#C0552E;
  --terracotta-2:#E07A3F;
  --gold:#D7A24B;
  --green:#5a7d52;
  --white:#fff;
  --shadow:0 10px 35px rgba(42,32,24,.12);
  --shadow-lg:0 20px 60px rgba(42,32,24,.18);
  --radius:18px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--espresso);background:var(--cream);line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.serif{font-family:"Playfair Display",Georgia,serif}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(251,246,238,.85);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--cream-3);
  transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{box-shadow:0 6px 24px rgba(42,32,24,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:16px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.35rem;letter-spacing:-.01em}
.logo .dot{width:12px;height:12px;border-radius:50%;background:var(--terracotta);box-shadow:0 0 0 4px rgba(192,85,46,.18)}
.logo b{color:var(--terracotta)}
.header-actions{display:flex;align-items:center;gap:14px}
.btn{
  display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;
  font-weight:600;font-family:inherit;font-size:.95rem;padding:11px 20px;border-radius:999px;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--terracotta);color:#fff;box-shadow:0 8px 20px rgba(192,85,46,.28)}
.btn-primary:hover{background:#a8481f;transform:translateY(-2px);box-shadow:0 12px 26px rgba(192,85,46,.36)}
.btn-ghost{background:transparent;color:var(--espresso);border:1.5px solid var(--cream-3)}
.btn-ghost:hover{border-color:var(--terracotta);color:var(--terracotta)}
.btn-block{width:100%;justify-content:center}
.btn-lg{padding:15px 30px;font-size:1.05rem}
.cart-btn{position:relative}
.cart-badge{
  position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;
  background:var(--gold);color:#2A2018;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;
}
.user-chip{font-size:.9rem;color:var(--espresso-soft);display:flex;align-items:center;gap:8px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:72px 0 90px}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(900px 500px at 85% -10%,rgba(215,162,75,.22),transparent 60%),
    radial-gradient(700px 500px at -5% 110%,rgba(192,85,46,.16),transparent 60%),
    linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%);
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--cream-3);
  color:var(--terracotta);font-weight:600;font-size:.82rem;padding:7px 14px;border-radius:999px;
  text-transform:uppercase;letter-spacing:.08em;box-shadow:var(--shadow)
}
.eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--terracotta);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(192,85,46,.5)}70%{box-shadow:0 0 0 10px rgba(192,85,46,0)}100%{box-shadow:0 0 0 0 rgba(192,85,46,0)}}
.hero h1{font-size:clamp(2.3rem,5vw,3.7rem);line-height:1.05;margin:.5em 0 .3em;font-weight:800;letter-spacing:-.02em}
.hero h1 .accent{color:var(--terracotta);position:relative}
.hero p.lead{font-size:1.18rem;color:var(--espresso-soft);max-width:33ch;margin:0 0 28px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;margin-top:34px}
.hero-stats .num{font-size:1.6rem;font-weight:800;color:var(--espresso)}
.hero-stats .lbl{font-size:.82rem;color:var(--espresso-soft)}
.hero-visual{position:relative}
.hero-card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:18px;
  transform:rotate(-2deg);transition:transform .5s var(--ease)
}
.hero-card:hover{transform:rotate(0)}
.hero-card img{border-radius:12px;aspect-ratio:4/3;object-fit:cover;width:100%}
.hero-float{
  position:absolute;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:12px 16px;
  font-weight:700;display:flex;align-items:center;gap:10px;animation:float 4s ease-in-out infinite
}
.hero-float.f1{top:-18px;right:-10px}
.hero-float.f2{bottom:-20px;left:-16px;animation-delay:1.5s}
.hero-float .ico{font-size:1.4rem}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ---------- Section heads ---------- */
.section{padding:64px 0}
.section-head{text-align:center;max-width:620px;margin:0 auto 44px}
.section-head .eyebrow{margin-bottom:14px}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:.2em 0;font-weight:800;letter-spacing:-.02em}
.section-head p{color:var(--espresso-soft);font-size:1.05rem;margin:0}

/* ---------- Offers grid ---------- */
.offers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:26px}
.offer-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column;position:relative;
  opacity:0;transform:translateY(24px);transition:transform .55s var(--ease),box-shadow .35s,opacity .55s var(--ease)
}
.offer-card.in{opacity:1;transform:none}
.offer-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.offer-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.offer-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.offer-card:hover .offer-media img{transform:scale(1.07)}
.offer-media .no-img{display:flex;align-items:center;justify-content:center;height:100%;font-size:3rem;opacity:.35}
.badge-deal{
  position:absolute;top:12px;left:12px;background:var(--terracotta);color:#fff;font-weight:700;
  font-size:.78rem;padding:6px 12px;border-radius:999px;box-shadow:0 6px 14px rgba(192,85,46,.35);
  display:flex;align-items:center;gap:6px;z-index:2
}
.badge-save{
  position:absolute;top:12px;right:12px;background:var(--gold);color:#2A2018;font-weight:800;
  font-size:.8rem;padding:6px 11px;border-radius:10px;z-index:2
}
.offer-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.offer-cat{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);font-weight:700}
.offer-name{font-size:1.12rem;font-weight:700;margin:6px 0 6px;line-height:1.25}
.offer-desc{font-size:.9rem;color:var(--espresso-soft);margin:0 0 16px;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.offer-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.price{display:flex;flex-direction:column;line-height:1.1}
.price .now{font-size:1.4rem;font-weight:800;color:var(--espresso)}
.price .old{font-size:.85rem;color:var(--espresso-soft);text-decoration:line-through}
.add-btn{
  background:var(--espresso);color:#fff;border:0;border-radius:12px;width:46px;height:46px;cursor:pointer;
  font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:transform .2s var(--ease),background .2s
}
.add-btn:hover{background:var(--terracotta);transform:scale(1.08)}
.add-btn.added{background:var(--green)}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:#fff;border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow);text-align:center}
.step .n{width:48px;height:48px;border-radius:50%;background:var(--cream-2);color:var(--terracotta);
  font-weight:800;font-size:1.3rem;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.step h3{margin:.2em 0;font-size:1.15rem}
.step p{color:var(--espresso-soft);font-size:.92rem;margin:0}

/* ---------- Cart drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(42,32,24,.45);opacity:0;visibility:hidden;transition:.3s;z-index:90}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;height:100%;width:min(420px,100%);background:var(--cream);z-index:100;
  transform:translateX(100%);transition:transform .35s var(--ease);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)
}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:22px;border-bottom:1px solid var(--cream-3)}
.drawer-head h3{margin:0;font-size:1.25rem}
.drawer-close{background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--espresso-soft)}
.drawer-body{flex:1;overflow-y:auto;padding:16px 22px}
.drawer-foot{padding:22px;border-top:1px solid var(--cream-3);background:#fff}
.drawer-empty{text-align:center;color:var(--espresso-soft);padding:50px 0}
.cart-line{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--cream-3)}
.cart-line img{width:64px;height:64px;border-radius:10px;object-fit:cover;background:var(--cream-2)}
.cart-line .info{flex:1}
.cart-line .nm{font-weight:600;font-size:.95rem}
.cart-line .pr{color:var(--terracotta);font-weight:700;font-size:.9rem}
.qty{display:inline-flex;align-items:center;gap:0;border:1px solid var(--cream-3);border-radius:10px;overflow:hidden;margin-top:6px}
.qty button{background:#fff;border:0;width:30px;height:30px;cursor:pointer;font-size:1.1rem;color:var(--espresso)}
.qty button:hover{background:var(--cream-2)}
.qty span{min-width:34px;text-align:center;font-weight:600}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:1.05rem}
.cart-total b{font-size:1.5rem}

/* ---------- Forms / auth ---------- */
.auth-wrap{min-height:calc(100vh - 74px);display:flex;align-items:center;justify-content:center;padding:40px 20px}
.card-panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:38px;width:100%;max-width:440px}
.card-panel h1{margin:0 0 6px;font-size:1.7rem}
.card-panel .sub{color:var(--espresso-soft);margin:0 0 26px;font-size:.95rem}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:6px}
.field input,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--cream-3);border-radius:12px;font:inherit;background:var(--cream);
  transition:border .2s,box-shadow .2s
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--terracotta);box-shadow:0 0 0 4px rgba(192,85,46,.12);background:#fff}
.alert{padding:13px 16px;border-radius:12px;font-size:.92rem;margin-bottom:18px}
.alert-err{background:#fdecec;color:#a02020;border:1px solid #f5c6c6}
.alert-ok{background:#e7f3ec;color:#2f6b3f;border:1px solid #bfe0c8}
.muted{color:var(--espresso-soft);font-size:.88rem}
.center{text-align:center}

/* ---------- Checkout ---------- */
.checkout-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:34px;align-items:start}
.summary{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;position:sticky;top:96px}
.summary h3{margin:0 0 16px}
.sum-line{display:flex;justify-content:space-between;padding:9px 0;font-size:.93rem;border-bottom:1px solid var(--cream-2)}
.sum-total{display:flex;justify-content:space-between;margin-top:16px;font-size:1.2rem;font-weight:800}
.pay-note{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--espresso-soft);margin-top:14px}

/* ---------- Footer ---------- */
.site-footer{background:var(--espresso);color:var(--cream-2);margin-top:70px;padding:52px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:34px}
.site-footer h4{color:#fff;margin:0 0 14px;font-size:1rem}
.site-footer a,.site-footer p{color:rgba(251,246,238,.7);font-size:.9rem;margin:6px 0;display:block}
.site-footer a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:.82rem;color:rgba(251,246,238,.55);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- Toast ---------- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--espresso);color:#fff;
  padding:14px 22px;border-radius:14px;box-shadow:var(--shadow-lg);font-weight:600;opacity:0;visibility:hidden;
  transition:.3s var(--ease);z-index:200;display:flex;align-items:center;gap:10px
}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-visual{order:-1;max-width:420px;margin:0 auto}
  .checkout-grid{grid-template-columns:1fr}
  .summary{position:static}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .hide-mobile{display:none}
}
