@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;500;700&family=Syne:wght@400;700;800&display=swap');
/* =========================
   DAILY TARGET PANEL (TABLE)
   ========================= */

.target-panel{
  margin-top: 14px;
  border: var(--border);
  border-radius: 16px;
  background: #F8FAFC;
  padding: 14px;
  box-shadow: var(--shadow-lg);
}

.target-panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.target-panel-title{
  font-weight: 800;
  letter-spacing: .3px;
  color: var(--fg);
}

.target-panel-total{
  font-weight: 800;
  color: var(--fg);
  background: #EEF2FF;
  border: var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  white-space: nowrap;
}

/* TABLE */
.target-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  margin-top:12px;
  overflow:hidden;
  border-radius:14px;
  border: var(--border);
  background: var(--white);
  box-shadow: var(--shadow);
}

.target-table thead th{
  background: rgba(15,23,42,.04);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 10px 12px;
  border-bottom: var(--border);
}

.target-table td{
  padding: 10px 12px;
  border-bottom: var(--border);
  font-size: 14px;
}

.target-table tbody tr:last-child td{
  border-bottom: none;
}

.target-meal-cell{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 800;
  color: var(--fg);
}

.target-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display:inline-block;
  flex: 0 0 auto;
  box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.08);
}

.target-kcal-cell{
  text-align:right;
  font-weight: 900;
  color: var(--fg);
}


*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#FEFCE8;--fg:#0F172A;--lime:#BEF264;--pink:#F472B6;--sky:#38BDF8;--white:#FFF;--shadow:4px 4px 0px 0px #0F172A;--shadow-sm:2px 2px 0px 0px #0F172A;--shadow-lg:6px 6px 0px 0px #0F172A;--shadow-xl:8px 8px 0px 0px #0F172A;--border:2px solid #0F172A;--radius:8px}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--fg);min-height:100vh;line-height:1.5}
h1,h2,h3,h4,h5,h6{font-family:'Syne',sans-serif}

/* HEADER */
.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;position:relative;z-index:10}
.header-left{display:flex;align-items:center;gap:12px}
.brand-text{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:-.5px;white-space:nowrap}
.brand-highlight{color:var(--lime);background:var(--fg);padding:2px 8px;border-radius:4px;margin-left:4px}

/* LANG TOGGLE */
.lang-toggle{display:flex;align-items:center;gap:8px;background:var(--white);border:var(--border);box-shadow:3px 3px 0 0 var(--fg);padding:8px 16px;border-radius:50px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.lang-toggle:hover{transform:translate(1px,1px);box-shadow:2px 2px 0 0 var(--fg)}
.lang-toggle:active{transform:translate(3px,3px);box-shadow:none}
.lang-toggle svg{width:16px;height:16px}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--lime);color:var(--fg);border:var(--border);box-shadow:var(--shadow-lg);padding:14px 28px;border-radius:var(--radius);font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.btn-primary:hover{transform:translate(2px,2px);box-shadow:var(--shadow)}
.btn-primary:active{transform:translate(6px,6px);box-shadow:none}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-primary.sm{padding:10px 20px;font-size:13px;box-shadow:var(--shadow)}
.btn-primary.sm:hover{box-shadow:var(--shadow-sm)}

