/* Bar Calc — Animations & Keyframes */
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

.card{background:var(--card);border-radius:18px;border:1px solid var(--border);padding:1.25rem;margin-bottom:.875rem;box-shadow:var(--sh);}
.card-title{font-family:'Fraunces',serif;font-size:15px;font-weight:600;color:var(--text);margin-bottom:1rem;}
.slabel{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin-bottom:10px;}

/* CITRUS SELECTOR */
.citrus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.citrus-btn{border-radius:16px;border:2.5px solid transparent;cursor:pointer;padding:0;overflow:hidden;transition:all .22s;display:flex;flex-direction:column;align-items:center;background:var(--card2);}
.citrus-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,0.15);}
.citrus-btn.active{border-color:var(--g);box-shadow:0 4px 16px rgba(45,140,80,0.3);}
.citrus-face{width:100%;height:90px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:38px;transition:transform .2s;position:relative;}
.citrus-btn:hover .citrus-face{transform:scale(1.1);}
.citrus-btn.active .citrus-face{transform:scale(1.08);}
.citrus-face img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0;}
.citrus-face.lime-bg{background:linear-gradient(145deg,#2d5a1b,#4a9a28);}
.citrus-face.lemon-bg{background:linear-gradient(145deg,#b8900a,#e8c020);}
.citrus-face.orange-bg{background:linear-gradient(145deg,#c05808,#f07820);}
.citrus-face.grapefruit-bg{background:linear-gradient(145deg,#c04060,#e87090);}
.citrus-name{font-size:11px;font-weight:600;color:var(--muted);padding:6px 0 7px;letter-spacing:0.2px;}
.citrus-btn.active .citrus-name{color:var(--g);}

/* INPUTS */
.inp-wrap{
  display:flex;
  align-items:center;
  border:2px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  background:var(--inp);
  transition:border-color .18s, box-shadow .18s;
}
.inp-wrap:focus-within{
  border-color:var(--g);
  box-shadow:0 0 0 3px rgba(45,140,80,0.12);
}
.inp-wrap.blue:focus-within{
  border-color:var(--b);
  box-shadow:0 0 0 3px rgba(34,114,176,0.12);
}
.inp-wrap.purple:focus-within{
  border-color:var(--p);
  box-shadow:0 0 0 3px rgba(110,61,181,0.12);
}
.inp-wrap.teal:focus-within{
  border-color:var(--t);
  box-shadow:0 0 0 3px rgba(26,122,122,0.15);
}
.inp-wrap input{flex:1;border:none;background:transparent;font-family:'Fraunces',serif;font-size:28px;color:var(--text);padding:10px 14px;outline:none;width:100%;}
.inp-wrap .ulab{padding:0 14px;font-size:14px;font-weight:500;color:var(--muted);border-left:1px solid var(--border);white-space:nowrap;}
.ilabel{font-size:13px;color:var(--muted);margin-bottom:7px;display:block;font-weight:500;}

.res-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.res-item{background:var(--card2);border-radius:12px;padding:12px 14px;}
.res-item.full{grid-column:span 2;background:var(--gl);border:1px solid var(--g);}
.res-item .ri-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:3px;}
.res-item.full .ri-label{color:var(--gd);}
.res-item .ri-val{font-family:'Fraunces',serif;font-size:24px;color:var(--text);line-height:1.1;}
.res-item.full .ri-val{color:var(--gd);}
.res-item .ri-unit{font-size:12px;color:var(--muted);}

.steps-title{font-size:12px;font-weight:600;color:var(--text);margin:1rem 0 8px;display:flex;align-items:center;gap:6px;}
.steps-title::before{content:'';display:block;width:3px;height:14px;background:var(--g);border-radius:2px;}
.step-row{display:flex;gap:10px;margin-bottom:8px;align-items:flex-start;}
.step-num{width:22px;height:22px;border-radius:50%;background:var(--g);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.step-text{font-size:12.5px;color:var(--muted);line-height:1.5;}
.step-text b{color:var(--text);font-weight:600;}
.yield-banner{background:var(--ol);border:1px solid var(--o);border-radius:12px;padding:10px 13px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--o);margin-top:10px;font-weight:500;}

/* ═══════════════════════════════════════════════════════════
   ABV CALCULATOR v8.0 — clean, airy, modern
   Inspired by DrinksMixer calculator
   ═══════════════════════════════════════════════════════════ */

/* Results card — final summary, placed after dilution */
.abv8-results{
  background:linear-gradient(135deg,var(--p) 0%,var(--b) 100%);
  border:none;
  padding:1.5rem;
  color:#fff;
  box-shadow:0 10px 30px rgba(110,61,181,0.25);
  position:relative;
  overflow:hidden;
}
.abv8-results::before{
  content:'';
  position:absolute;
  top:-60px;
  right:-60px;
  width:200px;
  height:200px;
  background:radial-gradient(circle,rgba(255,255,255,0.15),transparent 70%);
  pointer-events:none;
}
.abv8-results-title{
  font-family:'Fraunces',serif;
  font-size:14px;
  font-weight:600;
  color:#fff;
  opacity:0.85;
  text-transform:uppercase;
  letter-spacing:1.5px;
  margin-bottom:18px;
  position:relative;
  z-index:1;
}
.abv8-results-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  position:relative;
  z-index:1;
}
.abv8-res-item{
  padding:10px 0;
}
.abv8-res-hero{
  grid-column:span 2;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.2);
  margin-top:6px;
  text-align:center;
}
.abv8-res-lbl{
  font-size:10.5px;
  font-weight:700;
  color:rgba(255,255,255,0.7);
  margin-bottom:5px;
  letter-spacing:0.8px;
  text-transform:uppercase;
}
.abv8-res-val{
  font-family:'Fraunces',serif;
  font-size:24px;
  font-weight:600;
  color:#fff;
  line-height:1.1;
  display:flex;
  align-items:baseline;
  gap:4px;
  letter-spacing:-0.5px;
}
.abv8-res-hero .abv8-res-val{justify-content:center;}
.abv8-res-unit{
  font-size:13px;
  color:rgba(255,255,255,0.7);
  font-weight:400;
}
.abv8-res-big .abv8-res-unit{font-size:22px;color:rgba(255,255,255,0.85);}
.abv8-res-big{
  font-size:54px;
  color:#fff;
  letter-spacing:-2px;
  font-weight:700;
}
.abv8-warn{
  display:none;
  margin-top:12px;
  padding:10px 14px;
  background:var(--rl);
  border:1px solid var(--r);
  border-radius:11px;
  font-size:12px;
  color:var(--r);
  font-weight:600;
}
.abv8-warn.show{display:flex;align-items:center;gap:6px;}

/* Unit toggle — compact with accent icon + gradient active state */
.abv8-unit-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 1.25rem;
  border:1px solid var(--border);
  background:linear-gradient(135deg, var(--card) 0%, var(--card2) 100%);
  position:relative;
  overflow:hidden;
}
.abv8-unit-card::before{
  content:'';
  position:absolute;
  top:-30px;right:-30px;
  width:100px;height:100px;
  background:radial-gradient(circle, rgba(110,61,181,0.08), transparent 70%);
  pointer-events:none;
}
.abv8-unit-card-left{
  display:flex;
  align-items:center;
  gap:10px;
  position:relative;
  z-index:1;
}
.abv8-unit-icon{
  width:32px;height:32px;
  border-radius:9px;
  background:linear-gradient(135deg, var(--p), var(--b));
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  box-shadow:0 3px 10px rgba(110,61,181,0.25);
}
.abv8-unit-label{
  font-size:12px;
  font-weight:700;
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:0.8px;
}
.abv8-unit-toggle{
  display:flex;
  gap:4px;
  background:var(--card2);
  padding:4px;
  border-radius:12px;
  position:relative;
  z-index:1;
  border:1px solid var(--border);
}
.abv8-unit-btn{
  padding:7px 18px;
  border:none;
  background:transparent;
  border-radius:9px;
  font-family:'Outfit',sans-serif;
  font-size:12.5px;
  font-weight:600;
  color:var(--muted);
  cursor:pointer;
  transition:all .2s;
  min-width:46px;
}
.abv8-unit-btn:hover{color:var(--text);}
.abv8-unit-btn.active{
  background:linear-gradient(135deg, var(--p), var(--b));
  color:#fff;
  box-shadow:0 3px 10px rgba(110,61,181,0.35);
}

/* Category header */

/* ============================================================
   ANIMAȚII MODERNE v2.0 — Micro-interactions & Polish
   ============================================================ */

/* ── Keyframes noi ── */
@keyframes slideUpFade {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes slideDownFade {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.88); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes scaleInBounce {
  0%   { opacity: 0; transform: scale(0.7); }
  70%  { transform: scale(1.05); }
  100% { opacity: 1; transform: scale(1); }
}
@keyframes rippleFade {
  from { opacity: 1; }
  to   { opacity: 0; }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.5; }
}
@keyframes spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes bounceIn {
  0%   { transform: scale(0); opacity: 0; }
  60%  { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(1); }
}
@keyframes toastSlideIn {
  from { opacity: 0; transform: translateX(-50%) translateY(20px) scale(0.9); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}
@keyframes toastSlideOut {
  from { opacity: 1; transform: translateX(-50%) scale(1); }
  to   { opacity: 0; transform: translateX(-50%) scale(0.9); }
}
@keyframes numberPop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.25); color: var(--g); }
  100% { transform: scale(1); }
}
@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(69, 181, 104, 0); }
  50%       { box-shadow: 0 0 0 6px rgba(69, 181, 104, 0.2); }
}

