/* ══════════════════════════════════════════
   TOKENS — LagunLab Brand System
══════════════════════════════════════════ */
:root {
  --cream:   #F8F5EE;
  --graphite:#2A2A27;
  --green:   #3ECF6A;
  --gray:    #9B9B96;
  --neutral: #EDEAE2;
  --border:  #D9D6CE;
  --white:   #FFFFFF;
  --dark:    #1A1A17;
  --muted:   #6B6B67;
  --g10: rgba(62,207,106,.10);
  --g20: rgba(62,207,106,.20);
  --g25: rgba(62,207,106,.25);
  --fd: 'Satoshi','Inter',sans-serif;
  --fb: 'Inter',sans-serif;
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 20px;
  --sh: 0 8px 40px rgba(42,42,39,.10);
  --tr: 180ms cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;background:var(--cream);color:var(--graphite)}
body{font-family:var(--fb);-webkit-font-smoothing:antialiased;min-height:100vh}
::selection{background:var(--green);color:#fff}

/* Grid background */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(62,207,106,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(62,207,106,.035) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 100% 60% at 50% 0,black 0%,transparent 80%);
}
.rel{position:relative;z-index:1}

/* ══ TYPOGRAPHY ══ */
h1,h2,h3,h4{font-family:var(--fd)}
.fd{font-family:var(--fd)}

/* ══ LAYOUT ══ */
.wrap{max-width:1120px;margin:0 auto;padding:0 40px}
.wrap-sm{max-width:800px;margin:0 auto;padding:0 40px}
@media(max-width:680px){.wrap,.wrap-sm{padding:0 20px}}

/* ══ PAGES ══ */
.page{display:none}.page.active{display:block}

/* ══ HEADER ══ */
.hd{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:60px;
  background:rgba(248,245,238,.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.hd-i{
  max-width:1120px;margin:0 auto;padding:0 40px;
  height:60px;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
@media(max-width:680px){.hd-i{padding:0 20px}}

/* Logo: SalariosYA */
.logo{display:flex;align-items:baseline;gap:0;cursor:pointer;text-decoration:none;user-select:none}
.logo-word{font-family:var(--fd);font-size:19px;font-weight:700;letter-spacing:-.03em;color:var(--graphite)}
.logo-ya{color:var(--green)}
.logo-sub{font-size:10px;font-weight:500;color:var(--gray);letter-spacing:.05em;margin-left:8px;margin-bottom:1px;border-left:1px solid var(--border);padding-left:8px;align-self:center}

.nav{display:flex;align-items:center;gap:2px}
@media(max-width:720px){.nav{display:none}}
.nav-btn{
  font-family:var(--fb);font-size:13px;font-weight:500;
  padding:6px 12px;border-radius:var(--r-sm);
  color:var(--muted);border:none;background:transparent;cursor:pointer;
  transition:color var(--tr),background var(--tr);
}
.nav-btn:hover{color:var(--graphite);background:var(--neutral)}
.nav-btn.cur{color:var(--green);font-weight:600}

.hd-act{display:flex;align-items:center;gap:10px}
.btn-primary{
  background:var(--green);color:#fff;
  font-family:var(--fb);font-size:13px;font-weight:600;
  padding:9px 18px;border-radius:var(--r-sm);border:none;cursor:pointer;
  transition:opacity var(--tr),transform .1s;
}
.btn-primary:hover{opacity:.88;transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}

.btn-outline{
  background:transparent;color:var(--graphite);
  font-family:var(--fb);font-size:13px;font-weight:500;
  padding:9px 18px;border-radius:var(--r-sm);
  border:1.5px solid var(--graphite);cursor:pointer;
  transition:background var(--tr);
}
.btn-outline:hover{background:var(--neutral)}

.btn-ghost{
  background:transparent;color:var(--green);
  font-family:var(--fb);font-size:13px;font-weight:600;
  padding:9px 18px;border-radius:var(--r-sm);
  border:1.5px solid var(--green);cursor:pointer;
  transition:background var(--tr);
}
.btn-ghost:hover{background:var(--g10)}

/* Hamburger */
.hbg{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:4px;padding:6px}
.hbg span{display:block;width:20px;height:2px;background:var(--graphite);border-radius:2px;transition:transform .2s,opacity .2s}
@media(max-width:720px){.hbg{display:flex}}
.mob-nav{
  display:none;position:fixed;top:60px;left:0;right:0;
  background:rgba(248,245,238,.98);border-bottom:1px solid var(--border);
  padding:12px 20px 16px;z-index:199;flex-direction:column;gap:4px;
  backdrop-filter:blur(16px);
}
.mob-nav.open{display:flex}
.mob-nav .nav-btn{text-align:left;padding:10px 12px;width:100%;border-radius:var(--r-sm)}

/* ══ HERO ══ */
.hero{padding:116px 0 72px;position:relative;overflow:hidden}
.hero-glow{
  position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:800px;height:360px;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(62,207,106,.09) 0%,transparent 70%);
}
.badge{
  display:inline-flex;align-items:center;gap:7px;
  border:1px solid var(--g20);background:var(--g10);
  padding:4px 12px 4px 6px;border-radius:100px;
  font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--green);margin-bottom:24px;
}
.badge-dot{
  width:18px;height:18px;border-radius:50%;
  background:var(--green);display:flex;align-items:center;justify-content:center;
  font-size:9px;color:#fff;animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

.hero-h1{
  font-family:var(--fd);font-size:clamp(28px,4.5vw,56px);
  font-weight:700;letter-spacing:-.035em;line-height:1.08;
  color:var(--graphite);margin-bottom:20px;max-width:620px;
}
.hero-h1 .em{color:var(--green)}
.hero-sub{
  font-size:16px;color:var(--muted);line-height:1.72;
  max-width:480px;margin-bottom:32px;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px}

.hero-trust{display:flex;gap:20px;flex-wrap:wrap}
.trust-item{
  display:flex;align-items:center;gap:6px;
  font-size:12px;color:var(--gray);
}
.trust-item svg{flex-shrink:0}

/* Hero layout */
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr}}

