/**
 * Carrito de Compra - Estilos
 * Sistema de hosting + dominios + upsells
 */

:root {
  --bg: #04060f;
  --bg2: #080d1c;
  --bg3: #0c1225;
  --card: #0e1530;
  --border: #1a2545;
  --cyan: #00e5ff;
  --cyan2: #00b8d9;
  --lime: #a8ff3e;
  --text: #e8edf8;
  --muted: #7a8aaa;
  --accent: #ff4d6d;
  --gold: #ffc947;
  --radius: 12px;
  --radius-lg: 20px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:16px;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4,h5{font-family:'Poiret One',sans-serif;line-height:1.15}
button,a{cursor:pointer;border:none;font-family:'Inter',sans-serif;-webkit-tap-highlight-color:transparent}
input,select,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none}

/* ── CART SHELL ── */
.cart-shell{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}
.cart-topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.cart-topbar-logo{font-family:'Poiret One',sans-serif;font-weight:800;font-size:1.4rem;cursor:pointer;text-decoration:none;color:var(--text)}
.cart-topbar-logo span{color:var(--cyan)}

/* Progress steps */
.cart-progress{display:flex;align-items:center;gap:0;flex:1;justify-content:center;max-width:480px;margin:0 auto}
.cart-progress-mobile{display:none;font-size:.75rem;font-weight:600;color:var(--cyan);padding:4px 12px;background:rgba(0,229,255,.1);border-radius:100px}
.cart-step{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:var(--muted);white-space:nowrap}
.cart-step.active{color:var(--text)}
.cart-step.done{color:var(--cyan)}
.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);flex-shrink:0}
.cart-step.active .step-dot{background:var(--cyan)}
.cart-step.done .step-dot{background:var(--lime)}
.step-line{flex:1;height:2px;background:var(--border);min-width:20px;max-width:60px}
.step-line.done{background:var(--lime)}
.cart-secure-badge{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:.78rem;border:1px solid var(--border);padding:6px 12px;border-radius:100px}
.cart-secure-badge .shield{color:var(--lime)}

/* Cart body */
.cart-body{flex:1;padding:32px 24px 64px;max-width:1100px;margin:0 auto;width:100%}
.cart-body h1{font-size:1.8rem;font-weight:800;margin-bottom:28px}
.cart-empty{text-align:center;padding:80px 0;color:var(--muted)}
.cart-empty .icon{font-size:4rem;display:block;margin-bottom:16px;opacity:.4}
.cart-empty h3{font-size:1.3rem;margin-bottom:8px}

/* Grid Layout 50/50 */
.cart-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.cart-grid-left{display:flex;flex-direction:column;gap:20px}
.cart-grid-right{display:flex;flex-direction:column;gap:20px}
.cart-grid .cpc,.cart-grid .upsell-card{margin-bottom:0}

/* Cart product card */
.cpc{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden}
.cpc-header{padding:20px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border)}
.cpc-icon{width:44px;height:44px;border-radius:10px;background:rgba(0,229,255,.1);border:1px solid rgba(0,229,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.cpc-info{flex:1}
.cpc-name{font-size:1.05rem;font-weight:700;margin-bottom:2px}
.cpc-type{color:var(--cyan);font-size:.82rem;font-weight:600}
.cpc-price-col{text-align:right;flex-shrink:0}
.cpc-price-main{font-family:'Poiret One',sans-serif;font-size:1.5rem;font-weight:800;line-height:1}
.cpc-price-period{color:var(--muted);font-size:.78rem;margin-top:2px}
.cpc-price-renewal{color:var(--muted);font-size:.75rem;margin-top:4px}
.cpc-price-usd{color:var(--muted);font-size:.75rem}

/* CPC Body */
.cpc-body{padding:20px 24px}
.cpc-includes-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}
.cpc-includes{display:grid;grid-template-columns:1fr 1fr;gap:6px 20px;margin-bottom:20px}
.cpc-feat{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted)}
.cpc-feat .ck{color:var(--lime);font-size:.9rem}

