/* ============================================================
   AREA VENDITA
   ============================================================ */
/* nav badge */
.nav-sale{display:inline-flex;align-items:center;gap:8px}
.badge-new{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:var(--orange);padding:3px 7px;border-radius:999px;position:relative}
.badge-new::after{content:"";position:absolute;inset:0;border-radius:999px;border:1px solid var(--orange);
  animation:badgePulse 2s var(--ease) infinite}
@keyframes badgePulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.5);opacity:0}}

.sale{background:var(--ink);position:relative;overflow:hidden}
.sale .head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.sale-filters{margin-top:30px}
.sale-filters-tipo{margin-top:12px}
.sale-filters-tipo button{font-size:11px;padding:7px 16px}
.sale-note{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--fog-dim);margin-top:22px}

.sale-grid{margin-top:34px;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,26px)}
.sale-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,.03),0 18px 36px -26px rgba(0,0,0,.8);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .35s;will-change:transform}
.sale-card:hover{transform:translate3d(0,-6px,0);border-color:var(--line-strong);box-shadow:0 30px 54px -28px rgba(0,0,0,.9)}
.sale-card .plan{position:relative;aspect-ratio:16/11;background:radial-gradient(130% 130% at 30% 10%,#20262C,#15181C);display:grid;place-items:center;padding:20px;border-bottom:1px solid var(--line);overflow:hidden}
.sale-card .plan svg{width:100%;height:100%;overflow:visible}
.sale-card .plan img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.sale-card .plan .grid-fade{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:26px 26px;opacity:.5;pointer-events:none}
.status{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:6px 11px;border-radius:999px;display:inline-flex;align-items:center;gap:7px}
.status::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.status.ready{background:var(--orange);color:#fff}
.status.ready::before{background:#fff}
.status.building{background:rgba(255,196,0,.16);color:var(--yellow);border:1px solid rgba(255,196,0,.4)}
.status.design{background:rgba(154,161,168,.12);color:var(--fog);border:1px solid var(--line-strong)}
.status.upcoming{background:rgba(99,102,241,.12);color:#818cf8;border:1px solid rgba(99,102,241,.3)}
.sale-card .code{position:absolute;top:14px;right:14px;z-index:2;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--fog-dim)}
.sale-card .info{padding:22px}
.sale-card .loc{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);display:flex;align-items:center;gap:7px}
.sale-card .info h3{font-family:var(--font-display);text-transform:uppercase;font-size:23px;line-height:1.04;letter-spacing:.01em;margin:10px 0 10px}
.sale-card .desc{font-size:13.5px;color:var(--fog);line-height:1.5;margin:0}
.sale-card .meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.sale-card .meta div{display:flex;flex-direction:column;gap:3px}
.sale-card .meta .k{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fog-dim)}
.sale-card .meta .v{font-size:15px;color:var(--white);font-weight:600}
.sale-card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px}
.sale-card .price{font-family:var(--font-display);font-size:26px;color:var(--orange);line-height:1}
.sale-card .price small{font-family:var(--font-mono);font-size:10px;color:var(--fog-dim);letter-spacing:.1em;display:block;text-transform:uppercase;margin-bottom:2px}
.sale-card .open{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--white);display:inline-flex;gap:7px;align-items:center}
.sale-card:hover .open{color:var(--orange)}
.sale-card.hidden{display:none}

/* skeleton loading */
.sale-skeleton{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;height:360px}
.sale-skeleton::after{content:'';display:block;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);animation:shimmer 1.6s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* fade-in from top */
.reveal-top{opacity:0;transform:translate3d(0,-30px,0);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out);will-change:transform,opacity}
.reveal-top.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal-top{opacity:1;transform:none}}

/* slide-over */
.sov-overlay{position:fixed;inset:0;z-index:130;background:rgba(8,9,10,.62);backdrop-filter:blur(5px);
  opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s}
