/*!
 * product-landing.css
 * Stili riutilizzabili per le descrizioni prodotto in stile "landing page"
 * usate su schede prodotto che adottano il template product-v2.tpl.
 *
 * Tutte le regole sono scopate dentro .pl-landing per evitare conflitti
 * con il resto del template e con altre descrizioni prodotto.
 *
 * Uso (dentro la descrizione del prodotto):
 *   <div class="pl-landing">
 *     <section class="pl-section pl-intro">...</section>
 *     <section class="pl-section pl-gray"><div class="pl-container">...</div></section>
 *     ...
 *   </div>
 */

/* Reset locale */
.pl-landing,
.pl-landing * { box-sizing: border-box; }
.pl-landing { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; line-height: 1.65; color: #2c2c2c; background: #fff; }
.pl-landing img { max-width: 100%; height: auto; display: block; }
.pl-landing h2, .pl-landing h3, .pl-landing p, .pl-landing ul, .pl-landing li { margin: 0; padding: 0; }
.pl-landing ul { list-style: none; }

/* Layout */
.pl-landing .pl-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.pl-landing .pl-section { padding: 40px 0; }
.pl-landing .pl-gray { background: #f9f9f9; }
.pl-landing .pl-white { background: #fff; }

/* Tipografia */
.pl-landing h2 { font-size: 2em; font-weight: 700; margin-bottom: 20px; color: #2c2c2c; line-height: 1.3; }
.pl-landing h3 { font-size: 1.4em; font-weight: 600; margin-bottom: 12px; color: #2c2c2c; }
.pl-landing p { font-size: 1.1em; margin-bottom: 15px; color: #444; line-height: 1.7; }
.pl-landing strong { font-weight: 600; color: #2c2c2c; }
.pl-landing .pl-lead { font-size: 1.2em; color: #666; font-weight: 300; line-height: 1.6; }
.pl-landing .pl-subtitle { font-size: 1.1em; color: #666; margin-bottom: 30px; }

/* Intro hero (immagine + contenuto) */
.pl-landing .pl-intro { padding: 40px 20px; }
.pl-landing .pl-intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; max-width: 1200px; margin: 0 auto; }
.pl-landing .pl-intro-image { width: 100%; border-radius: 12px; box-shadow: 0 8px 25px rgba(0,0,0,.1); }
.pl-landing .pl-intro-content .pl-lead { margin-bottom: 20px; }

/* Prezzi */
.pl-landing .pl-price-block { margin: 20px 0; }
.pl-landing .pl-price-old { font-size: 1.2em; color: #666; text-decoration: line-through; margin-bottom: 5px; }
.pl-landing .pl-price { display: block; font-size: 2.8em; font-weight: 700; color: #d32f2f; margin: 10px 0; line-height: 1; }
.pl-landing .pl-price-big { display: block; font-size: 3.2em; font-weight: 700; color: #d32f2f; margin: 10px 0; line-height: 1; }
.pl-landing .pl-gift { font-size: 1.1em; color: #890606; font-weight: 600; margin: 15px 0 20px; }

/* CTA in alto verso le opzioni del prodotto */
.pl-landing .pl-cta-up { display: inline-block; background: linear-gradient(135deg, #d32f2f 0%, #b71c1c 100%); color: #fff; padding: 14px 32px; font-size: 1.05em; font-weight: 600; text-decoration: none; border-radius: 50px; margin-top: 15px; box-shadow: 0 4px 20px rgba(211,47,47,.3); transition: transform .2s ease, box-shadow .2s ease; }
.pl-landing .pl-cta-up:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(211,47,47,.45); color: #fff; text-decoration: none; }

/* Banner full-width (es. Scalapay) */
.pl-landing .pl-banner-full { margin: 40px 0; }
.pl-landing .pl-banner-full img { width: 100%; }
.pl-landing .pl-scalapay-intro { max-width: 100%; margin: 20px 0 0; }

/* Selettore colori */
.pl-landing .pl-colors { text-align: center; }
.pl-landing .pl-color-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; margin-top: 30px; }
.pl-landing .pl-color-card { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 15px rgba(0,0,0,.08); transition: transform .3s ease, box-shadow .3s ease; }
.pl-landing .pl-color-card:hover { transform: translateY(-10px); box-shadow: 0 8px 30px rgba(0,0,0,.15); }
.pl-landing .pl-color-card img { width: 100%; }
.pl-landing .pl-color-name { padding: 20px; font-size: 1.3em; font-weight: 600; text-align: center; color: #2c2c2c; }

/* Blocchi di contenuto editoriale */
.pl-landing .pl-content { max-width: 900px; margin: 0 auto; }
.pl-landing .pl-content h2 { border-left: 5px solid #d32f2f; padding-left: 20px; }
.pl-landing .pl-content ul { margin: 20px 0; }
.pl-landing .pl-content ul li { padding-left: 35px; margin-bottom: 12px; position: relative; font-size: 1.1em; line-height: 1.7; }
.pl-landing .pl-content ul li:before { content: "\2713"; position: absolute; left: 0; top: 0; color: #4caf50; font-weight: bold; font-size: 1.4em; line-height: 1; }
.pl-landing .pl-image { width: 100%; border-radius: 12px; margin: 30px 0; box-shadow: 0 8px 25px rgba(0,0,0,.1); }

/* Griglia features con icone */
.pl-landing .pl-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 30px; margin: 30px 0; padding: 40px 25px; background: #f5f5f0; border-radius: 12px; }
.pl-landing .pl-feature { text-align: center; }
.pl-landing .pl-feature img { width: 70px; height: 70px; margin: 0 auto 15px; object-fit: contain; }
.pl-landing .pl-feature h3 { font-size: 1.2em; margin-bottom: 8px; }
.pl-landing .pl-feature p { font-size: 1em; color: #666; margin: 0; }

/* Banner regalo / promo evidenziato (es. cuscinone Puffy) */
.pl-landing .pl-banner-gift { background: #fff; border: 3px solid #890606; border-radius: 16px; overflow: hidden; margin: 40px 0; box-shadow: 0 8px 30px rgba(0,0,0,.08); }
.pl-landing .pl-banner-gift-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; }
.pl-landing .pl-banner-gift-img { width: 100%; height: 100%; object-fit: cover; }
.pl-landing .pl-banner-gift-text { padding: 40px; }
.pl-landing .pl-banner-gift-text h2 { font-size: 2em; margin-bottom: 15px; border: none; padding: 0; }
.pl-landing .pl-banner-gift-value { display: block; font-size: 1.2em; font-weight: 700; color: #890606; margin-bottom: 20px; }
.pl-landing .pl-banner-gift-text p { font-size: 1.1em; line-height: 1.7; color: #444; margin-bottom: 15px; }
.pl-landing .pl-specs { background: #f9f9f9; padding: 15px; border-radius: 8px; margin-top: 20px; border-left: 4px solid #890606; }
.pl-landing .pl-specs p { margin: 0; font-size: .95em; }

/* Scheda tecnica */
.pl-landing .pl-tech-wrap { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
.pl-landing .pl-tech { border: 3px solid #4caf50; border-radius: 16px; padding: 40px 30px; background: #fff; }
.pl-landing .pl-tech h2 { text-align: center; border: none; padding: 0; margin-bottom: 30px; }
.pl-landing .pl-tech-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; }
.pl-landing .pl-tech-item { background: #f5f5f5; padding: 25px; border-radius: 8px; }
.pl-landing .pl-tech-item h3 { color: #890606; margin-bottom: 12px; font-size: 1.2em; }
.pl-landing .pl-tech-item p { color: #2c2c2c; line-height: 1.7; font-size: 1em; }

/* Riepilogo finale */
.pl-landing .pl-final { text-align: center; padding: 50px 20px; background: linear-gradient(135deg, #f5f5f0 0%, #fff 100%); }
.pl-landing .pl-final h2 { font-size: 2.3em; margin-bottom: 15px; border: none; padding: 0; }
.pl-landing .pl-final-gift { font-size: 1.15em; color: #890606; font-weight: 600; margin-bottom: 20px; }
.pl-landing .pl-final-details { font-size: 1.1em; color: #444; line-height: 1.7; max-width: 800px; margin: 0 auto 10px; }

/* Centratura helper */
.pl-landing .pl-text-center { text-align: center; }
.pl-landing .pl-no-border { border: none; padding: 0; }

/* Responsive */
@media (max-width: 768px) {
    .pl-landing h2 { font-size: 1.6em; }
    .pl-landing .pl-section { padding: 30px 0; }
    .pl-landing .pl-intro { padding: 30px 15px; }
    .pl-landing .pl-intro-grid { grid-template-columns: 1fr; gap: 25px; }
    .pl-landing .pl-intro-content { text-align: center; }
    .pl-landing .pl-color-grid { grid-template-columns: repeat(2, 1fr); gap: 15px; }
    .pl-landing .pl-features { grid-template-columns: repeat(2, 1fr); gap: 20px; padding: 30px 15px; }
    .pl-landing .pl-feature img { width: 60px; height: 60px; }
    .pl-landing .pl-banner-gift-grid { grid-template-columns: 1fr; }
    .pl-landing .pl-banner-gift-text { padding: 25px 20px; }
    .pl-landing .pl-banner-gift-text h2 { font-size: 1.7em; }
    .pl-landing .pl-tech { padding: 30px 20px; }
    .pl-landing .pl-tech-grid { grid-template-columns: 1fr; gap: 20px; }
    .pl-landing .pl-final h2 { font-size: 1.9em; }
    .pl-landing .pl-final .pl-price-big { font-size: 2.5em; }
}
