/* =============================================
   Conmus v5.0 – Constelaciones Musicales
   Glassmorphism para fondos de universo
   ============================================= */
:root{
  --cm-text:#fff;--cm-muted:rgba(255,255,255,.6);--cm-border:rgba(255,255,255,.15);
  --cm-accent:#A62639;--cm-accent-hover:#C43050;--cm-gold:#D4943A;
  --cm-glass:rgba(10,10,30,.75);--cm-glass-hover:rgba(10,10,30,.85);
  --cm-blur:16px;
  --cmx-gap-sq:clamp(16px,3vw,40px);
}

/* Contenedor: 100% del ancho de la columna Divi (sección al 100%). Se removió contain:paint para evitar bugs de repintado del fondo parallax en Divi */
.cmx-shop{font-family:inherit;color:var(--cm-text);width:100%;max-width:100%;min-width:0;overflow-x:hidden;min-height:0}
.cmx-shop *{box-sizing:border-box}
.cmx-shop img{max-width:100%;height:auto;display:block}

/* Disposición en 2 columnas (Divi: escritorio) – galería izquierda, panel derecha */
@media(min-width:981px){
  .cmx-shop--gallery{grid-column:1;min-width:0}
  .cmx-shop--panel{grid-column:2;min-width:0}
}

/* ================= GALERÍA ================= */
.cmx-preview{position:sticky;top:120px}
.cmx-swiper-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-width:0}
.cmx-swiper{position:relative;overflow:hidden;background:var(--cm-glass);backdrop-filter:blur(var(--cm-blur));-webkit-backdrop-filter:blur(var(--cm-blur));border:1px solid var(--cm-border);border-radius:12px;width:100%;max-width:1280px;aspect-ratio:1/1;margin-inline:auto;flex:0 0 auto;min-width:0;touch-action:pan-y pinch-zoom; transition: opacity 0.3s ease;}
.cmx-swiper.cmx-loading{pointer-events:none; opacity: 0.6;}
.cmx-slides{position:absolute;inset:0;display:flex;transition:transform .25s ease-out}
.cmx-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--cm-glass);overflow:hidden}
.cmx-slide img{width:100%;height:100%;object-fit:contain;border-radius:0;display:block}

.cmx-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:clamp(24px,5vw,48px);font-weight:700;color:var(--cm-gold);opacity:.5;text-align:center}

.cmx-dots{position:absolute;left:50%;transform:translateX(-50%);bottom:calc(var(--cmx-gap-sq) - 6px);display:flex;gap:6px;margin:0}
.cmx-dots button{width:10px;height:10px;border:0;border-radius:2px;background:rgba(255,255,255,.25);transition:background .2s;cursor:pointer;padding:0}
.cmx-dots button[aria-current="true"]{background:var(--cm-gold)}
.cmx-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:var(--cm-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--cm-border);border-radius:50%;color:#fff;font-size:28px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.7;transition:opacity .2s,background .2s}
.cmx-arrow:hover{opacity:1;background:var(--cm-glass-hover)}
.cmx-arrow.prev{left:10px}
.cmx-arrow.next{right:10px}
.cmx-arrow:focus{outline:none}

/* ================= PANEL (glass) – 100% ancho columna. Sin overlay de carga = evita parpadeo ================= */
.cmx-panel{width:100%;min-width:0;background:var(--cm-glass);backdrop-filter:blur(var(--cm-blur));-webkit-backdrop-filter:blur(var(--cm-blur));border:1px solid var(--cm-border);border-radius:12px;padding:24px;color:var(--cm-text);box-shadow:0 10px 30px rgba(0,0,0,0.2);overflow:hidden;position:relative;min-height:300px; transition: opacity 0.3s ease;}
.cmx-panel.cmx-loading{pointer-events:none; opacity: 0.6;}

