/* ════════════════════════════════════════════════════════════
   NOVERA — Canal Compradors (subpàgina)
   Hereta tokens de novera.css. Estètica producte digital.
   ════════════════════════════════════════════════════════════ */

/* hero compacte de marca */
.cc-hero{
  min-height:auto; padding-top:clamp(150px,18vh,210px); padding-bottom:clamp(70px,9vw,120px);
  display:block;
}
.cc-hero .wrap{ max-width:880px; text-align:center; }
.cc-hero .hero-chip{ margin-inline:auto; }
.cc-hero h1{ max-width:none; margin-inline:auto; }
.cc-hero .display{ font-size:clamp(2.7rem,7vw,5.4rem); }
.cc-hero .hero-sub{ max-width:52ch; margin:clamp(22px,3vw,30px) auto 0; }
.cc-hero .cc-secondary{
  margin:18px auto 0; max-width:48ch;
  color:rgba(255,255,255,.55); font-size:0.96rem; line-height:1.6;
}
.cc-hero .hero-actions{ justify-content:center; margin-top:clamp(32px,4vw,44px); }

/* ── COM FUNCIONA ────────────────────────────────────────────── */
.cc-how{ background:var(--paper); }
.cc-how .wrap{ max-width:980px; }
.cc-how .grid{
  display:grid; grid-template-columns:minmax(0,0.8fr) minmax(0,1fr);
  gap:clamp(36px,6vw,90px); align-items:center;
}
.cc-how h2{ font-size:clamp(2rem,4vw,3rem); }
.cc-how .lead{ margin-top:1.3rem; }
.cc-how .keyphrase{
  font-size:clamp(1.5rem,2.8vw,2.3rem); font-weight:600; letter-spacing:-0.03em; line-height:1.2;
  text-wrap:balance;
}
.cc-how .keyphrase .grad-text{ display:inline; }
.cc-how .keyphrase .sub{ display:block; margin-top:14px; font-size:0.95rem; font-weight:400;
  letter-spacing:0; color:var(--ink-3); line-height:1.6; max-width:30ch; }

/* ── TOOL (onboarding) ───────────────────────────────────────── */
.cc-tool{ background:var(--paper-2); }
.cc-tool .wrap{ max-width:1180px; }
.cc-tool-head{ text-align:center; max-width:600px; margin:0 auto clamp(34px,4vw,48px); }
.cc-tool-head .kicker{ color:var(--amber); justify-content:center; }
.cc-tool-head h2{ font-size:clamp(1.9rem,3.6vw,2.8rem); margin-top:1rem; }
.cc-tool-head p{ color:var(--ink-2); margin-top:0.9rem; font-size:1.05rem; }

.tool{
  max-width:720px; margin:0 auto; position:relative;
  background:var(--paper); border:1px solid var(--line); border-radius:26px;
  box-shadow:0 44px 100px -50px rgba(10,37,64,.5);
  padding:clamp(28px,4vw,52px); overflow:hidden;
}
.tool-top{ display:flex; align-items:center; justify-content:space-between; gap:18px; margin-bottom:30px; }
.tool-steplabel{ font-size:12px; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-3); }
.tool-progress{ display:flex; gap:6px; flex:1; max-width:280px; }
.tool-progress .seg{ flex:1; height:3px; border-radius:3px; background:var(--line); overflow:hidden; }
.tool-progress .seg i{ display:block; height:100%; width:0;
  background:linear-gradient(90deg, var(--amber), var(--green)); border-radius:3px; transition:width .6s var(--ease); }
.tool-progress .seg.done i{ width:100%; }

.tool-step{ display:none; }
.tool-step.active{ display:block; animation:stepIn .5s var(--ease) both; }
.tool-step h3{ font-size:clamp(1.5rem,2.6vw,2rem); font-weight:600; letter-spacing:-0.025em; line-height:1.14; margin-bottom:6px; }
.tool-step .tsub{ color:var(--ink-2); font-size:0.98rem; margin-bottom:26px; }

/* fields */
.tf-label{ display:flex; align-items:center; gap:8px; font-size:12px; font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:11px; }
.tf-input{
  width:100%; font-family:inherit; font-size:1.08rem; color:var(--ink);
  background:var(--paper); border:1.5px solid var(--line); border-radius:14px;
  padding:16px 18px; outline:none; transition:border-color .3s, box-shadow .3s, background .3s;
}
.tf-input::placeholder{ color:var(--ink-3); }
.tf-input:focus{ border-color:var(--blue-br); box-shadow:0 0 0 4px rgba(43,124,196,.14); }
.tf-grid{ display:grid; gap:14px; }