/* ══ CARD ══ */
.card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);
  box-shadow:var(--sh);overflow:hidden;
}
.card-hd{
  background:var(--cream);border-bottom:1px solid var(--border);
  padding:14px 20px;display:flex;align-items:center;justify-content:space-between;
}
.card-hd-title{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--graphite)}
.card-body{padding:20px}

/* ══ PILL TOGGLE (Simple | Avanzado) ══ */
.pill-toggle{
  display:inline-flex;
  background:var(--neutral);border:1.5px solid var(--border);
  border-radius:100px;padding:3px;gap:2px;margin-bottom:18px;
}
.pill-btn{
  font-family:var(--fd);font-size:12px;font-weight:700;
  padding:7px 18px;border-radius:100px;border:none;cursor:pointer;
  background:transparent;color:var(--gray);
  transition:all var(--tr);
}
.pill-btn.on{
  background:var(--white);color:var(--graphite);
  box-shadow:0 1px 6px rgba(42,42,39,.12);
}

/* ══ FORM ELEMENTS ══ */
.fg{margin-bottom:13px}
.fl{
  display:block;font-family:var(--fd);font-size:11px;font-weight:600;
  color:var(--gray);letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px;
}
.fi,.fs{
  width:100%;padding:9px 13px;
  font-family:var(--fb);font-size:14px;
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--r-sm);color:var(--graphite);
  outline:none;transition:border-color var(--tr);
  -webkit-appearance:none;appearance:none;
}
.fi:focus,.fs:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--g10)}
.fi.has-prefix{padding-left:26px}
.fi-wrap{position:relative;display:flex;align-items:center}
.fi-prefix{position:absolute;left:12px;font-family:var(--fd);font-weight:700;font-size:13px;color:var(--gray);pointer-events:none}
.fi-suffix{position:absolute;right:12px;font-size:13px;color:var(--gray);pointer-events:none}
.fs{
  cursor:pointer;padding-right:32px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239B9B96'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.fr2{grid-template-columns:1fr}}

/* Mode tabs within form (B→N / N→B) */
.mode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:3px;background:var(--neutral);border-radius:var(--r-sm);padding:3px;border:1.5px solid var(--border);margin-bottom:14px}
.mode-tab{font-family:var(--fd);font-size:12px;font-weight:700;padding:8px;border-radius:6px;border:none;cursor:pointer;background:transparent;color:var(--gray);transition:all var(--tr)}
.mode-tab.on{background:var(--white);color:var(--green);box-shadow:0 1px 6px rgba(42,42,39,.1)}