.btn-secondary{display:inline-flex;align-items:center;gap:10px;background:var(--pink);color:var(--fg);border:var(--border);box-shadow:var(--shadow);padding:14px 28px;border-radius:var(--radius);font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.btn-secondary:hover{transform:translate(2px,2px);box-shadow:var(--shadow-sm)}
.btn-secondary:active{transform:translate(4px,4px);box-shadow:none}
.btn-secondary.sm{padding:10px 20px;font-size:13px}

.btn-outline{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--fg);border:var(--border);box-shadow:var(--shadow-sm);padding:10px 20px;border-radius:var(--radius);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.btn-outline:hover{background:#f1f5f9;transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--fg)}

.btn-icon{padding:10px;border:var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm);display:flex;align-items:center}
.btn-icon:hover{background:#f1f5f9;transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--fg)}

/* HERO */
.hero{max-width:1200px;margin:0 auto;padding:40px 24px 80px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.badge{display:inline-block;background:var(--pink);border:var(--border);padding:4px 16px;border-radius:50px;margin-bottom:24px;box-shadow:var(--shadow-sm);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:1px}
.hero-title{font-size:clamp(3rem,8vw,6rem);font-weight:800;line-height:.9;letter-spacing:-3px;text-transform:uppercase;margin-bottom:20px}
.hero-subtitle{font-family:'Syne',sans-serif;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:700;color:var(--pink);text-transform:uppercase;letter-spacing:-.5px;margin-bottom:12px}
.hero-desc{font-size:16px;color:#475569;max-width:480px;line-height:1.7;margin-bottom:32px}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:320px}
.hero-card{background:var(--white);border:4px solid var(--fg);box-shadow:var(--shadow-xl);border-radius:16px;padding:40px;width:260px;height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.hero-card .big-number{font-size:72px;font-family:'Syne',sans-serif;font-weight:800;color:var(--lime);line-height:1}
.hero-card .big-label{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:8px}
.dots{display:flex;gap:4px;margin-top:16px}
.dot{width:16px;height:16px;border-radius:50%;border:var(--border)}
.sticker{position:absolute;background:var(--white);border:var(--border);padding:12px;border-radius:50%;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center}
.sticker svg{width:28px;height:28px}
.sticker-1{top:10px;left:40px;animation:float 3s ease-in-out infinite}
.sticker-2{top:60px;right:10px;animation:float 3s ease-in-out infinite 1.5s}
.sticker-3{bottom:60px;left:10px;animation:float 3s ease-in-out infinite 1s}
.sticker-4{bottom:10px;right:50px;animation:float 3s ease-in-out infinite .5s}

@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(3deg)}}
@keyframes slideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:slideIn .5s ease-out forwards}

/* FORM */
.form-wrapper{max-width:520px;margin:0 auto;padding:24px}
.form-card{background:var(--white);border:var(--border);box-shadow:var(--shadow-lg);border-radius:12px;padding:32px}
.form-title{font-size:28px;font-weight:800;text-transform:uppercase;letter-spacing:-1px;margin-bottom:8px}
.form-divider{width:64px;height:4px;background:var(--pink);margin-bottom:24px;border-radius:2px}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#334155;margin-bottom:6px}
.form-input{width:100%;background:var(--white);border:var(--border);border-radius:6px;padding:12px 16px;font-size:15px;font-weight:500;font-family:'DM Sans',sans-serif;transition:all .2s}
.form-input::placeholder{color:#94a3b8}
.form-input:focus{outline:none;box-shadow:0 0 0 3px rgba(15,23,42,.15)}
.form-submit{width:100%;margin-top:8px}
.form-toggle{text-align:center;margin-top:16px;font-size:14px}
.form-toggle a{color:var(--pink);font-weight:700;cursor:pointer;text-decoration:underline}
.form-toggle a:hover{color:var(--fg)}
.form-error{color:#ef4444;font-size:13px;font-weight:600;margin-top:8px;display:none}
.form-error.show{display:block}

.back-link{display:inline-flex;align-items:center;gap:8px;color:#475569;font-weight:700;cursor:pointer;margin-bottom:24px;transition:color .2s;background:none;border:none;font-size:15px;font-family:'DM Sans',sans-serif}
.back-link:hover{color:var(--fg)}

/* ROLE SELECTOR */
.role-selector{display:flex;gap:12px;margin-bottom:24px}
.role-btn{flex:1;padding:12px;border:var(--border);border-radius:var(--radius);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;text-align:center;transition:all .15s;background:var(--white);font-family:'DM Sans',sans-serif}
.role-btn.active{background:var(--lime);box-shadow:var(--shadow-sm)}
.role-btn:hover{background:var(--lime)}

/* TEACHER LINK */
.teacher-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:8px 20px;border:var(--border);border-radius:50px;background:var(--white);font-weight:700;font-size:13px;text-transform:uppercase;cursor:pointer;transition:all .15s;text-decoration:none;color:var(--fg);font-family:'DM Sans',sans-serif;box-shadow:var(--shadow-sm)}
.teacher-link:hover{background:var(--sky);transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--fg)}

/* TRACKER */
.tracker-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:var(--border);background:var(--white);flex-wrap:wrap;gap:12px}
.tracker-header-left{display:flex;align-items:center;gap:12px}
.tracker-title{font-size:18px;font-weight:800;text-transform:uppercase;letter-spacing:-.5px}
.tracker-welcome{font-size:14px;color:#64748b}
.tracker-welcome strong{color:var(--fg)}
.info-bar{background:var(--lime);border-bottom:var(--border);padding:10px 24px;display:flex;flex-wrap:wrap;gap:8px 16px;font-size:14px;font-weight:700}
.info-bar .sep{display:none}
.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.summary-card{background:var(--white);border:var(--border);box-shadow:var(--shadow);border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px}
.summary-icon{padding:12px;border-radius:var(--radius);border:var(--border);display:flex;align-items:center;justify-content:center}
.summary-icon svg{width:24px;height:24px}
.summary-icon.pink{background:var(--pink)}
.summary-icon.sky{background:var(--sky)}
.summary-icon.lime{background:var(--lime)}
.summary-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#64748b}
.summary-value{font-family:'Syne',sans-serif;font-size:24px;font-weight:800}
.summary-value span{font-size:12px;font-weight:600}
.action-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.table-wrapper{overflow-x:auto;border:var(--border);border-radius:12px;box-shadow:var(--shadow-lg);margin-bottom:40px;-webkit-overflow-scrolling:touch}
.meal-table{width:100%;border-collapse:collapse;min-width:920px}
.meal-table th{background:var(--lime);color:var(--fg);font-family:'Syne',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:-.3px;padding:12px;border-bottom:var(--border);border-right:var(--border);text-align:center;font-size:13px}
.meal-table th:last-child{border-right:none}
.meal-table th.sub-header{background:rgba(190,242,100,.4);font-size:10px;font-family:'DM Sans',sans-serif;font-weight:700;padding:6px}
.meal-table td{border-bottom:var(--border);border-right:var(--border);padding:0}
.meal-table td:last-child{border-right:none}
.meal-table tr:last-child td{border-bottom:none}
.meal-table th:first-child{position:sticky;left:0;z-index:4;background:var(--lime)}
.meal-table th.sub-header:first-child{background:rgba(190,242,100,.4)}
.meal-table td:first-child{position:sticky;left:0;z-index:3;background:var(--white)}
.meal-label-cell{padding:12px;font-weight:700;font-size:13px;white-space:nowrap;display:flex;align-items:center;gap:8px;min-width:140px}
.meal-dot{width:12px;height:12px;border-radius:50%;border:var(--border);flex-shrink:0}
.meal-input-group{display:grid;grid-template-columns:1fr 1fr;height:100%}
.meal-input{width:100%;background:transparent;border:none;text-align:center;font-size:12px;font-weight:600;padding:10px 6px;font-family:'DM Sans',sans-serif;overflow-wrap:anywhere}
.meal-input::placeholder{color:#cbd5e1}
.meal-input:focus{outline:none;background:#fefce8}
.meal-input.cal-input{font-weight:700}
.total-row td{background:rgba(244,114,182,.2)}
.total-label{padding:12px;font-family:'Syne',sans-serif;font-weight:800;font-size:13px;text-transform:uppercase;background:var(--pink)!important}
.total-cell{text-align:center;padding:12px;font-family:'Syne',sans-serif;font-weight:800;font-size:18px}
.total-cell span{font-size:11px;font-weight:600;color:#475569;margin-left:4px}
.tracker-content{max-width:1400px;margin:0 auto;padding:24px}

/* TEACHER PANEL */
.teacher-content{max-width:1200px;margin:0 auto;padding:24px}
.teacher-topbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}
.teacher-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}
.filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;align-items:center}
.filter-select{padding:10px 16px;border:var(--border);border-radius:var(--radius);font-weight:600;font-size:14px;background:var(--white);cursor:pointer;font-family:'DM Sans',sans-serif;min-width:180px}
.filter-select:focus{outline:none;box-shadow:0 0 0 3px rgba(15,23,42,.15)}
.student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:24px}
.student-card{background:var(--white);border:var(--border);box-shadow:var(--shadow);border-radius:12px;padding:20px;transition:all .15s;cursor:pointer}
.student-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.student-card-name{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;margin-bottom:4px}
.student-card-info{font-size:13px;color:#64748b;margin-bottom:2px}
.student-card-cal{display:inline-block;margin-top:8px;padding:4px 12px;background:var(--lime);border:var(--border);border-radius:50px;font-weight:700;font-size:12px}

/* MODAL */
.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:100;align-items:center;justify-content:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border:var(--border);box-shadow:var(--shadow-xl);border-radius:16px;max-width:1100px;width:100%;max-height:90vh;overflow-y:auto;padding:32px}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.modal-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;text-transform:uppercase}
.modal-close{width:40px;height:40px;border:var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;transition:all .15s}
.modal-close:hover{background:#fee2e2}
.modal-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.modal-info-item{padding:12px;background:#f8fafc;border:var(--border);border-radius:var(--radius)}
.modal-info-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#64748b}
.modal-info-value{font-weight:700;font-size:15px;margin-top:2px;overflow-wrap:anywhere}
.modal-table-wrap{overflow-x:auto;border:var(--border);border-radius:var(--radius);margin-bottom:16px;-webkit-overflow-scrolling:touch}
.modal-table{width:100%;border-collapse:collapse;min-width:700px;font-size:13px}
.modal-table th{background:var(--lime);padding:8px 12px;border-bottom:var(--border);border-right:var(--border);font-weight:700;text-align:center;text-transform:uppercase;font-size:11px}
.modal-table th:last-child{border-right:none}
.modal-table td{padding:6px 10px;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;text-align:center;overflow-wrap:anywhere}
.modal-table td:last-child{border-right:none}
.modal-table td:first-child{font-weight:700;text-align:left;white-space:nowrap}
.modal-table th:first-child{position:sticky;left:0;z-index:3;background:var(--lime)}
.modal-table td:first-child{position:sticky;left:0;z-index:2;background:var(--white)}
.modal-table tr:last-child td{border-bottom:none}
.modal-table .total-row-modal td{background:rgba(244,114,182,.15);font-weight:800}

/* PASSWORD MODAL */
.pw-modal{max-width:420px}

/* TOAST */
.toast{position:fixed;top:20px;right:20px;background:var(--white);border:var(--border);border-radius:var(--radius);padding:14px 24px;font-weight:700;font-size:14px;box-shadow:var(--shadow);z-index:200;transform:translateX(120%);transition:transform .3s ease}
.toast.show{transform:translateX(0)}
.toast.success{border-left:4px solid var(--lime)}
.toast.error{border-left:4px solid #ef4444}

/* BOTTOM BAR */
.bottom-bar{position:fixed;bottom:0;left:0;right:0;height:4px;background:linear-gradient(to right,var(--lime),var(--pink),var(--sky));z-index:50}

/* RESPONSIVE */
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-desc{margin:0 auto 32px}
  .hero-visual{min-height:200px;margin-top:16px}
  .hero-card{width:180px;height:180px;padding:20px}
  .hero-card .big-number{font-size:48px}
  .sticker{display:none}
  .summary-cards{grid-template-columns:1fr}
  .btn-primary,.btn-secondary{font-size:13px;padding:12px 18px}
  .tracker-header{flex-direction:column;align-items:flex-start}
  .form-card{padding:20px}
  .form-title{font-size:22px}
  .teacher-stats{grid-template-columns:1fr}
  .student-grid{grid-template-columns:1fr}
  .filter-bar{flex-direction:column}
  .filter-select{width:100%}
  .modal{padding:20px;margin:12px}
  .modal-info{grid-template-columns:1fr}
  .meal-table{min-width:840px}
  .modal-table{min-width:620px}
  .teacher-topbar{flex-direction:column;align-items:flex-start}
  .action-buttons{flex-direction:column}
  .action-buttons .btn-primary,.action-buttons .btn-secondary{width:100%;justify-content:center}
}
@media(min-width:769px){.info-bar .sep{display:inline}}
@media(max-width:480px){
  .header{padding:12px 16px}
  .brand-text{font-size:16px}
  .hero{padding:24px 16px 60px}
  .hero-title{letter-spacing:-2px}
  .tracker-content,.teacher-content{padding:16px}
  .summary-card{padding:12px;gap:12px}
  .summary-value{font-size:20px}
  .summary-value{font-size:20px}
}

/* ========================
   FOOD REFERENCE SECTION
   ======================== */
.food-ref-section{
  margin-top:40px;
  padding:24px;
  border:var(--border);
  border-radius:18px;
  background:var(--white);
  box-shadow:var(--shadow-lg)
}

/* Header */
.food-ref-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:20px;
  flex-wrap:wrap;
  gap:12px
}
.food-ref-title-wrap{display:flex;align-items:center;gap:10px}
.food-ref-icon{
  font-size:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  background:rgba(190,242,100,.25);
  border:var(--border);
  border-radius:12px
}
.food-ref-title{
  font-family:'Syne',sans-serif;
  font-size:20px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:-.3px;
  margin:0
}
.food-ref-add-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 20px;
  background:var(--lime);
  color:var(--fg);
  border:var(--border);
  border-radius:50px;
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.5px;
  cursor:pointer;
  transition:all .15s;
  box-shadow:var(--shadow-sm)
}
.food-ref-add-btn:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--fg)}
.food-ref-add-btn:active{transform:translate(2px,2px);box-shadow:none}

