/* === Chick-fil-A Calorie Calculator Plugin === */
.cfac-app-wrap {
  --bg0:#0c0c18; --bg1:#11111f; --bg2:#181828; --bg3:#1e1e30;
  --bdr:rgba(255,255,255,.07); --bdr-hi:rgba(255,255,255,.13);
  --t1:#e8e8f0; --t2:#8888aa; --t3:#55557a;
  --red:#e4002b; --red-dim:rgba(228,0,43,.2); --red-hi:#ff3355;
  --pro:#ff7a3d; --carb:#4da6ff; --fat:#ffe066;
  --fiber:#86efac; --sodium:#a78bfa;
  --sidebar-w:200px; --right-w:268px;
  --r:12px; --r-sm:8px; --rpill:999px;
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--bg0);
  border-radius:var(--r);
  overflow:hidden;
  max-width:1200px;
  margin:0 auto;
}

.cfac-app-wrap *,
.cfac-app-wrap *::before,
.cfac-app-wrap *::after {
  box-sizing:border-box;
}

.cfac-app-wrap button { font-family:inherit; cursor:pointer; }
.cfac-app-wrap input  { font-family:inherit; }

/* LAYOUT */
.cfac-app {
  display:flex;
  height:700px;
  overflow:hidden;
}

/* SIDEBAR */
.cfac-sidebar {
  width:var(--sidebar-w);
  background:var(--bg1);
  border-right:1px solid var(--bdr);
  display:flex;flex-direction:column;
  gap:4px;padding:16px 10px;
  overflow-y:auto;flex-shrink:0;
}
.cfac-sidebar-lbl {
  font-size:9px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--t3);padding:0 8px;margin-bottom:4px;
}
.cfac-cat-btn {
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:var(--r-sm);
  border:1px solid transparent;
  background:transparent;color:var(--t2);
  text-align:left;width:100%;transition:all .18s;
}
.cfac-cat-btn:hover  { background:rgba(255,255,255,.04);color:var(--t1); }
.cfac-cat-btn.cfac-active { background:var(--red-dim);border-color:rgba(228,0,43,.35);color:var(--t1); }
.cfac-cat-icon { width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0; }
.cfac-cat-name { font-size:12px;font-weight:600;display:block; }
.cfac-cat-sub  { font-size:9px;color:var(--t3);display:block;margin-top:1px; }
.cfac-ic-entree   { background:rgba(228,0,43,.16); }
.cfac-ic-sides    { background:rgba(255,165,0,.16); }
.cfac-ic-salads   { background:rgba(50,200,80,.16); }
.cfac-ic-sauces   { background:rgba(77,166,255,.16); }
.cfac-ic-dressing { background:rgba(180,80,200,.16); }
.cfac-ic-drinks   { background:rgba(0,200,200,.16); }
.cfac-ic-breakfast{ background:rgba(255,220,50,.16); }
.cfac-ic-desserts { background:rgba(255,100,180,.16); }

/* MAIN */
.cfac-main { flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--bg0); }

.cfac-build-hdr {
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 18px 11px;border-bottom:1px solid var(--bdr);flex-shrink:0;
}
.cfac-build-title { font-size:17px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:8px; }
.cfac-goal-btn {
  font-size:11px;background:var(--bg2);border:1px solid var(--bdr-hi);border-radius:var(--rpill);
  padding:4px 12px;color:var(--t2);margin-left:8px;display:flex;align-items:center;gap:5px;
}
.cfac-clear-btn {
  display:flex;align-items:center;gap:5px;background:rgba(228,0,43,.1);
  border:1px solid rgba(228,0,43,.28);border-radius:var(--rpill);padding:6px 12px;
  font-size:12px;color:var(--red-hi);transition:all .18s;
}
.cfac-clear-btn:hover { background:rgba(228,0,43,.22); }

