:root{
  --crust:#f6efe8;
  --crust-2:#fff7f0;
  --card:#ffffff;
  --card-2:#f7ece2;
  --cream:#2f241d;
  --cream-dim:#6e6258;
  --tomato:#d85a2a;
  --tomato-dark:#b84520;
  --basil:#4f8f63;
  --basil-dark:#35684a;
  --semolina:#c58f1d;
  --slate:#4f7890;
  --line: rgba(47,36,29,0.12);
  --radius: 14px;
}
*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  background:var(--crust);
  font-family:'Manrope', system-ui, sans-serif;
}
#pizzeria-root{
  font-family:'Manrope', system-ui, sans-serif;
  background:var(--crust);
  color:var(--cream);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-tap-highlight-color: transparent;
  user-select:none;
  max-width:720px;
  margin:0 auto;
  position:relative;
}
#pizzeria-root .num{font-family:'Fraunces', serif;}
#pizzeria-root button{font-family:inherit; cursor:pointer;}
#pizzeria-root input{font-family:inherit;}
.screen{padding:16px; flex:1; overflow-y:auto; padding-bottom:32px;}

/* Topbar */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; background:var(--crust-2); border-bottom:1px solid var(--line);
  position:sticky; top:0; z-index:5;
}
.topbar .role{font-weight:800; letter-spacing:.02em;}
.topbar .sub{font-size:12px; color:var(--cream-dim);}
.logout-btn{
  background:transparent; border:1px solid var(--line); color:var(--cream-dim);
  border-radius:10px; padding:8px 12px; font-size:13px; font-weight:700;
}

/* Login */
.login-wrap{display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:100vh; padding:32px 16px; text-align:center;}
.login-mark{font-family:'Fraunces',serif; font-size:34px; font-weight:700; margin-bottom:4px;}
.login-tag{color:var(--cream-dim); font-size:14px; margin-bottom:28px;}
.login-form{width:100%; max-width:320px; display:flex; flex-direction:column; gap:12px;}
.login-form input{
  background:var(--card); border:1px solid var(--line); color:var(--cream);
  border-radius:12px; padding:14px 16px; font-size:15px;
}
.login-form input:focus{outline:2px solid var(--tomato); border-color:transparent;}
.login-error{color:var(--tomato); font-size:13px; min-height:18px;}
.role-hint{color:var(--cream-dim); font-size:12px; margin-top:18px; line-height:1.6;}

/* Grid of articles */
.section-title{
  display:flex; align-items:center; justify-content:space-between;
  font-size:12px; text-transform:uppercase; letter-spacing:.08em; color:var(--cream-dim); margin:18px 0 8px;
}
.article-grid{display:grid; grid-template-columns:1fr 1fr; gap:10px;}
.article-tile{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px 12px; min-height:88px; display:flex; flex-direction:column; justify-content:space-between;
  text-align:left;
}
.article-tile:active{background:var(--card-2);}
.article-tile.pizza{background:linear-gradient(135deg, var(--tomato-dark), var(--tomato)); border:none;}
.article-name{font-weight:800; font-size:15px;}
.article-price{font-size:12px; color:var(--cream-dim); margin-top:6px;}
.article-tile.pizza .article-price{color:rgba(245,239,230,.85);}

