/* ═══════════════════════════════════════════
   BENESSERE NATURALE — Global Stylesheet
   ═══════════════════════════════════════════ */

/* ── HAMBURGER MENU ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;z-index:200}
.hamburger span{display:block;width:24px;height:2px;background:var(--deep-green);border-radius:2px;transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(30,58,47,.97);z-index:150;flex-direction:column;align-items:center;justify-content:flex-start;gap:0;overflow-y:auto;padding:70px 0 30px}
.mobile-nav.open{display:flex}
.mobile-nav a{color:#fff;font-size:16px;font-family:'Playfair Display',serif;font-weight:600;text-decoration:none;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1);width:80%;text-align:center;letter-spacing:.02em;flex-shrink:0}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav a:hover{color:var(--gold-light)}
.mobile-nav-close{position:fixed;top:20px;right:20px;background:none;border:none;color:#fff;font-size:26px;cursor:pointer;line-height:1;z-index:200}

/* ── MOBILE TABLE FIX ── */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px}
.table-wrap table{min-width:480px}
.table-scroll-hint{display:none;font-size:12px;color:var(--text-light);text-align:right;padding:4px 0 8px;font-style:italic}
:root {
  --cream: #FAF7F2;
  --warm-white: #FFFEF9;
  --deep-green: #1E3A2F;
  --mid-green: #2D5A3D;
  --sage: #7A9E7E;
  --sage-light: #C8DBC9;
  --gold: #C4922A;
  --gold-light: #F0D89A;
  --text-dark: #1A1A1A;
  --text-mid: #4A4A4A;
  --text-light: #7A7A7A;
  --border: #E8E0D0;
  --red: #C0392B;
  --red-light: #FDECEA;
  --blue-light: #EBF4FB;
  --blue: #2980B9;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--cream);color:var(--text-dark);font-family:'DM Sans',sans-serif;font-size:17px;line-height:1.75}
.progress-bar{position:fixed;top:0;left:0;height:3px;background:var(--gold);width:0%;z-index:9999;transition:width .1s}
.topbar{background:var(--deep-green);color:#fff;text-align:center;padding:10px 20px;font-size:13px;letter-spacing:.03em}
.topbar a{color:var(--gold-light);text-decoration:none;font-weight:600}
header{background:var(--warm-white);border-bottom:1px solid var(--border);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.logo{font-family:'Playfair Display',serif;font-size:22px;color:var(--deep-green);font-weight:700;text-decoration:none}
.logo span{color:var(--gold)}
nav{display:flex;gap:24px;flex-wrap:wrap}
nav a{text-decoration:none;color:var(--text-mid);font-size:13px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
nav a:hover{color:var(--deep-green)}
.article-wrap{max-width:780px;margin:0 auto;padding:0 20px 80px}
.breadcrumb{padding:18px 0 0;font-size:13px;color:var(--text-light)}
.breadcrumb a{color:var(--text-light);text-decoration:none}
.breadcrumb span{margin:0 6px}
.category-tag{display:inline-block;margin:18px 0 12px;background:var(--sage-light);color:var(--deep-green);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:2px}
h1{font-family:'Playfair Display',serif;font-size:clamp(26px,4.5vw,40px);line-height:1.18;color:var(--deep-green);margin-bottom:18px;font-weight:700}
h1 em{font-style:italic;color:var(--gold)}
.subtitle{font-family:'Lora',serif;font-size:18px;color:var(--text-mid);line-height:1.6;font-style:italic;margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--border)}
.meta{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.author-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--sage),var(--deep-green));display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Playfair Display',serif;font-size:18px;font-weight:700;flex-shrink:0}
.meta-name{font-size:14px;font-weight:500;color:var(--text-dark)}
.meta-date{font-size:13px;color:var(--text-light);margin-top:1px}
.partnership-note{font-size:13px;color:var(--text-light);font-style:italic;margin-bottom:28px;padding:10px 16px;background:var(--warm-white);border-left:3px solid var(--sage);border-radius:0 4px 4px 0}
.index-box{background:var(--warm-white);border:1px solid var(--border);border-radius:8px;padding:24px 28px;margin:32px 0}
.index-box h4{font-family:'Playfair Display',serif;font-size:15px;color:var(--deep-green);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.index-box ol{padding-left:20px}
.index-box ol li{font-size:15px;margin-bottom:7px}
.index-box ol li a{color:var(--mid-green);text-decoration:none;font-weight:500}
.index-box ol li a:hover{text-decoration:underline}
.hero-img{width:100%;aspect-ratio:16/7;border-radius:8px;margin-bottom:36px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
/* PLACEHOLDER — replace with <img> when photos ready */
.hero-placeholder{background:linear-gradient(135deg,#1E3A2F 0%,#2D5A3D 45%,#4A7C5B 75%,#7A9E7E 100%)}
.hero-img-text{text-align:center;color:#fff;z-index:1;padding:20px}
.hero-img-text .tag{font-size:11px;letter-spacing:.15em;text-transform:uppercase;opacity:.65;margin-bottom:10px}
.hero-img-text .title{font-family:'Playfair Display',serif;font-size:clamp(16px,3vw,24px);font-weight:600}
h2{font-family:'Playfair Display',serif;font-size:clamp(21px,3.5vw,29px);color:var(--deep-green);margin:50px 0 16px;font-weight:700;line-height:1.25;padding-top:6px;border-top:2px solid var(--sage-light)}
h2.no-border{border-top:none;margin-top:30px}
h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--deep-green);margin:28px 0 10px;font-weight:600}
.body-text p{font-family:'Lora',serif;font-size:17px;color:var(--text-dark);margin-bottom:22px;line-height:1.85}
.body-text p:first-child::first-letter{font-family:'Playfair Display',serif;font-size:60px;font-weight:700;line-height:.85;float:left;margin:6px 10px 0 0;color:var(--deep-green)}
.pull-quote{margin:36px 0;padding:28px 34px;background:var(--deep-green);color:#fff;border-radius:6px;position:relative}
.pull-quote::before{content:'"';font-family:'Playfair Display',serif;font-size:90px;color:var(--sage);position:absolute;top:-16px;left:20px;line-height:1;opacity:.5}
.pull-quote p{font-family:'Playfair Display',serif!important;font-size:19px!important;font-style:italic;line-height:1.55!important;margin:0!important;color:#fff!important;padding-top:22px}
.pull-quote .attribution{font-family:'DM Sans',sans-serif!important;font-size:13px!important;font-style:normal!important;color:var(--sage-light)!important;margin-top:10px!important;padding-top:0!important}
.info-box{background:var(--blue-light);border:1px solid rgba(41,128,185,.2);border-left:4px solid var(--blue);border-radius:0 8px 8px 0;padding:18px 22px;margin:26px 0}
.info-box h4{font-family:'Playfair Display',serif;font-size:15px;color:#154360;margin-bottom:8px}
.info-box p{font-size:15px;color:#1A5276;margin:0;line-height:1.65}
.warning-box{background:#FFF8E7;border:1px solid var(--gold-light);border-left:4px solid var(--gold);border-radius:0 8px 8px 0;padding:16px 20px;margin:26px 0;font-size:15px;color:#6B4C0A;line-height:1.65}
.green-box{background:#EDF6EE;border:1px solid rgba(45,90,61,.2);border-left:4px solid var(--mid-green);border-radius:0 8px 8px 0;padding:18px 22px;margin:26px 0}
.green-box h4{font-family:'Playfair Display',serif;font-size:15px;color:var(--deep-green);margin-bottom:8px}
.green-box p{font-size:15px;color:var(--mid-green);margin:0;line-height:1.65}
.green-box ul{margin-top:8px;padding-left:18px}
.green-box ul li{font-size:15px;color:var(--mid-green);margin-bottom:5px;line-height:1.55}
.criteria-winner{display:inline-block;background:#EDF6EE;color:var(--deep-green);font-size:13px;font-weight:600;padding:7px 16px;border-radius:3px;margin:6px 0 28px;border-left:3px solid var(--mid-green)}
.criteria-winner::before{content:'🏆 Vincitore: '}
table{width:100%;border-collapse:collapse}
thead{background:var(--deep-green);color:#fff}
thead th{padding:13px 14px;font-size:13px;font-weight:500;letter-spacing:.04em;text-align:left}
thead th:first-child{padding-left:22px;width:32%}
thead th.winner-th{background:var(--gold);color:var(--deep-green);font-weight:700}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:#F5F1E8}
td{padding:12px 14px;font-size:14px;vertical-align:middle;line-height:1.5}
td:first-child{padding-left:22px;font-size:13px;font-weight:600;color:var(--text-mid);text-transform:uppercase;letter-spacing:.04em}
td.winner-td{background:rgba(196,146,42,.07);font-weight:600;color:var(--deep-green)}
.check{color:#2D7A3D;font-size:15px}.cross{color:var(--red);font-size:15px}.half{color:var(--gold);font-size:15px}
.score-section{margin:40px 0;background:var(--warm-white);border-radius:10px;overflow:hidden;border:1px solid var(--border);box-shadow:0 4px 20px rgba(0,0,0,.07)}
.score-section-header{padding:22px 28px 18px;border-bottom:1px solid var(--border)}
.score-section-header h2{margin:0;padding:0;border:none;font-size:20px}
.score-section-header p{font-size:14px;color:var(--text-light);margin-top:4px}
.score-bar-section{padding:28px;border-top:1px solid var(--border)}
.score-bar-section h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-light);margin-bottom:18px}
.score-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.score-label{font-size:13px;font-weight:500;color:var(--text-dark);width:170px;flex-shrink:0}
.score-track{flex:1;height:8px;background:#EDE8DF;border-radius:4px;overflow:hidden}
.score-fill{height:100%;border-radius:4px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.score-fill.green{background:var(--mid-green)}.score-fill.gold{background:var(--gold)}.score-fill.gray{background:#B0A898}.score-fill.red{background:var(--red)}
.score-num{font-size:15px;font-weight:700;color:var(--text-dark);width:40px;text-align:right;flex-shrink:0}
.product-card{margin:36px 0;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--warm-white);box-shadow:0 4px 20px rgba(0,0,0,.07)}
.product-card.winner{border-color:var(--gold);box-shadow:0 6px 28px rgba(196,146,42,.2)}
.product-card-header{padding:20px 24px;display:flex;align-items:center;gap:18px;border-bottom:1px solid var(--border)}
.product-card.winner .product-card-header{background:linear-gradient(135deg,rgba(196,146,42,.06),rgba(45,90,61,.04))}
.product-img{width:84px;height:84px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;text-align:center;letter-spacing:.04em;font-weight:500;flex-shrink:0;line-height:1.4;overflow:hidden}
.product-img img{width:100%;height:100%;object-fit:cover}
.img-green{background:linear-gradient(135deg,var(--mid-green),#7A9E7E)}.img-blue{background:linear-gradient(135deg,#2471A3,#5DADE2)}.img-red{background:linear-gradient(135deg,#922B21,#E74C3C)}.img-gray{background:linear-gradient(135deg,#7F8C8D,#BDC3C7)}.img-amber{background:linear-gradient(135deg,#9A6B1A,#C4922A)}
.winner-badge{display:inline-flex;align-items:center;gap:5px;background:var(--gold);color:var(--deep-green);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:2px;margin-bottom:8px}
.product-card-title{font-family:'Playfair Display',serif;font-size:19px;color:var(--deep-green);font-weight:700;margin-bottom:3px}
.product-card-sub{font-size:13px;color:var(--text-light)}
.product-score-badge{margin-left:auto;flex-shrink:0;width:56px;height:56px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;border:2px solid}
.product-score-badge.s-gold{border-color:var(--gold);color:var(--gold)}.product-score-badge.s-gray{border-color:#9E9E9E;color:#9E9E9E}
.product-score-badge .score-big{font-size:20px;line-height:1}.product-score-badge .score-max{font-size:11px;color:var(--text-light)}
.product-card-body{padding:22px 24px}
.product-card-body p{font-family:'Lora',serif;font-size:16px;color:var(--text-dark);line-height:1.8;margin-bottom:16px}
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.pros h4,.cons h4{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.pros h4{color:#2D7A3D}.cons h4{color:var(--red)}
.pros ul,.cons ul{list-style:none}
.pros ul li,.cons ul li{font-size:14px;line-height:1.55;margin-bottom:7px;padding-left:20px;position:relative;color:var(--text-mid)}
.pros ul li::before{content:'✓';position:absolute;left:0;color:#2D7A3D;font-weight:700}
.cons ul li::before{content:'✗';position:absolute;left:0;color:var(--red);font-weight:700}
.myth-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:28px 0}
.myth-card{padding:20px;border-radius:8px;border:1px solid}
.myth-card.myth{background:var(--red-light);border-color:rgba(192,57,43,.2)}
.myth-card.fact{background:#EDF6EE;border-color:rgba(45,90,61,.2)}
.myth-card .card-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.myth-card.myth .card-label{color:var(--red)}.myth-card.fact .card-label{color:var(--mid-green)}
.myth-card p{font-size:14px!important;line-height:1.6!important;margin:0!important;font-family:'DM Sans',sans-serif!important;color:var(--text-dark)!important}
.testimonial-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:20px 0}
.testimonial-card{background:var(--warm-white);border:1px solid var(--border);border-radius:8px;padding:18px 20px}
.stars{color:var(--gold);font-size:14px;margin-bottom:8px}
.testimonial-card p{font-family:'Lora',serif;font-style:italic;font-size:14px!important;color:var(--text-dark)!important;line-height:1.65!important;margin-bottom:12px!important}
.testimonial-name{font-size:13px;font-weight:600;color:var(--text-mid)}
.verified{font-size:11px;color:var(--mid-green);margin-left:6px}
.mid-cta{background:var(--warm-white);border:1px solid var(--gold);border-radius:8px;padding:22px 26px;display:flex;align-items:center;gap:20px;margin:36px 0}
.mid-cta .cta-icon{font-size:36px;flex-shrink:0}
.mid-cta h4{font-family:'Playfair Display',serif;font-size:17px;color:var(--deep-green);margin-bottom:4px}
.mid-cta p{font-size:14px;color:var(--text-mid);margin:0;line-height:1.5}
.mid-cta .btn-sm{display:inline-block;background:var(--gold);color:var(--deep-green);font-weight:700;font-size:13px;padding:10px 22px;border-radius:3px;text-decoration:none;white-space:nowrap;flex-shrink:0}
.final-cta{margin:52px 0;background:var(--deep-green);border-radius:12px;padding:44px 38px;text-align:center;color:#fff}
.final-cta-tag{display:inline-block;background:var(--gold);color:var(--deep-green);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:2px;margin-bottom:16px}
.final-cta h2{font-family:'Playfair Display',serif;font-size:25px;color:#fff;margin:0 0 14px;border:none;padding:0}
.final-cta p{font-size:16px;color:rgba(255,255,255,.78);margin-bottom:24px;line-height:1.65}
.cta-checklist{list-style:none;text-align:left;display:inline-block;margin-bottom:32px}
.cta-checklist li{font-size:15px;color:rgba(255,255,255,.9);padding:5px 0 5px 28px;position:relative}
.cta-checklist li::before{content:'✅';position:absolute;left:0}
.btn-primary{display:inline-block;background:var(--gold);color:var(--deep-green);font-weight:700;font-size:16px;letter-spacing:.02em;padding:16px 44px;border-radius:4px;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(196,146,42,.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 26px rgba(196,146,42,.55)}
.discount-note{margin-top:14px;font-size:14px;color:var(--sage-light)}
.author-box{margin:48px 0;padding:28px;background:var(--warm-white);border:1px solid var(--border);border-radius:10px;display:flex;gap:22px;align-items:flex-start}
.author-box-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--sage),var(--mid-green));display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Playfair Display',serif;font-size:28px;font-weight:700;flex-shrink:0}
.author-box-text h4{font-family:'Playfair Display',serif;font-size:18px;color:var(--deep-green);margin-bottom:3px}
.author-role{font-size:13px;color:var(--text-light);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}
.author-box-text p{font-size:14px;color:var(--text-mid);line-height:1.65;margin:0}
.related{margin:48px 0 0;padding-top:36px;border-top:1px solid var(--border)}
.related h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--deep-green);margin-bottom:20px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.related-card{text-decoration:none}
.related-card-img{aspect-ratio:4/3;border-radius:6px;margin-bottom:10px}
.rg1{background:linear-gradient(135deg,#2D5A3D,#7A9E7E)}.rg2{background:linear-gradient(135deg,#1A2E3D,#4A7A8A)}.rg3{background:linear-gradient(135deg,#3D2A1A,#8A6A4A)}.rg4{background:linear-gradient(135deg,#2A1A3D,#6A4A8A)}.rg5{background:linear-gradient(135deg,#3D3A1A,#8A854A)}
.related-card p{font-size:14px;color:var(--text-dark);font-weight:500;line-height:1.45}
footer{background:var(--deep-green);color:rgba(255,255,255,.65);padding:40px 20px 28px;text-align:center;font-size:13px;margin-top:60px}
footer .footer-logo{font-family:'Playfair Display',serif;font-size:20px;color:#fff;margin-bottom:12px}
footer nav{justify-content:center;margin-bottom:12px}
footer nav a{color:rgba(255,255,255,.55);text-decoration:none;margin:0 10px;font-size:13px;text-transform:none;letter-spacing:0}
footer .disclaimer{max-width:620px;margin:16px auto 0;font-size:12px;line-height:1.65;opacity:.5}
@media(max-width:768px){
  .hamburger{display:flex}
  nav{display:none}
  .table-scroll-hint{display:block}
}
@media(max-width:640px){
  /* global overflow fix */
  html,body{overflow-x:hidden;max-width:100%}
  *{max-width:100%;box-sizing:border-box}
  .article-wrap{padding:0 16px 60px}
  .myth-grid,.pros-cons,.testimonial-grid,.related-grid{grid-template-columns:1fr}
  .author-box{flex-direction:column}
  .final-cta{padding:24px 16px;margin-left:0;margin-right:0;border-radius:6px}
  .mid-cta{flex-direction:column;text-align:center}
  .score-label{width:100px;font-size:12px}
  .product-card-header{flex-wrap:wrap}
  .product-card{margin-left:0;margin-right:0}
  .score-section{margin-left:0;margin-right:0}
  .pull-quote{margin-left:0;margin-right:0;padding:22px 20px 22px 40px}
  .info-box,.warning-box,.green-box{margin-left:0;margin-right:0}
  h1{font-size:clamp(20px,6vw,30px)}
  h2{font-size:clamp(18px,5vw,24px)}
  .score-section-header h2{font-size:16px}
  .props-grid{grid-template-columns:1fr 1fr}
  .usage-grid{grid-template-columns:1fr 1fr}
  .when-row{grid-template-columns:1fr}
  .hero-img{height:200px}
  .topbar{font-size:12px;padding:8px 12px}
  header{padding:14px 16px}
}
