/* ============== BREAK · Sanduíches Búzios ============== */
:root{
  --pine:#0C3A2E;
  --pine-700:#0A3327;
  --pine-800:#072A21;
  --pine-900:#052C26;
  --canvas:#FDF8EF;
  --cream:#FBEFD7;
  --cream-50:#FFF9EE;
  --cream-100:#F6E7C9;
  --cream-200:#EFDDB8;
  --amber:#E3922C;
  --amber-600:#CE7E18;
  --amber-200:#F4C988;
  --amber-100:#F8DFAE;
  --text:#103A2F;
  --muted:#5E7268;
  --line:rgba(5,44,38,.12);
  --line-strong:rgba(5,44,38,.22);
  --white:#fff;
  --ok:#2E8B6F;
  --red:#D4543F;
  --shadow-sm:0 1px 2px rgba(5,44,38,.06),0 2px 8px rgba(5,44,38,.05);
  --shadow:0 8px 30px rgba(5,44,38,.10),0 2px 8px rgba(5,44,38,.06);
  --shadow-lg:0 24px 60px rgba(5,44,38,.18),0 6px 18px rgba(5,44,38,.08);
  --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:34px;
  --maxw:1200px;
  --font-d:"Outfit",system-ui,sans-serif;
  --font-b:"Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--canvas);color:var(--text);
  font-family:var(--font-b);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--font-d);margin:0;line-height:1.05;letter-spacing:-.02em;color:var(--pine)}
p{margin:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{display:block;max-width:100%}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
::selection{background:var(--amber-200)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-d);font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--amber-600)}
.eyebrow.on-pine{color:var(--amber-200)}
.dash-label{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-d);font-weight:600;text-transform:uppercase;letter-spacing:.24em;font-size:12px;color:var(--pine)}
.dash-label::before,.dash-label::after{content:"";width:22px;height:2.5px;border-radius:2px;background:var(--amber)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-d);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 24px;border-radius:999px;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s;
  white-space:nowrap}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-amber{background:var(--amber);color:var(--pine-900)}
.btn-amber:hover{background:#eb9d38;box-shadow:0 10px 24px rgba(227,146,44,.35)}
.btn-pine{background:var(--pine);color:var(--cream-50)}
.btn-pine:hover{background:var(--pine-700);box-shadow:0 10px 24px rgba(5,44,38,.25)}
.btn-ghost{background:transparent;color:var(--pine);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn-ghost:hover{background:rgba(5,44,38,.05);box-shadow:inset 0 0 0 1.5px var(--pine)}
.btn-lg{padding:17px 30px;font-size:16px}
.btn-sm{padding:9px 16px;font-size:13.5px}
.btn-block{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed}

.chip{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:999px;
  font-family:var(--font-d);font-weight:600;font-size:13px;background:var(--cream-50);
  color:var(--pine);box-shadow:inset 0 0 0 1px var(--line);transition:all .15s}
.chip:hover{box-shadow:inset 0 0 0 1px var(--line-strong)}
.chip.active{background:var(--pine);color:var(--cream-50);box-shadow:none}

.card{background:var(--cream-50);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--line)}

/* nav */
.nav{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--canvas) 86%,transparent);
  backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:20px;height:74px}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:18px}
.nav-link{font-family:var(--font-d);font-weight:500;font-size:15px;color:var(--pine);
  padding:9px 14px;border-radius:999px;transition:background .15s;position:relative}
.nav-link:hover{background:rgba(5,44,38,.06)}
.nav-link.active{background:rgba(5,44,38,.08);font-weight:600}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.cart-btn{position:relative;display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:999px;
  background:var(--pine);color:var(--cream-50);font-family:var(--font-d);font-weight:600;font-size:14px;transition:all .15s}
.cart-btn:hover{background:var(--pine-700);box-shadow:0 8px 20px rgba(5,44,38,.22)}
.cart-badge{position:absolute;top:-6px;right:-6px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;
  background:var(--amber);color:var(--pine-900);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-d);box-shadow:0 0 0 3px var(--cream)}
.nav-burger{display:none}

.logo-row{display:flex;align-items:center;gap:13px}
.logo-mark{display:block;width:auto;object-fit:contain}
.logo-copy{display:flex;flex-direction:column}
.logo-word{font-family:var(--font-d);font-weight:700;letter-spacing:.18em;font-size:21px;color:var(--pine);line-height:1}
.logo-sub{font-family:var(--font-d);font-weight:600;letter-spacing:.2em;font-size:8.5px;color:var(--amber-600);text-transform:uppercase;margin-top:3px}
.logo-row-lockup{display:inline-flex;padding:10px 12px;border-radius:var(--r-sm);background:var(--cream)}
.logo-lockup{width:112px;height:auto}

/* ---- HOME (minimalist) ---- */
.minimal-hero {
  padding: 80px 0 40px;
  text-align: center;
}
.minimal-hero-wrap {
  max-width: 800px;
  margin: 0 auto;
}
.minimal-title {
  font-size: clamp(40px, 8vw, 76px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.05;
  color: var(--pine);
  margin-bottom: 24px;
}
.minimal-subtitle {
  font-size: clamp(16px, 2.5vw, 20px);
  color: var(--muted);
  margin-bottom: 40px;
}
.minimal-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.minimal-meta {
  font-family: var(--font-d);
  font-size: 13.5px;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.minimal-meta::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 0 3px rgba(46,139,111,.15);
}

.minimal-highlight {
  padding: 20px 0 60px;
}
.minimal-image-wrapper {
  max-width: 900px;
  margin: 0 auto;
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 16/9;
}
.minimal-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.minimal-section {
  padding: 60px 0;
}
.minimal-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 30px;
  flex-wrap: wrap;
}
.minimal-section-head h2 {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 600;
  letter-spacing: -0.02em;
}

.review-minimal {
  padding: 30px;
  border-radius: var(--r-lg);
  background: transparent;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.review-minimal p {
  font-size: 16px;
  color: var(--pine);
  line-height: 1.6;
  font-style: italic;
}
.review-minimal .meta {
  font-family: var(--font-d);
  font-size: 13px;
  color: var(--muted);
}
.review-minimal .meta b {
  color: var(--pine);
  font-weight: 600;
}

.reviews-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

@media(max-width:980px){
  .minimal-hero { padding: 50px 0 30px; }
  .reviews-strip { grid-template-columns: 1fr 1fr; }
}
@media(max-width:560px){
  .minimal-hero { padding: 40px 0 20px; }
  .reviews-strip { grid-template-columns: 1fr; }
  .minimal-image-wrapper { aspect-ratio: 4/3; border-radius: var(--r-lg); }
}

/* hero (legacy — still used by other pages if needed) */
.hero{position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:46px 0 64px}
.hero h1{font-size:clamp(40px,6vw,72px);font-weight:700;letter-spacing:-.03em}
.hero h1 .amber{color:var(--amber)}
.hero-sub{font-size:18px;color:var(--muted);max-width:30ch;margin-top:20px}
.hero-cta{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.hero-meta{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-meta div{display:flex;flex-direction:column}
.hero-meta b{font-family:var(--font-d);font-size:22px;color:var(--pine)}
.hero-meta span{font-size:13px;color:var(--muted)}
.hero-visual{position:relative;aspect-ratio:1/1;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg)}

/* photo placeholder */
.ph{position:relative;background:
  radial-gradient(120% 80% at 70% 12%,rgba(244,201,136,.55),transparent 55%),
  linear-gradient(160deg,var(--cream-100),var(--cream-200));
  display:flex;align-items:center;justify-content:center;color:var(--pine);overflow:hidden}
.ph::after{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(45deg,rgba(5,44,38,.025) 0 12px,transparent 12px 24px)}
.ph.has-img{background:var(--cream-100)}
.ph.has-img::after{display:none}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:var(--photo-position,center)}
.ph-sun{position:absolute;width:46%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 60%,var(--amber-200),var(--amber));
  filter:blur(.3px);bottom:34%;opacity:.9}
