:root{--night-primary:#8B5CF6;--night-primary-rgb:139,92,246;--night-accent:#EC4899;--night-accent-rgb:236,72,153;--night-food:#10B981;--night-food-rgb:16,185,129;--night-exercise:#F59E0B;--night-exercise-rgb:245,158,11;--night-emotion:#EC4899;--night-emotion-rgb:236,72,153;--night-positive:#10B981;--night-warning:#F59E0B;--night-negative:#EF4444;--night-bg-dark:#0F172A;--night-bg-mid:#1E293B;--night-bg-light:#334155;--night-glass-bg:rgba(255,255,255,0.05);--night-glass-border:rgba(255,255,255,0.1);--night-glass-hover:rgba(255,255,255,0.08);--night-text-primary:#E2E8F0;--night-text-secondary:#94A3B8;--night-text-muted:#64748B;--calendar-cell-size:16px}
.night-mode{min-height:100vh;color:var(--night-text-primary)}
.glass-card{background:var(--night-glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--night-glass-border);border-radius:16px}
.glass-card:hover{background:var(--night-glass-hover)}
.night-header{padding:16px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--night-glass-border);background:rgba(15,23,42,0.8);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}
.night-header__brand{display:flex;align-items:center;gap:12px}
.night-header__logo{width:44px;height:44px;background:linear-gradient(135deg,#22C55E,#16A34A);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 15px rgba(34,197,94,0.3)}
.night-header__title{margin:0;font-size:22px;font-weight:700}
.night-header__title-vir{color:#22C55E}
.night-header__title-tality{color:#E2E8F0}
.night-header__subtitle{margin:0;font-size:14px;color:var(--night-text-secondary)}
.night-header__nav{display:flex;align-items:center;gap:1.5rem}
.night-header__nav-link{color:#94A3B8;text-decoration:none;font-weight:600;font-size:0.9375rem;transition:color 0.2s;position:relative}
.night-header__nav-link:hover{color:#E2E8F0}
.night-header__nav-link::after{content:'';position:absolute;bottom:-0.375rem;left:0;width:0;height:2px;background:#22C55E;transition:width 0.2s}
.night-header__nav-link:hover::after{width:100%}
.night-header__nav-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:rgba(34,197,94,0.15);border:1px solid rgba(34,197,94,0.3);border-radius:8px;color:#22C55E;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s}
.night-header__nav-btn:hover{background:rgba(34,197,94,0.25);border-color:rgba(34,197,94,0.5)}
.night-header__nav-cta{display:inline-flex;align-items:center;padding:8px 16px;background:linear-gradient(135deg,#22C55E,#16A34A);color:white;text-decoration:none;font-weight:700;font-size:0.9375rem;border-radius:8px;box-shadow:0 4px 15px rgba(34,197,94,0.3);transition:all 0.2s}
.night-header__nav-cta:hover{background:linear-gradient(135deg,#16A34A,#15803D);transform:translateY(-1px);box-shadow:0 6px 20px rgba(34,197,94,0.4)}
.night-header__nav-cta--disabled{opacity:0.5;cursor:default;pointer-events:none}
.night-header__nav-settings{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:8px;cursor:pointer;transition:all 0.2s}
.night-header__nav-settings:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2)}
.night-nav{display:flex;gap:8px;padding:16px 24px;border-bottom:1px solid rgba(255,255,255,0.05)}
.night-nav__btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:1px solid transparent;border-radius:10px;cursor:pointer;color:var(--night-text-secondary);font-weight:500;font-size:14px;transition:all 0.2s ease}
.night-nav__btn:hover{background:rgba(255,255,255,0.05);color:var(--night-text-primary)}
.night-nav__btn.is-active{background:linear-gradient(135deg,rgba(139,92,246,0.3),rgba(236,72,153,0.3));border:1px solid rgba(139,92,246,0.5);color:var(--night-text-primary)}
.night-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;padding:24px;max-width:1400px;margin:0 auto}
@media (max-width:1024px){.night-layout{grid-template-columns:1fr}
}
.night-selectors{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.night-selector{display:flex;align-items:center;gap:12px;padding:16px;background:var(--night-glass-bg);border:1px solid var(--night-glass-border);border-radius:12px;cursor:pointer;transition:all 0.2s ease}
.night-selector:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,0.3)}
.night-selector--food{border-left:3px solid var(--night-food)}
.night-selector--exercise{border-left:3px solid var(--night-exercise)}
.night-selector--emotion{border-left:3px solid var(--night-emotion)}
.night-selector__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}
.night-selector--food .night-selector__icon{background:rgba(16,185,129,0.2)}
.night-selector--exercise .night-selector__icon{background:rgba(245,158,11,0.2)}
.night-selector--emotion .night-selector__icon{background:rgba(236,72,153,0.2)}
.night-selector__content{flex:1}
.night-selector__label{margin:0;font-size:14px;color:var(--night-text-secondary);text-transform:uppercase;letter-spacing:0.5px}
.night-selector__value{margin:4px 0 0 0;font-size:16px;font-weight:600;color:var(--night-text-primary)}
.night-simulation{background:var(--night-glass-bg);border:1px solid var(--night-glass-border);border-radius:16px;overflow:hidden}
.night-simulation__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--night-glass-border)}
.night-simulation__title-wrap{display:flex;flex-direction:column;gap:4px}
.night-simulation__title{margin:0;font-size:18px;font-weight:600;display:flex;align-items:center;gap:10px}
.night-simulation__title svg{color:var(--night-primary)}
.night-simulation__hint{margin:0;font-size:14px;color:#94A3B8;font-style:italic;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.night-simulation__done-btn{padding:4px 12px;background:rgba(139,92,246,0.2);border:1px solid rgba(139,92,246,0.4);border-radius:6px;color:#8B5CF6;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;font-style:normal}
.night-simulation__done-btn:hover{background:rgba(139,92,246,0.3)}
.night-view-toggle{display:flex;background:rgba(0,0,0,0.3);border-radius:8px;padding:4px}
.night-view-toggle__btn{padding:8px 16px;background:transparent;border:none;border-radius:6px;color:var(--night-text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s ease}
.night-view-toggle__btn.is-active{background:var(--night-primary);color:white}
.night-simulation__content{padding:24px;min-height:400px;display:flex;flex-direction:column;gap:16px}
.night-simulation__timeline-sync{margin-top:auto;border-top:1px solid rgba(255,255,255,0.1);padding-top:12px}
.night-simulation__calendar-panel{padding:0 24px 24px}
.night-calendar{background:var(--night-glass-bg);border:1px solid var(--night-glass-border);border-radius:16px;padding:20px;height:fit-content}
.night-calendar--heatmap{width:100%}
.night-calendar__header{margin-bottom:16px}
.night-calendar__header--compact{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.night-calendar__title-group{display:flex;align-items:center;gap:12px}
.night-calendar__title{margin:0;font-size:18px;font-weight:600;color:var(--night-text-primary)}
.night-calendar__subtitle{margin:2px 0 0 0;font-size:14px;color:var(--night-text-secondary)}
.night-calendar__selected{display:flex;flex-direction:column;align-items:flex-end;text-align:right;font-size:14px;color:var(--night-text-secondary)}
.night-calendar__selected-date{font-weight:600;color:var(--night-text-primary);font-size:14px}
.night-message{margin-top:20px;padding:16px 20px;background:rgba(139,92,246,0.1);border-radius:12px;border-left:4px solid var(--night-primary)}
.night-message p{margin:0;font-size:14px;line-height:1.6;color:var(--night-text-secondary)}
.night-btn{padding:12px 24px;border:none;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:all 0.2s ease}
.night-btn--primary{background:linear-gradient(135deg,var(--night-primary),var(--night-accent));color:white;box-shadow:0 4px 15px rgba(139,92,246,0.3)}
.night-btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(139,92,246,0.4)}
.night-btn--ghost{background:transparent;border:1px solid var(--night-glass-border);color:var(--night-text-primary)}
.night-btn--ghost:hover{background:var(--night-glass-bg)}
.night-empty{text-align:center;padding:60px 20px}
.night-empty__icon{font-size:48px;margin-bottom:16px}
.night-empty__title{margin:0 0 8px 0;font-size:18px;font-weight:600}
.night-empty__text{margin:0 0 24px 0;color:var(--night-text-secondary)}
@keyframes night-glow{0%,100%{box-shadow:0 0 20px rgba(139,92,246,0.3)}
50%{box-shadow:0 0 40px rgba(139,92,246,0.5)}
}
.night-glow{animation:night-glow 3s ease-in-out infinite}
.night-mode::-webkit-scrollbar{width:8px}
.night-mode::-webkit-scrollbar-track{background:var(--night-bg-dark)}
.night-mode::-webkit-scrollbar-thumb{background:var(--night-bg-light);border-radius:4px}
.night-mode::-webkit-scrollbar-thumb:hover{background:var(--night-primary)}
.night-layout--single{grid-template-columns:1fr;max-width:600px}
.night-settings{background:var(--night-glass-bg);border:1px solid var(--night-glass-border);border-radius:16px;overflow:hidden}
.night-settings__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--night-glass-border);background:rgba(139,92,246,0.05)}
.night-settings__title{margin:0;font-size:20px;font-weight:600;display:flex;align-items:center}
.night-settings__header-actions{display:flex;align-items:center;gap:12px}
.night-settings__randomize-all-btn{padding:8px 14px;background:rgba(139,92,246,0.15);border:1px solid rgba(139,92,246,0.3);border-radius:8px;color:#8B5CF6;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.night-settings__randomize-all-btn:hover{background:rgba(139,92,246,0.25);border-color:rgba(139,92,246,0.5)}
.night-settings__close{background:rgba(255,255,255,0.05);border:1px solid var(--night-glass-border);border-radius:8px;padding:8px;cursor:pointer;color:var(--night-text-secondary);transition:all 0.2s ease}
.night-settings__close:hover{background:rgba(239,68,68,0.2);border-color:rgba(239,68,68,0.3);color:#EF4444}
.night-settings__content{padding:24px;display:flex;flex-direction:column;gap:24px}
.night-settings__section{background:rgba(255,255,255,0.02);border:1px solid var(--night-glass-border);border-radius:12px;padding:20px}
.night-settings__section-title{margin:0 0 16px 0;font-size:14px;font-weight:600;color:var(--night-text-secondary);text-transform:uppercase;letter-spacing:0.5px;display:flex;align-items:center}
.night-settings__field{margin-bottom:16px}
.night-settings__field:last-child{margin-bottom:0}
.night-settings__label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--night-text-primary)}
.night-settings__input-group{display:flex;align-items:center;gap:12px}
.night-settings__input{flex:1;padding:12px 16px;background:rgba(255,255,255,0.05);border:1px solid var(--night-glass-border);border-radius:10px;color:var(--night-text-primary);font-size:16px;font-family:'Space Mono',monospace;transition:all 0.2s ease}
.night-settings__input:focus{outline:none;border-color:var(--night-primary);box-shadow:0 0 0 3px rgba(139,92,246,0.2)}
.night-settings__input::-webkit-inner-spin-button,.night-settings__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.night-settings__unit{font-size:14px;color:var(--night-text-muted);min-width:50px}
.night-settings__input-row{display:flex;align-items:center;gap:12px;justify-content:space-between}
.night-settings__input--small{width:60px;flex:none;text-align:center}
.night-settings__label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.night-settings__label-row .night-settings__label{margin-bottom:0}
.night-settings__unit-toggle{display:flex;background:rgba(0,0,0,0.3);border-radius:6px;padding:2px}
.night-settings__unit-btn{padding:4px 10px;background:transparent;border:none;border-radius:4px;color:var(--night-text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s}
.night-settings__unit-btn.is-active{background:var(--night-primary);color:white}
.night-settings__unit-btn:hover:not(.is-active){color:var(--night-text-primary)}
.night-settings__randomize-btn{padding:8px 14px;background:rgba(139,92,246,0.15);border:1px solid rgba(139,92,246,0.3);border-radius:8px;color:#8B5CF6;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.night-settings__randomize-btn:hover{background:rgba(139,92,246,0.25);border-color:rgba(139,92,246,0.5)}
.night-settings__select{flex:1;padding:12px 16px;background:rgba(255,255,255,0.05);border:1px solid var(--night-glass-border);border-radius:10px;color:var(--night-text-primary);font-size:14px;cursor:pointer;transition:all 0.2s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}
.night-settings__select:focus{outline:none;border-color:var(--night-primary);box-shadow:0 0 0 3px rgba(139,92,246,0.2)}
.night-settings__select option{background:var(--night-bg-mid);color:var(--night-text-primary);padding:12px}
.night-settings__info{display:flex;align-items:flex-start;gap:12px;padding:16px;background:rgba(139,92,246,0.1);border:1px solid rgba(139,92,246,0.2);border-radius:12px}
.night-settings__info p{margin:0;font-size:14px;line-height:1.6;color:var(--night-text-secondary)}
.night-settings__done-btn{width:100%;padding:14px 24px;background:#22C55E;border:none;border-radius:10px;color:white;font-size:16px;font-weight:600;cursor:pointer;transition:all 0.2s}
.night-settings__done-btn:hover{background:#16A34A;transform:translateY(-1px)}

.night-settings__btn-primary{padding:12px 24px;background:linear-gradient(135deg,#8B5CF6,#7C3AED);border:none;border-radius:10px;color:white;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;margin-top:8px}
.night-settings__btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,92,246,0.4)}
.night-settings__btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none;box-shadow:none}
.night-settings__btn-danger{padding:10px 20px;background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);border-radius:10px;color:#EF4444;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s}
.night-settings__btn-danger:hover{background:rgba(239,68,68,0.25)}
.night-layout-v2{display:grid;grid-template-columns:2fr 1fr;gap:24px;padding:24px;height:calc(100vh - 140px);max-width:100%}
.night-layout-v2__left{display:flex;flex-direction:column;gap:24px;min-width:0}
.night-layout-v2__right{display:flex;flex-direction:column;gap:24px;min-height:0;overflow:hidden}
.night-layout-v2__right .night-tracker-panel{flex:1;min-height:0;overflow:hidden}
.night-layout-v2__left .night-simulation{flex:1;display:flex;flex-direction:column}
.night-layout-v2__left .night-simulation__content{flex:1;min-height:350px}
.night-tracker-panel{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;background:var(--night-glass-bg);border:1px solid var(--night-glass-border);border-radius:16px;padding:20px}
.night-category-column{display:flex;flex-direction:column;gap:12px}
.night-category-column__header{display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--night-glass-border)}
.night-category-column__title{flex:1}
.night-category-column__search-btn{width:28px;height:28px;border-radius:8px;background:rgba(16,185,129,0.2);border:none;color:#10B981;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.night-category-column__search-btn:hover{background:rgba(16,185,129,0.3);transform:scale(1.05)}
.night-category-column__icon{font-size:20px}
.night-category-column__title{margin:0;font-size:16px;font-weight:600;color:var(--night-text-primary)}
.night-category-column__search{margin-bottom:12px}
.night-category-search{width:100%;padding:8px 12px;background:rgba(255,255,255,0.05);border:1px solid var(--night-glass-border);border-radius:8px;color:var(--night-text-primary);font-size:14px;outline:none;transition:all 0.2s ease;box-sizing:border-box}
.night-category-search:focus{border-color:var(--night-primary);background:rgba(255,255,255,0.08)}
.night-category-search::placeholder{color:var(--night-text-muted)}
.night-category-column__tags{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}
.night-category-column__empty{margin:0;padding:12px;text-align:center;color:var(--night-text-muted);font-size:14px}
.night-category-column__hint{margin:8px 0 0 0;padding:8px 12px;text-align:center;color:var(--night-text-muted);font-size:14px;font-style:italic}
.night-tag-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(255,255,255,0.03);border:1px solid var(--night-glass-border);border-radius:24px;cursor:pointer;transition:all 0.2s ease;width:fit-content;color:var(--night-text-primary);font-size:14px}
.night-tag-pill:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.2);transform:translateX(4px)}
.night-tag-pill.is-selected{background:linear-gradient(135deg,rgba(139,92,246,0.3),rgba(236,72,153,0.3));border-color:rgba(139,92,246,0.5)}
.night-tag-pill--add{background:rgba(139,92,246,0.15);border:1px dashed var(--night-primary);color:var(--night-primary)}
.night-tag-pill--add:hover{background:rgba(139,92,246,0.25);border-style:solid;transform:translateX(4px)}
.night-tag-pill--add .night-tag-pill__emoji{font-weight:700;font-size:14px}
.night-tag-pill__emoji{font-size:16px;line-height:1;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.night-tag-pill__emoji-img{display:block;width:20px;height:20px;background-size:contain;background-position:center;background-repeat:no-repeat;border-radius:2px;-webkit-touch-callout:none !important;-webkit-user-select:none !important;user-select:none !important;pointer-events:none !important}
.night-tag-pill__content{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.night-tag-pill__label{font-weight:500;white-space:nowrap}
.night-tag-pill__subtitle{font-size:14px;color:var(--night-text-muted);font-weight:400}
.night-tag-pill.has-subtitle{padding:8px 14px}
.night-category-column--food .night-tag-pill:hover{background:rgba(16,185,129,0.15);border-color:rgba(16,185,129,0.3)}
.night-category-column--exercise .night-tag-pill:hover{background:rgba(245,158,11,0.15);border-color:rgba(245,158,11,0.3)}
.night-category-column--emotion .night-tag-pill:hover{background:rgba(236,72,153,0.15);border-color:rgba(236,72,153,0.3)}
@media (max-width:1200px){.night-layout-v2{gap:16px;padding:16px}
.night-tracker-panel{padding:16px;gap:12px}
.night-tag-pill{padding:8px 12px;font-size:14px}
}
@media (max-width:1024px){.night-layout-v2{grid-template-columns:1fr}
.night-layout-v2__right{display:block}
}
@media (max-width:768px){.night-layout-v2{padding:12px;gap:12px}
.night-layout-v2__right{grid-template-columns:1fr}
.night-tracker-panel{grid-template-columns:1fr;gap:16px}
.night-category-column{background:rgba(255,255,255,0.02);border-radius:12px;padding:16px}
.night-category-column__tags{flex-direction:row;flex-wrap:wrap;gap:8px}
.night-tag-pill{padding:8px 14px}
}
@media (max-width:480px){.night-tracker-panel{padding:12px}
.night-category-column{padding:12px}
.night-tag-pill{padding:6px 10px;font-size:16px;gap:6px}
.night-tag-pill__emoji{font-size:16px}
}
/* ============================================
   GAMIFIED FOOD BROWSER STYLES
   ============================================ */

/* GI Guide Legend */
.gi-guide{
  background:rgba(255,255,255,0.05);
  border:2px solid rgba(255,255,255,0.1);
  border-radius:16px;
  padding:16px
}
.gi-guide__title{
  font-size:14px;
  font-weight:700;
  color:#94A3B8;
  margin-bottom:12px;
  letter-spacing:0.5px;
  display:flex;
  align-items:center;
  gap:6px
}
.gi-guide__citation{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:16px;
  height:16px;
  border-radius:50%;
  background:rgba(139,92,246,0.2);
  color:#8B5CF6;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition:all 0.2s
}
.gi-guide__citation:hover{
  background:rgba(139,92,246,0.4);
  color:#fff
}
.food-card__citation{
  position:absolute;
  top:6px;
  right:6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:16px;
  height:16px;
  border-radius:50%;
  background:rgba(139,92,246,0.2);
  color:#8B5CF6;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition:all 0.2s;
  z-index:10
}
.food-card__citation:hover{
  background:rgba(139,92,246,0.4);
  color:#fff
}
.food-info__citation{
  position:absolute;
  top:12px;
  right:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
  border-radius:50%;
  background:rgba(139,92,246,0.2);
  color:#8B5CF6;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition:all 0.2s;
  z-index:10
}
.food-info__citation:hover{
  background:rgba(139,92,246,0.4);
  color:#fff
}
.gi-guide__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:8px
}
.gi-guide__row:last-child{margin-bottom:0}
.gi-guide__color-label{
  display:flex;
  align-items:center;
  gap:8px
}
.gi-guide__dot{
  width:12px;
  height:12px;
  border-radius:4px
}
.gi-guide__color-label span{
  font-size:14px;
  color:#CBD5E1
}
.gi-guide__stars{
  display:flex;
  gap:2px
}
.gi-guide__star{
  font-size:14px;
  color:#374151
}
.gi-guide__star.is-filled{
  color:#FBBF24
}

/* GI/GL Guide Wrapper - side by side layout */
.gi-gl-guide-wrapper{
  display:flex;
  gap:12px
}
.gi-gl-guide-wrapper .gi-guide{
  flex:1
}

/* Gamified Food Card */
.food-card{
  background:rgba(255,255,255,0.05);
  border-radius:20px;
  padding:16px;
  cursor:pointer;
  transition:all 0.3s cubic-bezier(0.175,0.885,0.32,1.275);
  border:2px solid rgba(255,255,255,0.1);
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px
}
.food-card:hover{
  transform:translateY(-8px) scale(1.02);
  border-color:rgba(255,255,255,0.3);
  box-shadow:0 8px 25px rgba(0,0,0,0.3)
}
.food-card:active{
  transform:scale(0.98)
}
.food-card::before{
  content:'';
  position:absolute;
  top:-50%;
  left:-50%;
  width:200%;
  height:200%;
  background:linear-gradient(45deg,transparent,rgba(255,255,255,0.1),transparent);
  transform:rotate(45deg);
  transition:all 0.5s;
  opacity:0
}
.food-card:hover::before{
  opacity:1;
  animation:food-card-shine 0.5s ease-in-out
}
@keyframes food-card-shine{
  from{transform:translateX(-100%) rotate(45deg)}
  to{transform:translateX(100%) rotate(45deg)}
}
.food-card__emoji-wrap{
  font-size:48px;
  text-align:center;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,0.3))
}
.food-card__emoji-img{
  width:48px;
  height:48px;
  object-fit:contain;
  border-radius:8px
}
.food-card__emoji{
  font-size:48px;
  line-height:1
}
.food-card__name{
  font-weight:700;
  font-size:14px;
  text-align:center;
  color:#E2E8F0
}
.food-card__stars{
  display:flex;
  gap:2px;
  justify-content:center
}
.food-card__star{
  font-size:14px;
  color:#374151
}
.food-card__star.is-filled{
  color:#FBBF24
}
.food-card__footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  width:100%;
  gap:8px;
  margin-top:4px
}
.food-card__gi-pill{
  padding:6px 12px;
  border-radius:20px;
  font-size:14px;
  font-weight:700
}
.food-card__gi-pill--na{
  background:rgba(100,116,139,0.2);
  color:#64748B
}
.food-card__xp-badge{
  display:flex;
  align-items:center;
  gap:4px;
  padding:4px 10px;
  background:linear-gradient(135deg,#22C55E,#16A34A);
  border-radius:12px;
  font-size:14px;
  font-weight:700;
  color:white
}
.food-card__xp-icon{
  font-size:14px
}

/* Night Tracker Panel - History Layout */
.night-tracker-panel--history{
  display:flex;
  flex-direction:column;
  padding:20px;
  gap:16px
}
.night-tracker-panel__history{
  flex:1;
  display:flex;
  flex-direction:column;
  min-height:0
}
.night-tracker-panel__empty-state{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:var(--night-text-muted);
  padding:40px 20px
}
.night-tracker-panel__empty-icon{
  font-size:48px;
  opacity:0.5
}
.night-tracker-panel__empty-text{
  margin:0;
  font-size:14px;
  text-align:center
}
.night-tracker-panel__history-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow-y:auto;
  flex:1
}
.night-tracker-panel__history-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  background:rgba(255,255,255,0.03);
  border-radius:12px;
  border-left:3px solid #8B5CF6;
  transition:all 0.2s
}
.night-tracker-panel__history-item:hover{
  background:rgba(255,255,255,0.06)
}
.night-tracker-panel__history-emoji{
  font-size:24px;
  line-height:1;
  flex-shrink:0
}
.night-tracker-panel__history-info{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0
}
.night-tracker-panel__history-title{
  font-size:14px;
  font-weight:500;
  color:var(--night-text-primary);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis
}
.night-tracker-panel__history-time{
  font-size:14px;
  color:var(--night-text-muted)
}
.night-tracker-panel__history-delete{
  width:24px;
  height:24px;
  border-radius:6px;
  border:none;
  background:transparent;
  color:var(--night-text-muted);
  font-size:18px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:all 0.2s
}
.night-tracker-panel__history-item:hover .night-tracker-panel__history-delete{
  opacity:1
}
.night-tracker-panel__history-delete:hover{
  background:rgba(239,68,68,0.2);
  color:#EF4444
}
.night-tracker-panel--gamified .night-tracker-panel__search-wrap{
  max-width:100%
}
.night-tracker-panel__cards .night-tracker-panel__empty-state{
  grid-column:1 / -1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:60px 20px;
  color:var(--night-text-muted)
}
.night-tracker-panel__empty-icon{
  font-size:48px;
  opacity:0.5
}
.night-tracker-panel__empty-text{
  margin:0;
  font-size:14px;
  text-align:center
}
.night-tracker-panel__card-wrap{
  position:relative;
  transition:transform 0.2s ease, opacity 0.2s ease;
  cursor:pointer;
  user-select:none;
  -webkit-user-select:none
}
.night-tracker-panel__card-wrap:active{
  transform:scale(0.97)
}
.night-tracker-panel__card-wrap.show-delete{
  /* No wiggle - just show delete button */
}
@keyframes wiggle{
  0%,100%{transform:rotate(-1deg)}
  50%{transform:rotate(1deg)}
}
.night-tracker-panel__delete-btn{
  position:absolute;
  top:8px;
  left:8px;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#8B5CF6;
  border:1px solid #0F172A;
  color:white;
  font-size:6px;
  font-weight:bold;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10;
  box-shadow:0 1px 4px rgba(0,0,0,0.3);
  transition:transform 0.15s ease
}
.night-tracker-panel__delete-btn:hover{
  transform:scale(1.15);
  background:#DC2626
}
.night-tracker-panel__hint{
  text-align:center;
  color:var(--night-text-muted);
  font-size:14px;
  margin:8px 0 0 0;
  opacity:0.7
}