/* ══ IRPF MANUAL SLIDER ══ */
.irpf-manual{
  padding:10px 13px;
  background:rgba(62,207,106,.05);border:1px solid var(--g20);
  border-radius:var(--r-sm);margin-top:8px;
}
.irpf-manual-label{font-size:11px;font-weight:700;color:var(--green);margin-bottom:7px;font-family:var(--fd)}
input[type=range]{
  width:100%;height:4px;border-radius:2px;
  background:var(--neutral);outline:none;cursor:pointer;
  -webkit-appearance:none;
}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--green);cursor:pointer;box-shadow:0 0 0 3px var(--g20)}

/* ══ RESULTS ══ */
.result-hero{
  background:linear-gradient(135deg,#f0fef4,#e8fdf0 55%,#ecfdf5);
  border:1px solid rgba(62,207,106,.22);
  border-radius:var(--r-md);padding:18px 20px;margin-bottom:12px;
  position:relative;overflow:hidden;
}
.result-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(62,207,106,.15) 0%,transparent 70%)}
.rh-label{font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:5px}
.rh-value{font-family:var(--fd);font-size:32px;font-weight:700;letter-spacing:-.04em;color:#186a33;line-height:1}
.rh-sub{font-size:12px;color:#22a34a;margin-top:5px;opacity:.85}

.rrow{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;border-bottom:1px solid var(--neutral);
  font-size:13px;
}
.rrow:last-child{border-bottom:none}
.rrow-label{display:flex;align-items:center;gap:8px;color:var(--muted)}
.rdot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.rrow-value{font-family:var(--fd);font-weight:600;color:var(--graphite)}

/* Breakdown bars */
.bk-section{margin-top:16px}
.bk-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gray);margin-bottom:10px}
.bk-row{margin-bottom:10px}
.bk-meta{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px}
.bk-label{color:var(--muted)}
.bk-pct{font-family:var(--fd);font-weight:600;color:var(--graphite)}
.bk-track{height:6px;background:var(--neutral);border-radius:3px;overflow:hidden}
.bk-fill{height:100%;border-radius:3px;transition:width .5s ease}

/* IRPF edit button */
.irpf-edit-btn{
  margin-left:6px;padding:2px 8px;font-size:11px;
  border:1px solid var(--border);border-radius:4px;
  background:transparent;color:var(--gray);cursor:pointer;
  font-family:var(--fb);transition:all var(--tr);
}
.irpf-edit-btn:hover{color:var(--graphite);border-color:var(--graphite)}

