:root {
  --cielo-blue: #d4547a;
  --cream: #fffcf7;
  --navy: #003f5f;
  --navy-light: #004f78;
}

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

body { margin: 0; background: var(--cream); font-family: "Poppins", sans-serif; color: #444; }

.container { width: min(1100px, 90%); margin: 0 auto; }

/* ── HEADER ── */
.site-header {
  position: sticky; top: 0;
  background: rgba(255,252,247,.88);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0,0,0,.06);
  z-index: 50;
}
.header-content { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; }
.logo { font-family: "Playfair Display", serif; font-size: 1.4rem; color: var(--navy); text-decoration: none; }
.logo span { color: var(--cielo-blue); }
.main-nav { display: flex; align-items: center; gap: 1.2rem; }
.main-nav a { text-decoration: none; font-size: .85rem; letter-spacing: .08em; color: var(--navy); font-weight: 600; opacity: .7; transition: opacity .2s; }
.main-nav a:hover { opacity: 1; }

.cart-icon-btn {
  background: white;
  border: 2px solid #e8e0d5;
  border-radius: 2rem;
  padding: .4rem 1rem;
  font-size: .9rem;
  cursor: pointer;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  color: var(--navy);
  transition: all .2s;
  display: flex; align-items: center; gap: .4rem;
  position: relative;
}
.cart-icon-btn:hover { border-color: var(--cielo-blue); }

.cart-badge {
  background: var(--cielo-blue);
  color: white;
  font-size: .7rem;
  font-weight: 700;
  min-width: 18px; height: 18px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}