/* Food items list */
.food-ref-list{
  max-height:400px;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-right:4px;
  scrollbar-width:thin;
  scrollbar-color:var(--lime) transparent
}
.food-ref-list::-webkit-scrollbar{width:6px}
.food-ref-list::-webkit-scrollbar-track{background:transparent}
.food-ref-list::-webkit-scrollbar-thumb{background:var(--lime);border-radius:10px}

/* Individual food item card */
.food-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 18px;
  background:#f8fafc;
  border:2px solid #e2e8f0;
  border-radius:12px;
  transition:all .2s ease
}
.food-item:hover{
  background:rgba(190,242,100,.08);
  border-color:var(--lime);
  transform:translateX(4px);
  box-shadow:0 2px 8px rgba(15,23,42,.06)
}
.food-item-name{
  flex:1;
  font-weight:700;
  font-size:15px;
  color:var(--fg);
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap
}
.food-item-unit{
  flex-shrink:0;
  padding:4px 12px;
  background:var(--white);
  border:2px solid #e2e8f0;
  border-radius:50px;
  font-size:12px;
  font-weight:700;
  color:#64748b;
  text-transform:uppercase;
  letter-spacing:.3px
}
.food-item-cal{
  flex-shrink:0;
  padding:6px 16px;
  background:var(--lime);
  border:var(--border);
  border-radius:50px;
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:800;
  color:var(--fg);
  white-space:nowrap;
  box-shadow:2px 2px 0 0 var(--fg)
}

