: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;
  --line:#e3e9ef; --muted:#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:460px;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:16px;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;}

/* progress */
.progress-wrap{position:sticky;top:57px;z-index:20;background:#f6f9fc;border-bottom:1px solid var(--line);}
.progress-inner{max-width:1200px;margin:0 auto;padding:12px 26px;display:flex;align-items:center;gap:18px;}
.progress-text{font-size:13px;font-weight:600;color:var(--tech-gray);white-space:nowrap;}
.bar{flex-grow:1;height:9px;background:var(--light-gray);border-radius:6px;overflow:hidden;}
.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 40px;display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.group-title{font-size:17px;color:var(--deep-blue);display:flex;align-items:center;gap:10px;margin:4px 0 14px;padding-bottom:10px;border-bottom:2px solid var(--light-gray);}
.group-title i{color:var(--gael-blue);}

/* decision card */
.dcard{background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px 20px;margin-bottom:16px;box-shadow:0 4px 12px rgba(0,0,0,.03);}
.dcard.voted{border-left:4px solid var(--ka-green);}
.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:15.5px;font-weight:700;color:var(--deep-blue);}
.dcard .dq{font-size:13px;color:var(--tech-gray);margin:0 0 13px;}
.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);}

/* 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:24px;}
.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);}
.dafo-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.quad{border-radius:12px;padding:14px 16px;background:var(--soft);border:1px solid var(--line);}
.quad h4{margin:0 0 9px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid;padding-bottom:6px;}
.quad.F h4{color:var(--green);border-color:var(--green);}
.quad.D h4{color:var(--red);border-color:var(--red);}
.quad.O h4{color:var(--gael-blue);border-color:var(--gael-blue);}
.quad.A h4{color:var(--amber);border-color:var(--amber);}
.quad ul{margin:0;padding-left:17px;} .quad li{font-size:12.5px;line-height:1.45;margin-bottom:6px;}
.mvvbox{background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--deep-blue);border-radius:10px;padding:14px 18px;font-size:14px;line-height:1.55;margin-bottom:8px;}
.valgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.valitem{background:#fff;border:1px solid var(--line);border-radius:9px;padding:11px 13px;}
.valitem b{color:var(--deep-blue);font-size:13.5px;} .valitem p{margin:3px 0 0;font-size:12px;color:var(--tech-gray);line-height:1.4;}

/* 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:880px){
  .wrap{grid-template-columns:1fr;}
  .progress-inner{flex-wrap:wrap;}
  .topbar-title{display:none;}
  .dafo-grid,.valgrid{grid-template-columns:1fr;}
}
@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;}
}