/* Cycle selector */
.cpc-cycle-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.cpc-cycle-label{font-size:.85rem;font-weight:600;color:var(--muted)}
.cycle-select-wrap{position:relative;display:inline-flex;align-items:center}
.cycle-select{background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:8px 36px 8px 14px;border-radius:8px;font-family:'Inter',sans-serif;font-size:.88rem;appearance:none;outline:none;cursor:pointer;transition:border-color .2s}
.cycle-select:focus{border-color:var(--cyan)}
.cycle-arrow{position:absolute;right:10px;pointer-events:none;color:var(--muted);font-size:.7rem}
.discount-badge{background:rgba(168,255,62,.15);border:1px solid rgba(168,255,62,.3);color:var(--lime);padding:4px 10px;border-radius:100px;font-size:.75rem;font-weight:700}

/* Domain bonus */
.domain-bonus{background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.2);border-radius:12px;padding:14px 20px;display:flex;align-items:center;gap:12px;font-size:.88rem;margin-top:16px}
.domain-bonus .bonus-icon{font-size:1.3rem;flex-shrink:0}
.domain-bonus strong{color:var(--cyan)}
.domain-bonus span{color:var(--muted)}

/* Domain Section with Tabs */
.domain-section{background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.2);border-radius:12px;padding:0;margin-top:16px;overflow:hidden}
.domain-tabs{display:flex;border-bottom:1px solid rgba(0,229,255,.2);background:rgba(0,0,0,.2)}
.domain-tab{flex:1;background:transparent;border:none;color:var(--muted);padding:14px 20px;font-size:.88rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}
.domain-tab:hover{color:var(--cyan);background:rgba(0,229,255,.05)}
.domain-tab.active{color:var(--cyan);border-bottom-color:var(--cyan);background:rgba(0,229,255,.08)}
.domain-tab .tab-icon{font-size:1.1rem}
.domain-tab-content{display:none;padding:20px}
.domain-tab-content.active{display:block}
.domain-bonus-msg{display:flex;align-items:center;gap:12px;font-size:.88rem;margin-bottom:16px}
.domain-bonus-msg .bonus-icon{font-size:1.3rem;flex-shrink:0}
.domain-bonus-msg strong{color:var(--cyan)}
.domain-bonus-msg span{color:var(--muted)}
.domain-form{display:flex;flex-direction:column;gap:14px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:.82rem;font-weight:600;color:var(--muted)}
.form-input{background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:8px;font-family:'Inter',sans-serif;font-size:.9rem;outline:none;transition:border-color .2s}
.form-input:focus{border-color:var(--cyan)}
.form-error{color:var(--accent);font-size:.8rem;margin-top:4px}
.form-success{color:var(--lime);font-size:.8rem;margin-top:4px}
.btn-validate{background:var(--cyan);color:var(--bg);border:none;padding:11px 24px;border-radius:8px;font-weight:700;font-size:.88rem;cursor:pointer;transition:all .2s;text-align:center}
.btn-validate:hover{background:var(--lime)}
.domain-search-box{display:flex;gap:10px;margin-bottom:16px}
.domain-search-input{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:11px 14px;border-radius:8px;font-family:'Inter',sans-serif;font-size:.9rem;outline:none;transition:border-color .2s}
.domain-search-input:focus{border-color:var(--cyan)}
.btn-search-domain{background:var(--cyan);color:var(--bg);border:none;padding:11px 24px;border-radius:8px;font-weight:700;font-size:.88rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.btn-search-domain:hover{background:var(--lime)}
.btn-search-domain:disabled{opacity:.5;cursor:not-allowed}
.domain-search-result{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:14px;font-size:.88rem;line-height:1.5}
.domain-available{color:var(--lime)}
.domain-taken{color:var(--accent)}
.domain-error{color:var(--muted)}

/* Remove row */
.cpc-remove-row{padding:12px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}
.cpc-remove{background:none;border:none;color:var(--muted);font-size:.82rem;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .2s}
.cpc-remove:hover{color:var(--accent)}

/* Upsell card */
.upsell-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden}
.upsell-head{padding:20px 24px 12px}
.upsell-head h3{font-size:1.05rem;font-weight:800;margin-bottom:4px}
.upsell-head h3 span{color:var(--cyan)}
.upsell-head p{color:var(--muted);font-size:.85rem;line-height:1.5}
.upsell-item{margin:0 20px 16px;background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:16px}
.upsell-item-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.upsell-item-icon{width:38px;height:38px;border-radius:8px;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.upsell-item-info{flex:1}
.upsell-item-name{font-size:.95rem;font-weight:700}
.upsell-item-sub{color:var(--muted);font-size:.78rem}
.upsell-item-price{font-family:'Poiret One',sans-serif;font-size:1rem;font-weight:700;white-space:nowrap}
.upsell-add-btn{background:var(--cyan);color:var(--bg);border:none;padding:8px 20px;border-radius:8px;font-weight:700;font-size:.88rem;cursor:pointer;transition:all .2s;white-space:nowrap}
.upsell-add-btn:hover{background:var(--lime);transform:scale(1.03)}
.upsell-add-btn.added{background:var(--lime);pointer-events:none}
.upsell-feats{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.upsell-feat{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--muted)}
.upsell-feat .ck{color:var(--lime);font-size:.85rem}

/* Trust bar */
.cart-trust{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:0;overflow:hidden}
.cart-trust-inner{display:flex;flex-direction:column;gap:16px}
.trust-group{text-align:left}
.trust-group-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px}
.trust-logos{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.trust-logo{background:rgba(0,229,255,.05);border:1px solid rgba(0,229,255,.15);border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:5px}
.trust-logo i{color:var(--cyan);font-size:.85rem}

/* Cart footer */
.cart-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:20px}
.cart-back{background:none;border:1px solid var(--border);color:var(--muted);padding:11px 20px;border-radius:8px;font-size:.88rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;text-decoration:none}
.cart-back:hover{border-color:var(--cyan);color:var(--cyan)}
.cart-continue{background:var(--cyan);color:var(--bg);border:none;padding:13px 28px;border-radius:10px;font-family:'Poiret One',sans-serif;font-weight:700;font-size:1rem;cursor:pointer;transition:all .25s;display:flex;align-items:center;gap:8px;text-decoration:none}
.cart-continue:hover{background:var(--lime);transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,229,255,.25)}

