/* 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 */