/* Módulos Título y Descripción: 100% ancho columna, mismo aspecto que galería/panel */
.cmx-header-module.cmx-panel,
.cmx-desc-module.cmx-panel { width: 100%; min-width: 0; margin-bottom: 16px; background: var(--cm-glass); backdrop-filter: blur(var(--cm-blur)); -webkit-backdrop-filter: blur(var(--cm-blur)); border: 1px solid var(--cm-border); min-height: 100px; }
.cmx-header-module.cmx-panel { padding: 24px 24px; text-align: center; display: flex; align-items: center; justify-content: center; }
.cmx-desc-module.cmx-panel { padding: 25px 30px; }
.cmx-header-module .cmx-product-title { display: block; width: 100%; font-size: clamp(34px, 6vw, 54px); font-weight: 800; margin: 0; padding: 0; color: #fff; line-height: 1; letter-spacing: -0.03em; text-transform: uppercase; word-break: break-word; text-align: center; }
.cmx-desc-module .cmx-desc { font-size: 17px; color: rgba(255,255,255,0.85); line-height: 1.6; margin: 0; word-break: break-word; }

.cmx-desc{color:var(--cm-muted);font-size:14px;margin-bottom:16px}
.cmx-list{margin:0 0 12px 18px;padding:0;color:var(--cm-muted);font-size:14px}
.cmx-list li{margin:5px 0}
.cmx-section-title{font-weight:700;text-transform:uppercase;font-size:12px;margin:20px 0 8px;letter-spacing:.04em;color:rgba(255,255,255,.7)}

/* Constellation Selector & Thumbnail */
.cmx-constellation-wrap { margin-bottom: 20px; }
.cmx-constellation-img-wrap { margin-top: 20px; margin-bottom: 20px; text-align: center; min-height: 80px; background: transparent; }
.cmx-constellation-img-wrap img { max-width: 150px; width: auto; height: auto; border-radius: 0; box-shadow: none !important; display: block; margin: 0 auto; filter: none !important; background: transparent; transition: opacity 0.25s ease; }
.cmx-constellation-img-wrap img[data-cmx-loaded="1"] { opacity: 1; }
.cmx-constellation-img-wrap img:not([data-cmx-loaded="1"]) { opacity: 0; }

/* Pills – contenidos dentro del contenedor */
#cmx-constelaciones { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; width: 100%; box-sizing: border-box; }
#cmx-formas { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; width: 100%; box-sizing: border-box; }
.cmx-pill { appearance: none; border: 1px solid var(--cm-border); padding: 8px 4px; background: rgba(255,255,255,.05); border-radius: 6px; font-size: 13px; cursor: pointer; color: rgba(255,255,255,.6); transition: all .2s; width: 100%; min-width: 0; text-align: center; white-space: normal; height: 100%; min-height: 48px; display: flex; align-items: center; justify-content: center; font-family: inherit; line-height: 1.2; overflow: hidden; box-sizing: border-box; }
.cmx-pill:hover { border-color: rgba(255,255,255,.35); color: #fff; background: rgba(255,255,255,.08); }
.cmx-pill--active, .cmx-pill[aria-checked="true"] { border-color: var(--cm-gold); color: var(--cm-gold); background: rgba(212,148,58,.1); }

/* Color selector */
.cmx-color-name{font-size:13px;color:var(--cm-muted);margin-bottom:8px}
#cmx-colors { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; width: 100%; box-sizing: border-box; }
.cmx-color-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:8px 10px;border:1px solid var(--cm-border);border-radius:8px;background:rgba(255,255,255,.04);color:var(--cm-muted);cursor:pointer;transition:all .2s;font-size:12px; width: 100%; min-width: 0; height: 100%; min-height: 48px; font-family: inherit; box-sizing: border-box;}
.cmx-color-btn:hover{border-color:rgba(255,255,255,.3);color:#fff;background:rgba(255,255,255,.08)}
.cmx-color-btn--active{border-color:var(--cm-gold);color:var(--cm-gold);background:rgba(212,148,58,.1)}
.cmx-color-btn img{width:24px;height:24px;border-radius:5px;object-fit:contain}
.cmx-color-label{white-space:nowrap}
.cmx-color-dot{display:inline-block;width:18px;height:18px;border-radius:50%;border:1px solid rgba(255,255,255,.2);flex-shrink:0}
.cmx-color-dot--oro{background:linear-gradient(135deg,#D4A84B,#B8860B)}
.cmx-color-dot--plateado{background:linear-gradient(135deg,#D0D0D0,#8A8A8A)}
.cmx-color-dot--negro{background:linear-gradient(135deg,#444,#111)}
.cmx-color-dot--tornasol{background:linear-gradient(135deg,#E8A0BF,#7EB6FF,#B5F0C1,#FFE27A)}

/* Error states for fields */
.cmx-field input.cmx-error, .cmx-field textarea.cmx-error { border-color: #F87171; background: rgba(248,113,113,0.05); }

/* Total & Stock */
.cmx-stock-wrap{font-size:13px;font-weight:600;margin-top:16px;padding:8px 12px;border-radius:6px;background:rgba(255,255,255,.05);display:inline-block;}
.cmx-stock-wrap.cmx-in-stock{color:#5CE0A8;}
.cmx-stock-wrap.cmx-out-stock{color:#F87171;}

.cmx-price-row{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--cm-border);padding-top:14px;margin-top:18px}
.cmx-total-label{text-transform:uppercase;font-weight:700;font-size:13px;color:var(--cm-muted)}
.cmx-price{font-size:26px;font-weight:800;color:#fff}

/* CTAs */
.cmx-cta{display:flex;gap:10px;margin-top:14px}
.cmx-btn{flex:1 1 auto;display:inline-flex;align-items:center;justify-content:center;height:48px;border-radius:8px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;text-decoration:none;transition:all .2s;border:none}
.cmx-btn:hover{transform:translateY(-1px)}
.cmx-btn--primary{background:var(--cm-accent);color:#fff}
.cmx-btn--primary:hover{background:var(--cm-accent-hover)}
.cmx-btn--ghost{background:rgba(255,255,255,.08);border:1px solid var(--cm-border);color:#fff}
.cmx-btn--ghost:hover{background:rgba(255,255,255,.14)}
.cmx-msg{margin-top:10px;font-size:13px;font-weight:600}

/* Features */
.cmx-list.collapsed li:nth-child(n+4){display:none}
.cmx-list.expanded li{display:list-item}
.cmx-more-btn{display:inline-block;margin:0;padding:5px 10px;border:1px solid var(--cm-border);background:rgba(255,255,255,.05);color:var(--cm-muted);border-radius:4px;font-size:12px;line-height:1;cursor:pointer;transition:all .2s}
.cmx-more-btn:hover{border-color:var(--cm-gold);color:var(--cm-gold)}

/* Beneficios – columnas según breakpoint Divi (se controlan por JS en desktop) */
.provided-service-wrapper{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;text-align:center;color:var(--cm-muted);background:var(--cm-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--cm-border);border-radius:12px;padding:16px;width:100%;min-width:0}
.provided-service{display:flex;flex-direction:column;align-items:center}
.provided-service img, .provided-service svg{width:36px;height:auto;margin:0 0 6px;opacity:.5}
.provided-service__text{font-size:11px;line-height:1.25}

/* ================= IMAGEN CONSTELACIÓN (módulo separado) ================= */
.cmx-constellation-display{text-align:center;padding:20px 0}
.cmx-constellation-display img{max-width:100%;max-height:500px;object-fit:contain;border-radius:12px;transition:opacity .4s ease}
.cmx-constellation-display .cmx-const-name{font-size:clamp(20px,3vw,32px);font-weight:800;color:#fff;margin-top:12px;text-shadow:0 2px 20px rgba(0,0,0,.5)}

/* ================= CAMPOS PERSONALIZADOS ================= */
.cmx-custom-fields{background:var(--cm-glass);backdrop-filter:blur(var(--cm-blur));-webkit-backdrop-filter:blur(var(--cm-blur));border:1px solid var(--cm-border);border-radius:12px;padding:24px;color:var(--cm-text)}
.cmx-custom-fields h3{font-size:16px;font-weight:700;margin:0 0 16px;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.04em}
.cmx-field{margin-bottom:16px}
.cmx-field label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:rgba(255,255,255,.6);margin-bottom:6px}
.cmx-spotify-label .cmx-spotify-icon{display:inline-block;vertical-align:middle;margin-right:8px;color:#1DB954}
.cmx-spotify-label .cmx-spotify-icon svg{display:block;width:20px;height:20px}
.cmx-field input{width:100%;background:rgba(255,255,255,.06);border:1px solid var(--cm-border);border-radius:8px;padding:10px 14px;font-size:14px;color:#fff;font-family:inherit;transition:border-color .2s}
.cmx-field textarea{width:100%;background:#fff;border:1px solid var(--cm-border);border-radius:8px;padding:10px 14px;font-size:14px;color:#000;font-family:inherit;transition:border-color .2s;resize:vertical;min-height:70px}
.cmx-field input::placeholder{color:rgba(255,255,255,.3)}
.cmx-field textarea::placeholder{color:rgba(0,0,0,.5)}
.cmx-field input:focus,.cmx-field textarea:focus{outline:none;border-color:var(--cm-gold);box-shadow:0 0 0 3px rgba(212,148,58,.15)}
.cmx-field .cmx-char-count{font-size:11px;color:var(--cm-muted);text-align:right;margin-top:4px}
.cmx-field .cmx-char-count.cmx-limit{color:#F87171}

/* Modales – espacio a la derecha para que la X no se encime al título en móvil */
.cmx-modal { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.7); display: flex; align-items: center; justify-content: center; z-index: 9999; backdrop-filter: blur(4px); padding: 16px; box-sizing: border-box; }
.cmx-modal-content { background: #1a1a24; border: 1px solid var(--cm-border); border-radius: 12px; padding: 20px 56px 24px 24px; max-width: 500px; width: 90%; position: relative; box-shadow: 0 10px 30px rgba(0,0,0,0.5); max-height: 80vh; overflow-y: auto; box-sizing: border-box; }
.cmx-modal-close { position: absolute; top: 12px; right: 12px; background: none; border: none; color: #fff; font-size: 28px; cursor: pointer; opacity: 0.7; transition: opacity 0.2s; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; line-height: 1; padding: 0; z-index: 10; }
.cmx-modal-close:hover { opacity: 1; }
.cmx-modal-title { margin-top: 0; color: #fff; font-size: 18px; padding-right: 0; line-height: 1.3; margin-bottom: 16px; font-weight: 700; }

/* Descripción "Ver más" */
.cmx-desc-content { overflow: hidden; }
.cmx-desc-more { display: block; margin-top: 10px; background: none; border: none; color: var(--cm-gold); cursor: pointer; font-size: 13px; font-weight: 600; padding: 0; text-decoration: underline; font-family: inherit; }

/* Spotify search */
.cmx-spotify-search-wrap{position:relative; z-index: 50;}
.cmx-spotify-results{position:absolute;top:100%;left:0;right:0;z-index:51;background:rgba(15,15,35,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-top:none;border-radius:0 0 10px 10px;max-height:280px;overflow-y:auto;box-shadow:0 10px 25px rgba(0,0,0,.5)}
.cmx-spotify-result{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.06)}
.cmx-spotify-result:last-child{border-bottom:none}
.cmx-spotify-result:hover{background:rgba(255,255,255,.1)}
.cmx-spotify-result img{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0}
.cmx-spotify-result-info{flex:1;min-width:0}
.cmx-spotify-result-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmx-spotify-result-artist{font-size:11px;color:var(--cm-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmx-spotify-loading{padding:16px;text-align:center;color:var(--cm-muted);font-size:13px}

/* Spotify Plaque (v5.2) */
.cmx-spotify-plaque { margin-top: 16px; background: rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 20px; text-align: center; max-width: 100%; overflow: hidden; }
.cmx-spotify-plaque-inner { display: flex; flex-direction: column; align-items: center; gap: 12px; width: 100%; }
.cmx-spotify-sel-art { width: 120px; height: 120px; border-radius: 8px; object-fit: cover; box-shadow: 0 8px 24px rgba(0,0,0,0.5); max-width: 100%; }
.cmx-spotify-sel-info { margin-bottom: 8px; width: 100%; }
.cmx-spotify-sel-title { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 4px; word-wrap: break-word; }
.cmx-spotify-sel-artist { font-size: 13px; color: rgba(255,255,255,0.6); word-wrap: break-word; }
.cmx-spotify-code-img { max-width: 100%; height: auto; border-radius: 4px; background: #000; padding: 6px; }
.cmx-spotify-actions { display: flex; gap: 10px; margin-top: 12px; width: 100%; }
.cmx-spotify-btn { flex: 1; padding: 10px 16px; background: #1DB954; color: #fff !important; border-radius: 8px; text-decoration: none; font-size: 13px; font-weight: 700; transition: background 0.2s; text-align: center; display: inline-flex; align-items: center; justify-content: center; }
.cmx-spotify-btn:hover { background: #1ed760; }
.cmx-spotify-remove { flex: 1; padding: 10px 16px; background: rgba(255,255,255,0.1); color: #fff; border: 1px solid rgba(255,255,255,0.2); border-radius: 8px; cursor: pointer; font-size: 13px; font-weight: 600; transition: all 0.2s; text-align: center; }
.cmx-spotify-remove:hover { background: rgba(248,113,113,0.2); border-color: rgba(248,113,113,0.5); color: #F87171; }

/* ================= RESPONSIVE – Breakpoints Divi (navaja suiza) =================
   Divi: Teléfono <767 | Teléfono ancho <860 | Tableta <980 | Tableta ancha <1024
         Escritorio base | Pantalla ancha >1280 | Ultra ancho >1440
   Sección 100%: módulos se adaptan al ancho de la columna.
   ================================================================================ */
.cmx-shop{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
.cmx-modal-content{padding-left:max(24px,env(safe-area-inset-left));padding-right:max(56px,env(safe-area-inset-right))}

/* Mismo ancho: título, descripción y galería (igual que .cmx-swiper-wrap) */
@media(min-width:1440px){
  .cmx-swiper-wrap{max-width:min(100%,960px);margin-inline:auto}
  .cmx-header-module.cmx-panel,.cmx-desc-module.cmx-panel{max-width:min(100%,960px);margin-inline:auto}
  .cmx-header-module .cmx-product-title{font-size:clamp(36px,2.2vw,54px)}
  .cmx-desc-module .cmx-desc{font-size:clamp(15px,1vw,18px)}
}
@media(max-width:1280px){
  .cmx-panel{padding:22px 20px;min-height:280px}
  .cmx-header-module .cmx-product-title{font-size:clamp(28px,3vw,44px)}
  .cmx-desc-module .cmx-desc{font-size:clamp(14px,1.5vw,17px)}
  .cmx-section-title{font-size:clamp(11px,1.2vw,12px)}
  .cmx-price{font-size:clamp(22px,2vw,26px)}
}

/* Tableta ancha (980px–1023px) – Divi “Tablet” */
@media(max-width:1023px){
  .cmx-preview{position:static}
  .cmx-panel{min-height:260px;padding:20px 18px}
  #cmx-constelaciones{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
  .cmx-header-module .cmx-product-title{font-size:clamp(26px,3.5vw,40px)}
  .cmx-desc-module .cmx-desc{font-size:clamp(14px,2vw,16px)}
  .provided-service-wrapper{grid-template-columns:repeat(3,minmax(0,1fr)) !important;gap:14px;padding:14px}
  .provided-service__text{font-size:clamp(10px,1.5vw,12px)}
}

/* Tableta (860px–979px) – Divi “Tablet” estrecho */
@media(max-width:979px){
  .cmx-panel{padding:18px 16px}
  #cmx-constelaciones{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  #cmx-formas,#cmx-colors{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .cmx-pill{font-size:clamp(11px,1.5vw,13px);min-height:46px}
  .cmx-color-btn{font-size:clamp(11px,1.5vw,12px);min-height:46px}
}

/* Teléfono ancho (767px–859px) – Divi “Phone landscape” */
@media(max-width:859px){
  :root{--cmx-gap-sq:clamp(12px,3vw,24px)}
  .cmx-cta{flex-direction:column;gap:8px}
  .cmx-btn{width:100%;min-height:48px;font-size:clamp(12px,2vw,14px)}
  .cmx-header-module.cmx-panel,.cmx-desc-module.cmx-panel{padding:22px 16px;min-height:88px}
  .cmx-header-module .cmx-product-title{font-size:clamp(22px,4vw,34px)}
  .cmx-desc-module .cmx-desc{font-size:clamp(13px,2.2vw,15px)}
  .cmx-constellation-img-wrap{min-height:70px;margin-top:16px;margin-bottom:16px}
  .cmx-constellation-img-wrap img{max-width:min(140px,45vw)}
  .cmx-spotify-actions{flex-direction:column;gap:8px;width:100%}
  .cmx-spotify-btn,.cmx-spotify-remove{width:100%;min-width:0;flex:none;min-height:48px;font-size:clamp(13px,2vw,14px)}
  .cmx-modal-content{width:92%;max-width:92%;max-height:85vh;padding:20px 56px 20px 20px}
  .cmx-modal-close{top:12px;right:12px}
  .cmx-desc-more{min-height:44px;padding:8px 0}
}

/* Teléfono (<767px) – Divi “Phone” */
@media(max-width:767px){
  :root{--cmx-gap-sq:clamp(10px,2.5vw,20px)}
  .cmx-arrow{width:40px;height:40px;font-size:22px;min-width:40px;min-height:40px}
  .cmx-dots button{width:8px;height:8px;min-width:8px;min-height:8px}
  .cmx-panel{padding:16px 14px;min-height:240px}
  .cmx-header-module.cmx-panel,.cmx-desc-module.cmx-panel{min-height:80px;padding:18px 14px;text-align:center}
  .cmx-header-module .cmx-product-title{display:block;width:100%;text-align:center;font-size:clamp(20px,5vw,32px)}
  .cmx-desc-module .cmx-desc{font-size:clamp(13px,2.5vw,15px)}
  .cmx-price{font-size:clamp(18px,4vw,22px)}
  .cmx-section-title{font-size:clamp(10px,2vw,11px);margin:14px 0 6px}
  .cmx-total-label{font-size:clamp(11px,2vw,12px)}
  #cmx-constelaciones{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  #cmx-formas,#cmx-colors{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .cmx-pill{font-size:clamp(10px,2vw,12px);padding:10px 6px;min-height:44px}
  .cmx-color-btn{padding:8px 6px;font-size:clamp(10px,2vw,12px);min-height:44px}
  .cmx-color-dot{width:14px;height:14px}
  .cmx-field input,.cmx-field textarea{font-size:16px;min-height:48px}
  .cmx-field label{font-size:clamp(11px,2vw,12px)}
  .cmx-custom-fields h3{font-size:clamp(14px,3vw,16px)}
  .provided-service-wrapper{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:12px;padding:12px}
}

@media(max-width:480px){
  .cmx-arrow{width:36px;height:36px;font-size:20px;min-width:36px;min-height:36px}
  .cmx-panel{padding:14px 12px}
  .cmx-header-module.cmx-panel,.cmx-desc-module.cmx-panel{padding:16px 12px;text-align:center}
  .cmx-header-module .cmx-product-title{text-align:center}
  #cmx-constelaciones,#cmx-formas,#cmx-colors{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .cmx-constellation-img-wrap img{max-width:min(120px,42vw)}
  .cmx-spotify-sel-art{width:100px;height:100px}
  .cmx-spotify-sel-title{font-size:14px}
  .cmx-spotify-sel-artist{font-size:12px}
}

@media(max-width:360px){
  #cmx-constelaciones,#cmx-formas,#cmx-colors{grid-template-columns:1fr}
  .cmx-pill,.cmx-color-btn{min-height:48px}
  .cmx-constellation-img-wrap img{max-width:100px}
  .provided-service-wrapper{grid-template-columns:1fr !important}
}

@media(max-width:320px){
  .cmx-panel{padding:12px 10px;min-height:220px}
  .cmx-header-module .cmx-product-title{font-size:18px}
  .cmx-price{font-size:16px}
}

@media(prefers-reduced-motion:reduce){
  .cmx-slides{transition:none}
  .cmx-constellation-img-wrap img{transition:none}
}
