/* ============================================
   PÉTALOS DE NONNI — styles.css
   ============================================ */

/* ===== RESET & VARIABLES ===== */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --gold:#B8860B;
  --gold-light:#D4A017;
  --purple:#534AB7;
  --purple-light:#7F77DD;
  --purple-pale:#EEEDFE;
  --plum:#3C3489;
  --cream:#FDFBF7;
  --white:#FFFFFF;
  --text-dark:#1A1830;
  --text-mid:#3C3A5A;
  --text-soft:#6B6889;
  --border:#E2DFF5;
  --silver:#8B8FA8;
}
body{
  font-family:Arial,sans-serif;
  background:var(--cream);
  color:var(--text-dark);
  overflow-x:hidden;
}

/* ===== NAV ===== */
nav{position:sticky;top:0;z-index:100;background:rgba(253,251,247,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:0 2rem;}
.nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:68px;}
.nav-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;}
.logo-img{height:48px;width:auto;object-fit:contain;}
.nav-links{display:flex;gap:1.5rem;list-style:none;}
.nav-links a{font-family:Arial,sans-serif;font-size:.78rem;color:var(--text-soft);letter-spacing:.07em;text-transform:uppercase;transition:color .2s;text-decoration:none;}
.nav-links a:hover{color:var(--purple);}
.nav-cta{font-family:Arial,sans-serif;font-size:.82rem;background:var(--purple);color:#fff;padding:.5rem 1.2rem;border-radius:24px;cursor:pointer;border:none;transition:background .2s;}
.nav-cta:hover{background:var(--plum);}

/* ===== HERO ===== */
.hero{
  min-height:92vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  padding:4rem 2rem;
  background:linear-gradient(160deg,#F7F5FF 0%,#FDFBF7 50%,#F5EED0 100%);
  position:relative;overflow:hidden;
}
.hero-flor{position:absolute;pointer-events:none;}
.hero-flor-left{width:420px;height:420px;top:-80px;left:-120px;animation:flotar 8s ease-in-out infinite;}
.hero-flor-right{width:500px;height:500px;bottom:-100px;right:-130px;animation:flotar 10s ease-in-out infinite reverse;}
.hero-flor-top{width:220px;height:220px;top:20px;right:12%;animation:flotar 6s ease-in-out infinite;}
@keyframes flotar{
  0%,100%{transform:translateY(0px) rotate(0deg);}
  50%{transform:translateY(-18px) rotate(8deg);}
}
.hero-content{position:relative;z-index:1;max-width:760px;}

.hero-logo{display:block;height:140px;width:auto;max-width:300px;object-fit:contain;margin:0 auto 1.4rem;}
.hero-tag{font-family:Arial,sans-serif;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:block;}
.hero-title{font-family:'Georgia',serif;font-size:3rem;line-height:1.12;color:var(--plum);margin-bottom:1.4rem;font-weight:bold;}
.hero-title em{font-style:italic;color:var(--purple);font-weight:normal;}
.hero-sub{font-family:Arial,sans-serif;font-size:1rem;line-height:1.75;color:var(--text-mid);max-width:580px;margin:0 auto 2.5rem;}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.btn-p{font-family:Arial,sans-serif;font-size:.88rem;background:var(--purple);color:#fff;padding:.82rem 2rem;border-radius:30px;border:none;cursor:pointer;transition:all .2s;}
.btn-p:hover{background:var(--plum);transform:translateY(-1px);}
.btn-s{font-family:Arial,sans-serif;font-size:.88rem;background:transparent;color:var(--purple);padding:.82rem 2rem;border-radius:30px;border:1.5px solid var(--purple);cursor:pointer;transition:all .2s;}
.btn-s:hover{background:var(--purple-pale);}

/* ===== SECCIONES GENERALES ===== */
section{padding:5rem 2rem;}
.wrap{max-width:1100px;margin:0 auto;}
.stag{font-family:Arial,sans-serif;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem;}
.stitle{font-family:'Georgia',serif;font-size:2rem;color:var(--plum);margin-bottom:.9rem;font-weight:normal;}
.ssub{font-family:Arial,sans-serif;font-size:.93rem;color:var(--text-soft);line-height:1.7;max-width:540px;margin-bottom:2.5rem;}

/* ===== FILTROS ===== */
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;}
.fb{font-family:Arial,sans-serif;font-size:.74rem;padding:.4rem 1rem;border-radius:20px;border:1.5px solid var(--border);background:var(--white);color:var(--text-soft);cursor:pointer;transition:all .2s;}
.fb.on,.fb:hover{background:var(--purple);color:#fff;border-color:var(--purple);}

/* ===== CATÁLOGO ===== */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;}
.card{background:var(--white);border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:all .22s;cursor:pointer;display:flex;flex-direction:column;}
.card:hover{box-shadow:0 10px 36px rgba(83,74,183,.13);transform:translateY(-4px);}
.card-img{height:210px;overflow:hidden;}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.card:hover .card-img img{transform:scale(1.06);}
.card-body{padding:1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.28rem;}
.c-name{font-family:'Georgia',serif;font-size:1rem;color:var(--plum);line-height:1.3;font-weight:normal;margin:0;}
.c-type{font-family:Arial,sans-serif;font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;font-weight:700;margin:0;}
.c-song{font-family:Arial,sans-serif;font-size:.7rem;color:var(--silver);margin:0;font-style:italic;}
.c-foot{display:flex;align-items:center;justify-content:space-between;margin-top:.55rem;}
.c-price{font-family:'Georgia',serif;font-size:1.1rem;color:var(--purple);font-weight:bold;}
.c-see{font-family:Arial,sans-serif;font-size:.73rem;color:var(--purple);border:1.5px solid var(--purple);border-radius:18px;padding:.36rem .88rem;background:transparent;cursor:pointer;transition:all .2s;}
.c-see:hover{background:var(--purple);color:#fff;}

/* Colores por categoría */
.cat-atados{color:#7B2D8B;}.cat-bases{color:#1565C0;}.cat-bolsa{color:#B8860B;}
.cat-cajas{color:#C62828;}.cat-canasta{color:#2E7D32;}.cat-corona{color:#AD1457;}
.cat-flores{color:#6A1B9A;}.cat-navidad{color:#1B5E20;}

/* ===== PAGINACIÓN ===== */
.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:2.5rem;flex-wrap:wrap;}
.pg-btn{font-family:Arial,sans-serif;font-size:.82rem;min-width:38px;height:38px;border-radius:20px;border:1.5px solid var(--border);background:var(--white);color:var(--text-soft);cursor:pointer;transition:all .2s;padding:0 .7rem;}
.pg-btn:hover{border-color:var(--purple);color:var(--purple);}
.pg-btn.active{background:var(--purple);color:#fff;border-color:var(--purple);}
.pg-btn:disabled{opacity:.35;cursor:default;pointer-events:none;}

/* ===== MODAL ===== */
.modal-bg{position:fixed;inset:0;background:rgba(20,16,50,.55);z-index:400;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .25s;}
.modal-bg.open{opacity:1;pointer-events:all;}
.modal{background:var(--white);border-radius:24px;width:100%;max-width:860px;max-height:90vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;position:relative;}
/* ===== Formulario de pedido ===== */
.fp-card{background:var(--white);border-radius:24px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;position:relative;padding:2rem 1.8rem;}
.fp-title{font-family:'Georgia',serif;font-size:1.5rem;color:var(--plum);font-weight:bold;margin:0 0 .25rem;}
.fp-sub{font-family:Arial,sans-serif;font-size:.88rem;color:var(--text-soft);margin:0 0 1.1rem;}
.fp-resumen{background:var(--cream);border:1px solid var(--border);border-radius:14px;padding:.8rem 1rem;margin-bottom:1.1rem;}
.fp-row{display:flex;justify-content:space-between;gap:1rem;font-family:Arial,sans-serif;font-size:.86rem;color:var(--text-mid);padding:.22rem 0;}
.fp-row.fp-tot{border-top:1px dashed var(--border);margin-top:.4rem;padding-top:.5rem;font-weight:bold;color:var(--plum);}
.fp-lab{display:block;font-family:Arial,sans-serif;font-size:.78rem;color:var(--text-soft);margin:.7rem 0 .25rem;font-weight:bold;}
.fp-in{width:100%;font-family:Arial,sans-serif;font-size:.92rem;color:var(--text-dark);border:1.5px solid var(--border);border-radius:10px;padding:.65rem .8rem;background:#fff;}
.fp-in:focus{outline:none;border-color:var(--purple);}
textarea.fp-in{resize:vertical;}
.fp-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;}
.fp-nota{font-family:Arial,sans-serif;font-size:.76rem;color:var(--gold);font-weight:bold;text-align:center;margin:1rem 0 .9rem;}
.fp-card .modal-close{position:absolute;top:1rem;right:1rem;}
.modal-left{padding:1.8rem;display:flex;flex-direction:column;gap:1rem;border-right:1px solid var(--border);}
.modal-main-img{width:100%;height:300px;object-fit:cover;border-radius:14px;border:1px solid var(--border);transition:opacity .2s;}
.modal-thumbs{display:flex;gap:.6rem;}
.thumb{width:76px;height:64px;object-fit:cover;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:all .2s;opacity:.75;}
.thumb.active,.thumb:hover{border-color:var(--purple);opacity:1;}
.thumb-vid{position:relative;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;}
.thumb-vid::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.35);border-radius:8px;}
.thumb-vid span{position:relative;z-index:1;color:#fff;font-size:1rem;text-shadow:0 1px 4px rgba(0,0,0,.6);}
.modal-ig{display:inline-flex;align-items:center;gap:5px;margin:.4rem 0 .2rem;color:var(--purple);font-weight:bold;text-decoration:none;font-size:.85rem;}
.modal-ig:hover{color:var(--plum);}
.modal-right{padding:1.8rem;display:flex;flex-direction:column;gap:.8rem;}
.modal-cat{font-family:Arial,sans-serif;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;}
.modal-song{font-family:Arial,sans-serif;font-size:.82rem;color:var(--silver);font-style:italic;}
.modal-name{font-family:'Georgia',serif;font-size:1.5rem;color:var(--plum);line-height:1.25;font-weight:normal;}
.modal-price{font-family:'Georgia',serif;font-size:1.5rem;color:var(--purple);font-weight:bold;}
.modal-desc{font-family:Arial,sans-serif;font-size:.86rem;color:var(--text-mid);line-height:1.68;}
.modal-mats-label{font-family:Arial,sans-serif;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft);font-weight:600;}
.modal-mats{list-style:none;padding:.8rem;background:var(--cream);border-radius:10px;display:flex;flex-direction:column;gap:.3rem;}
.modal-mats li{font-family:Arial,sans-serif;font-size:.82rem;color:var(--text-soft);display:flex;align-items:center;gap:.5rem;}
.modal-mats li::before{content:'✦';font-size:.55rem;color:var(--gold);flex-shrink:0;}
.modal-actions{display:flex;flex-direction:column;gap:.8rem;margin-top:auto;padding-top:.5rem;}
.modal-qty-wrap{display:flex;align-items:center;gap:.5rem;background:#F5F0FA;border-radius:24px;padding:.3rem .5rem;width:fit-content;}
.modal-qty-btn{background:var(--purple);color:#fff;border:none;border-radius:50%;width:30px;height:30px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.modal-qty-btn:hover{background:var(--plum);}
.modal-qty-input{width:48px;text-align:center;border:none;background:transparent;font-size:1rem;font-family:Arial,sans-serif;color:var(--plum);font-weight:bold;-moz-appearance:textfield;}
.modal-qty-input::-webkit-outer-spin-button,.modal-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;}
.modal-add{flex:1;background:var(--purple);color:#fff;border:none;border-radius:24px;padding:.82rem;font-family:Arial,sans-serif;font-size:.88rem;cursor:pointer;transition:background .2s;}
.modal-add:hover{background:var(--plum);}
.modal-wa{font-family:Arial,sans-serif;font-size:.82rem;background:transparent;color:var(--purple);border:1.5px solid var(--purple);border-radius:24px;padding:.82rem 1.2rem;cursor:pointer;transition:all .2s;}
.modal-wa:hover{background:var(--purple-pale);}
.modal-share{width:100%;margin-top:.7rem;background:var(--purple-pale);color:var(--purple);border:none;border-radius:24px;padding:.72rem;font-family:Arial,sans-serif;font-size:.85rem;font-weight:bold;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:background .2s;}
.modal-share:hover{background:var(--border);}
.app-toast{position:fixed;left:50%;bottom:32px;transform:translateX(-50%) translateY(20px);background:var(--plum);color:#fff;padding:.8rem 1.3rem;border-radius:24px;font-family:Arial,sans-serif;font-size:.86rem;box-shadow:0 8px 28px rgba(60,52,137,.4);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:99999;max-width:90vw;text-align:center;}
.app-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.modal-close{position:absolute;top:1rem;right:1.2rem;background:none;border:none;font-size:1.4rem;color:var(--text-soft);cursor:pointer;z-index:1;}

/* ===== PROPUESTA DE VALOR ===== */
.val-bg{background:linear-gradient(160deg,#EEEDFE 0%,#FDFBF7 60%);}
.val-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem;}
.val-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:1.5rem;transition:all .2s;}
.val-card:hover{box-shadow:0 8px 28px rgba(83,74,183,.1);transform:translateY(-3px);}
.val-icon{font-size:1.4rem;margin-bottom:.7rem;}
.val-card h3{font-family:'Georgia',serif;font-size:1rem;color:var(--plum);margin-bottom:.45rem;}
.val-card p{font-family:Arial,sans-serif;font-size:.84rem;color:var(--text-soft);line-height:1.62;}

/* ===== POR QUÉ ELEGIRNOS ===== */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem;}
.why-card{background:var(--white);border-radius:14px;padding:1.4rem;text-align:center;}
.why-card h4{font-family:'Georgia',serif;font-size:.92rem;color:var(--plum);margin-bottom:.35rem;}
.why-card p{font-family:Arial,sans-serif;font-size:.78rem;color:var(--text-soft);line-height:1.5;}

/* ===== CARRITO FLOTANTE ===== */
.cart-bar{position:fixed;bottom:2rem;right:2rem;z-index:300;}
.cart-float{background:var(--purple);color:#fff;border:none;border-radius:50px;padding:.88rem 1.4rem;font-family:Arial,sans-serif;font-size:.88rem;cursor:pointer;display:flex;align-items:center;gap:.6rem;box-shadow:0 4px 20px rgba(83,74,183,.35);transition:all .2s;}
.cart-float:hover{background:var(--plum);transform:scale(1.04);}
.c-cnt{background:var(--gold);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.74rem;font-weight:bold;}

/* ===== PANEL CARRITO ===== */
.cart-panel{position:fixed;right:0;top:0;height:100vh;width:380px;background:var(--white);border-left:1px solid var(--border);z-index:350;transform:translateX(100%);transition:transform .3s;display:flex;flex-direction:column;}
.cart-panel.open{transform:translateX(0);}
.cart-hdr{padding:1.4rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.cart-hdr h3{font-family:'Georgia',serif;font-size:1.05rem;color:var(--plum);}
.cart-x{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-soft);}
.cart-items{flex:1;overflow-y:auto;padding:1rem;}
.ci{display:flex;align-items:center;gap:.9rem;padding:.75rem 0;border-bottom:1px solid var(--border);}
.ci-img{width:44px;height:44px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.ci-info{flex:1;}
.ci-name{font-size:.86rem;color:var(--text-dark);margin-bottom:.12rem;}
.ci-price{font-family:Arial,sans-serif;font-size:.78rem;color:var(--purple);}
.ci-rm{background:none;border:none;color:var(--silver);font-size:1.1rem;cursor:pointer;}
.cart-foot{padding:1.4rem;border-top:1px solid var(--border);}
.cart-tot{display:flex;justify-content:space-between;margin-bottom:.9rem;}
.cart-tot span{font-family:Arial,sans-serif;font-size:.88rem;color:var(--text-soft);}
.cart-tot strong{font-family:'Georgia',serif;font-size:1.18rem;color:var(--plum);}
.cart-co{width:100%;background:var(--purple);color:#fff;border:none;border-radius:30px;padding:.88rem;font-family:Arial,sans-serif;font-size:.88rem;cursor:pointer;transition:background .2s;}
.cart-co:hover{background:var(--plum);}
.cart-co.alt{background:#fff;color:var(--purple);border:1.5px solid var(--purple);margin-top:10px;}
.cart-co.alt:hover{background:#FDFBF7;color:var(--plum);border-color:var(--plum);}
.cart-empty{text-align:center;padding:3rem 1rem;color:var(--text-soft);font-family:Arial,sans-serif;font-size:.88rem;}

/* ===== CONTACTO ===== */
.ctc-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.canales{display:flex;flex-direction:column;gap:.9rem;margin-top:1.8rem;}
.canal{display:flex;align-items:center;gap:1rem;padding:.95rem 1.1rem;background:var(--white);border:1px solid var(--border);border-radius:14px;transition:all .2s;cursor:pointer;}
.canal:hover{border-color:var(--purple-light);transform:translateX(4px);}
.canal-logo{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ci-lbl h4{font-family:'Georgia',serif;font-size:.92rem;color:var(--text-dark);margin-bottom:.08rem;}
.ci-lbl p{font-family:Arial,sans-serif;font-size:.76rem;color:var(--text-soft);}
.cf{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:1.8rem;}
.cf h3{font-family:'Georgia',serif;font-size:1.2rem;color:var(--plum);margin-bottom:.28rem;}
.cf p{font-family:Arial,sans-serif;font-size:.83rem;color:var(--text-soft);margin-bottom:1.4rem;}
.fg{margin-bottom:.9rem;}
.fg label{font-family:Arial,sans-serif;font-size:.76rem;color:var(--text-soft);display:block;margin-bottom:.35rem;}
.fg input,.fg textarea,.fg select{width:100%;padding:.67rem .88rem;border:1px solid var(--border);border-radius:10px;font-family:Arial,sans-serif;font-size:.86rem;color:var(--text-dark);background:var(--cream);outline:none;transition:border .2s;}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--purple-light);}
.fg textarea{height:86px;resize:none;}
.cf-btn{width:100%;background:var(--purple);color:#fff;border:none;border-radius:24px;padding:.83rem;font-family:Arial,sans-serif;font-size:.88rem;cursor:pointer;margin-top:.4rem;transition:background .2s;}
.cf-btn:hover{background:var(--plum);}

/* ===== FOOTER ===== */
footer{background:var(--plum);color:#fff;padding:3rem 2rem 2rem;}
.ft-inner{max-width:1100px;margin:0 auto;}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2rem;}
.ft-brand h3{font-family:'Georgia',serif;font-size:1.2rem;margin-bottom:.45rem;}
.ft-brand h3 span{color:var(--gold-light);}
.ft-brand p{font-family:Arial,sans-serif;font-size:.8rem;line-height:1.65;opacity:.75;max-width:290px;}
.ft-col h4{font-family:Arial,sans-serif;font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;opacity:.6;margin-bottom:.9rem;}
.ft-col ul{list-style:none;}
.ft-col li{font-family:Arial,sans-serif;font-size:.8rem;opacity:.75;margin-bottom:.45rem;}
.ft-btm{border-top:1px solid rgba(255,255,255,.15);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;}
.ft-btm p{font-family:Arial,sans-serif;font-size:.76rem;opacity:.5;}
.ft-tag{font-style:italic;font-size:.85rem;opacity:.7;}

/* ===== OVERLAY ===== */
.overlay{position:fixed;inset:0;background:rgba(26,24,48,.4);z-index:250;opacity:0;pointer-events:none;transition:opacity .3s;}
.overlay.visible{opacity:1;pointer-events:all;}

/* ===== COMENTARIOS ===== */
.com-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.2rem;}
.com-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:1.3rem;}
.com-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.3rem;flex-wrap:wrap;gap:.3rem;}
.com-nombre{font-family:'Georgia',serif;font-size:.95rem;color:var(--plum);}
.com-fecha{font-family:Arial,sans-serif;font-size:.7rem;color:var(--silver);}
.com-ests{color:var(--gold);font-size:1rem;margin-bottom:.5rem;}
.com-texto{font-family:Arial,sans-serif;font-size:.86rem;color:var(--text-mid);line-height:1.6;}
.com-cargando{font-family:Arial,sans-serif;font-size:.88rem;color:var(--text-soft);padding:1rem 0;}
.com-form-wrap{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:2rem;max-width:560px;margin:0 auto;}
.com-form-titulo{font-family:'Georgia',serif;font-size:1.2rem;color:var(--plum);margin-bottom:.25rem;font-weight:normal;}
.com-form-sub{font-family:Arial,sans-serif;font-size:.8rem;color:var(--text-soft);margin-bottom:1.2rem;}
.com-estrellas{display:flex;gap:.4rem;margin-bottom:1.2rem;cursor:pointer;}
.estrella{font-size:1.9rem;color:var(--gold);transition:transform .1s;line-height:1;}
.estrella:hover{transform:scale(1.2);}
.com-msg-box{font-family:Arial,sans-serif;font-size:.9rem;margin-top:1rem;padding:1rem 1.2rem;border-radius:12px;line-height:1.5;}
.com-msg-ok{background:#E8F5E9;color:#2E7D32;border:1px solid #C8E6C9;}
.com-msg-error{background:#FFEBEE;color:#C62828;border:1px solid #FFCDD2;}

@media(max-width:768px){
  .hero-title{font-size:2rem;}
  .ctc-inner{grid-template-columns:1fr;}
  .ft-top{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .nav-cta{display:none;}
  nav{padding:0;}
  .nav-inner{padding:0 1rem;}
  .cart-bar{bottom:22px;right:22px;left:auto;}
  .cart-float{width:62px;height:62px;border-radius:50%;padding:0;gap:0;justify-content:center;position:relative;}
  .cart-float .cart-txt{display:none;}
  .cart-float .cart-ico{font-size:1.55rem;line-height:1;}
  .cart-float .c-cnt{position:absolute;top:-3px;right:-3px;width:20px;height:20px;border:2px solid #fff;font-size:.68rem;}
  .cart-panel{width:100%;}
  .modal-bg{padding:0;align-items:flex-end;}
  .modal{grid-template-columns:1fr;border-radius:24px 24px 0 0;max-height:92vh;width:100%;max-width:100%;}
  .modal-left{border-right:none;border-bottom:1px solid var(--border);}
  .modal-main-img{height:240px;}
  .modal-actions{flex-direction:column;}
  .modal-add,.modal-wa{width:100%;}
  .grid{grid-template-columns:repeat(2,1fr) !important;}
  .opiniones-inner{grid-template-columns:1fr;}
  .com-form-col{position:static;}
}

/* ===== SECCIÓN OPINIONES ===== */
.sec-opiniones{background:linear-gradient(160deg,#FAF5E4 0%,#F2E8C6 60%,#FAF5E4 100%);}
.opiniones-inner{display:grid;grid-template-columns:360px 1fr;gap:2.5rem;align-items:start;}
.com-form-col{position:sticky;top:5rem;}
.com-form-wrap{background:var(--white);border:1px solid rgba(184,134,11,.25);border-radius:20px;padding:2rem;box-shadow:0 4px 24px rgba(184,134,11,.10);}
.com-form-titulo{font-family:'Georgia',serif;font-size:1.2rem;color:var(--plum);margin-bottom:.25rem;font-weight:normal;}
.com-form-sub{font-family:Arial,sans-serif;font-size:.8rem;color:var(--text-soft);margin-bottom:1.2rem;}
.com-estrellas{display:flex;gap:.4rem;margin-bottom:1.2rem;cursor:pointer;}
.estrella{font-size:1.6rem;color:var(--gold-light);transition:color .15s;}
.opiniones-btn{background:var(--gold) !important;color:#fff !important;}
.opiniones-btn:hover{background:#8B6914 !important;}
.com-list-col{}
.com-card{background:var(--white);border:1px solid rgba(184,134,11,.2);border-radius:14px;padding:1.2rem 1.4rem;box-shadow:0 2px 10px rgba(184,134,11,.07);}
.com-paginacion{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:1rem;}
.com-pg-btn{font-family:Arial,sans-serif;font-size:.8rem;min-width:36px;height:36px;border-radius:18px;border:1.5px solid rgba(184,134,11,.35);background:var(--white);color:#8B6914;cursor:pointer;padding:0 .7rem;transition:all .2s;}
.com-pg-btn:hover,.com-pg-btn.active{background:var(--gold);color:#fff;border-color:var(--gold);}

@media(max-width:768px){
  .opiniones-inner{grid-template-columns:1fr !important;gap:1.5rem;}
  .com-form-col{position:static !important;}
  .com-form-wrap{padding:1.4rem;}
}
@media(max-width:520px){
  .grid{grid-template-columns:1fr !important;}
  .opiniones-inner{grid-template-columns:1fr !important;}
  .com-form-col{position:static !important;}
}