/* Night Tracker Panel - Gamified Layout */
.night-tracker-panel--gamified{
  display:flex;
  flex-direction:column;
  padding:20px;
  min-height:0;
  overflow:hidden
}
.night-tracker-panel__main{
  display:flex;
  flex-direction:column;
  gap:16px;
  flex:1;
  min-height:0;
  overflow:hidden
}
.night-tracker-panel__header{
  display:flex;
  gap:12px;
  align-items:center
}
.night-tracker-panel__search-wrap{
  position:relative;
  flex:1;
  max-width:280px
}
.night-tracker-panel__search-icon{
  position:absolute;
  left:26px;
  top:50%;
  transform:translateY(-50%);
  font-size:14px
}
.night-tracker-panel__search{
  width:100%;
  padding:12px 12px 12px 42px;
  background:rgba(255,255,255,0.08);
  border:2px solid rgba(255,255,255,0.1);
  border-radius:16px;
  color:#E2E8F0;
  font-size:14px;
  font-weight:500;
  outline:none;
  transition:all 0.2s;
  box-sizing:border-box;
  pointer-events:none
}
.night-tracker-panel__search:focus{
  border-color:#8B5CF6;
  background:rgba(255,255,255,0.1)
}
.night-tracker-panel__search::placeholder{
  color:#64748B
}
.night-tracker-panel__sort-btns{
  display:flex;
  gap:8px
}
.night-tracker-panel__sort-btn{
  padding:10px 16px;
  background:rgba(255,255,255,0.08);
  border:2px solid rgba(255,255,255,0.1);
  border-radius:25px;
  color:#94A3B8;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s
}
.night-tracker-panel__sort-btn:hover{
  background:rgba(255,255,255,0.12);
  transform:scale(1.05)
}
.night-tracker-panel__sort-btn.is-active{
  background:linear-gradient(135deg,#8B5CF6,#6366F1);
  border-color:transparent;
  color:white
}
.night-tracker-panel__sort-arrow{
  margin-left:4px;
  font-size:14px
}
.night-tracker-panel__toggles{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:12px
}
.night-tracker-panel__view-toggle{
  display:flex;
  background:rgba(255,255,255,0.05);
  border-radius:10px;
  padding:4px;
  gap:4px
}
.night-tracker-panel__toggle-btn{
  flex:1;
  padding:8px 12px;
  background:transparent;
  border:none;
  border-radius:8px;
  color:#94A3B8;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s
}
.night-tracker-panel__toggle-btn:hover{
  background:rgba(255,255,255,0.08);
  color:#E2E8F0
}
.night-tracker-panel__toggle-btn.is-active{
  background:linear-gradient(135deg,rgba(139,92,246,0.3),rgba(236,72,153,0.3));
  color:white
}
.night-tracker-panel__cards{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(120px,1fr));
  gap:12px;
  flex:1;
  min-height:0;
  overflow-y:auto;
  padding-right:8px;
  align-content:start
}
.night-tracker-panel__cards::-webkit-scrollbar{width:6px}
.night-tracker-panel__cards::-webkit-scrollbar-track{background:rgba(255,255,255,0.05);border-radius:3px}
.night-tracker-panel__cards::-webkit-scrollbar-thumb{background:rgba(139,92,246,0.4);border-radius:3px}
.night-tracker-panel__cards::-webkit-scrollbar-thumb:hover{background:rgba(139,92,246,0.6)}
.night-tracker-panel__empty{
  grid-column:1 / -1;
  text-align:center;
  color:#64748B;
  padding:20px;
  font-size:14px
}
.night-tracker-panel__hint{
  text-align:center;
  color:#64748B;
  font-size:14px;
  font-style:italic;
  margin:0
}

