/**
 * 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}
h1,h2,h3,h4,h5{font-family:'Poiret One',sans-serif;line-height:1.15}
button{cursor:pointer;border:none;font-family:'Inter',sans-serif}

/* ── 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-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 (movido arriba del footer) */
.cart-trust{border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px;margin-left:auto;max-width:500px}
.cart-trust-inner{display:flex;flex-direction:column;gap:20px}
.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:8px}
.trust-logos{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.trust-logo{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:5px}

/* Cart footer */
.cart-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:8px}
.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 */
@media(max-width:768px){
  .cart-grid{grid-template-columns:1fr;gap:0}
  .cpc-header{flex-direction:column}
  .cpc-price-col{text-align:left}
  .cpc-includes{grid-template-columns:1fr}
  .cart-trust{margin-left:0;max-width:100%;margin-bottom:16px}
  .cart-foot{flex-direction:column-reverse}
  .cart-back,.cart-continue{width:100%;justify-content:center}
  .domain-tab{font-size:.82rem;padding:12px 10px}
  .domain-tab .tab-icon{font-size:1rem}
  .domain-search-box{flex-direction:column}
  .btn-search-domain{width:100%;justify-content:center}
}