/* ── HERO ── */
.shop-hero {
  position: relative;
  text-align: center;
  padding: 5rem 1rem 4rem;
  overflow: hidden;
  background: linear-gradient(160deg, #ffd6de40, #fff7c230, #cfe8d540);
}
.hero-deco { position: absolute; border-radius: 50%; filter: blur(55px); opacity: .4; pointer-events: none; }
.d1 { width: 320px; height: 320px; background: #ffd6de; top: -80px; left: -60px; }
.d2 { width: 260px; height: 260px; background: #cfe8d5; bottom: -60px; right: -40px; }

.shop-hero h1 { font-family: "Playfair Display", serif; font-size: clamp(2rem, 5vw, 3.2rem); color: var(--navy); margin: 0 0 .8rem; position: relative; }
.shop-hero h1 em { font-style: italic; color: var(--cielo-blue); }
.shop-hero p { font-size: .95rem; opacity: .65; margin: 0 0 1.5rem; position: relative; }

.hero-info-row {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 1rem;
  position: relative;
}
.hero-info-row span {
  background: white;
  border-radius: 2rem;
  padding: .35rem 1rem;
  font-size: .82rem;
  font-weight: 600;
  color: var(--navy);
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
}

/* ── PRODUCTS ── */
.products-section { padding: 5rem 0; }

.section-title {
  font-family: "Playfair Display", serif;
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  color: var(--navy);
  margin: 0 0 2.5rem;
  text-align: center;
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.5rem;
}

.product-card {
  background: white;
  border-radius: 1.8rem;
  padding: 2rem 1.8rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.07);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: .6rem;
  transition: transform .25s, box-shadow .25s;
  position: relative;
}
.product-card:hover { transform: translateY(-6px); box-shadow: 0 14px 36px rgba(0,0,0,.11); }
.product-card.featured { border: 2px solid var(--cielo-blue); }
.product-card.shake-card { background: linear-gradient(135deg, #fff0f3, #ffd6de50); }

.product-badge {
  position: absolute;
  top: -10px; right: 1.2rem;
  background: var(--cielo-blue);
  color: white;
  font-size: .72rem;
  font-weight: 700;
  padding: .2rem .8rem;
  border-radius: 2rem;
  letter-spacing: .06em;
}

.product-emoji { font-size: 2.6rem; }
.product-info h3 { font-family: "Playfair Display", serif; font-size: 1.2rem; color: var(--navy); margin: 0 0 .3rem; }
.product-info p  { font-size: .85rem; opacity: .6; margin: 0; }
.product-price   { font-size: 1.3rem; font-weight: 700; color: var(--cielo-blue); margin-top: .4rem; }

.product-btn {
  margin-top: auto;
  background: var(--navy);
  color: white;
  border: none;
  padding: .75rem 1.6rem;
  border-radius: 2rem;
  font-family: "Poppins", sans-serif;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  text-decoration: none;
  display: inline-block;
}
.product-btn:hover { background: var(--navy-light); transform: translateY(-2px); }

/* ── CART SECTION ── */
.cart-section { padding: 4rem 0; background: #fff8f2; }

.cart-list { display: flex; flex-direction: column; gap: .8rem; margin-bottom: 1.5rem; }

.cart-item {
  background: white;
  border-radius: 1.2rem;
  padding: 1rem 1.4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 4px 14px rgba(0,0,0,.05);
  gap: 1rem;
}
.cart-item-info { display: flex; flex-direction: column; gap: .2rem; flex: 1; }
.cart-item-info strong { font-size: .95rem; color: var(--navy); }
.cart-item-flavors { font-size: .78rem; opacity: .6; }
.cart-item-right { display: flex; align-items: center; gap: .8rem; flex-shrink: 0; }
.cart-item-price { font-weight: 700; color: var(--cielo-blue); font-size: .95rem; }
.cart-remove {
  background: none; border: 1.5px solid #e0d8d0; border-radius: 50%;
  width: 28px; height: 28px;
  cursor: pointer; font-size: .75rem; color: #999;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.cart-remove:hover { background: #fee; border-color: #f99; color: #c55; }

.cart-empty { text-align: center; opacity: .5; font-size: .9rem; padding: 1rem 0; }

.cart-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  border-top: 1px solid #ede8e0;
  flex-wrap: wrap;
  gap: 1rem;
}
.cart-total { font-size: 1.1rem; color: var(--navy); }
.cart-total strong { color: var(--cielo-blue); }

.checkout-btn {
  background: var(--cielo-blue);
  color: white;
  border: none;
  padding: .9rem 2.2rem;
  border-radius: 2rem;
  font-family: "Poppins", sans-serif;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .22s;
  box-shadow: 0 6px 18px rgba(212,84,122,.3);
}
.checkout-btn:hover { transform: translateY(-2px); opacity: .9; }

/* ── CHECKOUT ── */
.checkout-section { padding: 4rem 0 6rem; }

.checkout-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
}
@media (max-width: 700px) { .checkout-grid { grid-template-columns: 1fr; } }

.form-field { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.5rem; }
.form-field label { font-size: .82rem; font-weight: 600; color: var(--navy); letter-spacing: .05em; text-transform: uppercase; }
.form-field input {
  padding: .85rem 1rem;
  border: 2px solid #e8e0d5;
  border-radius: 1rem;
  font-family: "Poppins", sans-serif;
  font-size: .95rem;
  outline: none;
  transition: border-color .2s;
  background: white;
}
.form-field input:focus { border-color: var(--cielo-blue); }

/* Time Wheel */
.time-wheel-wrap {
  position: relative;
  height: 250px;
  border-radius: 1.2rem;
  overflow: hidden;
  border: 2px solid #e8e0d5;
  background: white;
}

.time-wheel {
  height: 100%;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.time-wheel::-webkit-scrollbar { display: none; }

.tw-item {
  height: 50px;
  scroll-snap-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--navy);
  cursor: pointer;
  transition: font-size .15s;
}

.tw-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, white 0%, transparent 32%, transparent 68%, white 100%);
  pointer-events: none;
}

.tw-selector {
  position: absolute;
  top: 50%; left: 8%; right: 8%;
  height: 50px;
  transform: translateY(-50%);
  border-top: 2px solid var(--cielo-blue);
  border-bottom: 2px solid var(--cielo-blue);
  border-radius: 6px;
  pointer-events: none;
}

.time-note { font-size: .78rem; opacity: .55; margin: .5rem 0 0; text-align: center; }
.time-empty { font-size: .9rem; opacity: .6; padding: 1rem 0; text-align: center; }

/* Order Summary */
.order-summary {
  background: white;
  border-radius: 1.8rem;
  padding: 2rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.07);
}
.order-summary h3 { font-family: "Playfair Display", serif; font-size: 1.3rem; color: var(--navy); margin: 0 0 1.2rem; }
.summary-list { display: flex; flex-direction: column; gap: .6rem; margin-bottom: 1.2rem; }
.summary-item { display: flex; justify-content: space-between; font-size: .88rem; }
.summary-total { border-top: 1px solid #ede8e0; padding-top: .8rem; font-size: 1rem; font-weight: 600; color: var(--navy); margin-bottom: 1.4rem; }
.summary-total strong { color: var(--cielo-blue); }

.submit-btn {
  width: 100%;
  background: var(--cielo-blue);
  color: white;
  border: none;
  padding: 1rem;
  border-radius: 2rem;
  font-family: "Poppins", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .22s;
  box-shadow: 0 6px 18px rgba(212,84,122,.3);
}
.submit-btn:hover { opacity: .9; transform: translateY(-2px); }

/* ── CONFIRMATION ── */
.confirm-overlay {
  position: fixed; inset: 0;
  background: rgba(255,252,247,.96);
  backdrop-filter: blur(10px);
  z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: 2rem;
}
.confirm-overlay.hidden { display: none; }

.confirm-box {
  background: white;
  border-radius: 2rem;
  padding: 3rem 2.5rem;
  text-align: center;
  max-width: 500px;
  box-shadow: 0 20px 60px rgba(0,0,0,.12);
}
.confirm-icon { font-size: 4rem; margin-bottom: 1rem; }
.confirm-box h2 { font-family: "Playfair Display", serif; font-size: 1.8rem; color: var(--navy); margin: 0 0 .8rem; }
.confirm-box p { font-size: .9rem; opacity: .75; line-height: 1.7; margin: 0 0 .6rem; }
.confirm-sub { font-size: .82rem; opacity: .5; }

/* ── MODAL ── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
}
.modal-overlay.hidden { display: none; }

.modal-box {
  background: var(--cream);
  border-radius: 2rem;
  padding: 2.5rem 2rem 2rem;
  width: 100%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 24px 60px rgba(0,0,0,.18);
}

.modal-close {
  position: absolute; top: 1.2rem; right: 1.2rem;
  background: white; border: 1.5px solid #e0d8d0;
  border-radius: 50%; width: 36px; height: 36px;
  cursor: pointer; font-size: 1rem; color: var(--navy);
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.modal-close:hover { background: #fee; border-color: #f99; }

.modal-title { font-family: "Playfair Display", serif; font-size: 1.6rem; color: var(--navy); margin: 0 0 .4rem; }
.modal-sub   { font-size: .82rem; opacity: .6; margin: 0 0 1.5rem; }

.modal-slots {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1.5rem;
  min-height: 52px;
}

.mslot {
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 2px dashed #ccc;
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; color: #bbb;
  background: white;
  transition: all .25s;
}

.modal-flavor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: .8rem;
  margin-bottom: 1.8rem;
}

.mflavor-btn {
  position: relative;
  background: var(--fl, #f8f5f0);
  border: 2px solid transparent;
  border-radius: 1.2rem;
  padding: .9rem .7rem;
  cursor: pointer;
  transition: all .2s;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .3rem;
  font-family: "Poppins", sans-serif;
  font-size: .78rem;
  font-weight: 600;
  color: var(--navy);
}
.mflavor-btn:hover:not(:disabled) { transform: translateY(-3px); border-color: var(--fc); }
.mflavor-btn.selected  { border-color: var(--fc); transform: translateY(-3px); box-shadow: 0 6px 16px rgba(0,0,0,.1); }
.mflavor-btn.faded     { opacity: .35; cursor: not-allowed; transform: none; }
.mfb-emoji  { font-size: 1.8rem; }
.mfb-count  {
  position: absolute; top: .4rem; right: .4rem;
  background: var(--fc); color: white;
  font-size: .65rem; font-weight: 700;
  width: 18px; height: 18px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}

.modal-add-btn {
  width: 100%;
  background: var(--cielo-blue);
  color: white;
  border: none;
  padding: 1rem;
  border-radius: 2rem;
  font-family: "Poppins", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .22s;
  box-shadow: 0 6px 18px rgba(212,84,122,.3);
}
.modal-add-btn:hover:not(:disabled) { opacity: .9; transform: translateY(-2px); }
.modal-add-btn:disabled { opacity: .35; cursor: not-allowed; box-shadow: none; transform: none; }

/* ── FOOTER ── */
.site-footer { background: var(--navy); padding: 2rem 0; color: white; text-align: center; }
.footer-content { display: flex; flex-direction: column; gap: .35rem; }
.footer-logo { font-family: "Playfair Display", serif; font-size: 1.3rem; margin: 0; }
.footer-logo span { color: #f7b8ca; }
.footer-note { font-size: .75rem; opacity: .4; margin: 0; }

.hidden { display: none !important; }