/* Toast notification */
.toast{position:fixed;bottom:24px;right:24px;background:var(--card);border:1px solid var(--lime);border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:12px;z-index:3000;transform:translateY(100px);opacity:0;transition:all .3s;max-width:320px}
.toast.show{transform:translateY(0);opacity:1}
.toast .icon{font-size:1.3rem}
.toast .msg{font-size:.9rem;line-height:1.4}
.toast .msg strong{display:block;font-weight:600}

/* Responsive */

/* Tablets y pantallas medianas */
@media(max-width:1024px){
  .cart-grid{grid-template-columns:1fr;gap:0}
  .cart-body{padding:24px 16px 48px}
  .upsell-feats{grid-template-columns:1fr}
}

/* Mobile */
@media(max-width:768px){
  .cart-topbar{padding:0 16px;height:56px}
  .cart-topbar-logo{font-size:1.2rem}
  .cart-progress{display:none}
  .cart-progress-mobile{display:block}
  .cart-secure-badge{font-size:.7rem;padding:5px 10px}
  
  .cart-body{padding:20px 14px 40px}
  .cart-body h1{font-size:1.4rem;margin-bottom:20px}
  
  .cart-grid{grid-template-columns:1fr;gap:0}
  .cart-grid-left,.cart-grid-right{gap:16px}
  
  .cpc{margin-bottom:16px;border-radius:12px}
  .cpc-header{flex-direction:column;align-items:flex-start;padding:16px 18px;gap:12px}
  .cpc-icon{width:38px;height:38px;font-size:1.2rem}
  .cpc-info{width:100%}
  .cpc-name{font-size:.95rem}
  .cpc-type{font-size:.78rem}
  .cpc-price-col{text-align:left;width:100%;margin-top:8px}
  .cpc-price-main{font-size:1.3rem}
  .cpc-price-period{font-size:.75rem}
  .cpc-price-renewal,.cpc-price-usd{font-size:.7rem}
  
  .cpc-body{padding:16px 18px}
  .cpc-includes{grid-template-columns:1fr;gap:8px}
  .cpc-feat{font-size:.82rem}
  .cpc-cycle-row{flex-direction:column;align-items:flex-start;gap:10px}
  .cycle-select-wrap{width:100%}
  .cycle-select{width:100%;padding:10px 36px 10px 14px}
  .discount-badge{margin-left:0}
  
  .domain-section{margin-top:14px}
  .domain-tab{font-size:.8rem;padding:12px 8px;gap:6px}
  .domain-tab .tab-icon{font-size:1rem}
  .domain-tab-content{padding:16px}
  .domain-bonus-msg{font-size:.82rem;gap:10px}
  .domain-bonus-msg .bonus-icon{font-size:1.2rem}
  .domain-search-box{flex-direction:column;gap:8px}
  .btn-search-domain{width:100%;justify-content:center;padding:12px 20px}
  .btn-validate{width:100%;padding:12px 20px}
  
  .cpc-remove-row{padding:10px 18px}
  .cpc-remove{font-size:.78rem}
  
  .upsell-card{margin-bottom:16px;border-radius:12px}
  .upsell-head{padding:16px 18px 10px}
  .upsell-head h3{font-size:.95rem}
  .upsell-head p{font-size:.8rem}
  .upsell-item{margin:0 16px 14px;padding:14px}
  .upsell-item-top{flex-wrap:wrap;gap:10px}
  .upsell-item-icon{width:34px;height:34px;font-size:1rem}
  .upsell-item-name{font-size:.88rem}
  .upsell-item-sub{font-size:.75rem}
  .upsell-item-price{font-size:.9rem;width:100%;margin-top:4px}
  .upsell-add-btn{width:100%;margin-top:8px;padding:10px 20px}
  .upsell-feats{grid-template-columns:1fr;gap:6px}
  .upsell-feat{font-size:.78rem}
  
  .cart-trust{padding:16px;margin-bottom:0}
  .cart-trust-inner{gap:14px}
  .trust-group{text-align:center}
  .trust-group-label{font-size:.68rem;margin-bottom:8px}
  .trust-logos{justify-content:center;gap:6px}
  .trust-logo{font-size:.7rem;padding:5px 10px}
  
  .cart-foot{flex-direction:column-reverse;gap:10px;margin-top:16px}
  .cart-back,.cart-continue{width:100%;justify-content:center;padding:12px 20px}
  
  .toast{bottom:16px;right:16px;left:16px;max-width:none;padding:14px 16px}
  .toast .icon{font-size:1.2rem}
  .toast .msg{font-size:.85rem}
  
  .cart-empty{padding:60px 20px}
  .cart-empty .icon{font-size:3rem}
  .cart-empty h3{font-size:1.1rem}
  .cart-empty p{font-size:.88rem}
}

