/* PricedPerLb v1.3 — design system */
:root{
  --ppl-primary:#1F6B52;
  --ppl-primary-soft:#DDE8E2;
  --ppl-accent:#E7A93B;
  --ppl-bg:#F7F8F6;
  --ppl-text:#1D1D1D;
  --ppl-muted:#6B7570;
  --ppl-border:#E5E8E4;
  --ppl-card:#FFFFFF;
  --ppl-radius:14px;
  --ppl-radius-sm:10px;
  --ppl-shadow:0 1px 2px rgba(0,0,0,.04);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ppl-bg);color:var(--ppl-text);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}
h1,h2,h3{font-weight:600;letter-spacing:-0.01em;margin:0}
h1{font-size:22px}h2{font-size:17px}h3{font-size:15px}

/* ---------- Layout shell ---------- */
.ppl-app{max-width:480px;margin:0 auto;min-height:100vh;background:var(--ppl-bg);display:flex;flex-direction:column}
.ppl-main{padding:16px 16px 96px;flex:1}
.ppl-main.no-tabbar{padding-bottom:24px}
.ppl-section{margin-top:24px}
.ppl-section-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.ppl-section-h h2{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ppl-muted)}
.ppl-link{font-size:13px;font-weight:500;color:var(--ppl-primary)}
.ppl-link-quiet{font-size:13px;color:var(--ppl-muted)}
.ppl-spacer{flex:1}

/* ---------- Header ---------- */
.ppl-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;
  padding:12px 16px;background:rgba(247,248,246,.9);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--ppl-border)}
.ppl-h1{font-size:17px;font-weight:600}
.ppl-iconbtn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;background:transparent;color:var(--ppl-text);border:0;cursor:pointer}
.ppl-iconbtn:hover{background:var(--ppl-primary-soft)}
.ppl-brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:16px}
.ppl-brand-mark{width:20px;height:20px;border-radius:6px;background:var(--ppl-primary);
  position:relative;flex:none}
.ppl-brand-mark::after{content:"";position:absolute;inset:5px;border-radius:3px;background:var(--ppl-bg)}
.ppl-points-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;
  background:var(--ppl-primary-soft);color:var(--ppl-primary);font-size:13px;font-weight:600}

/* ---------- Buttons ---------- */
.ppl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 20px;border-radius:var(--ppl-radius);font-size:15px;font-weight:600;
  background:var(--ppl-primary);color:#fff;border:0;cursor:pointer;min-height:48px;width:100%;
  transition:transform .05s;}
.ppl-btn:active{transform:scale(.98)}
.ppl-btn:disabled{opacity:.5}
.ppl-btn-secondary{background:var(--ppl-card);color:var(--ppl-text);border:1px solid var(--ppl-border)}
.ppl-btn-ghost{background:transparent;color:var(--ppl-primary);box-shadow:none}
.ppl-btn-amber{background:var(--ppl-accent);color:#1D1D1D}
.ppl-btn-row{display:flex;gap:8px}

/* ---------- Inputs ---------- */
.ppl-field{display:block;margin-bottom:14px}
.ppl-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ppl-muted);margin-bottom:6px}
.ppl-input,.ppl-select,.ppl-textarea{width:100%;padding:12px 14px;border:1px solid var(--ppl-border);
  border-radius:var(--ppl-radius-sm);background:var(--ppl-card);color:var(--ppl-text);font-size:15px;min-height:48px}
.ppl-input:focus,.ppl-select:focus,.ppl-textarea:focus{outline:none;border-color:var(--ppl-primary);box-shadow:0 0 0 3px var(--ppl-primary-soft)}
.ppl-search{position:relative}
.ppl-search .ppl-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ppl-muted)}
.ppl-search .ppl-input{padding-left:40px;border-radius:999px}
.ppl-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ppl-chips{display:flex;gap:6px;flex-wrap:wrap}
.ppl-chip-btn{padding:8px 12px;border-radius:999px;border:1px solid var(--ppl-border);
  background:var(--ppl-card);font-size:13px;cursor:pointer;color:var(--ppl-text)}