.sov-overlay.open{opacity:1;visibility:visible}
.sov{position:fixed;top:0;right:0;height:100svh;width:min(580px,96vw);z-index:140;
  background:var(--anthracite);border-left:1px solid var(--line-strong);
  transform:translate3d(100%,0,0);transition:transform .55s var(--ease);
  display:flex;flex-direction:column;box-shadow:-30px 0 60px -30px rgba(0,0,0,.8)}
.sov.open{transform:translate3d(0,0,0)}
.sov-close{position:absolute;top:18px;right:18px;z-index:3;width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid var(--line-strong);color:#fff;display:grid;place-items:center;transition:.25s}
.sov-close:hover{background:var(--orange);border-color:var(--orange);transform:rotate(90deg)}
.sov-scroll{overflow-y:auto;height:100%;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--orange) transparent}
.sov-scroll::-webkit-scrollbar{width:9px}
.sov-scroll::-webkit-scrollbar-thumb{background:var(--concrete);border-radius:9px;border:2px solid var(--anthracite)}
.sov-scroll::-webkit-scrollbar-thumb:hover{background:var(--orange)}

/* plan viewer + tabs */
.sov-planwrap{position:relative;border-bottom:1px solid var(--line)}
.plan-tabs{display:flex;gap:0;background:var(--ink);border-bottom:1px solid var(--line);align-items:center}
.ptab{flex:0 0 auto;background:none;border:none;color:var(--fog);font-family:var(--font-mono);font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;padding:14px 18px;position:relative;transition:color .25s}
.ptab::after{content:"";position:absolute;left:18px;right:18px;bottom:0;height:2px;background:var(--orange);transform:scaleX(0);transition:transform .3s var(--ease)}
.ptab:hover{color:var(--white)}
.ptab.active{color:var(--white)}
.ptab.active::after{transform:scaleX(1)}
.plan-fs{margin-left:auto;display:inline-flex;align-items:center;gap:7px;background:none;border:none;
  color:var(--orange);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:14px 18px;transition:color .25s}
.plan-fs:hover{color:var(--white)}
.sov-plan{position:relative;background:radial-gradient(130% 130% at 30% 10%,#2E353C,#1B1F24);
  padding:30px clamp(24px,4vw,40px) 38px;overflow:hidden;cursor:zoom-in}
.sov-plan .grid-fade{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:30px 30px;pointer-events:none}
.plan-label{position:absolute;top:12px;left:clamp(24px,4vw,40px);z-index:2;font-family:var(--font-mono);font-size:9.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);background:rgba(14,15,17,.5);padding:5px 10px;border-radius:999px;pointer-events:none}
.plan-stage{position:relative;z-index:1;transition:transform .25s var(--ease);will-change:transform}
.plan-stage svg{width:100%;height:auto;max-height:300px;overflow:visible}
.plan-hint{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);z-index:2;font-family:var(--font-mono);
  font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fog-dim);background:rgba(14,15,17,.5);padding:5px 10px;border-radius:999px;pointer-events:none}

/* head */
.sov-head{padding:clamp(22px,4vw,30px) clamp(24px,4vw,40px) 0}
.sov-head .loc{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);display:flex;gap:8px;align-items:center}
.sov-head h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(26px,3.6vw,38px);line-height:1.0;margin:12px 0 0;text-wrap:balance}

/* 4 pillars */
.pillars-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  margin:clamp(20px,3vw,26px) clamp(24px,4vw,40px) 0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.pillar-i{background:var(--surface);display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 8px;text-align:center}
.pillar-i svg{width:24px;height:24px;color:var(--orange)}
.pillar-i b{font-size:15px;font-weight:700;letter-spacing:.01em;line-height:1.1}
.pillar-i span{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--fog-dim)}

/* price + status box */
.price-box{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin:clamp(18px,2.5vw,22px) clamp(24px,4vw,40px) 0;padding:20px 22px;
  background:var(--surface-2);border:1px solid var(--line-strong);border-radius:12px}
.price-box .pb-k{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fog-dim);margin-bottom:4px}
.price-box .pb-v{font-family:var(--font-display);font-size:34px;color:var(--orange);line-height:1}
.status.big{padding:9px 15px;font-size:11px}