/* Mobile pequeño */
@media(max-width:480px){
  .cart-topbar{flex-wrap:wrap;height:auto;padding:12px 14px;gap:8px}
  .cart-topbar-logo{font-size:1.1rem;order:1}
  .cart-progress-mobile{order:2;font-size:.7rem;padding:3px 10px}
  .cart-secure-badge{order:3;flex:1;justify-content:center;font-size:.68rem}
  .cart-secure-badge span{display:none}
  
  .cart-body{padding:16px 12px 32px}
  .cart-body h1{font-size:1.15rem;margin-bottom:16px}
  
  .cpc-header{padding:12px 14px;gap:10px}
  .cpc-icon{width:34px;height:34px;font-size:1.1rem}
  .cpc-name{font-size:.88rem}
  .cpc-price-main{font-size:1.2rem}
  
  .cpc-body{padding:12px 14px}
  .cpc-feat{font-size:.8rem}
  
  .cpc-remove-row{padding:8px 14px}
  
  .upsell-head{padding:12px 14px 8px}
  .upsell-head h3{font-size:.9rem}
  .upsell-item{margin:0 12px 10px;padding:12px}
  
  .domain-tab{padding:10px 6px;font-size:.78rem}
  .domain-tab-content{padding:14px}
  .form-input,.domain-search-input{font-size:.88rem;padding:11px 12px}
  .btn-validate,.btn-search-domain{font-size:.82rem;padding:11px 16px}
  
  .cart-trust{padding:14px;margin-bottom:0}
  .trust-logos{gap:5px}
  .trust-logo{font-size:.68rem;padding:4px 8px}
  
  .cart-foot{margin-top:14px}
  
  .toast{bottom:12px;right:12px;left:12px;padding:12px 14px}
  .toast .icon{font-size:1.1rem}
  .toast .msg{font-size:.8rem}
}

