/* Tellan Shop — mockup e-commerce (palette + font del sito istituzionale) */
:root{
  --green:#25895F; --green-d:#1c6b4a; --green-l:#e8f1ec;
  --cream:#FBF7EC; --cream-2:#FFFCDE;
  --ink:#1d2a23; --muted:#5d6b63; --line:#e3e0d6;
  --blue:#3071FF; --gold:#c98a2b;
  --maxw:1240px; --radius:4px;
  --shadow:0 6px 24px rgba(28,60,42,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Manrope",system-ui,sans-serif;color:var(--ink);background:#fff;line-height:1.55;font-size:17px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{line-height:1.12;letter-spacing:-.02em;font-weight:800}
.section{padding:72px 0}
.eyebrow{color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:.14em;font-size:13px}
.sec-head{text-align:center;max-width:640px;margin:0 auto 44px}
.sec-head h2{font-size:40px;margin:10px 0 8px}
.sec-head p{color:var(--muted)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:15px;
  padding:14px 26px;border-radius:var(--radius);cursor:pointer;border:2px solid var(--green);transition:.18s}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-d);border-color:var(--green-d)}
.btn-ghost{background:transparent;color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}
.btn-light{background:#fff;color:var(--green);border-color:#fff}
.btn-block{width:100%;justify-content:center;padding:16px}

/* announcement */
.topbar{background:var(--green);color:#fff;font-size:13.5px;font-weight:600;text-align:center;padding:9px 16px;letter-spacing:.02em}

/* header */
header.site{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:28px;height:78px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;color:var(--green);letter-spacing:.02em}
.brand .dot{width:34px;height:34px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-size:18px}
.menu{display:flex;gap:22px;margin-left:18px;font-weight:700;font-size:15px}
.menu a{padding:6px 0;border-bottom:2px solid transparent}
.menu a:hover{color:var(--green);border-color:var(--green)}
.nav-icons{margin-left:auto;display:flex;align-items:center;gap:18px;font-weight:700}
.icon-btn{position:relative;font-size:20px;cursor:pointer;background:none;border:0;color:var(--ink)}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--green);color:#fff;font-size:11px;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 4px}

/* hero */
.hero{position:relative;min-height:560px;display:flex;align-items:center;color:#fff;
  background:linear-gradient(90deg,rgba(20,45,30,.78),rgba(20,45,30,.25)),
  url("img/hero-azienda.webp") center/cover}
.hero .wrap{max-width:var(--maxw)}
.hero-card{max-width:620px}
.hero h1{font-size:60px;margin:14px 0 16px}
.hero p{font-size:19px;opacity:.95;margin-bottom:28px;max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* usp strip */
.usp{background:var(--cream);border-bottom:1px solid var(--line)}
.usp .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:22px 24px}
.usp .item{display:flex;align-items:center;gap:12px;font-weight:700;font-size:14.5px}
.usp .ic{font-size:24px}

/* category grid */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cat{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow)}
.cat img{width:100%;height:100%;object-fit:cover;transition:.4s}
.cat:hover img{transform:scale(1.06)}
.cat .ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,45,30,.82),rgba(20,45,30,.05) 60%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:22px;color:#fff}
.cat .ov h3{font-size:23px}
.cat .ov span{font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-top:6px;opacity:.9}

/* products */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:.2s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.card .ph{position:relative;aspect-ratio:1/1;background:var(--cream)}
.card .ph img{width:100%;height:100%;object-fit:cover}
.tag{position:absolute;top:12px;left:12px;background:var(--green);color:#fff;font-size:11px;font-weight:800;
  padding:5px 10px;border-radius:3px;letter-spacing:.04em;text-transform:uppercase}