/* Search input */
.food-search-wrap{margin-bottom:16px;position:relative}
.food-search-wrap .form-input{
  width:100%;
  padding:14px 18px 14px 44px;
  border:var(--border);
  border-radius:50px;
  box-shadow:var(--shadow-sm);
  font-size:15px;
  font-weight:600;
  transition:box-shadow .2s,transform .15s
}
.food-search-wrap .form-input:focus{box-shadow:0 0 0 4px rgba(190,242,100,.4);transform:translateY(-1px)}
.food-search-wrap::before{content:'🔍';position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none;z-index:1}

/* Add food form */
.add-food-form{
  display:none;
  margin-bottom:18px;
  padding:22px;
  background:linear-gradient(135deg,rgba(190,242,100,.1),rgba(56,189,248,.06));
  border-radius:14px;
  border:var(--border);
  box-shadow:var(--shadow-sm);
  animation:slideIn .3s ease-out
}
.form-grid{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:14px;align-items:end}
.form-grid .form-input{border:var(--border);border-radius:var(--radius);padding:12px 14px;font-size:14px;font-weight:600;transition:box-shadow .2s}
.form-grid .form-input:focus{box-shadow:0 0 0 3px rgba(15,23,42,.12)}
.form-grid .btn-primary{height:46px;border-radius:var(--radius);white-space:nowrap}