.ph-ico{position:relative;z-index:2;opacity:.5}
.ph-tag{position:absolute;bottom:14px;left:14px;z-index:3;font-family:var(--font-d);font-weight:600;font-size:12px;
  letter-spacing:.04em;color:var(--pine);background:var(--cream-50);padding:6px 12px;border-radius:999px;box-shadow:var(--shadow-sm)}

/* sections */
.section{padding:72px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:38px;flex-wrap:wrap}
.section-head h2{font-size:clamp(28px,4vw,44px);font-weight:700;margin-top:12px}
.section-head p{color:var(--muted);max-width:46ch;margin-top:8px}

/* feature row */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature{padding:28px;border-radius:var(--r-lg);background:var(--cream-50);border:1px solid var(--line);transition:transform .2s,box-shadow .2s}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.feature .ic{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--pine);color:var(--amber-200);margin-bottom:16px}
.feature h3{font-size:19px;margin-bottom:7px}
.feature p{color:var(--muted);font-size:14.5px}
.home-features{gap:0;border-top:1px solid var(--line-strong);border-bottom:1px solid var(--line-strong)}
.home-feature{padding:24px 28px 25px;background:transparent;border:0;border-radius:0;transition:none}
.home-feature:first-child{padding-left:0}
.home-feature:last-child{padding-right:0}
.home-feature+.home-feature{border-left:1px solid var(--line)}
.home-feature:hover{transform:none;box-shadow:none}
.home-feature .ic{width:auto;height:auto;margin-bottom:13px;border-radius:0;background:transparent;color:var(--amber-600);justify-content:flex-start}
.home-feature h3{font-size:18px}

/* menu cards */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.dish{display:flex;flex-direction:column;background:var(--cream-50);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.dish:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.dish-photo{aspect-ratio:4/3;position:relative}
.dish-photo>.ph,.modal-photo>.ph{width:100%;height:100%}
.dish-flag{position:absolute;top:12px;left:12px;z-index:3;background:var(--amber);color:var(--pine-900);
  font-family:var(--font-d);font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.dish-veg{position:absolute;top:12px;right:12px;z-index:3;width:30px;height:30px;border-radius:50%;background:var(--cream-50);
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.dish-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.dish-body h3{font-size:21px}
.dish-desc{color:var(--muted);font-size:14px;margin-top:7px;flex:1}
.dish-foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px}
.price{font-family:var(--font-d);font-weight:700;font-size:22px;color:var(--pine)}
.price small{font-size:13px;font-weight:600;color:var(--muted)}

/* modal */
.overlay{position:fixed;inset:0;z-index:90;background:rgba(5,30,24,.5);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;padding:24px}
.modal{background:var(--canvas);border-radius:var(--r-lg);width:min(560px,100%);max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}
.modal-photo{aspect-ratio:16/9;position:relative}
.modal-x{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:var(--cream-50);
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);z-index:4;transition:transform .15s}
.modal-x:hover{transform:rotate(90deg)}
.modal-body{padding:24px 26px 26px}
.opt-group{margin-top:20px}
.opt-group h4{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-family:var(--font-d);margin-bottom:12px}
.opt{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-radius:var(--r-sm);
  background:var(--cream-50);border:1px solid var(--line);margin-bottom:9px;cursor:pointer;transition:all .12s}
.opt:hover{border-color:var(--line-strong)}
.opt.sel{border-color:var(--pine);background:#fff;box-shadow:inset 0 0 0 1px var(--pine)}
.opt-l{display:flex;align-items:center;gap:12px}
.opt-check{width:22px;height:22px;border-radius:7px;border:2px solid var(--line-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
.opt.sel .opt-check{background:var(--pine);border-color:var(--pine);color:var(--cream-50)}
.opt-price{font-family:var(--font-d);font-weight:600;font-size:14px;color:var(--amber-600)}

/* qty stepper */
.stepper{display:inline-flex;align-items:center;gap:2px;background:var(--cream-50);border-radius:999px;padding:4px;border:1px solid var(--line)}
.stepper button{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--pine);transition:background .12s}
.stepper button:hover{background:rgba(5,44,38,.08)}
.stepper span{min-width:30px;text-align:center;font-family:var(--font-d);font-weight:700;font-size:16px}

/* cart drawer */
.drawer-overlay{position:fixed;inset:0;z-index:100;background:rgba(5,30,24,.45)}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,100%);background:var(--canvas);z-index:101;
  display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:none}}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 18px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:21px}
.drawer-body{flex:1;overflow:auto;padding:18px 22px}
.drawer-foot{padding:20px 22px 24px;border-top:1px solid var(--line);background:var(--cream-50)}
.citem{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.citem-photo{width:64px;height:64px;border-radius:var(--r-sm);flex-shrink:0;overflow:hidden}
.citem-mid{flex:1;min-width:0}
.citem-mid h4{font-family:var(--font-d);font-size:15.5px;font-weight:600;color:var(--pine)}
.citem-mid .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.citem-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.mini-step{display:inline-flex;align-items:center;gap:8px}
.mini-step button{width:26px;height:26px;border-radius:50%;background:var(--cream-100);display:flex;align-items:center;justify-content:center;color:var(--pine)}
.mini-step span{font-family:var(--font-d);font-weight:700;min-width:18px;text-align:center}
.row-line{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:10px;font-size:14.5px;color:var(--muted)}
.row-line>span:last-child{white-space:nowrap;flex-shrink:0}
.row-line.total{font-size:20px;color:var(--pine);font-family:var(--font-d);font-weight:700;margin-top:6px}
.empty-cart{text-align:center;padding:60px 20px;color:var(--muted)}

/* forms */
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-d);font-weight:600;font-size:13px;color:var(--pine);margin-bottom:7px}
.input,.select,textarea.input{width:100%;padding:13px 15px;border-radius:var(--r-sm);border:1.5px solid var(--line);
  background:var(--cream-50);font-family:var(--font-b);font-size:15px;color:var(--text);transition:border .15s,box-shadow .15s}
.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px rgba(12,58,46,.1)}
.input::placeholder{color:#9aa89f}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* segmented */
.seg{display:grid;grid-auto-flow:column;gap:8px;background:var(--cream-100);padding:6px;border-radius:var(--r);}
.seg button{padding:14px 16px;border-radius:11px;font-family:var(--font-d);font-weight:600;font-size:15px;color:var(--muted);transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:4px}
.seg button small{font-size:11.5px;font-weight:500;opacity:.8}
.seg button.on{background:var(--cream-50);color:var(--pine);box-shadow:var(--shadow-sm)}

/* checkout layout */
.checkout-grid{display:grid;grid-template-columns:1.3fr minmax(340px,.9fr);gap:30px;align-items:start}
.summary{position:sticky;top:96px}
.steps{display:flex;align-items:center;gap:10px;margin-bottom:26px}
.step{display:flex;align-items:center;gap:9px;font-family:var(--font-d);font-weight:600;font-size:14px;color:var(--muted)}
.step .num{width:26px;height:26px;border-radius:50%;background:var(--cream-100);display:flex;align-items:center;justify-content:center;font-size:13px}
.step.on{color:var(--pine)}.step.on .num{background:var(--pine);color:var(--cream-50)}
.step.done .num{background:var(--ok);color:#fff}
.step-line{flex:1;height:2px;background:var(--line);border-radius:2px;min-width:18px}

/* reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{padding:26px;border-radius:var(--r-lg);background:var(--cream-50);border:1px solid var(--line)}
.stars{display:flex;gap:3px;color:var(--amber);margin-bottom:14px}
.review p{font-size:15px;color:var(--text)}
.review .who{display:flex;align-items:center;gap:11px;margin-top:18px}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--pine);color:var(--amber-200);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700}
.review .who b{font-family:var(--font-d);font-size:15px;color:var(--pine)}
.review .who span{font-size:12.5px;color:var(--muted)}

/* about */
.about-hero{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.about-stat{text-align:center;padding:26px;border-radius:var(--r-lg);background:var(--pine);color:var(--cream-50)}
.about-stat b{font-family:var(--font-d);font-size:38px;display:block;color:var(--amber-200)}
.about-stat span{font-size:13px;opacity:.85}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* pine band */
.band{background:var(--pine);color:var(--cream-50);border-radius:var(--r-xl);padding:56px;position:relative;overflow:hidden}
.band h2{color:var(--cream-50)}
.band .blur-sun{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,var(--amber),transparent 65%);opacity:.4;right:-60px;top:-80px;filter:blur(10px)}

/* footer */
.footer{background:var(--pine-900);color:var(--cream-100);padding:60px 0 30px;margin-top:40px}
.footer .logo-row-lockup{display:inline-flex}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.footer h4{color:var(--cream-50);font-size:15px;margin-bottom:16px;font-family:var(--font-d)}
.footer a,.footer li{color:rgba(251,239,215,.75);font-size:14.5px;margin-bottom:10px;display:block;transition:color .15s}
.footer a:hover{color:var(--amber-200)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:44px;padding-top:24px;border-top:1px solid rgba(251,239,215,.14);font-size:13px;color:rgba(251,239,215,.5);flex-wrap:wrap;gap:12px}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:200;background:var(--pine);color:var(--cream-50);
  padding:14px 22px;border-radius:999px;font-family:var(--font-d);font-weight:600;font-size:14.5px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:10px}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%)}}