.ppl-chip-btn.is-active{background:var(--ppl-primary);color:#fff;border-color:var(--ppl-primary)}

/* ---------- Cards ---------- */
.ppl-card{display:block;background:var(--ppl-card);border:1px solid var(--ppl-border);
  border-radius:var(--ppl-radius);padding:14px;box-shadow:var(--ppl-shadow);color:var(--ppl-text)}
.ppl-card+.ppl-card{margin-top:8px}
.ppl-row-between{display:flex;justify-content:space-between;align-items:center;gap:8px}
.ppl-store-card .ppl-store-name{font-weight:600;font-size:15px}
.ppl-store-meta{display:flex;justify-content:space-between;align-items:center;color:var(--ppl-muted);font-size:13px;margin-top:6px;gap:8px}
.ppl-store-meta span{display:inline-flex;align-items:center;gap:4px}
.ppl-chip{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;
  background:var(--ppl-primary-soft);color:var(--ppl-primary)}
.ppl-chip.is-indep{background:#F1ECDF;color:#7A5A1F}
.ppl-chip.is-chain{background:var(--ppl-primary-soft);color:var(--ppl-primary)}

/* ---------- Hero ---------- */
.ppl-hero{margin:-16px -16px 0;padding:24px 16px 20px;background:linear-gradient(180deg,var(--ppl-primary-soft),var(--ppl-bg))}
.ppl-hero h1{font-size:26px;line-height:1.15;font-weight:700;letter-spacing:-0.02em}
.ppl-hero p{color:var(--ppl-muted);font-size:14px;margin:6px 0 16px}
.ppl-hero .ppl-cta-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}

/* ---------- Product cards ---------- */
.ppl-prod-card{padding:14px}
.ppl-prod-title{font-weight:600;font-size:15px;line-height:1.3}
.ppl-prod-sub{color:var(--ppl-muted);font-size:12px;margin-top:2px}
.ppl-prod-price{font-weight:700;font-size:17px;color:var(--ppl-primary)}
.ppl-strike{color:var(--ppl-muted);text-decoration:line-through;font-weight:400;margin-right:6px;font-size:13px}
.ppl-prod-photo{margin:-2px -2px 12px;border-radius:var(--ppl-radius-sm);overflow:hidden;background:var(--ppl-primary-soft)}
.ppl-prod-photo img{width:100%;max-height:280px;object-fit:cover}
.ppl-prod-desc{margin-top:10px;color:var(--ppl-muted);font-size:13px;line-height:1.5}
.ppl-prod-desc p{margin:0 0 8px}

/* ---------- Price rows ---------- */
.ppl-price-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  padding:14px;background:var(--ppl-card);border:1px solid var(--ppl-border);border-radius:var(--ppl-radius);box-shadow:var(--ppl-shadow);margin-bottom:8px}
.ppl-price-row.is-best{border-color:var(--ppl-primary);background:var(--ppl-primary-soft)}
.ppl-pr-store{display:flex;align-items:center;gap:8px;font-weight:600}
.ppl-best{display:inline-flex;padding:2px 7px;border-radius:999px;background:var(--ppl-primary);color:#fff;font-size:10px;font-weight:700;letter-spacing:.04em}
.ppl-pr-meta{margin-top:6px;color:var(--ppl-muted);font-size:12px;display:flex;flex-wrap:wrap;align-items:center;gap:4px}
.ppl-pr-dot{opacity:.4}
.ppl-verified{display:inline-flex;align-items:center;padding:2px 6px;border-radius:6px;background:var(--ppl-primary-soft);color:var(--ppl-primary);font-size:10px;font-weight:700;margin-left:4px}
.ppl-pr-price{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.ppl-pr-display{font-weight:700;font-size:17px;color:var(--ppl-primary)}
.ppl-trend{font-size:13px;font-weight:600}
.ppl-trend-up{color:var(--ppl-accent)}
.ppl-trend-down{color:var(--ppl-primary)}

/* ---------- Sparkline ---------- */
.ppl-spark{padding:8px 0}
.ppl-spark-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--ppl-muted);margin-top:4px}

/* ---------- Bottom tab bar ---------- */
.ppl-tabbar{position:fixed;bottom:0;left:0;right:0;z-index:20;background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);border-top:1px solid var(--ppl-border);padding-bottom:env(safe-area-inset-bottom)}
.ppl-tabbar-inner{max-width:480px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr)}
.ppl-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;padding:10px 4px;color:var(--ppl-muted);font-size:11px;font-weight:500;min-height:56px}
.ppl-tab.is-active{color:var(--ppl-primary)}
.ppl-tab-ico{display:inline-flex}
.ppl-tab-lbl{font-size:11px}