/* ── Secțiuni — animație la apariție ── */
.sec.vis {
  display: block !important;
  animation: slideUpFade 0.28s cubic-bezier(0.34, 1.2, 0.64, 1);
}

/* ── Cards — animație la apariție ── */
.card {
  animation: slideUpFade 0.22s ease both;
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1),
              box-shadow 0.2s ease,
              border-color 0.18s ease;
}

/* ── Modal — animație modernă ── */
#backupModal > div,
#bcAdminKeyModal > div,
#bonPrintModal > div,
.modal-box {
  animation: scaleInBounce 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── Nav tabs — hover cu glow ── */
.bnav-btn.active {
  animation: glowPulse 2.5s ease infinite;
}

/* ── Stoc final — animație la schimbare valoare ── */
.stock-final-cell {
  transition: color 0.25s ease, background 0.25s ease;
}
.stock-final-cell.changed {
  animation: numberPop 0.4s ease;
}

/* ── KPI Analytics — counter animat ── */
.analytics-kpi-val {
  transition: all 0.3s ease;
}

/* ── Toast modern ── */
.toast-msg {
  animation: toastSlideIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* ── Loading shimmer ── */
.shimmer {
  background: linear-gradient(
    90deg,
    var(--card2) 25%,
    var(--card) 50%,
    var(--card2) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 8px;
}

/* ── Buton save — shimmer la hover ── */
.save-btn::before {
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,0.25) 50%,
    transparent 100%
  );
  background-size: 200% 100%;
  transition: background-position 0.6s ease;
}
.save-btn:hover::before {
  background-position: right center;
}

/* ── Input focus — ring animat ── */
.inp-wrap {
  transition: border-color 0.18s ease,
              box-shadow 0.18s ease,
              transform 0.15s ease;
}
.inp-wrap:focus-within {
  transform: translateY(-1px);
}

/* ── Masa ocupată — pulsație subtilă ── */
.masa-ocupata-indicator {
  animation: pulse 2s ease infinite;
}

/* ── Alertă stoc scăzut — shake ── */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-4px); }
  40%       { transform: translateX(4px); }
  60%       { transform: translateX(-3px); }
  80%       { transform: translateX(3px); }
}
.stock-alert-shake {
  animation: shake 0.5s ease;
}

