*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#0a0f1a;color:#e0e0e0;overflow-x:hidden}

/* ── HEADER ── */
.header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(10,15,26,0.85);backdrop-filter:blur(20px);border-bottom:1px solid rgba(46,204,113,0.1);padding:14px 32px;display:flex;align-items:center;justify-content:space-between;transition:all .3s}
.brand{display:flex;align-items:center;gap:12px}
.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#2ecc71,#27ae60);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2em;box-shadow:0 4px 20px rgba(46,204,113,0.3)}
.brand h1{font-size:1.15em;font-weight:700;letter-spacing:1.5px;background:linear-gradient(135deg,#fff,#a8e6cf);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.brand-sub{font-size:.6em;font-weight:300;color:rgba(255,255,255,0.4);letter-spacing:3px;text-transform:uppercase}
.nav-links{display:flex;gap:24px}
.nav-links a{color:rgba(255,255,255,0.5);text-decoration:none;font-size:.82em;font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover{color:#2ecc71}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:#2ecc71;transition:width .3s}
.nav-links a:hover::after{width:100%}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:100px 32px 60px;background:linear-gradient(135deg,rgba(10,15,26,0.65) 0%,rgba(13,27,42,0.65) 100%), url('hero.png') center/cover no-repeat}
.hero-content{position:relative;z-index:2;text-align:center;max-width:800px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:rgba(46,204,113,0.1);border:1px solid rgba(46,204,113,0.2);border-radius:30px;font-size:.75em;color:#2ecc71;font-weight:500;margin-bottom:28px;animation:fadeUp .8s ease}
.hero-badge .dot{width:6px;height:6px;background:#2ecc71;border-radius:50%;animation:pulse2 2s infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.4}}
.hero-title{font-size:clamp(2.2em,5vw,3.8em);font-weight:800;line-height:1.1;margin-bottom:20px;animation:fadeUp .8s ease .1s both}
.hero-title span{background:linear-gradient(135deg,#2ecc71,#a8e6cf);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-desc{font-size:clamp(.9em,1.8vw,1.15em);color:rgba(255,255,255,0.45);max-width:560px;margin:0 auto 36px;line-height:1.7;animation:fadeUp .8s ease .2s both}
.hero-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;border:none;border-radius:14px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit;text-decoration:none;animation:fadeUp .8s ease .3s both;box-shadow:0 8px 32px rgba(46,204,113,0.3)}
.hero-cta:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(46,204,113,0.45)}
.hero-stats{display:flex;justify-content:center;gap:48px;margin-top:56px;animation:fadeUp .8s ease .4s both}
.hero-stat-num{font-size:2em;font-weight:800;color:#fff}
.hero-stat-label{font-size:.72em;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:2px;margin-top:4px}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ── MAP SECTION ── */
.map-section{padding:40px 0 80px;position:relative}
.section-header{text-align:center;margin-bottom:32px}
.section-tag{font-size:.7em;text-transform:uppercase;letter-spacing:3px;color:#2ecc71;font-weight:600;margin-bottom:10px}
.section-title{font-size:clamp(1.6em,3vw,2.4em);font-weight:700;color:#fff}
.map-container{width:100%;max-width:none;margin:0;height:auto}
.map-main{position:relative;background:none;border-radius:0;border:none;overflow:visible;min-height:600px;width:100%}
.map-canvas-wrap{width:100%;height:auto;display:block;overflow:visible;padding:0;scroll-behavior:smooth;position:relative}
.map-canvas{width:100%;height:auto;display:flex;align-items:center;justify-content:center;margin:0 auto;padding:0}
#map-svg{width:100%;height:auto}
.map-canvas svg{width:100%;height:auto;display:block}
.map-zoom-ctrls{display:none}
.map-zoom-btn{width:38px;height:38px;background:rgba(13,20,34,0.9);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1);border-radius:10px;color:rgba(255,255,255,0.6);cursor:pointer;font-size:1.1em;display:flex;align-items:center;justify-content:center;transition:all .2s}
.map-zoom-btn:hover{background:rgba(46,204,113,0.15);color:#2ecc71;border-color:rgba(46,204,113,0.3)}
.map-zoom-label{text-align:center;font-size:.68em;color:rgba(255,255,255,0.35);font-variant-numeric:tabular-nums}
.loading-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:rgba(10,15,26,0.95);z-index:5;transition:opacity .5s,visibility .5s;border-radius:0}
.loading-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.spinner{width:36px;height:36px;border:3px solid rgba(46,204,113,0.12);border-top-color:#2ecc71;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Legend sidebar */
.map-legend{position:fixed;left:20px;top:140px;width:280px;max-height:calc(100vh - 160px);overflow-y:auto;display:flex;flex-direction:column;gap:16px;z-index:30}
.map-legend::-webkit-scrollbar{width:4px}
.map-legend::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:4px}
.legend-card{background:rgba(13,20,34,0.8);border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:18px;backdrop-filter:blur(15px);box-shadow:0 8px 32px rgba(0,0,0,0.3)}
.legend-title{font-size:.68em;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.3);margin-bottom:14px;font-weight:600}
.legend-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;margin-bottom:6px;cursor:pointer;transition:all .2s;border:1px solid transparent;font-size:.82em;color:rgba(255,255,255,0.6);font-weight:500}
.legend-item:hover,.legend-item.active{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.08)}
.legend-dot{width:12px;height:12px;border-radius:4px;flex-shrink:0}
.legend-title{font-size:.68em;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.3);margin-bottom:14px;font-weight:600}
.legend-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;margin-bottom:6px;cursor:pointer;transition:all .2s;border:1px solid transparent;font-size:.82em;color:rgba(255,255,255,0.6);font-weight:500}
.legend-item:hover,.legend-item.active{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.08)}
.legend-dot{width:12px;height:12px;border-radius:4px;flex-shrink:0}
.legend-count{margin-left:auto;font-size:.85em;font-weight:600;color:rgba(255,255,255,0.4)}

/* Stats Section */
.stats-section{padding:60px 32px;background:#0a0f1a;border-top:1px solid rgba(255,255,255,0.06)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;max-width:1200px;margin:0 auto}

.stat-card{display:flex;align-items:center;gap:12px;padding:20px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:12px;transition:all .3s}
.stat-card:hover{background:rgba(46,204,113,0.05);border-color:rgba(46,204,113,0.2)}
.stat-card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1em;flex-shrink:0}
.stat-card-info .val{font-size:1.4em;font-weight:800;color:#fff}
.stat-card-info .lbl{font-size:.7em;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.tooltip{display:none;position:fixed;background:rgba(13,20,34,0.95);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1);color:#fff;padding:8px 14px;border-radius:8px;font-size:.78em;font-weight:500;white-space:nowrap;z-index:60;pointer-events:none}
.tooltip.visible{display:block}

/* ── Floating Button & Legend Modal ── */
.legend-fab{position:fixed;bottom:32px;right:32px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#2ecc71,#27ae60);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2em;z-index:40;box-shadow:0 8px 24px rgba(46,204,113,0.35);transition:all .3s}
.legend-fab:hover{box-shadow:0 12px 32px rgba(46,204,113,0.45);transform:translateY(-2px) scale(1.05)}
.legend-fab:active{transform:translateY(0) scale(0.95)}
.legend-fab svg{width:24px;height:24px;stroke-width:2.5}

.legend-modal{display:none;position:fixed;inset:0;z-index:100;animation:legendSlideIn .3s ease}
.legend-modal.active{display:flex}
@keyframes legendSlideIn{from{opacity:0}to{opacity:1}}
.legend-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);z-index:100}
.legend-modal-content{position:fixed;right:0;top:0;height:100%;width:320px;background:linear-gradient(135deg,#0d1b2a 0%,#0a1624 100%);border-left:1px solid rgba(46,204,113,0.2);box-shadow:-8px 0 32px rgba(0,0,0,0.5);display:flex;flex-direction:column;z-index:101;animation:modalDrawerIn .3s ease}
@keyframes modalDrawerIn{from{transform:translateX(100%)}to{transform:translateX(0)}}

.legend-modal-header{padding:24px;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.legend-modal-header h3{font-size:1.1em;font-weight:700;color:#fff;margin:0}
.legend-modal-close{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);width:40px;height:40px;border-radius:10px;color:#fff;cursor:pointer;font-size:1.4em;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:inherit}
.legend-modal-close:hover{background:rgba(231,76,60,0.15);border-color:rgba(231,76,60,0.3);color:#e74c3c}

.legend-modal-body{padding:24px;overflow-y:auto;flex:1}
.legend-modal-body::-webkit-scrollbar{width:6px}
.legend-modal-body::-webkit-scrollbar-track{background:transparent}
.legend-modal-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px}
.legend-modal-body::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.15)}

.legend-card{background:rgba(255,255,255,0.03);border:1px solid rgba(46,204,113,0.2);border-radius:12px;padding:20px;backdrop-filter:blur(10px);transition:all .3s}
.legend-card:hover{background:rgba(46,204,113,0.05);border-color:rgba(46,204,113,0.3)}
.legend-title{font-size:.75em;text-transform:uppercase;letter-spacing:2.5px;color:#2ecc71;margin-bottom:16px;font-weight:700}
.legend-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:10px;margin-bottom:8px;cursor:pointer;transition:all .2s;border:1.5px solid transparent;font-size:.9em;color:rgba(255,255,255,0.5);font-weight:500;background:rgba(255,255,255,0.02)}
.legend-item:hover{background:rgba(46,204,113,0.1);border-color:rgba(46,204,113,0.3);color:#fff}
.legend-item.active{background:rgba(46,204,113,0.15);border-color:#2ecc71;color:#2ecc71;font-weight:600}
.legend-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,0.3)}

/* ── FULL-SCREEN CARD OVERLAY (Cotización) ── */
.card-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(10,15,26,0.97);backdrop-filter:blur(20px);overflow-y:auto}
.card-overlay.active{display:block}
.card-full{width:100%;min-height:100vh;display:grid;grid-template-columns:1fr 1fr;animation:cardSlideIn .5s cubic-bezier(.16,1,.3,1)}
@keyframes cardSlideIn{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

/* Left panel - Info */
.card-left{background:linear-gradient(rgba(5,10,18,0.88),rgba(5,10,18,0.88)), url('hero.png') center/cover no-repeat, linear-gradient(180deg,#0d1b2a 0%,#0a1628 100%);padding:48px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid rgba(255,255,255,0.06);position:relative;overflow:hidden}
.card-left::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(46,204,113,0.12) 0%,transparent 42%);pointer-events:none}
.card-left::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,12,20,0.25) 0%,rgba(7,12,20,0.7) 100%);pointer-events:none}
.card-left > *{position:relative;z-index:1}
.card-logo-area{display:flex;align-items:center;gap:14px;margin-bottom:40px}
.card-logo-icon{width:52px;height:52px;background:linear-gradient(135deg,#2ecc71,#27ae60);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4em;box-shadow:0 8px 32px rgba(46,204,113,0.3)}
.card-logo-text h2{font-size:1.2em;font-weight:700;letter-spacing:1px;color:#fff}
.card-logo-text span{font-size:.65em;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:2px}
.card-lot-name{font-size:2.2em;font-weight:800;color:#fff;margin-bottom:8px}
.card-lot-badge{display:inline-flex;padding:6px 16px;border-radius:20px;font-size:.72em;font-weight:600;text-transform:uppercase;margin-bottom:32px}
.card-lot-badge.disponible{background:rgba(46,204,113,0.15);color:#2ecc71;border:1px solid rgba(46,204,113,0.25)}
.card-lot-badge.reservado{background:rgba(241,196,15,0.15);color:#f1c40f;border:1px solid rgba(241,196,15,0.25)}
.card-lot-badge.vendido{background:rgba(231,76,60,0.15);color:#e74c3c;border:1px solid rgba(231,76,60,0.25)}
.card-lot-badge.no_disponible{background:rgba(149,165,166,0.15);color:#95a5a6;border:1px solid rgba(149,165,166,0.25)}
.badge-disponible{background:rgba(46,204,113,0.15);color:#2ecc71;border:1px solid rgba(46,204,113,0.25)}
.badge-reservado{background:rgba(241,196,15,0.15);color:#f1c40f;border:1px solid rgba(241,196,15,0.25)}
.badge-vendido{background:rgba(231,76,60,0.15);color:#e74c3c;border:1px solid rgba(231,76,60,0.25)}
.badge-no_disponible{background:rgba(149,165,166,0.15);color:#95a5a6;border:1px solid rgba(149,165,166,0.25)}
.card-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:32px}
.card-info-box{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:18px}
.card-info-box .lbl{font-size:.62em;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.3);margin-bottom:6px}
.card-info-box .val{font-size:1.3em;font-weight:700;color:#fff}
.card-info-box .val.green{color:#2ecc71}
.card-desc-text{font-size:.85em;color:rgba(255,255,255,0.4);line-height:1.7;margin-bottom:32px}
.card-client-section{margin-bottom:24px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:18px}
.card-client-label{display:block;font-size:.68em;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.35);margin-bottom:8px;font-weight:600}
.card-client-input{width:100%;height:44px;padding:0 14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;color:#fff;font:inherit;outline:none;transition:all .2s;font-size:.9em}
.card-client-input::placeholder{color:rgba(255,255,255,0.2)}
.card-client-input:focus{border-color:rgba(46,204,113,0.35);background:rgba(255,255,255,0.06)}
.card-size-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.card-size-box{display:flex;flex-direction:column}
.card-size-label{font-size:.68em;text-transform:uppercase;letter-spacing:1.3px;color:rgba(255,255,255,0.35);margin-bottom:8px;font-weight:600}
.card-size-input{width:100%;height:44px;padding:0 14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;color:#fff;font:inherit;outline:none;transition:all .2s;font-size:.9em}
.card-size-input::placeholder{color:rgba(255,255,255,0.2)}
.card-size-input:focus{border-color:rgba(46,204,113,0.35);background:rgba(255,255,255,0.06)}
.card-actions{display:flex;flex-direction:column;gap:12px}
.btn-view,.btn-download{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 32px;border:none;border-radius:14px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit}
.btn-view{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}
.btn-download{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}
.btn-view:hover{box-shadow:0 8px 28px rgba(102,126,234,0.35);transform:translateY(-2px)}
.btn-download:hover{box-shadow:0 8px 28px rgba(46,204,113,0.35);transform:translateY(-2px)}

/* Right panel - Cotización */
.card-right{padding:48px;display:flex;flex-direction:column;background:#0a0f1a;overflow-y:auto}
.cotiz-header{margin-bottom:32px}
.cotiz-title{font-size:1.6em;font-weight:800;color:#fff;margin-bottom:8px}
.cotiz-title span{background:linear-gradient(135deg,#2ecc71,#a8e6cf);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.cotiz-subtitle{font-size:.82em;color:rgba(255,255,255,0.4)}
.card-lock-banner{display:flex;align-items:center;gap:10px;padding:14px 16px;margin:0 0 20px;border-radius:14px;border:1px solid rgba(231,76,60,0.25);background:rgba(231,76,60,0.12);color:#ffd7d2;font-weight:600;font-size:.82em;letter-spacing:.2px}
.card-lock-icon{font-size:1.05em}

/* Controls */
.cotiz-controls{display:flex;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.cotiz-control{flex:1;min-width:180px}
.cotiz-control label{display:block;font-size:.68em;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.35);margin-bottom:8px;font-weight:600}
.cotiz-select{width:100%;height:44px;padding:0 14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;color:#fff;font:inherit;outline:none;cursor:pointer;transition:all .2s}
.cotiz-select:focus{border-color:rgba(46,204,113,0.35);background:rgba(255,255,255,0.06)}
.cotiz-select option{background:#111827;color:#fff}
.cotiz-slider{width:100%;-webkit-appearance:none;appearance:none;height:6px;background:rgba(255,255,255,0.08);border-radius:3px;outline:none}
.cotiz-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#2ecc71,#27ae60);border-radius:50%;cursor:pointer;box-shadow:0 2px 10px rgba(46,204,113,0.4)}
.cotiz-slider::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,#2ecc71,#27ae60);border-radius:50%;cursor:pointer;border:none}
.cotiz-slider-val{display:flex;justify-content:space-between;margin-top:6px;font-size:.75em;color:rgba(255,255,255,0.5)}
.cotiz-slider-val .current{color:#2ecc71;font-weight:700;font-size:.9em}
.payment-note{min-height:20px;margin:-8px 0 18px;font-size:.78em;color:rgba(255,255,255,0.45);line-height:1.5}
.is-hidden{display:none!important}
.card-overlay.locked .cotiz-control,
.card-overlay.locked .cotiz-summary,
.card-overlay.locked .amort-table,
.card-overlay.locked .btn-wa{pointer-events:none}
.card-overlay.locked .cotiz-select,
.card-overlay.locked .cotiz-slider{opacity:.55}
.card-overlay.locked .cotiz-box{opacity:.75}
.cash-mode .cotiz-control:not(:first-child),
.cash-mode #amort-card,
.cash-mode .card-info-grid,
.cash-mode .card-desc-text{display:none!important}
.cash-mode .card-right{justify-content:center}
.cash-mode .cotiz-header{margin-bottom:20px}
.cash-mode .payment-note{font-size:.86em;color:#2ecc71}

/* Summary boxes */
.cotiz-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:28px}
.cotiz-box{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:18px;text-align:center;transition:all .3s}
.cotiz-box:hover{border-color:rgba(46,204,113,0.2);background:rgba(46,204,113,0.04)}
.cotiz-box .icon{font-size:1.4em;margin-bottom:8px}
.cotiz-box .amount{font-size:1.2em;font-weight:700;color:#fff;margin-bottom:4px}
.cotiz-box .label{font-size:.62em;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.3)}
.cotiz-box.highlight{border-color:rgba(46,204,113,0.3);background:rgba(46,204,113,0.06)}
.cotiz-box.highlight .amount{color:#2ecc71}

/* Charts */
.cotiz-charts{display:none}
.chart-card{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:16px;padding:20px}
.chart-card h4{font-size:.72em;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.35);margin-bottom:14px;font-weight:600}
.chart-card canvas{width:100%!important;max-height:220px}

/* Amort table */
.amort-table{width:100%;border-collapse:collapse;font-size:.78em}
.amort-table th{text-align:left;padding:10px 12px;color:rgba(255,255,255,0.35);font-weight:600;text-transform:uppercase;letter-spacing:1px;font-size:.75em;border-bottom:1px solid rgba(255,255,255,0.06)}
.amort-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,0.04);color:rgba(255,255,255,0.6)}
.amort-table tr:hover td{background:rgba(46,204,113,0.03)}
.amort-scroll{max-height:240px;overflow-y:auto;border-radius:12px;border:1px solid rgba(255,255,255,0.06)}
.amort-scroll::-webkit-scrollbar{width:4px}
.amort-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:4px}

/* Close button */
.card-close-btn{position:fixed;top:24px;right:24px;width:48px;height:48px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:14px;color:#fff;cursor:pointer;font-size:1.3em;z-index:210;display:flex;align-items:center;justify-content:center;transition:all .3s;backdrop-filter:blur(10px)}
.card-close-btn:hover{background:rgba(231,76,60,0.2);border-color:rgba(231,76,60,0.3);transform:rotate(90deg)}

/* ── FOOTER ── */
.footer{padding:48px 32px 32px;border-top:1px solid rgba(255,255,255,0.06);text-align:center}
.footer p{font-size:.78em;color:rgba(255,255,255,0.25)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .legend-modal-content{width:300px}
  .card-full{grid-template-columns:1fr}
  .card-left{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06);padding:32px}
  .card-right{padding:32px}
}
@media(max-width:768px){
  .hero-stats{flex-direction:column;gap:20px}
  .cotiz-summary{grid-template-columns:1fr}
  .card-info-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .map-main{min-height:450px}
  .map-canvas svg{width:100%;height:auto}
  .legend-fab{bottom:24px;right:24px;width:50px;height:50px}
  .legend-modal-content{width:100%;border-left:none;border-top:1px solid rgba(46,204,113,0.2)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .legend-fab{bottom:16px;right:16px;width:48px;height:48px}
  .stats-grid{grid-template-columns:1fr}
  .legend-modal-header{padding:16px}
  .legend-modal-body{padding:16px}
}