/* ---------- Sticky bottom CTA (for forms) ---------- */
.ppl-bottom-cta{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom));left:0;right:0;z-index:25;background:var(--ppl-bg);
  border-top:1px solid var(--ppl-border);padding:12px 16px env(safe-area-inset-bottom)}
.ppl-bottom-cta-inner{max-width:480px;margin:0 auto}
.ppl-with-bottom-cta{padding-bottom:160px}
.ppl-add-submit-primary{display:none;margin-top:14px}

/* ---------- Autocomplete ---------- */
.ppl-ac{position:relative}
.ppl-ac-list{position:absolute;left:0;right:0;top:100%;margin-top:6px;background:var(--ppl-card);
  border:1px solid var(--ppl-border);border-radius:var(--ppl-radius);box-shadow:var(--ppl-shadow);
  max-height:360px;overflow:auto;z-index:30}
.ppl-ac-group{padding:4px 0}
.ppl-ac-group + .ppl-ac-group{border-top:1px solid var(--ppl-border)}
.ppl-ac-h{padding:8px 12px 4px;font-size:11px;text-transform:uppercase;color:var(--ppl-muted);font-weight:700;letter-spacing:.06em}
.ppl-ac-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;font-size:14px;border:0;background:transparent;width:100%;text-align:left}
.ppl-ac-item:hover,.ppl-ac-item.is-active{background:var(--ppl-primary-soft)}
.ppl-ac-item .ppl-ac-text{display:flex;flex-direction:column;min-width:0;flex:1}
.ppl-ac-item .ppl-ac-text strong{font-weight:600;color:var(--ppl-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ppl-ac-item .ppl-ac-text small{color:var(--ppl-muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ppl-ac-thumb{flex-shrink:0;width:36px;height:36px;border-radius:8px;object-fit:cover;background:var(--ppl-primary-soft)}
.ppl-ac-thumb-empty{display:inline-flex;align-items:center;justify-content:center;font-size:18px}
.ppl-ac-empty{padding:14px 12px;display:flex;flex-direction:column;gap:2px}
.ppl-ac-empty strong{font-size:13px;color:var(--ppl-text)}
.ppl-ac-empty small{color:var(--ppl-muted);font-size:12px}

/* ---------- Toast ---------- */
.ppl-toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:#1D1D1D;color:#fff;
  padding:12px 16px;border-radius:999px;font-size:13px;font-weight:500;z-index:50;animation:pplFade .3s}
@keyframes pplFade{from{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translateX(-50%)}}
@keyframes pplPop{0%{transform:scale(.6);opacity:0}50%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
.ppl-pop{animation:pplPop .45s ease-out}

/* ---------- Scanner ---------- */
.ppl-scan{position:fixed;inset:0;background:#000;color:#fff;display:flex;flex-direction:column;z-index:40}
.ppl-scan-top{display:flex;justify-content:space-between;padding:12px 16px}
.ppl-scan-top .ppl-iconbtn{color:#fff;background:rgba(255,255,255,.1)}
.ppl-scan-stage{flex:1;position:relative;overflow:hidden}
.ppl-scan-stage video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ppl-reticle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:78%;max-width:340px;aspect-ratio:1;
  border:2px solid rgba(255,255,255,.3);border-radius:24px;pointer-events:none}
.ppl-reticle::before,.ppl-reticle::after{content:"";position:absolute;width:32px;height:32px;border:3px solid var(--ppl-accent)}
.ppl-reticle::before{top:-2px;left:-2px;border-right:0;border-bottom:0;border-radius:24px 0 0 0}
.ppl-reticle::after{bottom:-2px;right:-2px;border-left:0;border-top:0;border-radius:0 0 24px 0}
.ppl-scan-bar{position:absolute;left:12%;right:12%;top:50%;height:2px;background:var(--ppl-accent);box-shadow:0 0 16px var(--ppl-accent);animation:pplScan 1.6s ease-in-out infinite}
@keyframes pplScan{0%,100%{top:30%}50%{top:70%}}
.ppl-scan-foot{padding:16px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.7))}
.ppl-scan-hint{text-align:center;color:rgba(255,255,255,.7);font-size:13px;margin-bottom:12px}

/* ---------- Misc ---------- */
.ppl-feed-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--ppl-radius);background:var(--ppl-card);border:1px solid var(--ppl-border);box-shadow:var(--ppl-shadow);margin-bottom:8px}
.ppl-feed-item .right{text-align:right}
.ppl-feed-item .price{color:var(--ppl-primary);font-weight:700}
.ppl-feed-item .meta{font-size:11px;color:var(--ppl-muted);margin-top:2px}
.ppl-empty{text-align:center;padding:32px 16px;color:var(--ppl-muted)}
.ppl-divider{height:1px;background:var(--ppl-border);margin:24px 0}
details.ppl-details summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--ppl-primary);list-style:none;padding:8px 0}
details.ppl-details summary::-webkit-details-marker{display:none}
.ppl-strip{display:flex;gap:10px;overflow-x:auto;padding:4px 0 8px;margin:0 -16px;padding-left:16px;padding-right:16px;-webkit-overflow-scrolling:touch}
.ppl-strip > *{flex:none;min-width:170px}
.ppl-strip::-webkit-scrollbar{display:none}