/* Cart bar */
.cart-bar{
  position:sticky; bottom:0; background:var(--crust-2); border-top:1px solid var(--line);
  padding:12px 16px; display:flex; gap:10px; align-items:center;
}
.cart-summary{flex:1; font-size:13px; color:var(--cream-dim);}
.cart-summary b{color:var(--cream); font-family:'Fraunces',serif; font-size:16px;}
.btn{border:none; border-radius:12px; padding:14px 18px; font-weight:800; font-size:14px;}
.btn-primary{background:var(--tomato); color:#fff;}
.btn-primary:disabled{background:#4a3a30; color:var(--cream-dim);}
.btn-basil{background:var(--basil); color:#12200e;}
.btn-outline{background:transparent; border:1px solid var(--line); color:var(--cream);}
.btn-ghost{background:var(--card); color:var(--cream);}
.btn-small{padding:8px 12px; font-size:12px; border-radius:8px;}

/* Cart sheet */
.cart-sheet{background:var(--crust-2); border-top:1px solid var(--line); padding:12px 16px 4px;}
.cart-item{display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--line);}
.cart-item .name{flex:1; font-weight:700; font-size:14px;}
.cart-item .meta{font-size:11px; color:var(--cream-dim);}
.qty-ctrl{display:flex; align-items:center; gap:8px;}
.qty-btn{width:30px; height:30px; border-radius:8px; border:1px solid var(--line); background:var(--card); color:var(--cream); font-weight:800;}
.remove-btn{color:var(--tomato); background:none; border:none; font-size:12px; font-weight:800; padding:4px;}

/* Modal (pizza configurator) */
.modal-overlay{position:fixed; inset:0; background:rgba(15,10,7,.72); display:flex; align-items:flex-end; justify-content:center; z-index:20;}
.modal-sheet{background:var(--crust-2); width:100%; max-width:720px; max-height:88vh; border-radius:20px 20px 0 0; display:flex; flex-direction:column; overflow:hidden;}
.modal-header{padding:16px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line);}
.modal-title{font-family:'Fraunces',serif; font-weight:700; font-size:20px;}
.close-x{background:var(--card); border:none; color:var(--cream); width:32px; height:32px; border-radius:50%; font-size:16px;}
.modal-body{padding:14px 16px; overflow-y:auto;}
.ing-grid{display:grid; grid-template-columns:1fr 1fr; gap:10px;}
.ing-tile{
  position:relative; background:var(--card); border:1px solid var(--line); border-radius:12px;
  padding:14px 10px 10px; min-height:76px; display:flex; flex-direction:column; justify-content:flex-end; gap:4px;
}
.ing-tile.active{border-color:var(--tomato); background:var(--card-2);}
.ing-tile.disabled{opacity:.4;}
.ing-name{font-weight:700; font-size:13px;}
.ing-price{font-size:11px; color:var(--cream-dim);}
.ing-badge{
  position:absolute; top:8px; right:8px; background:var(--tomato); color:#fff; font-weight:800; font-size:12px;
  min-width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center;
}
.ing-minus{
  position:absolute; top:8px; left:8px; width:22px; height:22px; border-radius:50%; border:1px solid var(--line);
  background:var(--crust); color:var(--cream); font-weight:800; font-size:14px; line-height:1; display:none;
}
.ing-tile.active .ing-minus{display:block;}
.sold-out-tag{position:absolute; bottom:8px; right:8px; font-size:9px; letter-spacing:.05em; text-transform:uppercase; color:var(--semolina); font-weight:800;}
.modal-footer{padding:14px 16px; border-top:1px solid var(--line); display:flex; align-items:center; gap:12px;}

/* Tabs */
.tabs{display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap;}
.tab-btn{flex:1; min-width:100px; padding:10px; border-radius:10px; border:1px solid var(--line); background:var(--card); color:var(--cream-dim); font-weight:800; font-size:13px;}
.tab-btn.active{background:var(--tomato); color:#fff; border-color:transparent;}

/* Order cards */
.order-card{
  position:relative; background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:14px; margin-bottom:10px; overflow:hidden; touch-action:pan-y;
}
.order-card .row{display:flex; align-items:center; justify-content:space-between;}
.order-num{font-family:'Fraunces',serif; font-size:22px; font-weight:700; color:var(--semolina);}
.order-time{font-size:11px; color:var(--cream-dim);}
.order-meta{font-size:12px; color:var(--cream-dim); margin-top:4px;}
.order-price{font-size:12px; color:var(--cream-dim); margin-top:2px;}
.swipe-hint{font-size:11px; color:var(--cream-dim); margin-top:8px; display:flex; align-items:center; gap:4px;}
.order-detail{margin-top:10px; padding-top:10px; border-top:1px solid var(--line); font-size:13px; display:flex; flex-wrap:wrap; gap:6px;}
.zutat-chip{background:var(--crust); border:1px solid var(--line); border-radius:20px; padding:5px 10px; font-size:12px;}
.empty-state{color:var(--cream-dim); text-align:center; padding:40px 16px; font-size:14px;}

/* status badge */
.status-badge{font-size:10px; text-transform:uppercase; letter-spacing:.06em; font-weight:800; padding:4px 8px; border-radius:20px;}
.status-eingegangen{background:rgba(232,184,75,.18); color:var(--semolina);}
.status-uebergeben{background:rgba(92,138,155,.2); color:var(--slate);}
.status-ofen{background:rgba(225,81,43,.2); color:var(--tomato);}
.status-fertig{background:rgba(111,161,94,.22); color:var(--basil);}
.status-archiviert{background:rgba(201,191,174,.16); color:var(--cream-dim);}

/* ingredient / price management rows */
.ingredient-row{display:flex; align-items:center; justify-content:space-between; gap:10px; background:var(--card); border:1px solid var(--line); border-radius:12px; padding:12px 14px; margin-bottom:8px; flex-wrap:wrap;}
.ingredient-row .name{font-weight:700; flex:1; min-width:110px;}
.switch{width:46px; height:26px; border-radius:20px; background:#3a2c22; position:relative; border:none; flex-shrink:0;}
.switch.on{background:var(--basil);}
.switch .dot{position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; transition:left .15s ease;}
.switch.on .dot{left:23px;}
.price-field{display:flex; align-items:center; gap:6px;}
.price-field span{font-size:12px; color:var(--cream-dim);}
.price-input{
  width:76px; background:var(--crust); border:1px solid var(--line); color:var(--cream);
  border-radius:8px; padding:8px 10px; font-size:13px; text-align:right;
}
.price-input:focus{outline:2px solid var(--tomato); border-color:transparent;}
.save-price-btn{background:var(--basil); color:#12200e; border:none; border-radius:8px; padding:8px 10px; font-weight:800; font-size:12px;}

/* Display screen */
.display-grid{display:grid; grid-template-columns:1fr; gap:16px;}
@media(min-width:640px){ .display-grid{grid-template-columns:1fr 1fr;} }
.display-col{background:var(--card); border-radius:16px; padding:16px; border:1px solid var(--line);}
.display-col h2{font-family:'Fraunces',serif; font-size:18px; margin:0 0 12px;}
.ticket{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:'Fraunces',serif; font-size:26px; font-weight:700;
  background:var(--crust); border:2px dashed var(--line); border-radius:10px;
  padding:10px 16px; margin:0 8px 8px 0; color:var(--semolina);
}
.ticket.ready{color:var(--basil); border-color:var(--basil);}
.toast{
  position:fixed; left:16px; right:16px; bottom:16px; max-width:688px; margin:0 auto;
  background:var(--basil-dark); color:#fff;
  padding:12px 16px; border-radius:12px; font-weight:700; font-size:13px; text-align:center; z-index:30;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.toast.error{background:var(--tomato-dark);}

/* Archive */
.archive-item{background:var(--card); border:1px solid var(--line); border-radius:12px; padding:12px 14px; margin-bottom:8px;}
.archive-item .row{display:flex; justify-content:space-between; align-items:center;}