/* ── CONFIRM MODAL ── */
.confirm-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(4, 6, 15, 0.85);
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.confirm-overlay.show {
  opacity: 1;
  visibility: visible;
}

.confirm-modal {
  background: linear-gradient(135deg, #1a2332 0%, #0f1419 100%);
  border: 1px solid rgba(255, 77, 109, 0.3);
  border-radius: 20px;
  padding: 32px;
  max-width: 420px;
  width: 90%;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5), 0 0 30px rgba(255, 77, 109, 0.15);
  transform: scale(0.9) translateY(20px);
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  position: relative;
}

.confirm-overlay.show .confirm-modal {
  transform: scale(1) translateY(0);
}

.confirm-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto 20px;
  background: linear-gradient(135deg, rgba(255, 77, 109, 0.2), rgba(255, 77, 109, 0.1));
  border: 2px solid rgba(255, 77, 109, 0.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: #ff4d6d;
  animation: iconPulse 2s ease-in-out infinite;
}

@keyframes iconPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); box-shadow: 0 0 20px rgba(255, 77, 109, 0.4); }
}

.confirm-title {
  font-family: 'Poiret One', sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: #e8edf8;
  text-align: center;
  margin-bottom: 12px;
  letter-spacing: -0.02em;
}

.confirm-message {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  color: #7a8aaa;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 28px;
}

.confirm-actions {
  display: flex;
  gap: 12px;
}

.confirm-btn {
  flex: 1;
  padding: 14px 24px;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 600;
  transition: all 0.2s;
  border: none;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
}

.confirm-btn-cancel {
  background: rgba(122, 138, 170, 0.1);
  border: 1px solid rgba(122, 138, 170, 0.3);
  color: #7a8aaa;
}

.confirm-btn-cancel:hover {
  background: rgba(122, 138, 170, 0.2);
  border-color: rgba(122, 138, 170, 0.5);
  color: #e8edf8;
  transform: translateY(-2px);
}

.confirm-btn-delete {
  background: linear-gradient(135deg, #ff4d6d, #d63d5a);
  border: 1px solid rgba(255, 77, 109, 0.5);
  color: #ffffff;
  box-shadow: 0 4px 12px rgba(255, 77, 109, 0.3);
}

.confirm-btn-delete:hover {
  background: linear-gradient(135deg, #ff3355, #c72d47);
  box-shadow: 0 6px 20px rgba(255, 77, 109, 0.5);
  transform: translateY(-2px);
}

@media (max-width: 480px) {
  .confirm-modal {
    padding: 24px;
    max-width: 340px;
  }
  
  .confirm-icon {
    width: 56px;
    height: 56px;
    font-size: 28px;
  }
  
  .confirm-title {
    font-size: 20px;
  }
  
  .confirm-message {
    font-size: 14px;
  }
  
  .confirm-btn {
    padding: 12px 20px;
    font-size: 14px;
  }
}