/* indicepeidi.gaelika.es · frontend · GaeliKA */
:root{
  --gael-blue:#4FA3D1; --ka-green:#6BC46D; --deep-blue:#1F4E79;
  --tech-gray:#4A4A4A; --light-gray:#E9EEF2; --soft:#F5F9FC; --white:#fff;
  --red:#B02418; --amber:#B5791F; --green:#1E7B34; --violet:#6A4FA0;
  --line:#e3e9ef; --muted:#7a8893;
  /* estados de anotación del índice */
  --st-confirma:#1E7B34; --st-amplia:#2563a8; --st-simplifica:#B5791F;
  --st-matiza:#6A4FA0; --st-retira:#B02418; --st-pendiente:#7a8893;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:'Montserrat',sans-serif;background:#eef2f6;color:var(--tech-gray);font-size:15px;line-height:1.5;}
.hidden{display:none !important;}
.muted{color:var(--muted);} .small{font-size:12.5px;}
a{color:var(--gael-blue);}

/* logo */
.logo{font-weight:800;font-size:20px;letter-spacing:.4px;color:var(--deep-blue);line-height:1;}
.logo .k{color:var(--gael-blue);} .logo .a{color:var(--ka-green);}
.logo small{display:block;font-size:9px;font-weight:600;letter-spacing:2.5px;color:var(--tech-gray);opacity:.6;margin-top:3px;}
.logo.big{font-size:30px;margin-bottom:18px;}

/* buttons */
.btn{font-family:inherit;font-size:14px;font-weight:600;border:none;border-radius:9px;padding:11px 18px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s;}
.btn.primary{background:var(--deep-blue);color:#fff;} .btn.primary:hover{background:#163b5c;}
.btn.ghost{background:#fff;color:var(--deep-blue);border:1px solid var(--line);} .btn.ghost:hover{background:var(--soft);}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.iconbtn{background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer;padding:6px;border-radius:8px;}
.iconbtn:hover{background:var(--light-gray);color:var(--tech-gray);}

/* overlay */
.overlay{position:fixed;inset:0;background:rgba(15,34,53,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;}

/* login */
.login-card{background:#fff;border-radius:18px;max-width:470px;width:100%;padding:38px 38px 26px;box-shadow:0 24px 60px rgba(0,0,0,.3);}
.login-card h1{font-size:23px;color:var(--deep-blue);margin:0 0 10px;}
.login-card p{font-size:13.5px;margin:0 0 22px;}
.login-card form{display:flex;flex-direction:column;gap:5px;}
.login-card label{font-size:12px;font-weight:700;color:var(--tech-gray);margin-top:10px;text-transform:uppercase;letter-spacing:.5px;}
.login-card input{font-family:inherit;font-size:15px;padding:11px 13px;border:1px solid var(--line);border-radius:9px;outline:none;}
.login-card input:focus{border-color:var(--gael-blue);box-shadow:0 0 0 3px rgba(79,163,209,.15);}
.login-card .btn{margin-top:18px;justify-content:center;}
.login-foot{margin-top:18px;text-align:center;font-size:11.5px;color:var(--muted);}
.err{color:var(--red);font-size:13px;min-height:18px;margin-top:8px;font-weight:600;}

/* topbar */
.topbar{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:12px 26px;box-shadow:0 2px 10px rgba(0,0,0,.03);}
.topbar-title{font-weight:700;color:var(--deep-blue);font-size:15.5px;flex-grow:1;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.pill{background:var(--soft);border:1px solid var(--line);border-radius:30px;padding:5px 12px;font-size:12.5px;font-weight:600;color:var(--deep-blue);display:inline-flex;align-items:center;gap:6px;}
.pill i{color:var(--gael-blue);}
.pill.off i{color:var(--muted);} .pill.off{color:var(--muted);}
.me{font-size:13px;color:var(--tech-gray);font-weight:600;background:var(--light-gray);padding:6px 12px;border-radius:30px;}

/* subnav (tabs + progress) */
.subnav{position:sticky;top:57px;z-index:20;background:#f6f9fc;border-bottom:1px solid var(--line);}
.subnav-inner{max-width:1200px;margin:0 auto;padding:10px 26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.tabs{display:flex;gap:8px;}
.tab{font-family:inherit;font-size:13.5px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--tech-gray);border-radius:9px;padding:9px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.12s;}
.tab i{color:var(--gael-blue);}
.tab:hover{border-color:var(--gael-blue);}
.tab.active{background:var(--deep-blue);color:#fff;border-color:var(--deep-blue);}
.tab.active i{color:#fff;}
.tabcount{background:rgba(0,0,0,.12);border-radius:20px;font-size:11.5px;padding:1px 8px;font-weight:700;}
.tab.active .tabcount{background:rgba(255,255,255,.22);}
.progress-mini{display:flex;align-items:center;gap:14px;margin-left:auto;flex-grow:1;justify-content:flex-end;}
.progress-text{font-size:12.5px;font-weight:600;color:var(--tech-gray);white-space:nowrap;}
.progress-text b{color:var(--deep-blue);}
.bar{flex-grow:1;max-width:240px;height:9px;background:var(--light-gray);border-radius:6px;overflow:hidden;min-width:90px;}
.bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--gael-blue),var(--ka-green));transition:width .3s;}
.btn.gen{white-space:nowrap;}

/* layout */
.wrap{max-width:1200px;margin:0 auto;padding:22px 26px 44px;}
#blocks{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start;}

/* bloque de decisiones */
.block{background:transparent;}
.block-head{display:flex;align-items:center;gap:11px;margin:2px 0 14px;padding-bottom:10px;border-bottom:2px solid var(--light-gray);}
.block-head .bicon{width:34px;height:34px;border-radius:9px;background:var(--deep-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.block-head h2{font-size:16.5px;color:var(--deep-blue);margin:0;}
.block-head .bmeta{font-size:11.5px;color:var(--muted);font-weight:600;margin-left:auto;white-space:nowrap;}

/* decision card */
.dcard{background:#fff;border:1px solid var(--line);border-radius:13px;padding:17px 19px;margin-bottom:15px;box-shadow:0 4px 12px rgba(0,0,0,.03);scroll-margin-top:130px;}
.dcard.voted{border-left:4px solid var(--ka-green);}
.dcard.flash{animation:flash 1.4s ease;}
@keyframes flash{0%{box-shadow:0 0 0 3px rgba(79,163,209,.5);}100%{box-shadow:0 4px 12px rgba(0,0,0,.03);}}
.dcard .dhead{display:flex;align-items:flex-start;gap:11px;margin-bottom:6px;}
.dcard .dcode{flex-shrink:0;background:var(--deep-blue);color:#fff;font-weight:800;font-size:12px;border-radius:7px;padding:4px 8px;}
.dcard .dtitle{font-size:15px;font-weight:700;color:var(--deep-blue);}
.dcard .dq{font-size:13px;color:var(--tech-gray);margin:0 0 9px;}
.secchips{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 12px;}
.secchip{font-size:11px;font-weight:700;color:var(--gael-blue);background:rgba(79,163,209,.10);border:1px solid rgba(79,163,209,.25);border-radius:20px;padding:2px 9px;cursor:pointer;transition:.12s;}
.secchip:hover{background:var(--gael-blue);color:#fff;}
.opt{border:1px solid var(--line);border-radius:10px;padding:10px 13px;margin-bottom:8px;cursor:pointer;transition:.12s;position:relative;overflow:hidden;}
.opt:hover{border-color:var(--gael-blue);background:var(--soft);}
.opt.mine{border-color:var(--ka-green);background:#f0faf2;box-shadow:0 0 0 2px rgba(107,196,109,.18) inset;}
.opt .otop{display:flex;align-items:center;gap:10px;position:relative;z-index:2;}
.opt .radio{flex-shrink:0;width:18px;height:18px;border-radius:50%;border:2px solid #c4cfd8;display:flex;align-items:center;justify-content:center;}
.opt.mine .radio{border-color:var(--ka-green);background:var(--ka-green);}
.opt.mine .radio::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff;}
.opt .olabel{font-size:13.5px;font-weight:600;color:var(--tech-gray);flex-grow:1;}
.opt .ocount{font-size:12px;font-weight:700;color:var(--gael-blue);}
.opt .odetail{font-size:12px;color:var(--muted);margin:3px 0 0 28px;position:relative;z-index:2;}
.opt .otrack{position:absolute;left:0;top:0;bottom:0;background:rgba(79,163,209,.10);width:0;transition:width .35s;z-index:1;}
.opt.mine .otrack{background:rgba(107,196,109,.16);}
.dcard .dmaj{margin-top:6px;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px;}
.dcard .dmaj b{color:var(--green);} .dcard .dmaj.tie b{color:var(--amber);}

/* nota para matizar voto */
.notewrap{margin:8px 0 2px;}
.noteinput{width:100%;font-family:inherit;font-size:13px;padding:9px 11px;border:1px solid var(--gael-blue);border-radius:9px;outline:none;resize:vertical;min-height:48px;background:#fbfdff;color:var(--tech-gray);box-sizing:border-box;}
.noteinput::placeholder{color:#9fb3c4;}
.noteinput:focus{box-shadow:0 0 0 3px rgba(79,163,209,.15);}

/* ---------------- VISTA ÍNDICE ---------------- */
.idx-head{margin-bottom:18px;}
.idx-head h2{font-size:18px;color:var(--deep-blue);display:flex;align-items:flex-start;gap:10px;margin:0 0 6px;}
.idx-head h2 i{color:var(--gael-blue);margin-top:2px;}
.idx-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
.legitem{font-size:11px;font-weight:700;color:#fff;border-radius:20px;padding:3px 10px;}

#indexTree{background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px 6px;box-shadow:0 4px 12px rgba(0,0,0,.03);}
.chap{border-bottom:1px solid #f0f3f6;padding:6px 14px 10px;}
.chap:last-child{border-bottom:none;}
.chap-h{display:flex;align-items:baseline;gap:10px;padding:8px 0 4px;}
.chap-num{font-weight:800;color:#fff;background:var(--gael-blue);border-radius:7px;font-size:12.5px;padding:3px 9px;min-width:30px;text-align:center;}
.chap-t{font-size:14.5px;font-weight:700;color:var(--deep-blue);}
.sub{display:flex;align-items:baseline;gap:10px;padding:4px 0 4px 6px;}
.sub-num{font-weight:700;color:var(--muted);font-size:12px;min-width:34px;}
.sub-t{font-size:13px;color:var(--tech-gray);flex-grow:1;}
.sub.has-dec{background:var(--soft);border-radius:8px;padding-left:8px;padding-right:8px;}
.sub .decbadges{display:inline-flex;gap:5px;flex-wrap:wrap;}
.decbadge{font-size:10.5px;font-weight:800;color:#fff;border-radius:6px;padding:2px 7px;cursor:pointer;border:none;transition:.12s;letter-spacing:.3px;}
.decbadge:hover{filter:brightness(1.12);transform:translateY(-1px);}
.bg-CONCRE{background:var(--gael-blue);} .bg-ECON{background:var(--ka-green);}
.bg-EVAL{background:var(--violet);} .bg-ESTRUC{background:var(--amber);}

.appfoot{text-align:center;font-size:11.5px;color:var(--muted);padding:18px;}

/* ---------------- RESULT MODAL ---------------- */
.result-card{background:#fff;border-radius:16px;max-width:1080px;width:100%;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 24px 70px rgba(0,0,0,.4);}
.result-head{display:flex;justify-content:space-between;align-items:center;padding:20px 26px;border-bottom:1px solid var(--line);}
.result-head h2{margin:0;font-size:20px;color:var(--deep-blue);display:flex;align-items:center;gap:10px;}
.result-head h2 i{color:var(--ka-green);}
.result-body{padding:22px 26px;overflow-y:auto;}
.result-foot{padding:14px 26px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:14px;}
.rf-actions{display:flex;gap:10px;}
.rsec{margin-bottom:26px;}
.rsec h3{font-size:16px;color:var(--gael-blue);border-bottom:2px solid var(--light-gray);padding-bottom:7px;margin:0 0 14px;display:flex;align-items:center;gap:9px;}
.rsec h3 i{color:var(--deep-blue);}
.rsintesis{background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--deep-blue);border-radius:10px;padding:15px 18px;font-size:14px;line-height:1.6;margin-bottom:24px;}

/* implicaciones */
.impl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.impl{background:#fff;border:1px solid var(--line);border-radius:11px;padding:13px 14px;box-shadow:0 3px 9px rgba(0,0,0,.03);}
.impl .il{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);display:flex;align-items:center;gap:7px;}
.impl .il i{color:var(--gael-blue);}
.impl .iv{font-size:13px;font-weight:700;color:var(--deep-blue);margin-top:7px;line-height:1.35;}

/* bloques resueltos */
.rblock{margin-bottom:16px;border:1px solid var(--line);border-radius:12px;overflow:hidden;}
.rblock-h{background:var(--soft);padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);}
.rblock-h .ri{width:30px;height:30px;border-radius:8px;background:var(--deep-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;}
.rblock-h h4{margin:0;font-size:14.5px;color:var(--deep-blue);}
.rblock-syn{font-size:12.5px;color:var(--muted);padding:10px 16px 4px;font-style:italic;}
.rdec{display:flex;align-items:flex-start;gap:10px;padding:9px 16px;border-top:1px solid #f4f6f8;}
.rdec .rc{flex-shrink:0;background:var(--deep-blue);color:#fff;font-weight:800;font-size:11px;border-radius:6px;padding:3px 7px;}
.rdec .rt{flex-grow:1;}
.rdec .rt .rtl{font-size:13px;font-weight:700;color:var(--tech-gray);}
.rdec .rt .rch{font-size:12.5px;color:var(--deep-blue);margin-top:2px;}
.rdec .rt .rde{font-size:11.5px;color:var(--muted);margin-top:2px;}

/* estado chips */
.estado{font-size:10.5px;font-weight:800;color:#fff;border-radius:20px;padding:3px 9px;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;}
.e-confirma{background:var(--st-confirma);} .e-amplia{background:var(--st-amplia);}
.e-simplifica{background:var(--st-simplifica);} .e-matiza{background:var(--st-matiza);}
.e-retira{background:var(--st-retira);} .e-pendiente{background:var(--st-pendiente);}

/* indice anotado */
.anot{display:flex;align-items:flex-start;gap:11px;padding:10px 4px;border-bottom:1px solid #f0f3f6;}
.anot:last-child{border-bottom:none;}
.anot .ac{flex-shrink:0;background:var(--soft);border:1px solid var(--line);color:var(--deep-blue);font-weight:800;font-size:11px;border-radius:6px;padding:3px 7px;}
.anot .abody{flex-grow:1;}
.anot .atitle{font-size:13px;font-weight:700;color:var(--deep-blue);}
.anot .anota{font-size:12px;color:var(--tech-gray);margin-top:2px;}
.anot .asecs{font-size:10.5px;color:var(--muted);margin-top:3px;font-weight:600;}

/* loader */
.loader-card{background:#fff;border-radius:16px;padding:34px 44px;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.3);}
.spinner{width:46px;height:46px;border:5px solid var(--light-gray);border-top-color:var(--gael-blue);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px;}
@keyframes spin{to{transform:rotate(360deg);}}
#loaderText{font-weight:600;color:var(--deep-blue);}

@media (max-width:980px){
  #blocks{grid-template-columns:1fr;}
  .impl-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:880px){
  .topbar-title{display:none;}
  .progress-mini{width:100%;justify-content:flex-start;margin-left:0;}
}
@media (max-width:560px){
  .impl-grid{grid-template-columns:1fr;}
  .me{display:none;}
}
@media print{
  .overlay{position:static;background:#fff;backdrop-filter:none;}
  .result-card{box-shadow:none;max-height:none;}
  .result-head .iconbtn,.result-foot{display:none;}
}