/* Empty state */
.food-ref-empty{
  text-align:center;
  padding:48px 20px;
  color:#94a3b8;
  font-weight:600;
  font-size:15px
}

/* RESPONSIVE */
@media(max-width:768px){
  .food-ref-section{padding:18px}
  .food-ref-header{flex-direction:column;align-items:flex-start}
  .food-ref-add-btn{width:100%;justify-content:center}
  .form-grid{grid-template-columns:1fr;gap:10px}
  .form-grid .btn-primary{width:100%;justify-content:center}
  .food-ref-list{max-height:340px}
  .food-item{padding:12px 14px;gap:10px}
  .food-item-name{font-size:14px}
  .food-item-cal{padding:5px 12px;font-size:12px}
  .food-item-unit{padding:3px 10px;font-size:11px}
}
@media(max-width:480px){
  .food-ref-section{padding:14px;border-radius:14px}
  .food-ref-title{font-size:17px}
  .food-ref-icon{width:36px;height:36px;font-size:22px;border-radius:10px}
  .food-ref-list{max-height:280px;gap:6px}
  .food-item{padding:10px 12px;border-radius:10px;gap:8px;flex-wrap:wrap}
  .food-item-name{font-size:14px;flex-basis:100%}
  .food-item-cal{padding:4px 10px;font-size:11px;box-shadow:1px 1px 0 0 var(--fg)}
  .food-search-wrap .form-input{padding:12px 12px 12px 38px;font-size:14px}
  .add-food-form{padding:14px}
}