/* suggestion chips (zona) */
.tf-suggest{ display:flex; flex-wrap:wrap; gap:9px; margin-top:14px; }
.tf-suggest .sg{
  font-family:inherit; font-size:0.86rem; font-weight:500; color:var(--ink-2); cursor:pointer;
  background:var(--paper-2); border:1px solid var(--line); border-radius:100px;
  padding:8px 15px; transition:all .25s var(--ease); display:inline-flex; align-items:center; gap:7px;
}
.tf-suggest .sg:hover{ border-color:var(--blue-br); color:var(--navy); }
.tf-suggest .sg::before{ content:'+'; font-size:1rem; line-height:1; color:var(--blue-br); font-weight:600; }
.tf-tags{ display:flex; flex-wrap:wrap; gap:9px; margin-top:14px; }
.tf-tags:empty{ display:none; }
.tf-tag{
  font-size:0.88rem; font-weight:500; color:#fff; background:var(--navy);
  border-radius:100px; padding:8px 12px 8px 15px; display:inline-flex; align-items:center; gap:9px;
  animation:stepIn .3s var(--ease) both;
}
.tf-tag button{ background:rgba(255,255,255,.18); border:none; color:#fff; cursor:pointer;
  width:18px; height:18px; border-radius:50%; font-size:0.8rem; line-height:1; display:grid; place-items:center; transition:background .2s; }
.tf-tag button:hover{ background:rgba(255,255,255,.4); }

/* budget slider */
.budget{ margin-top:6px; }
.budget-vals{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:22px; }
.budget-vals .bv{ }
.budget-vals .bv .l{ font-size:12px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:5px; }
.budget-vals .bv .v{ font-size:1.5rem; font-weight:600; letter-spacing:-0.03em; color:var(--navy); font-variant-numeric:tabular-nums; }
.budget-vals .bv.hi{ text-align:right; }
.range-wrap{ position:relative; height:34px; }
.range-track{ position:absolute; top:50%; left:0; right:0; height:5px; transform:translateY(-50%);
  background:var(--line); border-radius:5px; }
.range-fill{ position:absolute; top:50%; height:5px; transform:translateY(-50%);
  background:linear-gradient(90deg, var(--blue-br), var(--green)); border-radius:5px; }
.range-wrap input[type=range]{
  position:absolute; top:0; left:0; width:100%; height:34px; margin:0; background:none; pointer-events:none;
  -webkit-appearance:none; appearance:none;
}
.range-wrap input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none; pointer-events:auto; cursor:grab;
  width:24px; height:24px; border-radius:50%; background:#fff; border:1.5px solid var(--line);
  box-shadow:0 4px 12px -2px rgba(10,37,64,.4); transition:transform .15s, box-shadow .2s;
}
.range-wrap input[type=range]::-webkit-slider-thumb:active{ cursor:grabbing; transform:scale(1.12); box-shadow:0 6px 18px -3px rgba(43,124,196,.5); }
.range-wrap input[type=range]::-moz-range-thumb{
  pointer-events:auto; cursor:grab; width:24px; height:24px; border-radius:50%; background:#fff;
  border:1.5px solid var(--line); box-shadow:0 4px 12px -2px rgba(10,37,64,.4);
}
.budget-foot{ margin-top:18px; font-size:0.84rem; color:var(--ink-3); display:flex; justify-content:space-between; }