/* Comparativa CCAA */
.comp-wrap{
  margin-top:14px;padding:14px;
  background:var(--neutral);border-radius:var(--r-md);
  border:1px solid var(--border);
}
.comp-title{font-family:var(--fd);font-size:11px;font-weight:700;color:var(--graphite);margin-bottom:10px;letter-spacing:.04em}
.comp-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}
.comp-label{min-width:120px;color:var(--muted);font-size:11px}
.comp-bar-track{flex:1;height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.comp-bar-fill{height:100%;border-radius:3px}
.comp-val{min-width:56px;text-align:right;font-family:var(--fd);font-weight:600;font-size:12px;color:var(--graphite)}
.comp-diff{
  display:inline-block;padding:3px 9px;border-radius:5px;
  font-family:var(--fd);font-size:12px;font-weight:700;
  margin-top:6px;
}

/* Link button to IRPF page */
.link-btn{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:14px;padding:9px 14px;
  background:rgba(62,207,106,.07);border:1px solid var(--g20);
  border-radius:var(--r-sm);font-size:12px;font-weight:600;
  color:var(--green);cursor:pointer;font-family:var(--fd);
  transition:background var(--tr);width:100%;justify-content:center;
}
.link-btn:hover{background:rgba(62,207,106,.12)}
.link-btn svg{flex-shrink:0}

/* Convenio badge */
.conv-info{
  padding:11px 13px;margin-bottom:13px;
  background:rgba(62,207,106,.05);border:1px solid var(--g20);border-radius:var(--r-sm);
  font-size:12px;color:var(--muted);line-height:1.6;display:none;
}
.conv-info strong{color:var(--graphite)}

/* Convenio autocomplete */
.conv-search-wrap{position:relative;margin-bottom:0}
.conv-input-row{display:flex;align-items:center;gap:6px}
.conv-input-row .fi{flex:1}
.conv-clear-btn{
  background:none;border:1.5px solid var(--border);cursor:pointer;
  color:var(--gray);font-size:13px;padding:5px 9px;
  border-radius:var(--r-sm);transition:all var(--tr);flex-shrink:0;line-height:1;
}
.conv-clear-btn:hover{color:var(--graphite);border-color:var(--graphite)}
.conv-dropdown{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;
  background:var(--white);border:1.5px solid var(--green);
  border-radius:var(--r-sm);
  max-height:248px;overflow-y:auto;
  box-shadow:0 8px 28px rgba(42,42,39,.14);
}
.conv-item{
  padding:9px 13px;cursor:pointer;border-bottom:1px solid var(--neutral);
  transition:background var(--tr);
}
.conv-item:last-child{border-bottom:none}
.conv-item:hover,.conv-item.sel{background:var(--g10)}
.conv-item-name{font-size:13px;font-weight:600;color:var(--graphite);line-height:1.4}
.conv-item-meta{font-size:11px;color:var(--gray);margin-top:1px}
.conv-msg{padding:11px 13px;text-align:center;font-size:12px;color:var(--gray);font-style:italic}
.conv-filter-toggle-link{color:var(--green);cursor:pointer;text-decoration:underline;font-style:normal}

/* ── Filtro CCAA ── */
.conv-filter-row{
  display:flex;align-items:center;gap:8px;margin:6px 0 6px;
}
.ccaa-filter-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:100px;border:1.5px solid var(--border);
  background:var(--neutral);color:var(--muted);
  font-family:var(--fd);font-size:11px;font-weight:600;cursor:pointer;
  transition:all var(--tr);white-space:nowrap;
}
.ccaa-filter-pill.on{
  border-color:var(--green);background:var(--g10);color:var(--graphite);
}
.ccaa-filter-pill:hover{border-color:var(--green);background:var(--g10)}
.ccaa-filter-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--border);flex-shrink:0;transition:background var(--tr);
}
.ccaa-filter-pill.on .ccaa-filter-dot{background:var(--green)}
.ccaa-filter-hint{font-size:11px;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}

/* Badge que aparece encima de los resultados filtrados */
.conv-ccaa-badge{
  padding:6px 13px;font-size:11px;font-weight:600;
  color:var(--green);background:var(--g10);border-bottom:1px solid var(--g20);
  display:flex;align-items:center;gap:4px;
}

/* ══ SECTION HEADERS ══ */
.sec-eyebrow{
  font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gray);display:block;margin-bottom:10px;
}
.sec-h2{
  font-family:var(--fd);font-size:clamp(22px,3vw,34px);font-weight:700;
  letter-spacing:-.025em;color:var(--graphite);margin-bottom:10px;
}
.sec-sub{font-size:15px;color:var(--muted);line-height:1.65;max-width:520px;margin-bottom:44px}

/* ══ RESULT SECTION ══ */
.result-section{
  padding:80px 0;background:var(--neutral);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
@media(max-width:680px){.result-grid{grid-template-columns:1fr 1fr}}
@media(max-width:420px){.result-grid{grid-template-columns:1fr}}

.rc{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px;
}
.rc.hi{border-color:rgba(62,207,106,.3);background:linear-gradient(135deg,#fff 0%,rgba(62,207,106,.04) 100%)}
.rc-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:9px}
.rc-value{font-family:var(--fd);font-size:24px;font-weight:700;letter-spacing:-.03em;color:var(--graphite)}
.rc-value .em{color:var(--green)}
.rc-sub{font-size:11px;color:var(--muted);margin-top:3px}

/* Breakdown card full width */
.breakdown-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:22px;
  grid-column:1 / -1;
}
.breakdown-bar{
  height:10px;border-radius:6px;overflow:hidden;
  background:var(--neutral);display:flex;margin-bottom:14px;
}
.breakdown-bar > div{transition:width .5s ease}

.legend{display:flex;gap:18px;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}

.irpf-note{
  grid-column:1 / -1;
  background:rgba(62,207,106,.06);border:1px solid var(--g20);
  border-radius:var(--r-sm);padding:12px 16px;font-size:13px;color:var(--muted);line-height:1.6;
  display:none;
}

/* ══ IRPF PAGE ══ */
.irpf-page{padding:88px 0 80px}
.page-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:800px){.page-grid{grid-template-columns:1fr}}