/* ========================
   FOOD SELECTION MODE
   ======================== */

/* Food items are clickable */
.food-item{cursor:pointer;user-select:none}

/* Selected food item card */
.food-item--selected{
  background:var(--lime) !important;
  border-color:var(--fg) !important;
  box-shadow:3px 3px 0 0 var(--fg) !important;
  transform:scale(1.02);
  animation:foodPulse 1.5s ease-in-out infinite
}
@keyframes foodPulse{
  0%,100%{box-shadow:3px 3px 0 0 var(--fg)}
  50%{box-shadow:3px 3px 12px 2px rgba(190,242,100,.6)}
}

/* Floating selection bar */
.food-selection-bar{
  position:fixed;
  bottom:-80px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 22px;
  background:var(--fg);
  color:var(--white);
  border-radius:16px 16px 0 0;
  box-shadow:0 -4px 30px rgba(15,23,42,.3);
  z-index:1000;
  transition:bottom .35s cubic-bezier(.34,1.56,.64,1);
  max-width:600px;
  width:calc(100% - 32px)
}
.food-selection-bar.show{
  bottom:0
}
.food-selection-info{
  display:flex;
  align-items:center;
  gap:8px;
  flex:1;
  min-width:0;
  flex-wrap:wrap
}
.food-selection-icon{font-size:22px;flex-shrink:0}
.food-selection-name{
  font-weight:800;
  font-size:15px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:160px
}
.food-selection-cal{
  padding:3px 10px;
  background:var(--lime);
  color:var(--fg);
  border-radius:50px;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
  flex-shrink:0
}
.food-selection-arrow{
  font-size:18px;
  opacity:.5;
  flex-shrink:0
}
.food-selection-hint{
  font-size:13px;
  opacity:.7;
  white-space:nowrap
}
.food-selection-cancel{
  flex-shrink:0;
  width:36px;
  height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.15);
  border:2px solid rgba(255,255,255,.3);
  border-radius:50%;
  color:var(--white);
  font-size:16px;
  font-weight:700;
  cursor:pointer;
  transition:all .15s
}
.food-selection-cancel:hover{
  background:rgba(255,59,48,.8);
  border-color:rgba(255,59,48,1);
  transform:scale(1.1)
}

/* Page dimming during selection */
body.food-selecting .tracker-header,
body.food-selecting .summary-grid,
body.food-selecting .action-buttons,
body.food-selecting .food-ref-section{
  opacity:.4;
  pointer-events:none;
  transition:opacity .3s
}
body.food-selecting .table-wrapper{
  position:relative;
  z-index:10
}
body.food-selecting .food-ref-section{
  opacity:.5;
  pointer-events:auto
}

/* Selectable meal cells */
.meal-cell--selectable{
  position:relative;
  cursor:pointer !important;
  outline:2px dashed var(--lime);
  outline-offset:-2px;
  animation:cellGlow 1.2s ease-in-out infinite alternate;
  transition:all .2s
}
.meal-cell--selectable:hover{
  background:rgba(190,242,100,.2) !important;
  outline:3px solid var(--lime);
  outline-offset:-3px
}
.meal-cell--selectable .meal-input{
  pointer-events:none;
  opacity:.7
}
@keyframes cellGlow{
  0%{outline-color:rgba(190,242,100,.4)}
  100%{outline-color:rgba(190,242,100,1)}
}

/* Cell filled flash */
.meal-cell--filled{
  animation:cellFlash .8s ease-out !important
}
@keyframes cellFlash{
  0%{background:var(--lime)}
  100%{background:transparent}
}

/* Selection mode responsive */
@media(max-width:480px){
  .food-selection-bar{
    padding:12px 16px;
    gap:10px;
    border-radius:14px 14px 0 0
  }
  .food-selection-name{max-width:100px;font-size:13px}
  .food-selection-cal{font-size:11px;padding:2px 8px}
  .food-selection-arrow{display:none}
  .food-selection-hint{font-size:11px}
}
