/* ═══════════════════════════════════════════
   PlateBird Landing Page Styles
   (Nav, footer, buttons in style.css)
   ═══════════════════════════════════════════ */

/* HERO */
.hero { text-align: center; padding: 120px clamp(20px, 5vw, 56px) 0; max-width: 1100px; margin: 0 auto; }
.proof-cluster { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 24px; animation: rise 0.6s cubic-bezier(0.16,1,0.3,1) both; }
.proof-faces { display: flex; }
.proof-face { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--linen); margin-left: -7px; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: white; }
.proof-face:first-child { margin-left: 0; }
.proof-face.a { background: var(--ember); } .proof-face.b { background: var(--sage); } .proof-face.c { background: var(--sky); } .proof-face.d { background: var(--plum); }
.proof-label { font-size: 13px; color: var(--ink-muted); font-weight: 500; }
.proof-label strong { color: var(--ink-soft); font-weight: 700; }
.hero h1 { font-family: var(--serif); font-size: clamp(40px, 6vw, 72px); line-height: 1.04; letter-spacing: -0.03em; margin-bottom: 20px; animation: rise 0.6s cubic-bezier(0.16,1,0.3,1) 0.06s both; }
.hero h1 em { font-style: italic; color: var(--ember); }
.hero-sub { font-size: clamp(16px, 2vw, 19px); color: var(--ink-muted); line-height: 1.65; max-width: 500px; margin: 0 auto 32px; animation: rise 0.6s cubic-bezier(0.16,1,0.3,1) 0.12s both; }
.hero-cta { display: inline-flex; align-items: center; gap: 8px; background: var(--ink); color: var(--cream); padding: 16px 36px; border-radius: var(--r-md); font-size: 16px; font-weight: 700; text-decoration: none; transition: all 0.3s cubic-bezier(0.16,1,0.3,1); box-shadow: var(--shadow-sm); animation: rise 0.6s cubic-bezier(0.16,1,0.3,1) 0.18s both; }
.hero-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(26,22,18,0.18); color: var(--cream); }
.hero-note { margin-top: 14px; font-size: 13px; color: var(--ink-faint); animation: rise 0.6s cubic-bezier(0.16,1,0.3,1) 0.22s both; margin-bottom: 0; }

/* ═══ PHONE ═══ */
.hero-device { margin-top: 56px; display: flex; justify-content: center; position: relative; animation: rise 0.8s cubic-bezier(0.16,1,0.3,1) 0.28s both; }
.phone-glow { position: absolute; width: 360px; height: 280px; background: radial-gradient(ellipse, var(--ember-glow), transparent 70%); bottom: -30px; left: 50%; transform: translateX(-50%); filter: blur(40px); }
.device {
  width: 290px;
  height: 629px;
  background: #faf9f6;
  border-radius: 32px;
  overflow: hidden;
  font-family: var(--app);
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 2;
  box-shadow: 0 25px 80px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.06);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: left;
}