.gauge-wrap{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);padding:16px;margin-top:16px;
}
.gauge-track{height:8px;background:var(--neutral);border-radius:4px;overflow:hidden;margin:8px 0}
.gauge-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--green),#22d463);transition:width .5s ease}

.bracket-table{display:flex;flex-direction:column;gap:3px;margin-top:12px}
.bracket-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:7px 12px;border-radius:var(--r-sm);
  font-size:12px;border:1px solid transparent;
  color:var(--muted);transition:all var(--tr);
}
.bracket-row.active{border-color:rgba(62,207,106,.25);background:rgba(62,207,106,.06);color:var(--graphite)}

/* IRPF results grid */
.irpf-rg{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
@media(max-width:480px){.irpf-rg{grid-template-columns:1fr}}
.ir-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:14px}
.ir-card-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:7px}
.ir-card-val{font-family:var(--fd);font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--graphite)}
.ir-card-val .em{color:var(--green)}

/* ══ DIVISAS PAGE ══ */
.divisas-page{padding:88px 0 80px}
.div-card{max-width:680px;margin:0 auto 28px}

.fx-result-big{
  font-family:var(--fd);font-size:clamp(28px,4vw,42px);font-weight:700;
  letter-spacing:-.04em;color:var(--graphite);padding:14px 0;line-height:1;
}
.fx-result-big .em{color:var(--green)}

.fx-rate-line{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 13px;background:var(--neutral);border-radius:var(--r-sm);
  border:1px solid var(--border);font-size:12px;color:var(--muted);
  margin-top:12px;
}
.fx-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
@media(max-width:600px){.fx-grid{grid-template-columns:repeat(2,1fr)}}
.fx-cell{
  padding:10px 12px;background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);cursor:pointer;transition:border-color var(--tr),transform var(--tr);
  text-align:center;
}
.fx-cell:hover{border-color:var(--green);transform:translateY(-1px)}
.fx-cell-code{font-family:var(--fd);font-size:12px;font-weight:700;color:var(--graphite)}
.fx-cell-rate{font-size:11px;color:var(--muted);margin-top:2px}

/* Salary converter section */
.salary-conv{
  max-width:680px;margin:0 auto 28px;
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;
}

/* ══ FAQ ══ */
.faq-section{padding:80px 0;background:var(--neutral);border-top:1px solid var(--border)}
.faq-list{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:44px}
@media(max-width:680px){.faq-list{grid-template-columns:1fr}}

.faq-item{
  background:var(--white);padding:20px 24px;
  border:1px solid var(--border);cursor:pointer;
  transition:background var(--tr);
}
.faq-item:hover{background:var(--cream)}
.faq-q{
  font-family:var(--fd);font-size:14px;font-weight:600;color:var(--graphite);
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;
}
.faq-ic{color:var(--green);font-size:16px;flex-shrink:0;transition:transform .2s}
.faq-item.op .faq-ic{transform:rotate(45deg)}
.faq-a{font-size:13px;color:var(--muted);line-height:1.7;max-height:0;overflow:hidden;transition:max-height .3s ease}

/* ══ WHY / FEATURES ══ */
.why-section{padding:80px 0;border-top:1px solid var(--border)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:44px}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.why-grid{grid-template-columns:1fr}}
.why-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:22px;
  transition:box-shadow var(--tr),transform var(--tr);
}
.why-card:hover{box-shadow:var(--sh);transform:translateY(-2px)}
.why-icon{
  width:36px;height:36px;border-radius:var(--r-sm);
  background:var(--g10);display:flex;align-items:center;justify-content:center;
  margin-bottom:13px;
}
.why-title{font-family:var(--fd);font-size:14px;font-weight:600;color:var(--graphite);margin-bottom:6px}
.why-text{font-size:13px;color:var(--muted);line-height:1.65}

