/* Brand Book Ollyburger — token (v1, Sprint 0). Fonte: BRANDBOOK_OLLYBURGER_v1.md */
:root{
  --olly-orange:#DD6900; --olly-orange-dark:#B95700; --olly-orange-tint:#FBE9D6;
  --olly-mustard:#C8961F; --olly-red:#F45353; --olly-red-dark:#D83A3A;
  --olly-sand:#E9D7CB; --olly-border:#D8C2B2; --olly-ink:#303030; --olly-grey:#6B6B6B;
  --olly-white:#FFFFFF;
  --font-display:"Associate Sans","Roboto",sans-serif; /* fallback Roboto: licenza Associate Sans da verificare */
  --font-ui:"Roboto",sans-serif;
}

*{box-sizing:border-box;}
body{
  margin:0; font-family:var(--font-ui); color:var(--olly-ink);
  background:var(--olly-sand);
  -webkit-font-smoothing:antialiased;
}
.olly-header{
  display:flex; align-items:center; gap:14px;
  background:var(--olly-white); border-bottom:1px solid var(--olly-border);
  padding:12px 24px;
}
.olly-header img{height:44px; width:auto;}
.olly-header .env-badge{
  margin-left:auto; font-size:12px; font-weight:600; letter-spacing:.5px;
  color:var(--olly-grey); border:1px solid var(--olly-border); border-radius:999px;
  padding:3px 10px; text-transform:uppercase;
}
h1,h2,.display{font-family:var(--font-display); color:var(--olly-ink);}
.olly-main{max-width:880px; margin:32px auto; padding:0 24px;}
.olly-card{
  background:var(--olly-white); border:1px solid var(--olly-border);
  border-radius:12px; padding:28px 32px;
}
.btn-primary{
  display:inline-block; background:var(--olly-orange); color:var(--olly-white);
  font-weight:700; text-decoration:none; border:none; border-radius:999px;
  padding:11px 22px; cursor:pointer; text-transform:uppercase; font-size:15px;
}
.btn-primary:hover{background:var(--olly-orange-dark);}
.muted{color:var(--olly-grey);}

form label{display:block; margin:14px 0 4px; font-size:14px; font-weight:600;}
form input{
  display:block; width:100%; margin-top:4px; padding:10px 12px;
  border:1px solid var(--olly-border); border-radius:8px; font-size:15px;
  font-family:var(--font-ui); background:#fff;
}
form .btn-primary{margin-top:20px; width:100%;}
.flash{padding:11px 16px; border-radius:8px; margin-bottom:18px; font-size:14px;}
.flash-error{background:#FDE0E0; color:var(--olly-red-dark); border:1px solid #f3b4b4;}
.flash-ok{background:var(--olly-orange-tint); color:var(--olly-orange-dark); border:1px solid #f1cda8;}

/* Catalogo */
.olly-main{max-width:1100px;}
.catalog-head h1{margin-bottom:4px;}
.catalog-filter{display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin:16px 0;}
.catalog-filter input[type=search]{flex:1; min-width:200px; padding:10px 12px; border:1px solid var(--olly-border); border-radius:8px; font-size:15px;}
.catalog-filter select{padding:10px 12px; border:1px solid var(--olly-border); border-radius:8px; font-size:15px; background:#fff;}
.catalog-filter .btn-primary{width:auto;}
.reset-link{color:var(--olly-grey); font-size:14px;}
.cat-title{font-family:var(--font-display); margin:26px 0 12px; border-bottom:2px solid var(--olly-border); padding-bottom:6px;}
.product-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:18px;}
.product-card{background:#fff; border:1px solid var(--olly-border); border-radius:12px; overflow:hidden; display:flex; flex-direction:column;}
.product-img{position:relative; aspect-ratio:4/3; background:var(--olly-sand);}
.product-img img{width:100%; height:100%; object-fit:cover; display:block;}
.img-badge{position:absolute; bottom:6px; left:6px; background:rgba(48,48,48,.72); color:#fff; font-size:11px; padding:2px 7px; border-radius:6px;}
.product-body{padding:12px 14px; display:flex; flex-direction:column; gap:4px;}
.product-name{font-weight:600; line-height:1.25;}
.product-sub{font-size:13px; color:var(--olly-mustard); font-weight:600;}
.product-meta{font-size:13px; color:var(--olly-grey);}
.product-price{margin-top:6px; font-size:19px; font-weight:700; color:var(--olly-orange);}
.product-price .unit{font-size:13px; font-weight:600; color:var(--olly-grey);}

/* Nav */
.olly-nav{display:flex; gap:18px; margin-left:24px; align-items:center;}
.olly-nav a{color:var(--olly-ink); text-decoration:none; font-weight:600; font-size:15px;}
.olly-nav a:hover{color:var(--olly-orange);}
.cart-badge{background:var(--olly-orange); color:#fff; border-radius:999px; padding:1px 8px; font-size:12px;}

/* Aggiungi nel catalogo */
.add-form{display:flex; gap:6px; margin-top:10px;}
.add-form input[type=number]{width:62px; padding:7px; border:1px solid var(--olly-border); border-radius:8px;}
.btn-add{background:var(--olly-orange); color:#fff; border:none; border-radius:8px; padding:7px 12px; font-weight:600; cursor:pointer;}
.btn-add:hover{background:var(--olly-orange-dark);}

/* Ordine / carrello */
.order-layout{display:grid; grid-template-columns:1fr 320px; gap:20px; align-items:start;}
@media(max-width:760px){.order-layout{grid-template-columns:1fr;}}
.cart-table{width:100%; border-collapse:collapse;}
.cart-table th,.cart-table td{text-align:left; padding:10px 8px; border-bottom:1px solid var(--olly-border); vertical-align:middle;}
.cart-table th{font-size:13px; color:var(--olly-grey); text-transform:uppercase;}
.qty-form{display:flex; gap:6px; align-items:center;}
.qty-form input[type=number]{width:64px; padding:6px; border:1px solid var(--olly-border); border-radius:8px;}
.btn-mini{background:#fff; border:1px solid var(--olly-border); border-radius:8px; padding:6px 12px; font-weight:600; cursor:pointer; color:var(--olly-ink); text-decoration:none; font-size:14px;}
.btn-mini:hover{border-color:var(--olly-orange); color:var(--olly-orange);}
.btn-remove{background:none; border:none; color:var(--olly-red-dark); cursor:pointer; font-size:16px;}
.small{font-size:12px;}
.note-form{margin-top:16px;}
.note-form textarea{width:100%; padding:10px; border:1px solid var(--olly-border); border-radius:8px; font-family:var(--font-ui); margin-top:6px;}
.totals-table{width:100%; border-collapse:collapse;}
.totals-table td{padding:7px 4px;}
.totals-table td:last-child{text-align:right; font-weight:600;}
.totals-table tr.discount td{color:var(--olly-orange-dark);}
.totals-table tr.grand td{border-top:2px solid var(--olly-border); font-size:18px; color:var(--olly-orange); padding-top:12px;}
.order-actions{margin-top:18px; display:flex; flex-direction:column; gap:10px;}
.btn-primary.disabled{background:var(--olly-border); cursor:not-allowed;}