.cfac-meal-bowl-wrap { padding:11px 18px 10px;border-bottom:1px solid var(--bdr);flex-shrink:0; }
.cfac-bowl-label { font-size:10px;letter-spacing:.6px;text-transform:uppercase;color:var(--t2);margin-bottom:7px; }
.cfac-meal-bowl {
  background:var(--bg2);border:1px dashed rgba(255,255,255,.1);border-radius:var(--r);
  min-height:58px;max-height:90px;overflow-y:auto;
  display:flex;flex-wrap:wrap;gap:5px;padding:7px;align-content:flex-start;
  transition:border-color .3s;
}
.cfac-meal-bowl.cfac-has-items { border-style:solid;border-color:var(--bdr-hi); }
.cfac-empty-bowl { width:100%;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--t3);font-size:12px;padding:6px; }
.cfac-meal-tag {
  display:flex;align-items:center;gap:5px;background:var(--bg3);border:1px solid var(--bdr-hi);
  border-radius:var(--rpill);padding:4px 8px 4px 7px;font-size:11px;color:var(--t1);
  animation:cfacPopIn .2s ease;flex-shrink:0;
}
@keyframes cfacPopIn { from{opacity:0;transform:scale(.75);}to{opacity:1;transform:scale(1);} }
.cfac-tag-name { font-weight:500;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.cfac-tag-cal  { color:var(--t2);font-size:10px; }
.cfac-tag-rm {
  width:15px;height:15px;border-radius:50%;background:rgba(255,255,255,.07);border:none;
  color:var(--t2);display:flex;align-items:center;justify-content:center;font-size:9px;
  margin-left:2px;transition:all .15s;flex-shrink:0;
}
.cfac-tag-rm:hover { background:rgba(228,0,43,.35);color:var(--red-hi); }

.cfac-items-section { flex:1;overflow-y:auto;padding:13px 16px 16px; }
.cfac-items-hdr { display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--t2);margin-bottom:11px; }

.cfac-search-wrap { position:relative;margin-bottom:13px; }
.cfac-s-icon { position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--t3);pointer-events:none; }
.cfac-search-wrap input {
  width:100%;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rpill);
  padding:9px 14px 9px 36px;color:var(--t1);font-size:13px;outline:none;transition:border-color .2s;
}
.cfac-search-wrap input::placeholder { color:var(--t3); }
.cfac-search-wrap input:focus { border-color:var(--red); }

.cfac-items-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px; }
.cfac-item-card {
  background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);
  padding:12px;display:flex;flex-direction:column;gap:9px;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.cfac-item-card:hover { border-color:var(--bdr-hi);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.4); }
.cfac-card-top  { display:flex;align-items:flex-start;gap:8px; }
.cfac-card-emo  { font-size:19px;line-height:1;flex-shrink:0; }
.cfac-card-name { font-size:12px;font-weight:600;color:var(--t1);flex:1;line-height:1.35; }
.cfac-card-dot  { width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 5px var(--red-dim);flex-shrink:0;margin-top:4px; }

.cfac-card-macros { display:grid;grid-template-columns:repeat(4,1fr);gap:3px; }
.cfac-mpill       { display:flex;flex-direction:column;gap:1px; }
.cfac-mpill-lbl   { font-size:8px;color:var(--t3);text-transform:uppercase;letter-spacing:.3px; }
.cfac-mpill-val   { font-size:12px;font-weight:700; }
.cfac-mpill.cfac-cal  .cfac-mpill-val { color:var(--t1); }
.cfac-mpill.cfac-pro  .cfac-mpill-val { color:var(--pro); }
.cfac-mpill.cfac-carb .cfac-mpill-val { color:var(--carb); }
.cfac-mpill.cfac-fat  .cfac-mpill-val { color:var(--fat); }

