:root{
  --navy:#0b2447;
  --navy-2:#19376d;
  --accent:#1d4ed8;
  --saffron:#ff9933;
  --green:#138808;
  --bg:#f4f6fb;
  --card:#ffffff;
  --line:#e3e8f2;
  --text:#0f172a;
  --muted:#5b6577;
  --high:#138808;
  --medium:#b45309;
  --low:#8a8f98;
  --shadow:0 1px 3px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter','Noto Sans Gujarati',system-ui,Arial,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.5;
}
.tricolor-bar{height:4px;background:linear-gradient(90deg,var(--saffron) 0 33%,#fff 33% 66%,var(--green) 66% 100%)}

.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;background:var(--navy);color:#fff;
}
.brand{display:flex;align-items:center;gap:14px}
.emblem{
  width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.12);font-size:20px;border:1px solid rgba(255,255,255,.25)
}
.brand-text{display:flex;flex-direction:column}
.brand-title{font-weight:700;font-size:16px;letter-spacing:.2px}
.brand-sub{font-size:12px;opacity:.8}
.status{display:flex;align-items:center;gap:8px;font-size:12.5px;opacity:.95}
.status .dot{width:9px;height:9px;border-radius:50%;background:#f59e0b;box-shadow:0 0 0 3px rgba(245,158,11,.2)}
.status.ok .dot{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2)}
.status.bad .dot{background:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.2)}

.container{max-width:920px;margin:28px auto;padding:0 20px}

.query-card{
  background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:18px;box-shadow:var(--shadow);
}
#complaint{
  width:100%;min-height:130px;resize:vertical;border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;font-size:15px;font-family:inherit;color:var(--text);
  outline:none;background:#fbfcfe;transition:border .15s,box-shadow .15s;
}
#complaint:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(29,78,216,.12);background:#fff}
.query-actions{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:14px}
.hint{font-size:12.5px;color:var(--muted)}
.run-btn{
  background:linear-gradient(180deg,var(--accent),#173db8);color:#fff;border:none;
  padding:12px 26px;font-size:15px;font-weight:600;border-radius:10px;cursor:pointer;
  box-shadow:0 4px 12px rgba(29,78,216,.28);transition:transform .05s,box-shadow .15s,opacity .15s;white-space:nowrap;
}
.run-btn:hover{box-shadow:0 6px 18px rgba(29,78,216,.36)}
.run-btn:active{transform:translateY(1px)}
.run-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}

.progress{
  display:flex;align-items:center;gap:12px;margin-top:18px;color:var(--muted);
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 18px;font-size:14px;
}
.spinner{width:18px;height:18px;border:3px solid #d7def0;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.meta{
  margin-top:18px;font-size:12.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px 18px;
  padding:0 4px;
}
.meta b{color:var(--text);font-weight:600}

.results{margin-top:16px;display:flex;flex-direction:column;gap:16px}

.rec{
  background:var(--card);border:1px solid var(--line);border-left:5px solid var(--accent);
  border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);animation:rise .25s ease both;
}
.rec.high{border-left-color:var(--high)}
.rec.medium{border-left-color:var(--medium)}
.rec.low{border-left-color:var(--low)}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.rec-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.sec-badge{
  display:inline-flex;align-items:baseline;gap:8px;background:var(--navy);color:#fff;
  padding:7px 14px;border-radius:10px;font-weight:700;font-size:15px;letter-spacing:.3px;
}
.sec-badge small{font-weight:500;opacity:.8;font-size:11px}
.rec-title{font-weight:600;font-size:16px;margin:8px 0 2px}
.conf{
  font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:5px 11px;border-radius:20px;white-space:nowrap;
}
.conf.high{background:#e7f6e7;color:var(--high)}
.conf.medium{background:#fdf0dd;color:var(--medium)}
.conf.low{background:#eef0f3;color:var(--low)}

.reasoning{margin:10px 0 14px;font-size:14.5px;color:#1f2937}

.ing-list{display:flex;flex-direction:column;gap:8px;margin:6px 0 4px}
.ing{
  background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13.5px;
}
.ing .ing-label{font-weight:600;color:var(--navy-2)}
.ing .ing-id{font-size:11px;color:var(--muted);font-weight:500;margin-left:6px}
.ing .evidence{margin-top:5px;color:#334155;font-style:italic;border-left:3px solid var(--saffron);padding-left:9px}
.ing .evidence.ungrounded{border-left-color:#ef4444}
.ing .warn{color:#b91c1c;font-style:normal;font-size:12px;margin-top:3px}

.unmet{margin-top:10px;font-size:13px;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:9px;padding:8px 11px}
.unmet b{color:#92400e}

.facts{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;padding-top:13px;border-top:1px dashed var(--line)}
.chip{font-size:12.5px;color:#1f2937;background:#eef2fb;border:1px solid #dce4f7;border-radius:8px;padding:6px 11px}
.chip b{color:var(--navy-2)}
.chip.ipc{background:#f4f4f5;border-color:#e4e4e7}

.label-tag{font-size:12px;color:var(--muted);margin-bottom:6px}

.notes{
  margin-top:18px;background:#f8fafc;border:1px solid var(--line);border-radius:12px;
  padding:14px 18px;font-size:13.5px;color:var(--muted);
}
.notes b{color:var(--text)}

.empty{margin-top:18px;text-align:center;color:var(--muted);padding:30px;font-size:15px}

.error-box{margin-top:18px;background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:12px;padding:14px 18px;font-size:14px}

.foot{max-width:920px;margin:30px auto 40px;padding:0 24px;text-align:center;color:var(--muted);font-size:12px}
.hidden{display:none}

@media(max-width:560px){
  .topbar{flex-direction:column;gap:10px;align-items:flex-start}
  .query-actions{flex-direction:column;align-items:stretch}
  .run-btn{width:100%}
}
