/* Parafarmacia San Martino — product.css (palette: plum + rosewood + gold) */
.product-hero{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;padding:48px 0}
.product-image{background:var(--plum-50);border-radius:var(--radius-xl);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--plum-100)}
.product-image img{width:100%;height:100%;object-fit:contain;padding:32px}
.product-info h1{font-family:'Cormorant',serif;font-size:2.6rem;color:var(--plum-900);margin-bottom:8px;font-weight:500}
.product-category-badge{display:inline-flex;align-items:center;gap:6px;background:var(--rose-50);color:var(--rose-700);padding:5px 14px;border-radius:20px;font-size:0.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:16px;border:1px solid var(--rose-100)}
.product-category-badge svg{width:14px;height:14px}
.product-rating{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:0.9rem;color:var(--stone-600)}
.product-rating .stars{color:var(--gold-500);font-size:1.1rem;letter-spacing:2px}
.product-price-block{background:var(--cream);border-radius:0;padding:22px 26px;margin-bottom:24px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-left:3px solid var(--rose-700)}
.product-price-old{font-size:1rem;color:var(--stone-400);text-decoration:line-through}
.product-price-new{font-family:'Cormorant',serif;font-style:italic;font-size:2.3rem;font-weight:600;color:var(--plum-900)}
.product-price-badge{display:inline-block;background:var(--rose-700);color:#fff;padding:4px 12px;font-size:0.72rem;font-weight:700;letter-spacing:0.08em}
.product-specs{margin:20px 0}
.product-specs table{width:100%;border-collapse:collapse}
.product-specs td{padding:12px 0;border-bottom:1px solid var(--stone-100);font-size:0.9rem}
.product-specs td:first-child{font-family:'Tenor Sans',serif;font-weight:400;color:var(--plum-900);width:40%;letter-spacing:0.04em}
.product-specs td:last-child{color:var(--stone-600)}
.product-specs .spec-icon{width:18px;height:18px;vertical-align:middle;margin-right:8px;color:var(--rose-700)}
.product-badges{display:flex;gap:12px;margin:20px 0;flex-wrap:wrap}
.product-badges .pbadge{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:0;background:#fff;border:1px solid var(--stone-100);font-size:0.78rem;font-weight:500;color:var(--stone-600)}
.product-badges .pbadge svg{width:16px;height:16px;color:var(--rose-700)}
.order-form{background:#fff;border:2px solid var(--plum-900);border-radius:0;padding:26px 32px}
.order-form-wide{grid-column:1/-1;scroll-margin-top:150px}
.order-form-wide form{display:flex;align-items:center;gap:12px}
.order-form-wide form input[type="text"],.order-form-wide form input[type="tel"]{flex:1;margin-bottom:0}
.order-form-wide form button{flex:1;min-width:220px}
.order-form-wide form input[type="hidden"]{display:none}
.order-form-wide .form-note{margin-top:10px}
@media(max-width:768px){.order-form-wide form{flex-direction:column}.order-form-wide form input[type="text"],.order-form-wide form input[type="tel"],.order-form-wide form button{width:100%}}
.order-form .order-form-title{font-family:'Cormorant',serif;font-style:italic;font-size:1.5rem;font-weight:500;color:var(--plum-900);margin-bottom:18px;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}
.order-form .order-form-title svg{width:20px;height:20px;color:var(--rose-700)}
.order-form input{width:100%;padding:13px 16px;border:1px solid var(--stone-100);border-radius:0;font-size:0.95rem;font-family:'Inter',sans-serif;margin-bottom:12px;transition:border .3s}
.order-form input:focus{outline:none;border-color:var(--rose-700)}
.order-form button{width:100%;padding:15px;background:var(--plum-900);color:var(--cream);border:none;border-radius:0;font-size:0.84rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;font-family:'Inter',sans-serif;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px}
.order-form button:hover{background:var(--rose-700);color:#fff}
.order-form button svg{width:18px;height:18px}
.order-form .form-note{font-size:0.78rem;color:var(--stone-400);text-align:center;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:4px}
.order-form .form-note svg{width:14px;height:14px;color:var(--rose-700);flex-shrink:0}
.content-section{padding:40px 0}
.content-section h2{font-family:'Cormorant',serif;font-style:italic;font-size:2rem;color:var(--plum-900);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--rose-300);display:flex;align-items:center;gap:10px;font-weight:500}
.content-section h2 svg{width:24px;height:24px;color:var(--rose-700);flex-shrink:0}
.content-section p,.content-section li{color:var(--stone-600);font-size:0.98rem;line-height:1.85;margin-bottom:14px}
.content-section ul{list-style:none;padding:0}
.content-section ul li{padding-left:28px;position:relative;margin-bottom:10px}
.content-section ul li svg{position:absolute;left:0;top:3px;width:18px;height:18px;color:var(--rose-700)}
.ingredients-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ingredient-card{background:var(--cream);border-radius:0;padding:24px;border:1px solid var(--stone-100);display:flex;gap:14px;align-items:flex-start;transition:all .3s;border-left:3px solid var(--rose-700)}
.ingredient-card:hover{background:#fff;box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.ingredient-card .ing-icon{width:42px;height:42px;min-width:42px;background:var(--plum-50);border-radius:50%;display:flex;align-items:center;justify-content:center}
.ingredient-card .ing-icon svg{width:20px;height:20px;color:var(--plum-900)}
.ingredient-card strong{font-family:'Cormorant',serif;font-style:italic;display:block;color:var(--plum-900);margin-bottom:6px;font-size:1.2rem;font-weight:600}
.ingredient-card p{font-size:0.88rem;margin:0}
.reviews-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.review-card{background:var(--cream);border-radius:0;padding:28px 24px;border:1px solid var(--stone-100);border-top:3px solid var(--rose-700);transition:all .3s}
.review-card:hover{background:#fff;box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.review-header{margin-bottom:14px}
.review-author{font-weight:600;color:var(--plum-900);font-size:0.9rem;display:flex;align-items:center;gap:10px;margin-bottom:4px}
.review-author .avatar{width:34px;height:34px;background:var(--plum-900);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant',serif;font-style:italic;font-size:0.9rem;font-weight:500;color:var(--cream);border:1px solid var(--gold-300)}
.review-stars{color:var(--gold-500);font-size:0.85rem;letter-spacing:1px}
.review-text{color:var(--plum-900);font-family:'Cormorant',serif;font-style:italic;font-size:1.02rem;font-weight:400;line-height:1.55}
.review-meta{font-size:0.72rem;color:var(--stone-400);margin-top:12px;display:flex;align-items:center;gap:4px;text-transform:uppercase;letter-spacing:0.1em}
.review-meta svg{width:12px;height:12px}
.faq-item{background:var(--cream);margin-bottom:14px;border:1px solid var(--stone-100);overflow:hidden;transition:all .3s}
.faq-item:hover{border-color:var(--rose-500);background:#fff}
.faq-q{padding:24px 30px;font-family:'Cormorant',serif;font-weight:600;color:var(--plum-900);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:1.2rem}
.faq-q::after{content:"›";font-family:'Cormorant',serif;font-size:1.8rem;color:var(--rose-700);transition:transform .3s;width:34px;height:34px;border-radius:50%;border:1px solid var(--rose-500);display:flex;align-items:center;justify-content:center;padding-bottom:4px;line-height:1}
.faq-q.active::after{transform:rotate(90deg);background:var(--rose-700);color:var(--cream);border-color:var(--rose-700)}
.faq-a{padding:0 30px 26px;color:var(--stone-600);font-size:0.98rem;line-height:1.8;display:none}
.faq-a.active{display:block}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.related-card{background:var(--cream);padding:24px;text-align:center;transition:all .3s;text-decoration:none;border:1px solid var(--stone-100)}
.related-card:hover{background:#fff;box-shadow:var(--shadow-sm);transform:translateY(-3px);border-color:var(--rose-500)}
.related-card .related-img{aspect-ratio:1;background:var(--plum-50);margin-bottom:14px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.related-card h3{font-family:'Cormorant',serif;font-style:italic;font-size:1.35rem;color:var(--plum-900);margin-bottom:6px;font-weight:600}
.related-card .related-price{font-size:0.9rem;color:var(--rose-700);font-weight:700;margin-bottom:12px;letter-spacing:0.04em}
.related-card .related-btn{display:inline-block;padding:10px 24px;background:var(--plum-900);color:var(--cream);font-size:0.72rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;transition:all .3s}
.related-card:hover .related-btn{background:var(--rose-700);color:#fff}
.cta-bottom{background:var(--plum-900);padding:56px 48px;text-align:center;color:var(--cream);margin:40px 0;position:relative;overflow:hidden}
.cta-bottom::before{content:"";position:absolute;top:-120px;right:-120px;width:380px;height:380px;background:radial-gradient(circle,rgba(201,161,91,.20),transparent 65%)}
.cta-bottom h2{font-family:'Cormorant',serif;font-style:italic;color:#fff;margin-bottom:12px;font-size:2.1rem;border:none;justify-content:center;font-weight:500}
.cta-bottom h2 svg{color:var(--gold-300);width:24px;height:24px}
.cta-bottom p{opacity:0.88;margin-bottom:24px;font-size:1rem}
.cta-bottom .form-note-outer{color:rgba(255,255,255,0.7);font-size:0.8rem;text-align:center;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:6px}
.breadcrumb{padding:24px 0;font-size:0.82rem;color:var(--stone-400);letter-spacing:0.04em}
.breadcrumb a{color:var(--plum-700);text-decoration:none}
.breadcrumb a:hover{color:var(--rose-700)}
.breadcrumb span{margin:0 8px;color:var(--stone-400)}
.breadcrumb strong{color:var(--plum-900);font-weight:700}
@media(max-width:992px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .product-hero{grid-template-columns:1fr;gap:24px}
  .ingredients-grid,.reviews-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
}
.input-error{border-color:#e53e3e !important;background:#fff5f5 !important}
.field-error{color:#e53e3e;font-size:0.78rem;margin-top:-8px;margin-bottom:10px;padding-left:4px}

/* Expert opinion card */
.expert-card{display:flex;gap:20px;align-items:flex-start;background:#fff;border:1px solid var(--plum-100);border-left:4px solid var(--plum-700);border-radius:var(--radius-xl);padding:24px 28px;box-shadow:var(--shadow-sm);margin-top:12px}
.expert-avatar{width:60px;height:60px;min-width:60px;background:linear-gradient(135deg,var(--plum-700),var(--plum-900));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:700;font-size:1.3rem;letter-spacing:-0.02em;box-shadow:0 4px 12px rgba(100,40,90,.25)}
.expert-body{flex:1}
.expert-name{font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:700;color:var(--plum-900);margin-bottom:2px}
.expert-title{font-size:0.85rem;color:var(--plum-900);font-weight:600;margin-bottom:14px;text-transform:uppercase;letter-spacing:0.02em}
.expert-quote{margin:0;padding:0;border:0;font-style:italic;color:var(--plum-700);font-size:0.95rem;line-height:1.7;position:relative;padding-left:18px;border-left:2px solid var(--plum-100)}
@media(max-width:600px){.expert-card{flex-direction:column;gap:14px;padding:20px 22px}.expert-avatar{width:52px;height:52px;min-width:52px;font-size:1.1rem}}