/* multi-select cards */
.ms-grid{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.ms-card{
  display:flex; align-items:center; gap:14px; text-align:left; width:100%; font-family:inherit;
  font-size:1.0rem; font-weight:500; color:var(--ink); cursor:pointer;
  background:var(--paper); border:1.5px solid var(--line); border-radius:15px; padding:17px 18px;
  transition:border-color .25s, background .25s, transform .25s, box-shadow .25s;
}
.ms-card:hover{ border-color:var(--blue-br); transform:translateY(-2px); }
.ms-card .box{ width:22px; height:22px; flex:none; border-radius:7px; border:1.5px solid var(--line);
  position:relative; transition:border-color .25s, background .25s; }
.ms-card .box::after{ content:''; position:absolute; left:7px; top:3px; width:5px; height:10px;
  border-right:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(45deg) scale(0);
  transition:transform .25s var(--ease); }
.ms-card.sel{ border-color:var(--navy); background:linear-gradient(160deg, rgba(43,124,196,.07), rgba(46,140,99,.05)); }
.ms-card.sel .box{ background:var(--navy); border-color:var(--navy); }
.ms-card.sel .box::after{ transform:rotate(45deg) scale(1); }

/* priority chips */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  font-family:inherit; font-size:0.96rem; font-weight:500; color:var(--ink-2); cursor:pointer;
  background:var(--paper); border:1.5px solid var(--line); border-radius:100px; padding:12px 19px;
  display:inline-flex; align-items:center; gap:9px; transition:all .25s var(--ease);
}
.chip:hover{ border-color:var(--blue-br); color:var(--navy); transform:translateY(-1px); }
.chip .ck{ width:16px; height:16px; border-radius:50%; border:1.5px solid var(--line); position:relative; transition:.25s; }
.chip .ck::after{ content:''; position:absolute; inset:0; margin:auto; width:5px; height:5px; border-radius:50%; background:#fff; transform:scale(0); transition:transform .25s var(--ease); }
.chip.sel{ background:var(--navy); border-color:var(--navy); color:#fff; }
.chip.sel .ck{ background:var(--gold-2); border-color:var(--gold-2); }
.chip.sel .ck::after{ transform:scale(1); background:var(--navy); }
.chip.disabled{ opacity:.4; pointer-events:none; }
.chips-count{ margin-top:16px; font-size:0.84rem; color:var(--ink-3); }
.chips-count b{ color:var(--navy); font-weight:600; }

/* single-select (hipoteca) */
.ss-list{ display:grid; gap:10px; }
.ss-opt{
  display:flex; align-items:center; gap:14px; text-align:left; width:100%; font-family:inherit;
  font-size:1.02rem; font-weight:500; color:var(--ink); cursor:pointer;
  background:var(--paper); border:1.5px solid var(--line); border-radius:15px; padding:16px 18px;
  transition:border-color .25s, background .25s, transform .25s;
}
.ss-opt:hover{ border-color:var(--blue-br); transform:translateY(-1px); }
.ss-opt .rd{ width:22px; height:22px; flex:none; border-radius:50%; border:1.5px solid var(--line); position:relative; transition:.25s; }
.ss-opt .rd::after{ content:''; position:absolute; inset:0; margin:auto; width:8px; height:8px; border-radius:50%; background:#fff; transform:scale(0); transition:transform .25s var(--ease); }
.ss-opt.sel{ border-color:var(--navy); background:linear-gradient(160deg, rgba(43,124,196,.07), rgba(46,140,99,.05)); }
.ss-opt.sel .rd{ background:var(--navy); border-color:var(--navy); }
.ss-opt.sel .rd::after{ transform:scale(1); }

/* nav row */
.tool-nav{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:30px; }
.tool-back{ font-size:0.9rem; font-weight:500; color:var(--ink-3); cursor:pointer; background:none; border:none;
  font-family:inherit; padding:8px 0; display:inline-flex; align-items:center; gap:8px; transition:color .3s; }
.tool-back:hover{ color:var(--navy); }
.tool-back[hidden]{ display:none; }
.tool-next{
  display:inline-flex; align-items:center; gap:10px; margin-left:auto;
  background:linear-gradient(100deg, var(--green), var(--green-d)); color:#fff; font-family:inherit;
  font-size:0.98rem; font-weight:600; padding:14px 28px; border-radius:100px; border:none; cursor:pointer;
  box-shadow:0 14px 32px -14px rgba(34,111,78,.55); transition:transform .35s var(--ease), filter .35s, opacity .3s;
}
.tool-next:hover{ transform:translateY(-2px); filter:brightness(1.06); }
.tool-next:disabled{ opacity:.4; cursor:not-allowed; transform:none; filter:none; box-shadow:none; }
.tool-next svg{ width:15px; height:15px; }
.tool-fine{ margin-top:18px; font-size:0.78rem; color:var(--ink-3); text-align:center; line-height:1.5; }

/* success */
.tool-done{ display:none; text-align:center; animation:stepIn .6s var(--ease) both; }
.tool-done.active{ display:block; }
.done-mark{ width:74px; height:74px; margin:0 auto 26px; border-radius:50%;
  background:linear-gradient(150deg, var(--green), var(--green-d)); display:grid; place-items:center;
  box-shadow:0 18px 40px -16px rgba(34,111,78,.6); animation:pop .6s var(--ease) both; }
@keyframes pop{ 0%{ transform:scale(.4); opacity:0; } 60%{ transform:scale(1.08); } 100%{ transform:scale(1); opacity:1; } }
.done-mark svg{ width:34px; height:34px; stroke:#fff; }
.tool-done h3{ font-size:clamp(1.6rem,3vw,2.2rem); font-weight:600; letter-spacing:-0.03em; margin-bottom:14px; }
.tool-done p{ color:var(--ink-2); font-size:1.05rem; line-height:1.6; max-width:38ch; margin:0 auto; }
.done-profile{ display:flex; flex-wrap:wrap; justify-content:center; gap:9px; margin:26px auto 0; max-width:540px; }
.done-profile span{ font-size:0.82rem; color:var(--ink-2); background:var(--paper-2);
  border:1px solid var(--line); padding:8px 14px; border-radius:100px; }
.done-profile span b{ color:var(--navy); font-weight:600; }
.done-actions{ margin-top:30px; display:flex; gap:18px; justify-content:center; align-items:center; flex-wrap:wrap; }
.done-restart{ background:none; border:none; font-family:inherit; cursor:pointer; font-size:0.9rem;
  font-weight:500; color:var(--ink-3); transition:color .3s; }
.done-restart:hover{ color:var(--navy); }

@media (max-width:860px){
  .cc-how .grid{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:600px){
  .ms-grid{ grid-template-columns:1fr; }
  .tool{ padding:26px 20px; }
  .tool-top{ flex-direction:column; align-items:flex-start; gap:12px; }
  .tool-progress{ max-width:none; width:100%; }
  .budget-vals .bv .v{ font-size:1.25rem; }
}