/* ══ LAGUNLAB SECTION ══ */
.ll-section{
  padding:80px 0;
  background:var(--graphite);
  border-top:1px solid rgba(255,255,255,.06);
}
.ll-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  max-width:1120px;margin:0 auto;padding:0 40px;
}
@media(max-width:680px){.ll-inner{grid-template-columns:1fr;padding:0 20px}}
.ll-h2{
  font-family:var(--fd);font-size:clamp(22px,3vw,34px);font-weight:700;
  letter-spacing:-.025em;color:var(--cream);margin-bottom:14px;line-height:1.2;
}
.ll-h2 span{color:var(--green)}
.ll-text{font-size:15px;color:rgba(248,245,238,.5);line-height:1.7;margin-bottom:24px}
.ll-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--cream);
  border:1.5px solid rgba(248,245,238,.2);border-radius:var(--r-sm);
  font-size:13px;font-weight:600;padding:10px 18px;cursor:pointer;
  font-family:var(--fd);transition:border-color var(--tr),background var(--tr);
}
.ll-btn:hover{border-color:rgba(248,245,238,.4);background:rgba(248,245,238,.05)}

/* Orbit visual */
.orbit-wrap{position:relative;width:220px;height:220px;margin:0 auto}
.orbit-ring{
  position:absolute;border:1px solid rgba(62,207,106,.12);
  border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);
}
.orbit-ring:nth-child(1){width:72px;height:72px}
.orbit-ring:nth-child(2){width:130px;height:130px;animation:spin 20s linear infinite}
.orbit-ring:nth-child(3){width:190px;height:190px;animation:spin 30s linear infinite reverse}
@keyframes spin{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}
.orbit-sat{position:absolute;width:7px;height:7px;border-radius:50%;background:rgba(248,245,238,.35);top:0;left:50%;transform:translateX(-50%) translateY(-3.5px)}

/* ══ FOOTER ══ */
.footer{background:var(--dark);padding:52px 0 28px}
.footer-top{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;
  padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:28px;
}
@media(max-width:680px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:420px){.footer-top{grid-template-columns:1fr}}
.ft-logo{font-family:var(--fd);font-size:17px;font-weight:700;color:var(--cream);margin-bottom:4px}
.ft-logo .ya{color:var(--green)}
.ft-sub{font-size:11px;color:rgba(248,245,238,.3);margin-bottom:14px}
.ft-nav-title{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(248,245,238,.25);margin-bottom:12px}
.ft-nav a{display:block;font-size:13px;color:rgba(248,245,238,.45);margin-bottom:7px;cursor:pointer;transition:color var(--tr)}
.ft-nav a:hover{color:var(--cream)}
.footer-bottom{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}
.ft-legal{font-size:11px;color:rgba(248,245,238,.2);line-height:1.7;max-width:560px}
.ft-credit{font-size:11px;color:rgba(248,245,238,.2);text-align:right}

/* ══ TOAST ══ */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--graphite);color:var(--cream);
  font-family:var(--fd);font-size:13px;font-weight:600;
  padding:10px 20px;border-radius:100px;
  display:flex;align-items:center;gap:8px;
  z-index:999;transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 4px 20px rgba(42,42,39,.3);white-space:nowrap;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ══ SEO PROSE ══ */
.seo{margin-top:52px;padding:32px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg)}
.seo h2{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--graphite);margin-bottom:10px;margin-top:20px}
.seo h2:first-child{margin-top:0}
.seo h3{font-family:var(--fd);font-size:15px;font-weight:600;color:var(--graphite);margin-bottom:8px;margin-top:16px}
.seo p{font-size:14px;color:var(--muted);line-height:1.75;margin-bottom:10px}
.seo ul{font-size:14px;color:var(--muted);line-height:1.75;padding-left:18px;margin-bottom:10px}
.seo ul li{margin-bottom:4px}
.seo strong{color:var(--graphite)}

/* ══ DISCLAIMER ══ */
.discl{
  display:flex;gap:8px;font-size:11px;color:var(--gray);line-height:1.6;
  padding:10px 0;border-top:1px solid var(--neutral);margin-top:12px;
}
.discl svg{flex-shrink:0;margin-top:1px}