.cfac-card-actions { display:flex;gap:7px;align-items:center; }
.cfac-qty-wrap {
  display:flex;background:var(--bg3);border:1px solid var(--bdr);
  border-radius:var(--rpill);overflow:hidden;flex-shrink:0;
}
.cfac-qty-btn {
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  background:none;border:none;color:var(--t2);font-size:16px;transition:all .15s;
}
.cfac-qty-btn:hover { color:var(--t1);background:rgba(255,255,255,.07); }
.cfac-qty-num { width:24px;text-align:center;font-size:12px;font-weight:700;color:var(--t1);line-height:30px; }
.cfac-add-btn {
  flex:1;background:var(--red);border:none;border-radius:var(--rpill);color:#fff;
  font-size:12px;font-weight:700;padding:7px 10px;display:flex;align-items:center;
  justify-content:center;gap:4px;transition:all .18s;min-height:30px;
}
.cfac-add-btn:hover { background:#c5001f;box-shadow:0 4px 14px rgba(228,0,43,.4); }
.cfac-add-btn:active { transform:scale(.96); }

/* RIGHT PANEL */
.cfac-right-panel {
  width:var(--right-w);background:var(--bg1);border-left:1px solid var(--bdr);
  display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;
}
.cfac-rp-card { padding:16px;border-bottom:1px solid var(--bdr); }
.cfac-rp-card:last-child { border-bottom:none; }
.cfac-rp-title { font-size:10px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:var(--t2);margin-bottom:12px; }
.cfac-cal-big  { font-size:46px;font-weight:800;line-height:1;text-align:center;color:var(--t1); }
.cfac-cal-lbl  { font-size:10px;color:var(--t2);text-align:center;margin-top:2px; }
.cfac-cal-pct  { font-size:10px;color:var(--t3);text-align:center;margin-bottom:12px;margin-top:2px; }
.cfac-donut-wrap { display:flex;justify-content:center;margin-bottom:14px; }

.cfac-m-row     { margin-bottom:11px; }
.cfac-m-row:last-child { margin-bottom:0; }
.cfac-m-row-hdr { display:flex;align-items:center;justify-content:space-between;margin-bottom:4px; }
.cfac-m-lbl     { font-size:11px;font-weight:600; }
.cfac-m-lbl.cfac-pro  { color:var(--pro); }
.cfac-m-lbl.cfac-carb { color:var(--carb); }
.cfac-m-lbl.cfac-fat  { color:var(--fat); }
.cfac-m-val   { font-size:11px;font-weight:700;color:var(--t1); }
.cfac-prog-bar { height:5px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden; }
.cfac-prog-fill { height:100%;border-radius:3px;transition:width .4s cubic-bezier(.25,.46,.45,.94); }
.cfac-prog-fill.cfac-pro  { background:linear-gradient(90deg,var(--pro),#ffaa80); }
.cfac-prog-fill.cfac-carb { background:linear-gradient(90deg,var(--carb),#80ccff); }
.cfac-prog-fill.cfac-fat  { background:linear-gradient(90deg,var(--fat),#fff080); }
.cfac-m-pct   { font-size:9px;color:var(--t3);text-align:right;margin-top:2px; }

.cfac-nd-row { display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--bdr);font-size:12px; }
.cfac-nd-row:last-child { border-bottom:none; }
.cfac-nd-name { color:var(--t2); }
.cfac-nd-val  { font-weight:700; }
.cfac-nd-val.cfac-cal    { color:var(--t1); }
.cfac-nd-val.cfac-pro    { color:var(--pro); }
.cfac-nd-val.cfac-carb   { color:var(--carb); }
.cfac-nd-val.cfac-fat    { color:var(--fat); }
.cfac-nd-val.cfac-fiber  { color:var(--fiber); }
.cfac-nd-val.cfac-sodium { color:var(--sodium); }

.cfac-sum-empty { text-align:center;color:var(--t3);font-size:11px;padding:10px 0; }
.cfac-sum-item  {
  display:flex;align-items:center;gap:7px;padding:5px 0;
  border-bottom:1px solid var(--bdr);font-size:11px;animation:cfacPopIn .2s ease;
}
.cfac-sum-item:last-child { border-bottom:none; }
.cfac-sum-emo  { font-size:13px;flex-shrink:0; }
.cfac-sum-name { flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--t1); }
.cfac-sum-cal  { color:var(--t2);font-weight:600;flex-shrink:0; }

/* SCROLLBARS */
.cfac-items-section::-webkit-scrollbar,
.cfac-right-panel::-webkit-scrollbar,
.cfac-meal-bowl::-webkit-scrollbar,
.cfac-sidebar::-webkit-scrollbar { width:3px; }
.cfac-items-section::-webkit-scrollbar-thumb,
.cfac-right-panel::-webkit-scrollbar-thumb,
.cfac-meal-bowl::-webkit-scrollbar-thumb,
.cfac-sidebar::-webkit-scrollbar-thumb { background:rgba(255,255,255,.1);border-radius:2px; }

/* MODAL */
.cfac-modal-ov {
  position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:99999;
  opacity:0;pointer-events:none;transition:opacity .22s;padding:20px;
}
.cfac-modal-ov.cfac-open { opacity:1;pointer-events:all; }
.cfac-modal {
  background:var(--bg2);border:1px solid var(--bdr-hi);border-radius:var(--r);
  padding:24px;width:100%;max-width:320px;transform:translateY(16px);transition:transform .22s;
}
.cfac-modal-ov.cfac-open .cfac-modal { transform:translateY(0); }
.cfac-modal h3    { font-size:15px;color:var(--t1);margin-bottom:14px; }
.cfac-modal label { font-size:11px;color:var(--t2);display:block;margin-bottom:5px; }
.cfac-modal input {
  width:100%;background:var(--bg1);border:1px solid var(--bdr);border-radius:var(--r-sm);
  padding:10px 12px;color:var(--t1);font-size:15px;outline:none;margin-bottom:14px;
}
.cfac-modal input:focus { border-color:var(--red); }
.cfac-modal-foot { display:flex;gap:8px;justify-content:flex-end; }
.cfac-modal-cancel {
  background:rgba(255,255,255,.06);border:1px solid var(--bdr);border-radius:var(--r-sm);
  padding:9px 18px;color:var(--t2);font-size:13px;
}
.cfac-modal-save  { background:var(--red);border:none;border-radius:var(--r-sm);padding:9px 18px;color:#fff;font-size:13px;font-weight:700; }
.cfac-modal-save:hover { background:#c5001f; }

/* TOAST */
.cfac-toast {
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(10px);
  background:var(--bg3);border:1px solid var(--bdr-hi);border-radius:var(--rpill);
  padding:9px 20px;font-size:12px;color:var(--t1);pointer-events:none;opacity:0;
  transition:all .28s;z-index:100000;white-space:nowrap;max-width:calc(100vw - 40px);
}
.cfac-toast.cfac-show { opacity:1;transform:translateX(-50%) translateY(0); }

/* RESPONSIVE */
@media(max-width:900px){
  .cfac-app-wrap { --sidebar-w:52px; --right-w:240px; }
  .cfac-cat-name,.cfac-cat-sub,.cfac-sidebar-lbl { display:none; }
  .cfac-cat-btn { justify-content:center;padding:8px 0; }
}
@media(max-width:640px){
  .cfac-app { flex-direction:column;height:auto; }
  .cfac-sidebar {
    width:100%;flex-direction:row;overflow-x:auto;overflow-y:hidden;
    padding:10px 8px;border-right:none;border-bottom:1px solid var(--bdr);
    height:auto;gap:4px;scrollbar-width:none;
  }
  .cfac-sidebar::-webkit-scrollbar { display:none; }
  .cfac-cat-btn { flex-direction:column;justify-content:center;padding:8px 12px;min-width:60px;gap:4px;flex-shrink:0; }
  .cfac-cat-icon { width:28px;height:28px;font-size:14px; }
  .cfac-cat-name { display:block;font-size:9px;text-align:center;white-space:nowrap; }
  .cfac-items-section { padding:12px 12px 20px;height:auto;overflow:visible; }
  .cfac-items-grid { grid-template-columns:1fr; }
  .cfac-right-panel { width:100%;border-left:none;border-top:1px solid var(--bdr);overflow:visible; }
  .cfac-main { overflow:visible; }
}
@media(max-width:640px) and (min-width:420px){
  .cfac-items-grid { grid-template-columns:repeat(2,1fr); }
}