.tag.alt{background:var(--gold)}
.card .body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .cat-lbl{font-size:12px;color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.card h3{font-size:17.5px;font-weight:800}
.card .desc{font-size:13.5px;color:var(--muted);flex:1}
.price-row{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.price{font-size:21px;font-weight:800;color:var(--ink)}
.price small{font-size:12px;color:var(--muted);font-weight:600}
.add{border:2px solid var(--green);background:var(--green);color:#fff;font-weight:800;font-size:13px;
  padding:9px 14px;border-radius:var(--radius);cursor:pointer;transition:.18s;white-space:nowrap}
.add:hover{background:var(--green-d)}

/* gift banner */
.gift{background:var(--green);color:#fff}
.gift .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.gift h2{font-size:38px;margin-bottom:14px}
.gift p{opacity:.92;margin-bottom:22px;max-width:460px}
.gift .img{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;box-shadow:var(--shadow)}
.gift .img img{width:100%;height:100%;object-fit:cover}

/* story */
.story .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.story img{border-radius:var(--radius);aspect-ratio:5/4;object-fit:cover;box-shadow:var(--shadow)}
.story h2{font-size:36px;margin:10px 0 16px}
.story p{color:var(--muted);margin-bottom:16px}

/* newsletter */
.news{background:var(--cream-2)}
.news .wrap{text-align:center;max-width:620px}
.news h2{font-size:32px;margin-bottom:8px}
.news p{color:var(--muted);margin-bottom:22px}
.news form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.news input{padding:14px 18px;border:2px solid var(--line);border-radius:var(--radius);min-width:300px;font-size:15px;font-family:inherit}
.news input:focus{outline:none;border-color:var(--green)}

/* footer */
footer.site{background:#16271d;color:#cfe0d6;padding:56px 0 26px;font-size:14.5px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:36px}
footer .brand{color:#fff;margin-bottom:14px}
footer h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:18px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#8aa294;font-size:13px}

/* ===== PDP ===== */
.crumb{color:var(--muted);font-size:13.5px;padding:20px 0}
.crumb a:hover{color:var(--green)}
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-bottom:24px}
.gallery .main{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:var(--cream)}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.thumbs{display:flex;gap:12px;margin-top:12px}
.thumbs img{width:78px;height:78px;object-fit:cover;border:2px solid var(--line);border-radius:3px;cursor:pointer;background:var(--cream)}
.thumbs img.active{border-color:var(--green)}
.pdp-info .cat-lbl{color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:13px}
.pdp-info h1{font-size:36px;margin:8px 0 14px}
.pdp-price{font-size:32px;font-weight:800;margin-bottom:6px}
.pdp-info .lead{color:var(--muted);margin:14px 0 22px}
.variants{margin:20px 0}
.variants label{font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:10px}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{border:2px solid var(--line);border-radius:var(--radius);padding:10px 16px;font-weight:700;font-size:14px;cursor:pointer;background:#fff}
.chip.active{border-color:var(--green);background:var(--green-l);color:var(--green-d)}
.buy{display:flex;gap:12px;align-items:stretch;margin:22px 0}
.qty{display:flex;align-items:center;border:2px solid var(--line);border-radius:var(--radius)}
.qty button{width:44px;height:100%;border:0;background:#fff;font-size:20px;cursor:pointer;color:var(--green)}
.qty span{width:40px;text-align:center;font-weight:800}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0;padding:16px;background:var(--cream);border-radius:var(--radius)}
.badge{display:flex;align-items:center;gap:7px;font-weight:700;font-size:13px;color:var(--green-d)}
.pdp-sections{padding:20px 0 10px}
.acc{border-top:1px solid var(--line);padding:18px 0}
.acc h3{font-size:19px;margin-bottom:8px}
.acc p,.acc li{color:var(--muted)}
.acc ul{margin-left:18px}
table.nutri{width:100%;border-collapse:collapse;margin-top:6px;font-size:14.5px}
table.nutri td{border:1px solid var(--line);padding:9px 12px}
table.nutri tr td:first-child{font-weight:700;background:var(--cream)}

/* responsive */
@media(max-width:960px){
  .menu,.usp .wrap{display:none}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .cats{grid-template-columns:repeat(2,1fr)}
  .gift .wrap,.story .wrap,.pdp,.foot-grid{grid-template-columns:1fr}
  .hero h1{font-size:40px}.sec-head h2{font-size:30px}
}
@media(max-width:560px){.prod-grid,.cats{grid-template-columns:1fr}}

/* ===== page banner (inner pages) ===== */
.pbanner{background:var(--green-l);border-bottom:1px solid var(--line);padding:34px 0}
.pbanner h1{font-size:40px;color:var(--ink)}
.pbanner p{color:var(--muted);margin-top:6px}

/* ===== PLP filters ===== */
.plp-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:10px 0 22px;flex-wrap:wrap}
.plp-head h1{font-size:32px}
.plp-head #plp-count{color:var(--muted);font-weight:700;font-size:14px}
#filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.fchip{border:2px solid var(--line);background:#fff;border-radius:var(--radius);padding:9px 16px;font-weight:700;font-size:14px;cursor:pointer;transition:.15s}
.fchip:hover{border-color:var(--green);color:var(--green)}
.fchip.active{background:var(--green);border-color:var(--green);color:#fff}

/* ===== cart ===== */
.cart-grid{display:grid;grid-template-columns:1fr 340px;gap:36px;align-items:start;padding:30px 0 60px}
.cart-empty{grid-column:1/-1;text-align:center;padding:60px 0;display:flex;flex-direction:column;gap:18px;align-items:center}
.cart-empty p{color:var(--muted);font-size:18px}
.crow{display:grid;grid-template-columns:84px 1fr auto auto auto;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.crow img{width:84px;height:84px;object-fit:cover;border-radius:var(--radius);background:var(--cream)}
.cinfo{display:flex;flex-direction:column;gap:4px}
.cinfo span{color:var(--muted);font-size:13.5px}
.cline{font-weight:800;min-width:78px;text-align:right}
.crm{border:0;background:none;color:var(--muted);font-size:16px;cursor:pointer;padding:6px}
.crm:hover{color:#c62828}
.cart-sum{border:1px solid var(--line);border-radius:var(--radius);padding:24px;background:var(--cream);position:sticky;top:96px}
.cart-sum h3{font-size:20px;margin-bottom:16px}
.sl{display:flex;justify-content:space-between;padding:8px 0;font-size:15px}
.sl.tot{border-top:1px solid var(--line);margin-top:8px;padding-top:14px;font-size:20px;font-weight:800}
.ship-hint{font-size:13px;color:var(--green);background:#fff;border:1px dashed var(--green);padding:8px 10px;border-radius:var(--radius);margin:6px 0}
.cart-sum .btn{margin-top:14px}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:46px 0 70px}
.contact-info h3{font-size:20px;margin:18px 0 8px}
.contact-info p{color:var(--muted);margin-bottom:6px}
.cform{display:grid;gap:14px}
.cform input,.cform textarea{padding:13px 15px;border:2px solid var(--line);border-radius:var(--radius);font-family:inherit;font-size:15px}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--green)}
.cform textarea{min-height:130px;resize:vertical}
.info-list{list-style:none}
.info-list li{padding:14px 0;border-bottom:1px solid var(--line);display:flex;gap:12px}
.info-list .ic{font-size:22px}
.prose{max-width:760px;padding:30px 0 60px}
.prose h2{font-size:24px;margin:28px 0 10px}
.prose p,.prose li{color:var(--muted);margin-bottom:8px}
.prose ul{margin-left:20px}

/* ===== toast ===== */
#toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  padding:13px 22px;border-radius:6px;font-weight:700;font-size:15px;opacity:0;pointer-events:none;transition:.25s;z-index:200;box-shadow:var(--shadow)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:960px){
  .cart-grid,.contact-grid{grid-template-columns:1fr}
  .pbanner h1{font-size:30px}
}