/* Status bar */
.d-sb { display: flex; justify-content: space-between; align-items: center; padding: 10px 20px 0; height: 37px; flex-shrink: 0; }
.d-time { font-size: 11px; font-weight: 600; color: #1c1917; letter-spacing: -0.3px; }
.d-si { display: flex; gap: 4px; align-items: center; }
.d-si svg { display: block; }
.d-gap { height: 15px; flex-shrink: 0; }

/* Top nav */
.d-tn { display: flex; align-items: center; justify-content: space-between; padding: 0 20px 6px; flex-shrink: 0; }
.d-brand { font-size: 10.5px; font-weight: 600; color: #1c1917; letter-spacing: -0.4px; }
.d-nr { display: flex; align-items: center; }
.d-div { width: 1px; height: 9px; background: #ddd9d5; margin-right: 7px; }
.d-streak { display: flex; align-items: center; gap: 2px; margin-right: 7px; }
.d-streak-fire { font-size: 8px; line-height: 1; }
.d-streak-num { font-size: 9px; font-weight: 700; color: #ea580c; }
.d-gear { display: flex; align-items: center; justify-content: center; }
.d-gear svg { width: 11px; height: 11px; }

/* Week strip */
.d-ws { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; padding: 0 15px 8px; flex-shrink: 0; border-bottom: 1px solid #f2f0ed; }
.d-wd { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 3px 0; }
.d-wl { font-size: 8.5px; font-weight: 500; color: #c4bfb8; }
.d-wl.today { color: #ea580c; }
.d-wn-wrap { width: 27px; height: 27px; border-radius: 9px; display: flex; align-items: center; justify-content: center; }
.d-wn-wrap.today { background: rgba(234,88,12,0.05); }
.d-wn { font-size: 11.5px; font-weight: 400; color: #c4bfb8; letter-spacing: -0.3px; }
.d-wn.past { font-weight: 500; color: #78716c; }
.d-wn.today { font-weight: 700; color: #ea580c; }
.d-wn.future { color: #ddd9d5; }

/* Content */
.d-ct { flex: 1; padding: 0 20px; overflow: hidden; }
.d-ct-gap { height: 15px; }
.d-rule { height: 1px; background: #ece9e6; }

/* Food entry */
.d-fe { display: flex; justify-content: space-between; align-items: center; padding: 11px 0; border-bottom: 1px solid #f2f0ed; }
.d-fl { display: flex; flex-direction: column; gap: 2px; flex: 1; text-align: left; }
.d-fn { font-size: 11.8px; font-weight: 400; color: #1c1917; letter-spacing: -0.2px; text-align: left; }
.d-fd { font-size: 9.5px; color: #a8a29e; font-weight: 400; letter-spacing: -0.1px; text-align: left; }
.d-fr { display: flex; align-items: baseline; gap: 3px; margin-left: 14px; flex-shrink: 0; }
.d-fc { font-size: 12.5px; font-weight: 600; color: #1c1917; font-variant-numeric: tabular-nums; letter-spacing: -0.3px; }
.d-fu { font-size: 9.5px; color: #a8a29e; font-weight: 400; }

/* Input */
.d-il { margin-top: 3px; padding: 11px 0; min-height: 34px; border-bottom: 1px solid #f2f0ed; display: flex; align-items: center; text-align: left; }
.d-ip { font-size: 11px; color: #c4bfb8; font-weight: 400; text-align: left; }

/* Bottom */
.d-bw { flex-shrink: 0; padding: 0 20px 3px; }
.d-bc { background: #f5f4f1; border-radius: 12px; overflow: hidden; }
.d-br { display: flex; align-items: center; justify-content: space-between; padding: 7px 12px; }
.d-bcal { font-size: 14.8px; font-weight: 700; color: #1c1917; letter-spacing: -0.5px; font-variant-numeric: tabular-nums; }
.d-bg { font-size: 9.5px; color: #a8a29e; font-weight: 400; margin-left: 3px; }
.d-ms { display: flex; align-items: center; gap: 9px; }
.d-m { display: flex; align-items: baseline; gap: 1.5px; }
.d-ml { font-size: 8px; font-weight: 700; }
.d-mv { font-size: 9.5px; font-weight: 500; color: #78716c; font-variant-numeric: tabular-nums; }
.d-bt { height: 3px; background: #e7e5e4; }
.d-bf { height: 100%; background: linear-gradient(90deg, #f59e0b, #f97316, #ef4444); width: 0%; animation: barGrow 1.4s cubic-bezier(0.16,1,0.3,1) 1s forwards; }
@keyframes barGrow { to { width: 81.75%; } }

/* Home bar */
.d-hb { height: 25px; display: flex; justify-content: center; align-items: flex-end; padding-bottom: 6px; flex-shrink: 0; }
.d-hi { width: 99px; height: 4px; background: #1c1917; border-radius: 2px; opacity: 0.15; }

/* ═══ VALUE PROPS ═══ */
.props { max-width: 1100px; margin: 0 auto; padding: 80px clamp(20px, 5vw, 56px) 0; }
.props-label { text-align: center; font-family: var(--serif); font-size: clamp(26px, 3.5vw, 38px); margin-bottom: 40px; letter-spacing: -0.02em; line-height: 1.15; }
.props-label em { font-style: italic; color: var(--ember); }
.props-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.prop { background: var(--cream); border: 1px solid var(--ink-whisper); border-radius: var(--r-lg); padding: 28px 24px; transition: all 0.3s; }
.prop:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: transparent; }
.prop-em { font-size: 28px; margin-bottom: 12px; display: block; }
.prop h3 { font-family: var(--serif); font-size: 18px; margin-bottom: 6px; }
.prop p { font-size: 14px; color: var(--ink-muted); line-height: 1.6; margin-bottom: 0; }

/* ═══ REVIEWS ═══ */
.reviews { padding: 80px 0 0; overflow: hidden; }
.reviews-title { text-align: center; font-family: var(--serif); font-size: clamp(24px, 3vw, 34px); margin-bottom: 36px; padding: 0 clamp(20px, 5vw, 56px); letter-spacing: -0.02em; }
.reviews-track { display: flex; gap: 16px; animation: scroll 30s linear infinite; width: max-content; padding: 0 0 4px; }
.reviews-track:hover { animation-play-state: paused; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.rev { background: var(--cream); border: 1px solid var(--ink-whisper); border-radius: var(--r-lg); padding: 24px; width: 300px; flex-shrink: 0; }
.rev-stars { color: #E8A830; font-size: 14px; letter-spacing: 1px; margin-bottom: 12px; }
.rev-text { font-size: 14px; color: var(--ink-soft); line-height: 1.65; margin-bottom: 16px; }
.rev-who { display: flex; align-items: center; gap: 10px; }
.rev-av { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: white; }
.rev-av.a { background: var(--ember); } .rev-av.b { background: var(--sage); } .rev-av.c { background: var(--sky); } .rev-av.d { background: var(--plum); } .rev-av.e { background: #D4794B; }
.rev-name { font-size: 13px; font-weight: 600; }
.rev-note { font-size: 11px; color: var(--ink-faint); }

/* ═══ BOTTOM CTA ═══ */
.bottom-cta { max-width: 1100px; margin: 0 auto; padding: 80px clamp(20px, 5vw, 56px) 80px; }
.cta-card { background: var(--ink); border-radius: var(--r-xl); padding: clamp(48px, 6vw, 72px) clamp(24px, 4vw, 56px); text-align: center; position: relative; overflow: hidden; }
.cta-card::before { content: ''; position: absolute; top: -100px; left: 50%; transform: translateX(-50%); width: 500px; height: 500px; background: radial-gradient(circle, rgba(232,106,51,0.15), transparent 60%); border-radius: 50%; pointer-events: none; }
.cta-rating { position: relative; z-index: 2; margin-bottom: 24px; }
.cta-stars { font-size: 24px; color: #E8A830; letter-spacing: 3px; }
.cta-rating-text { font-size: 14px; color: rgba(255,255,255,0.45); margin-top: 6px; }
.cta-rating-text strong { color: rgba(255,255,255,0.7); }
.cta-card h2 { font-family: var(--serif); font-size: clamp(30px, 4vw, 46px); color: white; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 14px; position: relative; z-index: 2; }
.cta-card h2 em { font-style: italic; color: var(--ember); }
.cta-card .cta-sub { color: rgba(255,255,255,0.4); font-size: 16px; line-height: 1.6; margin-bottom: 32px; position: relative; z-index: 2; }

/* ═══ ANIMATIONS ═══ */
@keyframes rise { from { opacity:0; transform: translateY(16px); } to { opacity:1; transform: translateY(0); } }
.reveal { opacity:0; transform: translateY(20px); transition: all 0.6s cubic-bezier(0.16,1,0.3,1); }
.reveal.vis { opacity:1; transform: translateY(0); }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 768px) {
  .hero { padding: 100px 20px 0; }
  .device { width: 250px; height: 542px; border-radius: 28px; }
  .props-grid { grid-template-columns: 1fr; gap: 12px; }
  .props { padding: 60px 20px 0; }
  .reviews { padding: 60px 0 0; }
  .bottom-cta { padding: 60px 20px 60px; }
}