/* Responsive adjustments for gamified panel */
@media (max-width:900px){
  .gi-guide{
    padding:12px
  }
}
@media (max-width:600px){
  .night-tracker-panel__header{
    flex-wrap:wrap
  }
  .night-tracker-panel__search-wrap{
    max-width:100%;
    order:1;
    flex-basis:100%
  }
  .night-tracker-panel__toggles{
    gap:8px
  }
  .night-tracker-panel__view-toggle{
    flex-wrap:nowrap
  }
  .night-tracker-panel__toggle-btn{
    padding:6px 8px;
    font-size:16px
  }
  .night-tracker-panel__sort-btns{
    justify-content:center
  }
  .night-tracker-panel__sort-btn{
    padding:6px 10px;
    font-size:16px
  }
  .night-tracker-panel__cards{
    grid-template-columns:repeat(auto-fill,minmax(100px,1fr))
  }
  .food-card{
    padding:12px
  }
  .food-card__emoji-wrap{
    font-size:36px
  }
  .food-card__emoji{
    font-size:36px
  }
  .food-card__emoji-img{
    width:36px;
    height:36px
  }
  .food-card__name{
    font-size:16px
  }
  .food-card__star{
    font-size:16px
  }
  .food-card__gi-pill{
    padding:4px 8px;
    font-size:16px
  }
  .food-card__xp-badge{
    padding:3px 8px;
    font-size:16px
  }
}