.ppl-rewards-card{padding:18px;background:linear-gradient(135deg,var(--ppl-primary),#15523F);color:#fff;border-radius:var(--ppl-radius);margin-bottom:16px}
.ppl-rewards-card .num{font-size:36px;font-weight:700;letter-spacing:-.02em}
.ppl-leaderboard{list-style:none;padding:0;margin:0}
.ppl-leaderboard li{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--ppl-border);font-size:14px}
.ppl-leaderboard li:last-child{border-bottom:0}
.ppl-leaderboard .rank{display:inline-flex;width:22px;height:22px;border-radius:6px;background:var(--ppl-primary-soft);color:var(--ppl-primary);align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-right:8px}
.ppl-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ppl-badge-trusted{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--ppl-primary-soft);color:var(--ppl-primary);font-size:12px;font-weight:600}

@media (min-width:520px){
  .ppl-grid-2{gap:14px}
  .ppl-hero h1{font-size:30px}
}

/* ---------- v1.3.7 — Responsive shell (fluid from 600px, true desktop ≥760px) ---------- */
@media (min-width:600px) and (max-width:759px){
  .ppl-app{max-width:640px}
  .ppl-main{padding:18px 20px 110px}
}
@media (min-width:760px){
  .ppl-app{max-width:min(1180px, 96vw);background:transparent}
  body{background:var(--ppl-bg)}
  .ppl-main{padding:24px 32px 48px;display:block}
  .ppl-main.ppl-with-bottom-cta{padding-bottom:48px}
  .ppl-header{padding:14px 32px}
  .ppl-header .ppl-h1{font-size:20px}
  .ppl-desktop-nav{display:flex;gap:6px;margin-left:24px;flex-wrap:wrap}
  .ppl-desktop-nav a{padding:8px 14px;border-radius:999px;font-size:14px;color:var(--ppl-muted);font-weight:500}
  .ppl-desktop-nav a:hover{background:var(--ppl-primary-soft);color:var(--ppl-primary)}
  .ppl-desktop-nav a.is-active{background:var(--ppl-primary);color:#fff}
  .ppl-tabbar{display:none}
  .ppl-bottom-cta{display:none}
  .ppl-add-submit-primary{display:inline-flex;width:auto;min-width:240px}

  /* Hero: constrain text, real desktop sizing */
  .ppl-hero{margin:0;border-radius:var(--ppl-radius);padding:48px 40px}
  .ppl-hero h1{font-size:40px;max-width:720px}
  .ppl-hero p{font-size:16px;max-width:640px;margin-bottom:24px}
  .ppl-hero .ppl-search{max-width:720px}
  .ppl-hero .ppl-cta-row{max-width:720px;grid-template-columns:auto auto;justify-content:start}
  .ppl-hero .ppl-cta-row .ppl-btn{width:auto;min-width:220px}

  /* Horizontal rails on mobile → wrap grids on desktop */
  .ppl-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin:0;padding:0;overflow:visible}
  .ppl-strip > *{min-width:0;flex:initial}

  /* Forms */
  .ppl-grid-2{grid-template-columns:repeat(4, minmax(0,1fr))}
  .ppl-form-2col{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:24px;align-items:start}
  .ppl-form-2col > form{min-width:0}
  .ppl-form-side{position:sticky;top:80px}

  /* Archive lists become responsive grids */
  .post-type-archive-ppl_store .ppl-section,
  .post-type-archive-ppl_product .ppl-section{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
  .post-type-archive-ppl_store .ppl-section .ppl-card+.ppl-card,
  .post-type-archive-ppl_product .ppl-section .ppl-card+.ppl-card{margin-top:0}

  /* Search bars + recent submissions feed: cap at a readable width */
  .ppl-main > .ppl-search{max-width:720px}
  .ppl-feed-item{max-width:none}

  /* Rewards two-column */
  .page-template-page-rewards .ppl-main{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:24px;align-items:start}
  .page-template-page-rewards .ppl-main > *{min-width:0}
  .page-template-page-rewards .ppl-rewards-card{grid-column:1/-1}

  /* Auth pages */
  .ppl-auth-card{padding:32px}
}
@media (max-width:759px){
  .ppl-desktop-nav{display:none}
  /* On mobile, the sticky bottom CTA IS the submit. Hide the inline one to avoid a duplicate button. */
  .ppl-add-submit-primary{display:none}
  .ppl-form-2col > .ppl-form-side{margin-top:16px}
}

/* ---------- v1.3.7 — Auth pages ---------- */
.ppl-auth-main{display:flex;justify-content:center}
.ppl-auth-card{width:100%;max-width:420px;background:var(--ppl-card);border:1px solid var(--ppl-border);
  border-radius:var(--ppl-radius);padding:24px;box-shadow:var(--ppl-shadow);margin-top:8px}
.ppl-auth-foot{text-align:center;color:var(--ppl-muted);margin:16px 0 0;font-size:13px}
.ppl-divider{height:1px;background:var(--ppl-border);margin:16px 0}


/* ---------- v1.3.3 — Photo upload ---------- */
.ppl-photo-drop{display:flex;align-items:center;gap:12px;padding:14px;border:1px dashed var(--ppl-border);border-radius:var(--ppl-radius-sm);background:var(--ppl-card);cursor:pointer}
.ppl-photo-drop:hover{border-color:var(--ppl-primary);background:var(--ppl-primary-soft)}
.ppl-photo-drop input[type=file]{display:none}
.ppl-photo-thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;background:var(--ppl-primary-soft);flex:none}
.ppl-photo-meta{font-size:13px;color:var(--ppl-muted)}
.ppl-photo-meta strong{display:block;color:var(--ppl-text);font-weight:600;font-size:14px;margin-bottom:2px}