/* sections */
.sov-section{padding:clamp(20px,3vw,28px) clamp(24px,4vw,40px)}
.sov-section h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fog-dim);margin:0 0 14px}
.sov-desc p{color:var(--fog);font-size:15px;line-height:1.7;margin:0 0 14px}
.sov-desc p b{color:var(--white);font-weight:700}
.sov-desc .feats{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.sov-desc .feats span{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--white);background:var(--surface-2);border:1px solid var(--line);padding:6px 11px;border-radius:999px}

/* accordion */
.acc-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;padding:15px 18px;color:var(--white);
  font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;transition:border-color .25s}
.acc-head:hover{border-color:var(--line-strong)}
.acc-ic{transition:transform .35s var(--ease);color:var(--orange)}
.acc-head.closed .acc-ic{transform:rotate(-90deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.acc-body.open{max-height:640px}
.acc-body .spec-table{margin-top:6px}
.spec-table{width:100%;border-collapse:collapse}
.spec-table tr{border-top:1px solid var(--line)}
.spec-table tr:last-child{border-bottom:1px solid var(--line)}
.spec-table td{padding:12px 2px;font-size:14px;vertical-align:middle}
.spec-table td:first-child{color:var(--fog);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase}
.spec-table td:last-child{text-align:right;color:var(--white);font-weight:600}

/* sticky CTA mini-form */
.sov-cta{position:sticky;bottom:0;z-index:5;background:var(--ink);border-top:1px solid var(--line-strong);
  box-shadow:0 -18px 30px -20px rgba(0,0,0,.9)}
.cta-inner{padding:18px clamp(24px,4vw,40px) 20px}
.cta-copy b{display:block;font-size:15px;font-weight:700}
.cta-copy span{display:block;font-size:12.5px;color:var(--fog);margin-top:3px;line-height:1.45}
.cta-form{margin-top:14px}
.cta-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.cta-fields input{width:100%;background:var(--anthracite);border:1px solid var(--line-strong);border-radius:6px;
  color:var(--white);font-family:var(--font-sans);font-size:13.5px;padding:11px 12px;outline:none;transition:border-color .2s}
.cta-fields input:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.cta-form .btn{width:100%;justify-content:center}
.trust{display:flex;align-items:center;gap:8px;margin-top:12px;font-family:var(--font-mono);font-size:9.5px;
  letter-spacing:.06em;text-transform:uppercase;color:var(--fog);line-height:1.4}
.trust svg{color:var(--orange);flex:none}
.cta-ok{display:none;align-items:center;gap:9px;margin-top:12px;color:var(--orange);font-size:13.5px;font-weight:600}
.cta-ok.show{display:flex}

/* fullscreen plan overlay */
.plan-fs-overlay{position:fixed;inset:0;z-index:160;background:rgba(8,9,10,.95);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;overflow:hidden}
.plan-fs-overlay.open{display:flex}
.pfs-stage{width:min(86vw,1000px);transition:none;will-change:transform;touch-action:none}
.pfs-stage svg{width:100%;height:auto;max-height:82vh;overflow:visible;filter:drop-shadow(0 20px 50px rgba(0,0,0,.6))}
.pfs-close{position:fixed;top:22px;right:22px;width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.06);
  border:1px solid var(--line-strong);color:#fff;display:grid;place-items:center;transition:.25s;z-index:2}
.pfs-close:hover{background:var(--orange);border-color:var(--orange);transform:rotate(90deg)}
.pfs-zoom{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.pfs-zoom button{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--line-strong);
  color:#fff;font-size:20px;display:grid;place-items:center;transition:.2s}
.pfs-zoom button:hover{background:var(--orange);border-color:var(--orange)}
.pfs-cap{position:fixed;top:26px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--fog);text-align:center;max-width:80vw;z-index:2}

@media(max-width:900px){.sale-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){
  .sale-grid{grid-template-columns:1fr}
  .pillars-row{grid-template-columns:repeat(2,1fr)}
  .cta-fields{grid-template-columns:1fr}
}

/* ============================================================ */