/* Right column responsive - tablet landscape */
@media (max-width:1200px){
  .night-layout-v2__right{
    gap:16px
  }
  .night-tracker-panel--gamified{
    padding:16px
  }
  .night-tracker-panel__cards{
    grid-template-columns:repeat(auto-fill,minmax(110px,1fr));
    gap:10px
  }
}

/* Right column responsive - tablet portrait */
@media (max-width:1024px){
  .night-layout-v2__right{
    display:flex;
    flex-direction:column;
    gap:16px;
    max-height:none;
    overflow:visible
  }
  .night-layout-v2__right .night-tracker-panel{
    flex:none;
    max-height:500px;
    overflow:hidden
  }
  .night-tracker-panel__cards{
    grid-template-columns:repeat(auto-fill,minmax(100px,1fr));
    max-height:300px
  }
}

/* Right column responsive - mobile landscape */
@media (max-width:768px){
  .night-layout-v2__right{
    gap:12px
  }
  .night-tracker-panel--gamified{
    padding:14px
  }
  .night-tracker-panel__main{
    gap:12px
  }
  .night-tracker-panel__toggles{
    flex-direction:column;
    gap:8px
  }
  .night-tracker-panel__view-toggle{
    width:100%;
    justify-content:center
  }
  .night-tracker-panel__sort-btns{
    width:100%;
    justify-content:center
  }
  .night-tracker-panel__cards{
    grid-template-columns:repeat(auto-fill,minmax(90px,1fr));
    gap:8px;
    max-height:250px
  }
  .food-card{
    padding:10px
  }
  .food-card__emoji-wrap{
    font-size:32px
  }
  .food-card__emoji{
    font-size:32px
  }
  .food-card__emoji-img{
    width:32px;
    height:32px
  }
  .food-card__name{
    font-size:16px
  }
}