/* ---------- v1.3.3 — Places finder ---------- */
.ppl-places-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.ppl-places-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px;border:1px solid var(--ppl-border);border-radius:var(--ppl-radius-sm);background:var(--ppl-card);width:100%;text-align:left;font:inherit;color:inherit;cursor:pointer;margin-top:6px}
.ppl-places-item:hover,.ppl-places-item:focus-visible{border-color:var(--ppl-primary);outline:none}
.ppl-places-item .nm{font-weight:600;font-size:14px}
.ppl-places-item .ad{font-size:12px;color:var(--ppl-muted);margin-top:2px}
.ppl-places-item .add-btn{padding:8px 12px;border-radius:999px;border:1px solid var(--ppl-primary);background:transparent;color:var(--ppl-primary);font-size:12px;font-weight:600;cursor:pointer;flex:none}
.ppl-places-item .add-btn.is-added{background:var(--ppl-primary);color:#fff}
.ppl-helper{font-size:12px;color:var(--ppl-muted);margin-top:6px}
.ppl-form-error{margin:0 0 12px;padding:10px 12px;border-radius:var(--ppl-radius-sm);background:#FDECEC;color:#8A1F1F;font-size:13px;font-weight:600}
.ppl-ocr-result{margin-top:10px;padding:12px;border-radius:var(--ppl-radius-sm);background:var(--ppl-primary-soft);color:var(--ppl-text);font-size:13px}
.ppl-ocr-result strong{display:block;color:var(--ppl-primary);font-size:13px;margin-bottom:2px}
.ppl-ocr-result span{display:block;color:var(--ppl-muted)}
.ppl-ocr-result small{display:block;margin-top:6px;color:var(--ppl-muted);max-height:72px;overflow:auto;white-space:pre-wrap}