/* page enter — visible at rest; transform-only so it never hides content */
.page{opacity:1}
@keyframes pageIn{from{transform:translateY(10px)}to{transform:none}}
@media (prefers-reduced-motion: no-preference){
  .page{animation:pageIn .35s ease}
}

/* misc */
.divider{height:1px;background:var(--line);margin:18px 0}
.muted{color:var(--muted)}
.center{text-align:center}
.mt-s{margin-top:10px}.mt{margin-top:20px}.mt-l{margin-top:36px}
.pill-note{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;border-radius:999px;background:var(--cream-50);
  box-shadow:inset 0 0 0 1px var(--line);font-size:13.5px;font-family:var(--font-d);font-weight:600;color:var(--pine)}
.badge-amber{background:var(--amber-100);color:var(--amber-600);padding:4px 11px;border-radius:999px;font-family:var(--font-d);font-weight:700;font-size:12px}

/* responsive */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-visual{max-width:460px}
  .features,.menu-grid,.reviews,.values{grid-template-columns:1fr 1fr}
  .checkout-grid{grid-template-columns:1fr}
  .summary{position:static}
  .about-hero{grid-template-columns:1fr;gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .wrap{padding:0 18px}
  .nav-links{display:none}
  .nav-burger{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:var(--cream-50);box-shadow:inset 0 0 0 1px var(--line);color:var(--pine)}
  .features,.menu-grid,.reviews,.values,.about-stats,.field-row{grid-template-columns:1fr}
  .home-feature,.home-feature:first-child,.home-feature:last-child{padding:19px 0}
  .home-feature+.home-feature{border-left:0}
  .home-feature:not(:last-child){border-bottom:1px solid var(--line)}
  .footer-grid{grid-template-columns:1fr}
  .band{padding:34px 24px}
  .section{padding:52px 0}
  .cart-btn span.lbl{display:none}
  .mobile-menu{display:flex}
}
/* mobile slide menu */
.mobile-menu{position:fixed;inset:0;z-index:220;min-height:100dvh;background:var(--canvas);display:flex;flex-direction:column;padding:90px 28px 28px;gap:6px;overflow:auto}
.mobile-menu a{font-family:var(--font-d);font-weight:600;font-size:24px;color:var(--pine);padding:16px 0;border-bottom:1px solid var(--line)}

/* accounting */
/* ---- ACCOUNTING (Minimalist Banking App) ---- */
.acc-page {
  min-height: 100vh;
  background: var(--canvas);
  color: var(--text);
  padding: 40px 24px;
  font-family: var(--font-b);
}
.acc-max {
  max-width: 540px;
  margin: 0 auto;
}
.acc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
}
.acc-title {
  font-family: var(--font-d);
  font-size: 32px;
  font-weight: 700;
  color: var(--pine);
  margin: 0;
}
.acc-title-sm {
  font-family: var(--font-d);
  font-size: 20px;
  font-weight: 700;
  color: var(--pine);
  margin: 0;
}
.acc-icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--cream-50);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--pine);
  transition: all 0.2s;
  padding: 0;
}
.acc-icon-btn:hover {
  background: var(--cream-100);
}

.acc-balance-card {
  background: var(--pine);
  color: #fff;
  border-radius: var(--r-xl);
  padding: 32px;
  margin-bottom: 40px;
  box-shadow: 0 12px 30px rgba(12, 58, 46, 0.15);
  position: relative;
  overflow: hidden;
}
.acc-balance-card::before {
  content: "";
  position: absolute;
  top: -50px;
  right: -50px;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(244,201,136,0.15) 0%, transparent 70%);
  border-radius: 50%;
}
.acc-balance-label {
  display: block;
  font-family: var(--font-d);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.8;
  margin-bottom: 4px;
}
.acc-balance-amount {
  display: block;
  font-family: var(--font-d);
  font-size: 48px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 24px;
}
.acc-balance-row {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 20px;
}
.acc-balance-row > div {
  display: flex;
  flex-direction: column;
}
.acc-balance-row span {
  font-size: 13px;
  opacity: 0.7;
  margin-bottom: 2px;
}
.acc-balance-row strong {
  font-family: var(--font-d);
  font-size: 18px;
  font-weight: 600;
}
.acc-balance-row strong.in { color: var(--ok); }
.acc-balance-row strong.out { color: var(--amber-200); }

.acc-feed-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.acc-feed-head h2 {
  font-family: var(--font-d);
  font-size: 20px;
  font-weight: 700;
  margin: 0;
}
.acc-month-select {
  background: transparent;
  border: none;
  font-family: var(--font-d);
  font-size: 14px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  outline: none;
}