/* Right column responsive - mobile portrait */
@media (max-width:480px){
  .night-tracker-panel--gamified{
    padding:12px
  }
  .night-tracker-panel__search-wrap{
    padding:10px 14px
  }
  .night-tracker-panel__search{
    font-size:16px
  }
  .night-tracker-panel__toggle-btn{
    padding:6px 10px;
    font-size:16px
  }
  .night-tracker-panel__sort-btn{
    padding:5px 8px;
    font-size:16px
  }
  .night-tracker-panel__cards{
    grid-template-columns:repeat(auto-fill,minmax(80px,1fr));
    gap:6px;
    max-height:200px
  }
  .food-card{
    padding:8px;
    border-radius:10px
  }
  .food-card__emoji-wrap{
    font-size:28px
  }
  .food-card__emoji{
    font-size:28px
  }
  .food-card__emoji-img{
    width:28px;
    height:28px
  }
  .food-card__name{
    font-size:16px
  }
  .food-card__gi-pill{
    padding:3px 6px;
    font-size:16px
  }
  .night-tracker-panel__hint{
    font-size:16px
  }
}

/* ============================================
   FOOD INFO CARD MODAL
   ============================================ */
.food-info-overlay{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(0,0,0,0.8);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1000;
  backdrop-filter:blur(8px);
  animation:food-info-fade-in 0.2s ease-out
}
@keyframes food-info-fade-in{
  from{opacity:0}
  to{opacity:1}
}
.food-info-card{
  position:relative;
  width:360px;
  max-width:90vw;
  max-height:90vh;
  overflow-y:auto;
  background:linear-gradient(180deg,#1E1B2E 0%,#151222 100%);
  border-radius:28px;
  padding:28px;
  border:2px solid rgba(255,255,255,0.1);
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  animation:food-info-pop 0.3s cubic-bezier(0.175,0.885,0.32,1.275)
}
@keyframes food-info-pop{
  from{transform:scale(0.8);opacity:0}
  to{transform:scale(1);opacity:1}
}
.food-info__badge{
  padding:8px 20px;
  border-radius:20px;
  font-size:14px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px
}
.food-info__emoji-wrap{
  font-size:80px;
  animation:food-info-float 3s ease-in-out infinite;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,0.4))
}
@keyframes food-info-float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-10px) rotate(3deg)}
}
.food-info__emoji-img{
  width:80px;
  height:80px;
  object-fit:contain;
  border-radius:12px
}
.food-info__emoji{
  font-size:80px;
  line-height:1
}
.food-info__name{
  margin:0;
  font-size:24px;
  font-weight:800;
  color:#E2E8F0;
  text-align:center
}
.food-info__stars{
  display:flex;
  gap:4px;
  justify-content:center
}
.food-info__star{
  font-size:24px;
  color:#374151
}
.food-info__star.is-filled{
  color:#FBBF24
}
.food-info__metrics{
  display:flex;
  gap:12px;
  width:100%
}
.food-info__metric{
  flex:1;
  padding:14px 12px;
  border-radius:16px;
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:4px
}
.food-info__metric--xp{
  background:rgba(34,197,94,0.15)
}
.food-info__metric-label{
  font-size:14px;
  color:#94A3B8;
  text-transform:uppercase;
  letter-spacing:0.5px
}
.food-info__metric-value{
  font-size:26px;
  font-weight:800
}
.food-info__metric-value--xp{
  color:#22C55E
}
.food-info__nutrition{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  width:100%
}
.food-info__nutrition-box{
  padding:14px 12px;
  background:rgba(255,255,255,0.05);
  border-radius:14px;
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:4px
}
.food-info__nutrition-label{
  font-size:14px;
  color:#64748B;
  text-transform:uppercase;
  letter-spacing:0.5px
}
.food-info__nutrition-value{
  font-size:20px;
  font-weight:700;
  color:#E2E8F0
}
.food-info__nutrition-unit{
  font-size:14px;
  color:#64748B;
  font-weight:400
}
.food-info__log-btn{
  width:100%;
  padding:18px 32px;
  background:linear-gradient(135deg,#22C55E,#16A34A);
  border:none;
  border-radius:18px;
  color:white;
  font-size:18px;
  font-weight:800;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  box-shadow:0 8px 24px rgba(34,197,94,0.4);
  transition:all 0.2s ease;
  margin-top:8px
}
.food-info__log-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(34,197,94,0.5)
}
.food-info__log-btn:active{
  transform:scale(0.98)
}
.food-info__log-icon{
  font-size:20px
}