/* ══ BREADCRUMB ══ */
.bc{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray);margin-bottom:20px}
.bc-sep{color:var(--border)}
.bc span:first-child{cursor:pointer;transition:color var(--tr)}
.bc span:first-child:hover{color:var(--graphite)}

/* ══ PAGE HERO ══ */
.ph-badge{
  display:inline-block;padding:4px 12px;border-radius:6px;
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:14px;
}
.ph-h1{
  font-family:var(--fd);font-size:clamp(24px,4vw,40px);
  font-weight:700;letter-spacing:-.03em;color:var(--graphite);
  margin-bottom:12px;line-height:1.15;
}
.ph-sub{font-size:15px;color:var(--muted);line-height:1.7;max-width:540px;margin-bottom:28px}

/* ══ RESPONSIVE HELPERS ══ */
@media(max-width:680px){
  .result-section{padding:60px 0}
  .irpf-page,.divisas-page{padding:80px 0 60px}
  .faq-section,.why-section,.ll-section,.footer{padding:60px 0}
  .ll-section{padding:60px 0}
  .orbit-wrap{display:none}
}

/* Fade in */
.fade-in{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.fade-in.vis{opacity:1;transform:translateY(0)}

/* Ilink strip */
.ilink-strip{margin-top:32px;padding:18px 20px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg)}
.ilink-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:10px}
.ilink-btns{display:flex;gap:8px;flex-wrap:wrap}
.ilink-btn{
  font-family:var(--fd);font-size:12px;font-weight:700;
  padding:7px 14px;border-radius:100px;
  background:var(--neutral);border:1px solid var(--border);
  color:var(--muted);cursor:pointer;transition:all var(--tr);
}
.ilink-btn:hover{border-color:var(--green);color:var(--green);background:var(--g10)}

/* ══ SECTOR PILLS ══ */
.sector-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;min-height:0}
.sector-pills:empty{display:none}
.sector-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 10px;border-radius:100px;
  font-size:11px;font-weight:600;font-family:var(--fd);
  border:1.5px solid var(--border);background:var(--white);
  color:var(--muted);cursor:pointer;transition:all var(--tr);white-space:nowrap;line-height:1.2;
}
.sector-pill:hover{border-color:var(--green);color:var(--graphite);background:var(--g10)}
.sector-pill.on{border-color:var(--green);background:var(--green);color:#fff}
.sector-pill.on:hover{opacity:.88}
.sp-count{font-size:9px;opacity:.65;margin-left:1px}

/* Convenio dropdown separator (buscar / categoría hints) */
.conv-sep{
  padding:6px 13px;
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gray);background:var(--neutral);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  position:sticky;top:0;
}
.buscar-item .conv-item-name{font-size:12px;line-height:1.5}
.buscar-salary{color:var(--green);font-weight:700;font-family:var(--fd)}