.acc-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.acc-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  background: #fff;
  border-radius: var(--r-lg);
  box-shadow: 0 2px 10px rgba(5,44,38,.03);
  transition: transform 0.2s, box-shadow 0.2s;
  border: 1px solid rgba(0,0,0,0.03);
}
.acc-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(5,44,38,.06);
}
.acc-item-main {
  display: flex;
  align-items: center;
  gap: 16px;
}
.acc-item-icon {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.acc-item-icon.in { background: #e4f2ec; color: #23735d; }
.acc-item-icon.out { background: #fdf3f0; color: #bf563d; }
.acc-item-icon.stock { background: #f7eddc; color: #9c6210; }
.acc-item-text {
  display: flex;
  flex-direction: column;
}
.acc-item-text strong {
  font-family: var(--font-d);
  font-size: 16px;
  font-weight: 600;
  color: var(--pine);
  line-height: 1.2;
}
.acc-item-text span {
  font-size: 13px;
  color: var(--muted);
  margin-top: 4px;
}
.acc-item-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.acc-item-val {
  font-family: var(--font-d);
  font-size: 16px;
  font-weight: 700;
  text-align: right;
}
.acc-item-val.in { color: #23735d; }
.acc-item-val.out { color: var(--text); }
.acc-item-val.stock { color: #9c6210; }
.acc-item-del {
  color: var(--line-strong);
  padding: 8px;
  border-radius: 50%;
  transition: all 0.2s;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
}
.acc-item-del:hover {
  background: #fdf3f0;
  color: #bf563d;
}

.acc-empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--muted);
  font-style: italic;
  font-size: 15px;
}

.acc-form {
  background: #fff;
  border-radius: var(--r-xl);
  padding: 40px;
  box-shadow: var(--shadow);
}
.acc-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-bottom: 40px;
}
.acc-pill {
  padding: 10px 18px;
  border-radius: 999px;
  background: var(--cream-50);
  border: 1px solid var(--line);
  color: var(--muted);
  font-family: var(--font-d);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.acc-pill.active {
  background: var(--pine);
  color: #fff;
  border-color: var(--pine);
}

.acc-huge-input {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 8px;
  margin-bottom: 40px;
}
.acc-currency {
  font-family: var(--font-d);
  font-size: 32px;
  font-weight: 700;
  color: var(--muted);
}
.acc-huge-input input {
  font-family: var(--font-d);
  font-size: 64px;
  font-weight: 700;
  color: var(--pine);
  background: transparent;
  border: none;
  width: 100%;
  max-width: 240px;
  text-align: left;
}
.acc-huge-input input:focus {
  outline: none;
}
.acc-huge-input input::placeholder {
  color: var(--cream-200);
}

.acc-field {
  margin-bottom: 24px;
}
.acc-field label {
  display: block;
  font-family: var(--font-d);
  font-size: 13px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.acc-input {
  width: 100%;
  padding: 16px;
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: var(--cream-50);
  font-family: var(--font-b);
  font-size: 16px;
  color: var(--pine);
  transition: all 0.2s;
  appearance: none;
}
.acc-input:focus {
  outline: none;
  border-color: var(--pine);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(12, 58, 46, 0.1);
}
.acc-actions {
  margin-top: 40px;
}

.acc-sync-msg {
  margin: -18px 0 24px;
  padding: 12px 14px;
  border-radius: var(--r);
  background: var(--cream-50);
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.acc-lines-box {
  background: var(--cream-50);
  padding: 16px;
  border-radius: var(--r);
  margin-bottom: 24px;
}
.acc-lines-box-soft {
  border: 1px solid var(--line);
}
.acc-audit-box {
  border: 1px solid var(--line);
}
.acc-section-label {
  display: block;
  font-size: 13px;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 12px;
  font-weight: 700;
}
.acc-field-row-compact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.acc-field-row-compact .acc-field {
  margin-bottom: 0;
}
.acc-line-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 92px auto 40px;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}
.acc-line-row .acc-input {
  padding: 8px 12px;
}
.acc-line-qty {
  text-align: center;
}
.acc-line-unit {
  min-width: 34px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.acc-mini-empty {
  color: var(--muted);
  font-size: 13px;
  font-style: italic;
  margin-bottom: 4px;
}

@media(max-width: 680px) {
  .acc-page { padding: 24px 16px; }
  .acc-balance-card { padding: 24px; }
  .acc-balance-amount { font-size: 40px; }
  .acc-form { padding: 24px 16px; }
  .acc-huge-input input { font-size: 48px; max-width: 180px; }
  .acc-field-row-compact,
  .acc-line-row {
    grid-template-columns: 1fr;
  }
  .acc-line-row .acc-icon-btn {
    justify-self: end;
  }
}

.acc-ai-hero {
  background: var(--pine);
  border-radius: var(--r-xl);
  padding: 30px;
  color: var(--cream-50);
  box-shadow: 0 12px 30px rgba(12, 58, 46, 0.15);
  margin-bottom: 32px;
}
.acc-ai-input {
  width: 100%;
  background: transparent;
  border: none;
  font-family: var(--font-b);
  font-size: 24px;
  color: #fff;
  resize: none;
  outline: none;
}
.acc-ai-input::placeholder {
  color: rgba(255,255,255,0.4);
}
.acc-ai-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
}
.acc-ai-icon-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  transition: all 0.2s;
}
.acc-ai-icon-btn:hover {
  background: rgba(255,255,255,0.2);
}
.acc-ai-icon-btn.recording {
  background: var(--red);
  color: #fff;
  box-shadow: 0 0 0 6px rgba(215, 77, 59, 0.18);
  animation: acc-recording-pulse 1.1s ease-in-out infinite;
}
@keyframes acc-recording-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.06); }
}
.acc-ai-followup {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.acc-ai-followup ul {
  margin: 10px 0;
  padding-left: 20px;
  font-size: 14px;
  opacity: 0.9;
}
.acc-ai-reply {
  display: flex;
  gap: 8px;
  margin-top: 14px;
}
.acc-ai-reply input {
  flex: 1;
  background: #fff;
  border: none;
  border-radius: 999px;
  padding: 0 16px;
  font-family: var(--font-b);
  font-size: 15px;
  outline: none;
}
.acc-ai-msg {
  margin-top: 16px;
  font-size: 14px;
  color: var(--amber-200);
}

/* ---- FACTORY TYCOON ---- */
.fx-page{
  min-height:100vh;
  padding:32px 20px 80px;
  font-family:var(--font-b);
  color:var(--cream-50);
  background:
    radial-gradient(circle at 15% 10%, rgba(244,201,136,.08), transparent 40%),
    radial-gradient(circle at 85% 90%, rgba(227,146,44,.07), transparent 45%),
    linear-gradient(165deg,#062520 0%,#0A332A 45%,#0E4536 100%);
  background-attachment:fixed;
}
.fx-max{max-width:760px;margin:0 auto}
.fx-top{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.fx-back{
  width:44px;height:44px;border-radius:16px;font-size:26px;line-height:1;
  background:rgba(255,255,255,.08);color:var(--cream-50);
  border:1.5px solid rgba(255,255,255,.14);box-shadow:0 4px 0 rgba(0,0,0,.3);
  cursor:pointer;transition:transform .1s}
.fx-back:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(0,0,0,.3)}
.fx-title{flex:1;display:flex;flex-direction:column}
.fx-title strong{font-family:var(--font-d);font-size:22px;letter-spacing:-.01em}
.fx-title span{font-size:12px;opacity:.65;text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.fx-coins{
  font-family:var(--font-d);font-weight:800;font-size:18px;padding:10px 18px;border-radius:999px;
  background:linear-gradient(180deg,#F8DFAE,#E3922C);color:var(--pine-900);
  box-shadow:0 4px 0 #9c6210,0 8px 18px rgba(0,0,0,.35);white-space:nowrap}

.fx-card{
  background:var(--cream-50);color:var(--pine-900);
  border-radius:22px;padding:18px 20px;
  border:2px solid rgba(7,42,33,.12);
  box-shadow:0 6px 0 rgba(3,20,16,.35),0 16px 30px rgba(0,0,0,.25);
  position:relative}
.fx-section{margin-top:30px}
.fx-section h2{
  font-family:var(--font-d);font-size:17px;font-weight:700;color:var(--cream-50);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;
  display:flex;align-items:center;gap:10px}
.fx-count{
  background:var(--amber);color:var(--pine-900);min-width:24px;height:24px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
.fx-section .fx-card+.fx-card{margin-top:14px}
.fx-empty{text-align:center;color:var(--muted);font-weight:600;padding:28px 20px}

/* nivel / XP */
.fx-level{display:flex;gap:16px;align-items:center}
.fx-level-badge{
  width:64px;height:64px;border-radius:20px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-d);font-weight:800;font-size:19px;color:var(--pine-900);
  background:linear-gradient(180deg,#F8DFAE,#E3922C);
  box-shadow:0 4px 0 #9c6210,inset 0 2px 0 rgba(255,255,255,.5)}
.fx-level-body{flex:1;display:flex;flex-direction:column;gap:8px}
.fx-level-row{display:flex;justify-content:space-between;align-items:baseline}
.fx-level-row strong{font-family:var(--font-d);font-size:17px;color:var(--pine)}
.fx-level-row span{font-size:12px;font-weight:700;color:var(--muted)}
.fx-produced{display:flex;gap:8px;flex-wrap:wrap}

/* barras de progreso */
.fx-bar{
  position:relative;height:14px;border-radius:999px;overflow:hidden;
  background:rgba(7,42,33,.12);box-shadow:inset 0 2px 3px rgba(0,0,0,.15)}
.fx-bar-sm{height:18px;margin-top:10px}
.fx-bar-fill{
  height:100%;border-radius:999px;min-width:6px;
  background:linear-gradient(180deg,#5FB874,#2E8B57);
  background-size:auto, 28px 28px;
  transition:width .2s linear;position:relative}
.fx-bar-fill::after{
  content:"";position:absolute;inset:0;border-radius:999px;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.25) 0 8px,transparent 8px 16px);
  animation:fxStripes 1s linear infinite}
@keyframes fxStripes{to{transform:translateX(22px)}}
.fx-bar-green{background:linear-gradient(180deg,#5FB874,#2E8B57)}
.fx-bar-danger{background:linear-gradient(180deg,#F08A7E,#D4543F)}
.fx-bar-xp{background:linear-gradient(180deg,#F4C988,#E3922C)}
.fx-bar-label{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--pine-900);text-shadow:0 1px 0 rgba(255,255,255,.4)}

/* botones game */
.fx-btn{
  font-family:var(--font-d);font-weight:800;font-size:14px;
  padding:10px 16px;border-radius:14px;cursor:pointer;border:none;
  background:linear-gradient(180deg,#fff,#EFE3CC);color:var(--pine);
  box-shadow:0 4px 0 rgba(7,42,33,.35),inset 0 2px 0 rgba(255,255,255,.7);
  transition:transform .08s, box-shadow .08s}
.fx-btn:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(7,42,33,.35)}
.fx-btn-amber{background:linear-gradient(180deg,#F8DFAE,#E3922C);color:var(--pine-900);box-shadow:0 4px 0 #9c6210,inset 0 2px 0 rgba(255,255,255,.5)}
.fx-btn-pine{background:linear-gradient(180deg,#15573F,#0C3A2E);color:var(--cream-50);box-shadow:0 4px 0 #03150f,inset 0 2px 0 rgba(255,255,255,.12)}
.fx-btn-off{opacity:.45;filter:saturate(.4)}
.fx-btn-block{display:block;width:100%;margin-top:12px;text-align:center}

/* recetas */
.fx-recipe-head{display:flex;align-items:center;gap:14px}
.fx-recipe-emoji{font-size:42px;line-height:1;filter:drop-shadow(0 3px 2px rgba(0,0,0,.2))}
.fx-recipe-title{flex:1;display:flex;flex-direction:column;gap:2px}
.fx-recipe-title strong{font-family:var(--font-d);font-size:19px;color:var(--pine)}
.fx-recipe-title span{font-size:12.5px;font-weight:600;color:var(--muted)}
.fx-recipe-actions{display:flex;gap:8px}
.fx-steps-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:14px}
.fx-step-arrow{color:var(--amber-600);font-weight:800;font-size:16px}
.fx-step-chip{
  display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:999px;
  background:#fff;border:1.5px solid rgba(7,42,33,.12);font-size:12px;font-weight:700;color:var(--pine)}
.fx-step-chip em{font-style:normal;color:var(--amber-600);font-weight:800}
.fx-recipe-needs{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.fx-need{
  font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;
  background:rgba(46,139,87,.12);color:#1F6B43}
.fx-need-missing{background:rgba(212,84,63,.14);color:#B23A28;animation:fxBlink 1.2s ease-in-out infinite}
@keyframes fxBlink{50%{opacity:.45}}

/* órdenes */
.fx-job-head{display:flex;align-items:center;gap:12px}
.fx-job-emoji{font-size:30px;line-height:1}
.fx-job-title{flex:1;display:flex;flex-direction:column;gap:1px}
.fx-job-title strong{font-family:var(--font-d);font-size:15.5px;color:var(--pine)}
.fx-job-title span{font-size:12px;font-weight:600;color:var(--muted)}
.fx-status{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:5px 10px;border-radius:999px}
.fx-status-run{background:rgba(46,139,87,.15);color:#1F6B43}
.fx-status-wait{background:rgba(7,42,33,.08);color:var(--muted)}
.fx-status-warn{background:rgba(227,146,44,.2);color:#9c6210;animation:fxBlink 1.2s ease-in-out infinite}
.fx-status-danger{background:rgba(212,84,63,.16);color:#B23A28;animation:fxBlink 1.2s ease-in-out infinite}
.fx-status-choice{background:rgba(126,87,194,.16);color:#5E35B1;animation:fxBlink 1.2s ease-in-out infinite}
.fx-choice-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.fx-choice-btn{
  font-family:var(--font-d);font-weight:800;font-size:12.5px;cursor:pointer;
  padding:9px 14px;border-radius:12px;border:none;
  background:linear-gradient(180deg,#EDE7F6,#D1C4E9);color:#4527A0;
  box-shadow:0 3px 0 #7E57C2,inset 0 2px 0 rgba(255,255,255,.6);
  transition:transform .08s, box-shadow .08s}
.fx-choice-btn:hover{background:linear-gradient(180deg,#F3EFFB,#DCD0F0)}
.fx-choice-btn:active{transform:translateY(2px);box-shadow:0 1px 0 #7E57C2}
.fx-job-x{
  width:26px;height:26px;border-radius:50%;border:none;cursor:pointer;font-size:12px;
  background:rgba(7,42,33,.08);color:var(--muted);flex-shrink:0}
.fx-job-x:hover{background:rgba(212,84,63,.16);color:#B23A28}
.fx-job-skip:hover{background:rgba(227,146,44,.25);color:#9c6210}
.fx-test-btn{
  margin-left:auto;border:1.5px dashed rgba(255,255,255,.45);background:rgba(255,255,255,.06);
  color:var(--cream-50);font-family:var(--font-d);font-weight:700;font-size:12px;
  padding:6px 14px;border-radius:999px;cursor:pointer;letter-spacing:.04em;text-transform:none;
  transition:all .15s}
.fx-test-btn:hover{background:rgba(255,255,255,.16);border-style:solid}
.fx-job-steps{display:flex;gap:6px;margin-top:14px}
.fx-job-seg{flex:1;height:12px;border-radius:999px;background:rgba(7,42,33,.1);overflow:hidden;position:relative}
.fx-job-seg.done{background:rgba(46,139,87,.2)}
.fx-job-seg .fx-job-seg-fill{
  height:100%;border-radius:999px;background:linear-gradient(180deg,#5FB874,#2E8B57);transition:width .2s linear}
.fx-job-seg .fx-job-seg-fill.full{width:100%}
.fx-job-seg.current{box-shadow:0 0 0 2px var(--amber)}
.fx-job-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-size:12.5px;font-weight:600;color:var(--muted)}
.fx-job-stepcount{font-weight:800;color:var(--pine)}

/* máquinas */
.fx-grid{display:grid;gap:14px}
.fx-grid-machines{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}
.fx-grid-insumos{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.fx-machine{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding-top:24px}
.fx-machine-emoji{font-size:44px;line-height:1;transition:transform .3s}
.fx-working .fx-machine-emoji{animation:fxShake .5s ease-in-out infinite}
@keyframes fxShake{0%,100%{transform:rotate(0)}25%{transform:rotate(-6deg) scale(1.05)}75%{transform:rotate(6deg) scale(1.05)}}
.fx-working{box-shadow:0 6px 0 rgba(3,20,16,.35),0 0 0 3px var(--amber),0 16px 36px rgba(227,146,44,.35);animation:fxGlow 1.6s ease-in-out infinite}
@keyframes fxGlow{50%{box-shadow:0 6px 0 rgba(3,20,16,.35),0 0 0 3px var(--amber-200),0 16px 44px rgba(227,146,44,.55)}}
.fx-machine-name{font-family:var(--font-d);font-size:15.5px;color:var(--pine)}
.fx-machine-desc{font-size:11.5px;color:var(--muted);font-weight:600;min-height:28px}
.fx-machine-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.fx-tag{
  font-size:11px;font-weight:800;padding:4px 9px;border-radius:999px;
  background:rgba(7,42,33,.08);color:var(--pine)}
.fx-slots{display:inline-flex;gap:4px;align-items:center}
.fx-slots i{width:10px;height:10px;border-radius:50%;background:rgba(7,42,33,.15)}
.fx-slots i.on{background:var(--amber);box-shadow:0 0 6px rgba(227,146,44,.8)}
.fx-machine .fx-bar-sm{width:100%}
.fx-bottleneck{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:linear-gradient(180deg,#F08A7E,#D4543F);color:#fff;
  font-size:11px;font-weight:800;padding:4px 12px;border-radius:999px;white-space:nowrap;
  box-shadow:0 3px 0 #8e2f1f;animation:fxBounce .8s ease-in-out infinite;z-index:2}
@keyframes fxBounce{50%{transform:translateX(-50%) translateY(-3px)}}

/* insumos */
.fx-insumo{display:flex;flex-direction:column;gap:10px}
.fx-insumo-low{box-shadow:0 6px 0 rgba(3,20,16,.35),0 0 0 2.5px #D4543F,0 16px 30px rgba(212,84,63,.3)}
.fx-insumo-head{display:flex;align-items:center;gap:12px}
.fx-insumo-emoji{font-size:32px;line-height:1}
.fx-insumo-head div{display:flex;flex-direction:column}
.fx-insumo-head strong{font-family:var(--font-d);font-size:15px;color:var(--pine)}
.fx-insumo-head span{font-size:12px;font-weight:700;color:var(--muted)}
.fx-insumo .fx-btn-block{margin-top:2px}

/* log */
.fx-log{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;padding:14px 16px}
.fx-log-row{display:flex;gap:10px;font-size:13px;font-weight:600;line-height:1.4}
.fx-log-time{color:var(--muted);font-size:11px;font-weight:700;flex-shrink:0;padding-top:2px}
.fx-log-ok{color:#1F6B43}
.fx-log-warn{color:#9c6210}
.fx-log-info{color:var(--pine-900)}

/* footer + pops */
.fx-footer{margin-top:36px;text-align:center}
.fx-reset{
  background:transparent;border:1.5px solid rgba(255,255,255,.2);color:rgba(255,255,255,.55);
  font-size:12px;font-weight:700;padding:8px 18px;border-radius:999px;cursor:pointer}
.fx-reset:hover{color:#fff;border-color:rgba(255,255,255,.5)}
.fx-pops{position:fixed;bottom:90px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;z-index:120}
.fx-pop{
  font-family:var(--font-d);font-weight:800;font-size:20px;color:var(--pine-900);
  background:linear-gradient(180deg,#F8DFAE,#E3922C);padding:12px 26px;border-radius:999px;
  box-shadow:0 5px 0 #9c6210,0 16px 36px rgba(0,0,0,.4);
  animation:fxPop 2.6s cubic-bezier(.2,.8,.3,1) forwards}
@keyframes fxPop{
  0%{opacity:0;transform:translateY(30px) scale(.6)}
  12%{opacity:1;transform:translateY(0) scale(1.08)}
  20%{transform:translateY(0) scale(1)}
  80%{opacity:1;transform:translateY(-10px)}
  100%{opacity:0;transform:translateY(-44px) scale(.9)}
}

/* banner en caja */
.acc-factory-banner{
  display:flex;align-items:center;gap:16px;width:100%;text-align:left;cursor:pointer;border:none;
  background:
    radial-gradient(circle at 85% 20%, rgba(244,201,136,.25), transparent 55%),
    linear-gradient(135deg,#0E4536,#072A21);
  color:var(--cream-50);border-radius:var(--r-xl);padding:22px 24px;margin-bottom:32px;
  box-shadow:0 5px 0 rgba(3,20,16,.5),0 16px 32px rgba(5,44,38,.3);
  transition:transform .12s}
.acc-factory-banner:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(3,20,16,.5)}
.acc-factory-banner .em{font-size:40px;line-height:1;filter:drop-shadow(0 3px 3px rgba(0,0,0,.3))}
.acc-factory-banner div{flex:1;display:flex;flex-direction:column;gap:3px}
.acc-factory-banner strong{font-family:var(--font-d);font-size:18px}
.acc-factory-banner span{font-size:13px;opacity:.75}
.acc-factory-banner .go{
  font-family:var(--font-d);font-weight:800;font-size:14px;padding:10px 18px;border-radius:999px;
  background:linear-gradient(180deg,#F8DFAE,#E3922C);color:var(--pine-900);
  box-shadow:0 3px 0 #9c6210;white-space:nowrap}

/* cocina ilustrada (vista desde arriba, estilo juego) */
.fxk-viewport{
  overflow-x:auto;border-radius:28px;
  border:3px solid rgba(7,42,33,.35);
  box-shadow:0 8px 0 rgba(3,20,16,.45),0 20px 44px rgba(0,0,0,.35);
  scrollbar-width:thin}
.fxk-room{
  position:relative;min-width:780px;height:560px;
  /* piso damero de la cocina */
  background:
    repeating-conic-gradient(rgba(7,42,33,.045) 0% 25%, transparent 0% 50%) 0 0/64px 64px,
    linear-gradient(180deg,#EEDFBD 0%,#E6D3A8 100%)}
.fxk-backwall{
  position:absolute;top:0;left:0;right:0;height:88px;z-index:1;
  background:
    repeating-linear-gradient(90deg, rgba(7,42,33,.06) 0 2px, transparent 2px 38px),
    repeating-linear-gradient(0deg, rgba(7,42,33,.06) 0 2px, transparent 2px 38px),
    linear-gradient(180deg,#F7EFDC 0%,#F1E5C8 100%);
  border-bottom:7px solid #8A6B43;
  box-shadow:0 6px 12px rgba(7,42,33,.25)}
.fxk-window{
  position:absolute;top:14px;left:24px;width:104px;height:62px;border-radius:12px;
  background:linear-gradient(180deg,#BFE3EE 0%,#DFF2E9 100%);
  border:5px solid #8A6B43;box-shadow:0 3px 0 rgba(7,42,33,.25),inset 0 0 0 2px rgba(255,255,255,.4)}
.fxk-window::before{content:"";position:absolute;top:0;bottom:0;left:50%;width:4px;background:#8A6B43}
.fxk-window i{
  position:absolute;top:6px;right:9px;width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle,#F8DFAE 30%,#E3922C 100%);
  box-shadow:0 0 14px rgba(227,146,44,.9);animation:fxGlowSun 3s ease-in-out infinite}
@keyframes fxGlowSun{50%{box-shadow:0 0 22px rgba(227,146,44,1)}}
.fxk-sign{
  position:absolute;top:16px;left:50%;transform:translateX(-50%) rotate(-1.5deg);
  font-family:var(--font-d);font-weight:800;font-size:13px;letter-spacing:.22em;
  background:var(--pine);color:var(--cream-50);padding:8px 20px;border-radius:10px;
  box-shadow:0 4px 0 rgba(3,20,16,.45)}
.fxk-deco{position:absolute;font-size:24px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.2))}
.fxk-deco-plant{top:18px;right:28px;animation:fxSway 3.4s ease-in-out infinite}
@keyframes fxSway{50%{transform:rotate(6deg)}}
.fxk-deco-pans{top:34px;right:90px;font-size:19px;letter-spacing:6px}
/* mesadas de madera pegadas a las paredes */
.fxk-counter{position:absolute;background:linear-gradient(180deg,#C19260,#A87B4D);box-shadow:inset 0 3px 0 rgba(255,255,255,.25), 0 6px 10px rgba(7,42,33,.28)}
.fxk-counter-back{top:95px;left:0;right:0;height:52px;border-bottom:6px solid #8A6B43}
.fxk-counter-left{top:147px;left:0;bottom:64px;width:58px;border-right:6px solid #8A6B43;border-radius:0 0 14px 0}
.fxk-counter-right{top:147px;right:0;bottom:64px;width:58px;border-left:6px solid #8A6B43;border-radius:0 0 0 14px}
/* alfombra bajo la isla central */
.fxk-rug{
  position:absolute;left:50%;top:64%;transform:translate(-50%,-50%);
  width:330px;height:190px;border-radius:50%;
  background:radial-gradient(ellipse, rgba(12,58,46,.18) 0%, rgba(12,58,46,.1) 55%, transparent 72%)}
.fxk-doormat{
  position:absolute;bottom:14px;right:36px;z-index:2;
  font-family:var(--font-d);font-weight:800;font-size:12px;color:#6b5430;
  background:repeating-linear-gradient(45deg,#D9C492 0 8px,#CDB67F 8px 16px);
  border:3px solid #8A6B43;border-radius:10px;padding:10px 18px;
  box-shadow:0 4px 8px rgba(7,42,33,.25);transform:rotate(-2deg)}
.fxk-spot{position:absolute}
.fxk-station{display:flex;flex-direction:column;align-items:center;gap:5px}
.fxk-badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;min-height:24px}
.fxk-occ,.fxk-units,.fxk-wait{
  font-family:var(--font-d);font-weight:800;font-size:11px;padding:4px 10px;border-radius:999px;
  background:var(--cream-50);color:var(--pine);box-shadow:0 2px 0 rgba(7,42,33,.3);white-space:nowrap}
.fxk-occ.full{background:#F8D3CB;color:#B23A28}
.fxk-units{background:#D9EBDD;color:#1F6B43}
.fxk-wait{background:linear-gradient(180deg,#F08A7E,#D4543F);color:#fff;animation:fxBounce2 .8s ease-in-out infinite}
@keyframes fxBounce2{50%{transform:translateY(-3px)}}
.fxk-body{position:relative;display:flex;flex-direction:column;align-items:center}
.fxk-body::after{ /* sombra elíptica en el piso */
  content:"";position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);
  width:82%;height:18px;border-radius:50%;z-index:-1;
  background:radial-gradient(ellipse, rgba(7,42,33,.35) 0%, transparent 70%)}
.fxk-sprite{
  display:block;width:auto;user-select:none;
  filter:drop-shadow(0 12px 10px rgba(7,42,33,.3));
  transition:transform .2s}
.fxk-station.working .fxk-sprite{
  animation:fxkWork 1.1s ease-in-out infinite;
  filter:drop-shadow(0 12px 10px rgba(7,42,33,.3)) drop-shadow(0 0 18px rgba(227,146,44,.55))}
@keyframes fxkWork{
  0%,100%{transform:rotate(0) scale(1)}
  25%{transform:rotate(-1.6deg) scale(1.015)}
  75%{transform:rotate(1.6deg) scale(1.015)}
}
.fxk-steam{top:-22px;z-index:3}
.fxk-chefs{
  position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);
  display:flex;gap:2px;z-index:3}
.fxk-chefs .fx-chef{font-size:30px;filter:drop-shadow(0 3px 2px rgba(0,0,0,.3))}
.fxk-job-row{display:flex;align-items:center;gap:4px;width:100%;max-width:196px;margin-top:4px}
.fxk-mini-actions{display:flex;gap:3px;flex-shrink:0}
.fxk-mini-btn{
  width:21px;height:21px;border-radius:50%;border:none;cursor:pointer;padding:0;
  display:flex;align-items:center;justify-content:center;font-size:10px;
  background:var(--cream-50);color:var(--pine);
  box-shadow:0 2px 0 rgba(7,42,33,.4);transition:transform .08s, background .15s}
.fxk-mini-btn:hover{background:#F4C988}
.fxk-mini-btn:active{transform:translateY(2px);box-shadow:0 0 0 rgba(7,42,33,.4)}
.fxk-mini-x:hover{background:#F8D3CB;color:#B23A28}
.fxk-wait-chip{
  flex:1;font-family:var(--font-d);font-weight:800;font-size:10.5px;text-align:center;
  background:linear-gradient(180deg,#F08A7E,#D4543F);color:#fff;padding:4px 8px;border-radius:999px;
  white-space:nowrap;animation:fxBlink 1.4s ease-in-out infinite}
.fxk-recv{
  width:100%;max-width:170px;margin-top:5px;cursor:pointer;border:none;
  font-family:var(--font-d);font-weight:800;font-size:11.5px;padding:7px 10px;border-radius:999px;
  background:linear-gradient(180deg,#EDE7F6,#B39DDB);color:#4527A0;
  box-shadow:0 3px 0 #7E57C2;animation:fxBounce2 .9s ease-in-out infinite;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fxk-recv:hover{background:linear-gradient(180deg,#F3EFFB,#C9B8E8)}
.fxk-recv:active{transform:translateY(2px);box-shadow:0 1px 0 #7E57C2;animation:none}
/* botones flotantes de la cocina */
.fxk-fabs{position:absolute;bottom:14px;left:24px;z-index:60;display:flex;gap:8px;flex-wrap:wrap}
.fxk-fab{
  cursor:pointer;border:none;
  background:var(--cream-50);color:var(--pine);
  font-family:var(--font-d);font-weight:800;font-size:13px;padding:10px 18px;border-radius:999px;
  box-shadow:0 4px 0 rgba(7,42,33,.4),0 8px 16px rgba(7,42,33,.25);transition:all .12s}
.fxk-fab:hover{background:#fff}
.fxk-fab:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(7,42,33,.4)}
.fxk-fab-main{
  background:linear-gradient(180deg,#F8DFAE,#E3922C);color:var(--pine-900);
  box-shadow:0 4px 0 #9c6210,0 8px 16px rgba(227,146,44,.4)}
.fxk-fab-main:hover{background:linear-gradient(180deg,#FAE7C2,#EB9D38)}
.fxk-fab-main:active{box-shadow:0 1px 0 #9c6210}
.fxk-fab-test{border:1.5px dashed rgba(7,42,33,.5);background:rgba(255,249,238,.85)}

/* paneles sobre la cocina */
.fxk-overlay{
  position:fixed;inset:0;z-index:220;display:flex;align-items:center;justify-content:center;
  background:rgba(5,30,24,.55);backdrop-filter:blur(3px);padding:20px}
.fxk-panel{
  width:min(540px,100%);max-height:82vh;display:flex;flex-direction:column;
  background:var(--cream-50);border-radius:22px;
  border:2px solid rgba(7,42,33,.15);
  box-shadow:0 8px 0 rgba(3,20,16,.4),0 28px 60px rgba(0,0,0,.45)}
.fxk-panel-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1.5px dashed rgba(7,42,33,.15)}
.fxk-panel-head strong{font-family:var(--font-d);font-size:17px;color:var(--pine)}
.fxk-panel-head .fxk-mini-btn{width:28px;height:28px;font-size:12px}
.fxk-panel-body{overflow-y:auto;padding:12px 16px 16px}
.fxk-panel-row{
  display:flex;align-items:center;gap:12px;padding:12px;border-radius:16px;
  background:#fff;border:1.5px solid rgba(7,42,33,.08);margin-top:10px}
.fxk-panel-row:first-child{margin-top:0}
.fxk-panel-row.low{border-color:rgba(212,84,63,.5);background:rgba(212,84,63,.05)}
.fxk-panel-emoji{font-size:30px;line-height:1;flex-shrink:0}
.fxk-panel-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.fxk-panel-info strong{font-family:var(--font-d);font-size:15px;color:var(--pine)}
.fxk-panel-info span{font-size:12px;font-weight:600;color:var(--muted)}
.fxk-panel-info em{font-style:normal;font-size:11.5px;font-weight:800;color:#B23A28}
.fxk-panel-bar{height:8px;margin-top:4px}
.fxk-stepper-sm{padding:3px}
.fxk-stepper-sm button{width:30px;height:30px;font-size:15px;border-radius:9px}
.fxk-stepper-sm strong{font-size:15px;min-width:26px}
.fxk-go{padding:10px 16px;font-size:15px}
.fxk-prog{
  position:relative;flex:1;width:100%;max-width:150px;height:18px;border-radius:999px;overflow:hidden;
  background:rgba(7,42,33,.25);box-shadow:inset 0 2px 3px rgba(0,0,0,.25)}
.fxk-prog>div{
  height:100%;border-radius:999px;min-width:6px;
  background:linear-gradient(180deg,#F4C988,#E3922C);position:relative;transition:width 1s linear}
.fxk-prog>div::after{
  content:"";position:absolute;inset:0;border-radius:999px;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.3) 0 7px,transparent 7px 14px);
  animation:fxStripes 1s linear infinite}
.fxk-prog>span{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap;overflow:hidden}
.fxk-label{
  font-family:var(--font-d);font-weight:800;font-size:11px;text-align:center;
  background:linear-gradient(180deg,#A87B4D,#8A6B43);color:var(--cream-50);
  padding:5px 12px;border-radius:8px;box-shadow:0 3px 0 rgba(7,42,33,.4);
  max-width:140px;line-height:1.25}
@media (max-width:560px){
  .fxk-room{min-width:720px;height:520px}
  .fxk-deco-pans{display:none}
}

/* cocina virtual */
.fx-kitchen{
  background:
    repeating-conic-gradient(#F3E7CB 0% 25%, #E8D9B5 0% 50%) 0 0 / 56px 56px;
  border-radius:26px;padding:18px;
  border:3px solid rgba(7,42,33,.25);
  box-shadow:inset 0 0 46px rgba(7,42,33,.22), 0 8px 0 rgba(3,20,16,.4), 0 18px 36px rgba(0,0,0,.3)}
.fx-station{padding-top:28px;overflow:visible}
.fx-station-top{position:relative}
.fx-steam{position:absolute;top:-16px;left:50%;transform:translateX(-50%);display:flex;gap:7px}
.fx-steam i{
  width:7px;height:7px;border-radius:50%;background:rgba(7,42,33,.3);
  animation:fxSteam 1.6s ease-in infinite}
.fx-steam i:nth-child(2){animation-delay:.45s}
.fx-steam i:nth-child(3){animation-delay:.9s}
@keyframes fxSteam{
  0%{opacity:0;transform:translateY(8px) scale(.5)}
  30%{opacity:1}
  100%{opacity:0;transform:translateY(-16px) scale(1.4)}
}
.fx-chefs{display:flex;gap:7px;align-items:center;justify-content:center;margin-top:4px;min-height:30px}
.fx-chef{font-size:23px;line-height:1;animation:fxChef 1s ease-in-out infinite;filter:drop-shadow(0 2px 1px rgba(0,0,0,.2))}
.fx-chef:nth-child(2n){animation-delay:.35s}
.fx-chef:nth-child(3n){animation-delay:.6s}
@keyframes fxChef{50%{transform:translateY(-3px) rotate(-6deg)}}
.fx-chef-empty{width:24px;height:24px;border:2.5px dashed rgba(7,42,33,.28);border-radius:50%;flex-shrink:0}
.fx-occup{font-family:var(--font-d);font-weight:800;font-size:15px;color:var(--pine);margin-left:5px}
.fx-occup.full{color:#B23A28}
.fx-units{width:100%;margin-top:6px}
.fx-units-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.fx-units-label span{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.fx-units-label strong{font-family:var(--font-d);font-size:13px;font-weight:800;color:var(--pine)}
.fx-units-label strong.full{color:#B23A28}
.fx-station-job{
  width:100%;margin-top:8px;display:flex;flex-direction:column;gap:5px;
  background:#fff;border-radius:12px;padding:8px 10px;border:1.5px solid rgba(7,42,33,.08)}
.fx-station-job-head{display:flex;justify-content:space-between;gap:8px;font-size:12px;font-weight:800;color:var(--pine)}
.fx-station-job-head span:last-child{color:var(--amber-600);white-space:nowrap}
.fx-station-queue{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-top:8px}
.fx-queue-chip{
  font-size:11px;font-weight:800;padding:4px 10px;border-radius:999px;
  background:rgba(227,146,44,.2);color:#9c6210;animation:fxBlink 1.4s ease-in-out infinite}
.fx-station-idle{font-size:12px;font-weight:700;color:var(--muted);margin-top:8px}
.fx-station-price{
  position:absolute;bottom:-9px;left:50%;transform:translateX(-50%);
  font-size:10.5px;font-weight:800;white-space:nowrap;
  background:var(--pine);color:var(--cream-50);padding:3px 11px;border-radius:999px;
  box-shadow:0 2px 0 rgba(3,20,16,.5)}
.fx-grid-machines{row-gap:22px}

/* lanzar producción: tamaño de tanda */
.fx-launch{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-top:14px;padding-top:14px;border-top:1.5px dashed rgba(7,42,33,.15)}
.fx-stepper{display:flex;align-items:center;gap:4px;background:rgba(7,42,33,.07);border-radius:14px;padding:4px}
.fx-stepper button{
  width:36px;height:36px;border-radius:11px;border:none;cursor:pointer;
  font-family:var(--font-d);font-weight:800;font-size:18px;color:var(--pine);
  background:linear-gradient(180deg,#fff,#EFE3CC);
  box-shadow:0 3px 0 rgba(7,42,33,.3),inset 0 2px 0 rgba(255,255,255,.7);
  transition:transform .08s, box-shadow .08s}
.fx-stepper button:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(7,42,33,.3)}
.fx-stepper strong{font-family:var(--font-d);font-weight:800;font-size:18px;color:var(--pine);min-width:34px;text-align:center}
.fx-launch-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:150px}
.fx-launch-info strong{font-family:var(--font-d);font-size:15px;color:var(--pine)}
.fx-launch-info span{font-size:12px;font-weight:600;color:var(--muted)}
.fx-launch-warn{
  margin-top:10px;font-size:12.5px;font-weight:700;color:#B23A28;
  background:rgba(212,84,63,.1);border-radius:12px;padding:8px 12px}
.fx-config-btn{font-size:18px}

/* configuración (variables meta) */
.fx-config-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:12px}
.fx-cfg-field{display:flex;flex-direction:column;gap:4px}
.fx-cfg-field span{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.fx-input{
  background:#fff;border:1.5px solid rgba(7,42,33,.15);border-radius:10px;
  padding:9px 11px;font-family:var(--font-b);font-size:14px;font-weight:600;
  color:var(--pine-900);min-width:0;outline:none;transition:border-color .15s}
.fx-input:focus{border-color:var(--amber)}
.fx-input-sm{width:86px;text-align:center}
.fx-input-emoji{width:56px;text-align:center;font-size:18px;padding:7px 4px}
select.fx-input{cursor:pointer}
.fx-del{
  width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;
  background:rgba(212,84,63,.12);color:#B23A28;font-weight:800;font-size:13px;
  margin-bottom:3px;transition:background .15s}
.fx-del:hover{background:rgba(212,84,63,.25)}
.fx-add{
  background:transparent;border:1.5px dashed rgba(7,42,33,.35);color:var(--pine);
  border-radius:12px;padding:9px 16px;font-family:var(--font-d);font-weight:700;font-size:13px;
  cursor:pointer;transition:all .15s}
.fx-add:hover{background:rgba(7,42,33,.06);border-style:solid}
.fx-add-light{border-color:rgba(255,255,255,.4);color:var(--cream-50);width:100%;padding:14px}
.fx-add-light:hover{background:rgba(255,255,255,.08)}
.fx-config-sub{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin:14px 0 10px}
.fx-step-edit{
  background:#fff;border:1.5px solid rgba(7,42,33,.1);border-radius:16px;
  padding:14px;margin-bottom:12px}
.fx-step-edit .fx-config-sub{margin-top:10px}
.fx-dur-hint{font-size:11px;font-weight:800;color:var(--amber-600);white-space:nowrap;margin-bottom:12px}
.fx-savebar{
  position:sticky;bottom:14px;display:flex;gap:10px;margin-top:30px;flex-wrap:wrap;
  background:rgba(7,42,33,.85);backdrop-filter:blur(8px);border-radius:18px;padding:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.4)}
.fx-savebar-main{flex:1;min-width:200px}

@media (max-width:560px){
  .fx-page{padding:20px 14px 70px}
  .fx-recipe-head{flex-wrap:wrap}
  .fx-grid-machines,.fx-grid-insumos{grid-template-columns:repeat(2,1fr)}
  .fx-launch{align-items:flex-start}
  .fx-input-sm{width:70px}
}