/* ── Citrus buttons — hover 3D ── */
.citrus-btn {
  transition: transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1),
              box-shadow 0.22s ease,
              border-color 0.18s ease;
}
.citrus-btn:hover {
  transform: translateY(-5px) scale(1.02);
  box-shadow: 0 12px 28px rgba(0,0,0,0.2);
}
.citrus-btn.active {
  transform: translateY(-3px) scale(1.01);
}

/* ── Paginator / scroll indicator ── */
.scroll-hint {
  animation: pulse 2s ease infinite;
  opacity: 0.6;
}

/* ── Transition pentru schimbarea temei ── */
html {
  transition: background-color 0.3s ease;
}

/* ── Card hover pe desktop ── */
@media (hover: hover) {
  .card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  }
  .an-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
  }
}

/* ── Staggered animation pentru liste ── */
.card:nth-child(1) { animation-delay: 0ms; }
.card:nth-child(2) { animation-delay: 40ms; }
.card:nth-child(3) { animation-delay: 80ms; }
.card:nth-child(4) { animation-delay: 120ms; }
.card:nth-child(5) { animation-delay: 160ms; }

/* ── Progress bar animat ── */
.margin-bar-fill {
  transition: width 0.6s cubic-bezier(0.34, 1.2, 0.64, 1);
}

/* ── Buton cu ripple effect ── */
.btn-ripple {
  position: relative;
  overflow: hidden;
}
.btn-ripple::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
  transform: scale(0);
  animation: rippleExpand 0.5s ease-out forwards;
  pointer-events: none;
}
@keyframes rippleExpand {
  to { transform: scale(4); opacity: 0; }
}