/* Mobile adjustments for food info card */
@media (max-width:480px){
  .food-info-card{
    padding:20px;
    border-radius:20px
  }
  .food-info__emoji-wrap{
    font-size:64px
  }
  .food-info__emoji-img{
    width:64px;
    height:64px
  }
  .food-info__emoji{
    font-size:64px
  }
  .food-info__name{
    font-size:20px
  }
  .food-info__star{
    font-size:20px
  }
  .food-info__metric{
    padding:12px 8px
  }
  .food-info__metric-value{
    font-size:22px
  }
  .food-info__nutrition-box{
    padding:12px 8px
  }
  .food-info__nutrition-value{
    font-size:18px
  }
  .food-info__log-btn{
    padding:16px 24px;
    font-size:16px
  }
}

/* ============================================
   GAMIFICATION STATS (XP, Streak, Daily Goal)
   ============================================ */
.night-simulation__stats{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
  padding:16px 20px;
  border-bottom:1px solid var(--night-glass-border)
}
.game-stat{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  background:rgba(255,255,255,0.05);
  border-radius:14px;
  border:2px solid rgba(255,255,255,0.08)
}
.game-stat--xp{
  background:linear-gradient(135deg,rgba(34,197,94,0.15),rgba(22,163,74,0.08))
}
.game-stat--streak{
  background:linear-gradient(135deg,rgba(249,115,22,0.15),rgba(234,88,12,0.08))
}
.game-stat--goal{
  background:linear-gradient(135deg,rgba(168,85,247,0.15),rgba(124,58,237,0.08))
}
.game-stat--daily-xp{
  background:linear-gradient(135deg,rgba(34,197,94,0.15),rgba(22,163,74,0.08))
}
.game-stat__icon{
  width:40px;
  height:40px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0
}
.game-stat--xp .game-stat__icon{
  background:linear-gradient(135deg,#22C55E,#16A34A)
}
.game-stat--streak .game-stat__icon{
  background:linear-gradient(135deg,#F97316,#EA580C)
}
.game-stat--goal .game-stat__icon{
  background:linear-gradient(135deg,#A855F7,#7C3AED)
}
.game-stat--daily-xp .game-stat__icon{
  background:linear-gradient(135deg,#22C55E,#16A34A)
}
.game-stat__content{
  display:flex;
  flex-direction:column;
  gap:2px
}
.game-stat__content--wide{
  flex:1
}
.game-stat__label{
  font-size:14px;
  font-weight:600;
  color:#94A3B8;
  letter-spacing:0.5px
}
.game-stat__value{
  font-size:20px;
  font-weight:800
}
.game-stat__value--xp{
  color:#22C55E
}
.game-stat__value--streak{
  color:#F97316
}
.game-stat__value--daily-xp{
  color:#22C55E
}
.game-stat__value--goal{
  color:#A855F7
}
.game-stat__goal-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:6px
}
.game-stat__goal-count{
  font-size:14px;
  font-weight:700;
  color:#A855F7
}
.game-stat__progress{
  height:10px;
  background:rgba(255,255,255,0.1);
  border-radius:8px;
  overflow:hidden;
  position:relative
}
.game-stat__progress-fill{
  height:100%;
  background:linear-gradient(90deg,#A855F7,#7C3AED);
  border-radius:8px;
  transition:width 0.5s ease-out;
  position:relative
}
.game-stat__progress-fill::after{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:50%;
  background:linear-gradient(180deg,rgba(255,255,255,0.3),transparent);
  border-radius:8px 8px 0 0
}
.game-stat__complete-star{
  font-size:24px;
  animation:game-stat-bounce 1s ease-in-out infinite
}
@keyframes game-stat-bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

/* Responsive adjustments for game stats */
@media (max-width:900px){
  .night-simulation__stats{
    grid-template-columns:repeat(3, 1fr);
    gap:10px
  }
}
@media (max-width:600px){
  .night-simulation__stats{
    grid-template-columns:repeat(2, 1fr);
    padding:10px 14px;
    gap:10px
  }
  .game-stat{
    padding:10px 12px;
    gap:10px
  }
  .game-stat__icon{
    width:32px;
    height:32px
  }
  .game-stat__icon svg{
    width:16px;
    height:16px
  }
  .game-stat__label{
    font-size:16px
  }
  .game-stat__value{
    font-size:18px
  }
  /* Hide plants on mobile */
  .food-stack-timeline__energy{
    display:none
  }
  /* Smaller Daily History */
  .food-stack-heatmap__item{
    width:36px;
    height:36px
  }
  .food-stack-heatmap__emoji{
    font-size:20px
  }
  .food-stack-heatmap__emoji-img{
    width:24px;
    height:24px
  }
  .food-stack-heatmap__hour{
    font-size:16px
  }
  .night-simulation__header{
    padding:14px 16px
  }
  .night-simulation__title{
    font-size:16px
  }
  .night-simulation__content{
    padding:14px
  }
  .night-header__title{
    font-size:18px
  }
  .night-header__subtitle{
    font-size:16px
  }
  /* Mobile: prevent page scroll, fixed layout */
  body, html{
    overflow:hidden !important;
    height:100vh !important
  }
  .night-mode{
    overflow-y:auto !important;
    height:100vh !important
  }
  /* Mobile layout: grid with reversed order */
  .night-layout-v2{
    display:grid !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    grid-template-areas:"right" "left" !important;
    height:auto !important;
    padding:12px !important;
    gap:16px !important;
    overflow-x:hidden !important;
    max-width:100vw !important
  }
  .night-mode .night-layout-v2 .night-layout-v2__left{
    grid-area:left;
    width:calc(100vw - 24px);
    max-width:calc(100vw - 24px);
    overflow:hidden;
    box-sizing:border-box
  }
  .night-mode .night-layout-v2 .night-layout-v2__right{
    grid-area:right;
    width:calc(100vw - 24px);
    max-width:calc(100vw - 24px);
    overflow:hidden;
    box-sizing:border-box
  }
  .night-mode .night-tracker-panel{
    width:100%;
    max-width:100%;
    overflow:hidden;
    box-sizing:border-box
  }
  .night-mode .night-tracker-panel__main{
    width:100%;
    max-width:100%;
    overflow:hidden;
    box-sizing:border-box
  }
  .night-tracker-panel{
    max-height:none !important;
    overflow:visible !important
  }
  .night-tracker-panel__cards{
    display:flex !important;
    flex-wrap:nowrap !important;
    overflow-x:scroll !important;
    overflow-y:hidden !important;
    gap:10px !important;
    padding:12px !important;
    -webkit-overflow-scrolling:touch;
    background:rgba(255,255,255,0.03) !important;
    border:1px solid rgba(255,255,255,0.1) !important;
    border-radius:12px !important;
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important
  }
  .night-tracker-panel__cards .rarity-food-card{
    flex-shrink:0 !important;
    width:120px !important
  }
  .night-simulation,
  .night-simulation__content{
    min-height:auto !important;
    overflow:visible !important
  }
}

/* Rarity Food Search Modal */
.rarity-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.85);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.rarity-modal{width:100%;max-width:600px;max-height:90vh;background:linear-gradient(180deg,#1F2937 0%,#111827 100%);border-radius:24px;padding:24px;overflow-y:auto;animation:rarity-slide-up 0.3s ease-out}
@keyframes rarity-slide-up{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes rarity-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}
.rarity-search-input-wrap{position:relative;margin-bottom:16px}
.rarity-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:18px}
.rarity-search-input{width:100%;padding:16px 16px 16px 50px;background:rgba(255,255,255,0.05);border:2px solid rgba(255,255,255,0.1);border-radius:16px;color:#E2E8F0;font-size:16px;outline:none;transition:border-color 0.2s}
.rarity-search-input:focus{border-color:rgba(139,92,246,0.5)}
.rarity-spinner{position:absolute;right:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;border:2px solid rgba(255,255,255,0.2);border-top-color:#8B5CF6;border-radius:50%;animation:spin 0.8s linear infinite}
.rarity-tabs{display:flex;gap:4px;padding:4px;background:rgba(255,255,255,0.03);border-radius:16px;margin-bottom:16px}
.rarity-tab{flex:1;padding:12px;background:transparent;border:none;color:#64748B;font-size:16px;font-weight:700;cursor:pointer;border-radius:12px;transition:all 0.2s}
.rarity-tab.active{background:linear-gradient(135deg,#8B5CF6,#6366F1);color:white}
.rarity-source-toggle{display:flex;gap:8px;margin-bottom:12px}
.rarity-source-btn{flex:1;padding:10px;background:rgba(255,255,255,0.05);border:2px solid rgba(255,255,255,0.1);border-radius:10px;color:#94A3B8;font-size:16px;font-weight:600;cursor:pointer;transition:all 0.2s}
.rarity-source-btn.active{background:rgba(139,92,246,0.2);border-color:rgba(139,92,246,0.5);color:#A78BFA}
.rarity-sort-buttons{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.rarity-sort-btn{padding:10px 16px;background:rgba(255,255,255,0.05);border:2px solid rgba(255,255,255,0.1);border-radius:12px;color:#94A3B8;font-size:16px;font-weight:700;cursor:pointer;transition:all 0.2s}
.rarity-sort-btn:hover{background:rgba(255,255,255,0.08)}
.rarity-sort-btn.active{background:linear-gradient(135deg,#8B5CF6,#6366F1);border-color:transparent;color:white}
.rarity-error{color:#EF4444;font-size:16px;margin-bottom:12px}
.rarity-food-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:16px;max-height:400px;overflow-y:auto;padding-right:4px}
.rarity-food-grid::-webkit-scrollbar{width:6px}
.rarity-food-grid::-webkit-scrollbar-track{background:rgba(255,255,255,0.05);border-radius:3px}
.rarity-food-grid::-webkit-scrollbar-thumb{background:rgba(139,92,246,0.4);border-radius:3px}
.rarity-food-card{background:rgba(255,255,255,0.03);border-radius:16px;padding:12px;cursor:pointer;transition:all 0.3s cubic-bezier(0.175,0.885,0.32,1.275);position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;border:2px solid rgba(139,92,246,0.4)}
.rarity-citation-link{position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,0.1);color:#94A3B8;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all 0.2s;z-index:2}
.rarity-citation-link:hover{background:rgba(139,92,246,0.3);color:#A78BFA}
.rarity-citation-link--modal{top:12px;right:12px;width:24px;height:24px;font-size:16px}
.report-inaccuracy-link{display:block;text-align:center;margin-top:16px;padding:10px 16px;color:#94A3B8;font-size:16px;text-decoration:none;transition:all 0.2s;border-radius:8px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08)}
.report-inaccuracy-link:hover{color:#F59E0B;background:rgba(245,158,11,0.1);border-color:rgba(245,158,11,0.3)}
.rarity-food-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px rgba(139,92,246,0.2)}
/* Rarity-specific styles - COMMENTED OUT
.rarity-food-card.legendary{border:2px solid rgba(245,158,11,0.5);background:linear-gradient(135deg,rgba(245,158,11,0.1),transparent)}
.rarity-food-card.legendary:hover{box-shadow:0 12px 40px rgba(245,158,11,0.3)}
.rarity-food-card.epic{border:2px solid rgba(168,85,247,0.5);background:linear-gradient(135deg,rgba(168,85,247,0.1),transparent)}
.rarity-food-card.epic:hover{box-shadow:0 12px 40px rgba(168,85,247,0.3)}
.rarity-food-card.rare{border:2px solid rgba(59,130,246,0.5);background:linear-gradient(135deg,rgba(59,130,246,0.1),transparent)}
.rarity-food-card.rare:hover{box-shadow:0 12px 40px rgba(59,130,246,0.3)}
.rarity-food-card.common{border:2px solid rgba(107,114,128,0.3)}
.rarity-food-card.common:hover{box-shadow:0 12px 40px rgba(0,0,0,0.3)}
*/
/* Rarity badge - COMMENTED OUT
.rarity-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;margin-bottom:8px}
.rarity-badge-emoji{font-size:14px}
.rarity-badge-name{font-size:9px;font-weight:800;color:white;letter-spacing:0.5px}
*/
.rarity-food-emoji{font-size:40px;text-align:center;margin-bottom:6px;line-height:1}
/* Floating animation - COMMENTED OUT
.rarity-food-emoji.floating{animation:rarity-float 3s ease-in-out infinite}
*/
.rarity-food-emoji-img{display:block;width:40px;height:40px;margin:0 auto;background-size:contain;background-position:center;background-repeat:no-repeat;-webkit-touch-callout:none !important;-webkit-user-select:none !important;user-select:none !important;pointer-events:none !important}
.rarity-food-name{text-align:center;font-weight:700;font-size:16px;margin-bottom:8px;white-space:normal;overflow:hidden;text-overflow:ellipsis;max-width:100%;color:#E2E8F0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;min-height:2.6em}
.rarity-food-footer{display:flex;justify-content:space-between;align-items:center;width:100%;gap:6px}
.rarity-gi-pill{padding:3px 8px;border-radius:6px;border:1.5px solid;font-size:16px;font-weight:700}
/* XP pill - COMMENTED OUT
.rarity-xp-pill{display:flex;align-items:center;gap:2px;padding:3px 8px;background:linear-gradient(135deg,#22C55E,#16A34A);border-radius:6px;font-size:14px;font-weight:700;color:white}
*/
.rarity-loading,.rarity-hint,.rarity-empty{grid-column:1/-1;text-align:center;color:#64748B;padding:24px;font-size:16px}
.rarity-loading-text{text-align:center;color:#64748B;padding:12px;font-size:16px}
.rarity-spinner-large{display:block;width:32px;height:32px;margin:0 auto 12px;border:3px solid rgba(255,255,255,0.2);border-top-color:#8B5CF6;border-radius:50%;animation:spin 0.8s linear infinite}
.rarity-guide{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:8px;padding:12px 16px;background:rgba(17,24,39,0.95);border-radius:12px;border:1px solid rgba(255,255,255,0.1);margin-bottom:16px}
.rarity-guide-item{display:flex;align-items:center;gap:4px}
.rarity-guide-emoji{font-size:16px}
.rarity-guide-name{font-size:16px;font-weight:700}
.rarity-guide-xp{font-size:16px;font-weight:700;color:#22C55E;background:rgba(34,197,94,0.15);padding:2px 5px;border-radius:4px}
.rarity-btn-cancel{width:100%;padding:14px;background:rgba(255,255,255,0.05);border:2px solid rgba(255,255,255,0.1);border-radius:12px;color:#94A3B8;font-size:16px;font-weight:600;cursor:pointer;transition:all 0.2s}
.rarity-btn-cancel:hover{background:rgba(255,255,255,0.08)}
/* Preview Modal */
.rarity-back-btn{background:transparent;border:none;color:#94A3B8;font-size:16px;font-weight:700;cursor:pointer;padding:0;margin-bottom:16px}
.rarity-preview-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:14px;margin:0 auto 20px}
.rarity-preview-banner-emoji{font-size:18px}
.rarity-preview-banner-name{font-size:16px;font-weight:900;color:white;letter-spacing:1px}
.rarity-preview-emoji{font-size:80px;text-align:center;margin-bottom:12px;line-height:1}
/* Floating animation for preview - COMMENTED OUT
.rarity-preview-emoji.floating{animation:rarity-float 3s ease-in-out infinite}
*/
.rarity-preview-emoji-img{display:block;width:80px;height:80px;margin:0 auto;background-size:contain;background-position:center;background-repeat:no-repeat;-webkit-touch-callout:none !important;-webkit-user-select:none !important;user-select:none !important;pointer-events:none !important}
.rarity-preview-info{text-align:center;margin-bottom:20px}
.rarity-preview-name{font-size:24px;font-weight:900;margin:0 0 4px}
.rarity-preview-brand{font-size:16px;color:#64748B;margin:0 0 8px}
.rarity-preview-tagline{font-size:16px;font-weight:700;margin:0}
.rarity-preview-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.rarity-stat-box{padding:14px;border-radius:14px;border:2px solid;text-align:center}
.rarity-stat-box.rarity-stat-xp{background:rgba(34,197,94,0.1);border-color:rgba(34,197,94,0.3)}
.rarity-stat-label{display:block;font-size:16px;color:#94A3B8;font-weight:700;margin-bottom:4px}
.rarity-stat-value{font-size:24px;font-weight:900}
.rarity-stat-xp .rarity-stat-value{color:#22C55E}
.rarity-slider-section{margin-bottom:16px}
.rarity-slider-label{font-size:16px;color:#64748B;font-weight:600;margin-bottom:8px}
.rarity-slider-track{height:10px;border-radius:5px;position:relative}
.rarity-slider-track.gi{background:linear-gradient(90deg,#22C55E 0%,#22C55E 55%,#F59E0B 55%,#F59E0B 69%,#EF4444 69%,#EF4444 100%)}
.rarity-slider-track.gl{background:linear-gradient(90deg,#22C55E 0%,#22C55E 33%,#F59E0B 33%,#F59E0B 63%,#EF4444 63%,#EF4444 100%)}
.rarity-slider-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;background:white;border-radius:50%;border:3px solid;box-shadow:0 2px 8px rgba(0,0,0,0.3)}
.rarity-slider-labels{display:flex;justify-content:space-between;margin-top:6px}
.rarity-slider-labels span{font-size:16px;font-weight:600}
.rarity-nutrition-link{display:block;width:100%;padding:12px;background:transparent;border:none;color:#8B5CF6;font-size:16px;font-weight:700;cursor:pointer;text-align:center;margin-bottom:16px}
.rarity-preview-actions{display:flex;gap:12px}
.rarity-btn-log{flex:1;padding:16px;border:none;border-radius:14px;color:white;font-size:16px;font-weight:800;cursor:pointer;transition:all 0.2s}
.rarity-btn-log:hover{transform:scale(1.02)}
.rarity-btn-cancel-sm{flex:1;padding:16px;background:rgba(255,255,255,0.05);border:2px solid rgba(255,255,255,0.1);border-radius:14px;color:#94A3B8;font-size:16px;font-weight:800;cursor:pointer;transition:all 0.2s}
.rarity-btn-cancel-sm:hover{background:rgba(255,255,255,0.08);transform:scale(1.02)}

/* ============================================
   iOS PWA SAFE AREA SUPPORT
   ============================================ */
@supports(padding: env(safe-area-inset-top)){
  .night-header{padding-top:calc(16px + env(safe-area-inset-top));padding-left:calc(24px + env(safe-area-inset-left));padding-right:calc(24px + env(safe-area-inset-right))}
  .night-layout-v2{padding-bottom:calc(24px + env(safe-area-inset-bottom));padding-left:calc(24px + env(safe-area-inset-left));padding-right:calc(24px + env(safe-area-inset-right))}
  .rarity-modal{padding-bottom:calc(24px + env(safe-area-inset-bottom))}
}

/* PWA standalone mode adjustments */
@media(display-mode: standalone){
  .night-header{position:fixed;top:0;left:0;right:0;z-index:1000}
  .night-mode{padding-top:80px}
}