/* ══════════════════════════════════════════
   MODO OSCURO
══════════════════════════════════════════ */
html[data-theme="dark"]{
  --graphite:#E5E2D9;
  --gray:    #6B6B67;
  --neutral: #252522;
  --border:  #38382F;
  --white:   #222220;
  --dark:    #0E0E0C;
  --muted:   #ABABAA;
  --sh:      0 8px 40px rgba(0,0,0,.35);
  background:#18181A;
}
html[data-theme="dark"] body{background:#18181A}
html[data-theme="dark"] .hd{background:rgba(24,24,26,.92)}
html[data-theme="dark"] .mob-nav{background:rgba(24,24,26,.98);border-color:var(--border)}
html[data-theme="dark"] .card-hd{background:#282825}
html[data-theme="dark"] .faq-item:hover{background:var(--neutral)}
html[data-theme="dark"] .result-hero{background:linear-gradient(135deg,#0d2416,#091e12 55%,#0d2416);border-color:rgba(62,207,106,.18)}
html[data-theme="dark"] .rh-value{color:#4ade80}
html[data-theme="dark"] .rh-sub{color:#86efac}
html[data-theme="dark"] .ll-section{background:#0F0F0D}
html[data-theme="dark"] .toast{background:#3A3A37;color:#E5E2D9}
html[data-theme="dark"] .fs{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B6B67'/%3E%3C/svg%3E")}
html[data-theme="dark"] body::before{background-image:linear-gradient(rgba(62,207,106,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(62,207,106,.06) 1px,transparent 1px)}
html[data-theme="dark"] .hbg span{background:var(--graphite)}

/* Botón toggle tema */
.theme-toggle{
  width:34px;height:34px;border-radius:var(--r-sm);
  border:1.5px solid var(--border);background:transparent;
  color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:color var(--tr),border-color var(--tr),background var(--tr);
  flex-shrink:0;
}
.theme-toggle:hover{color:var(--graphite);border-color:var(--graphite);background:var(--neutral)}
.icon-sun{display:block}
.icon-moon{display:none}
html[data-theme="dark"] .icon-sun{display:none}
html[data-theme="dark"] .icon-moon{display:block}

/* ══ BADGE IRPF (tipo efectivo semántico) ══ */
.irpf-badge{
  display:inline-flex;align-items:center;padding:2px 7px;border-radius:100px;
  font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.03em;
  white-space:nowrap;
}
.badge-green{background:rgba(62,207,106,.14);color:#186a33}
.badge-amber{background:rgba(245,158,11,.14);color:#b45309}
.badge-red{background:rgba(220,38,38,.10);color:#b91c1c}

/* ══ RETRIBUCIÓN FLEXIBLE ACORDEÓN ══ */
.flex-accord{
  border:1px solid var(--border);border-radius:var(--r-sm);
  margin-bottom:13px;overflow:hidden;
}
.flex-accord-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 13px;background:var(--cream);
  border:none;cursor:pointer;width:100%;
  font-family:var(--fd);font-size:12px;font-weight:600;color:var(--graphite);
  transition:background var(--tr);
}
.flex-accord-hd:hover{background:var(--neutral)}
.flex-accord-body{padding:12px 13px 4px;background:var(--white)}
.hint{
  font-size:10px;font-weight:400;letter-spacing:0;text-transform:none;
  color:var(--gray);margin-left:3px;
}

/* ══ RANKING TODAS LAS CCAA ══ */
.ccaa-ranking{
  margin-top:14px;background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:14px;overflow:hidden;
}
.ccaa-rank-row{
  display:flex;align-items:center;gap:6px;
  padding:3px 4px;border-radius:4px;font-size:11px;
}
.ccaa-rank-row.current{background:rgba(62,207,106,.08)}
.ccaa-rank-pos{
  min-width:24px;font-family:var(--fd);font-weight:700;
  color:var(--gray);font-size:10px;text-align:center;flex-shrink:0;
}
.ccaa-rank-name{
  min-width:0;flex:0 0 140px;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:10px;
}
.ccaa-rank-bar-track{flex:1;height:4px;background:var(--neutral);border-radius:2px;overflow:hidden}
.ccaa-rank-bar-fill{
  height:100%;border-radius:2px;
  background:linear-gradient(90deg,#186a33,var(--green));
  transition:width .5s ease;
}
.ccaa-rank-val{
  min-width:52px;text-align:right;font-family:var(--fd);
  font-weight:600;color:var(--graphite);font-size:11px;flex-shrink:0;
}

/* ══ PRINT / PDF ══ */
@media print {
  header,.mob-nav,.nav,.hd-act,.pill-toggle,.mode-tabs,
  .btn-primary,.btn-outline,.link-btn,
  #conv-section,#adv-fields,.discl,.irpf-edit-btn,
  #s-irpf-manual-wrap,#r-irpf-note,
  .comp-wrap,.ccaa-ranking,.flex-accord,
  .footer,.ilink-strip,.seo,#cta-header,
  .faq-section,.hero-ctas,.hero-trust,
  #faq-sect,[onclick*="nav("] { display:none !important }

  body,html{background:#fff !important}
  .page{display:none !important}
  .page.active{display:block !important}
  .main-calc-grid{
    display:grid !important;grid-template-columns:1fr 1fr !important;
    gap:16px;page-break-inside:avoid;
  }
  .card{box-shadow:none;border:1px solid #ccc}
  .hd{position:static;box-shadow:none;border-bottom:1px solid #ccc;height:auto;padding:8px 0}
  .hd-i{padding:0 20px}
  .wrap{padding:0 20px}
  .page.active{padding-top:8px}
  * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}
