*{box-sizing:border-box}
:root{--bg:#f5f7fb;--card:#fff;--text:#0f172a;--muted:#64748b;--line:#dbe3ee;--primary:#0f4c81;--danger:#b91c1c;--shadow:0 10px 30px rgba(15,23,42,.06)}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,"Segoe UI",sans-serif;overflow-x:hidden}
button,input,select{font:inherit}
button{cursor:pointer}
.app{width:min(1580px,calc(100% - 24px));margin:0 auto;padding:16px 0 26px}
.topbar{display:flex;justify-content:space-between;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:18px}
.tag{display:inline-block;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:900;padding:5px 9px;border-radius:999px;text-transform:uppercase}
h1{margin:8px 0 0;font-size:34px;line-height:1}
h2{margin:0;font-size:17px}
p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.35}
.top-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.top-stats div{min-width:108px;border:1px solid var(--line);padding:10px 12px;background:#fbfdff}
.top-stats strong{display:block;font-size:24px}
.top-stats span{display:block;color:var(--muted);font-size:12px;font-weight:800}
.main-grid{display:grid;grid-template-columns:minmax(460px,560px) minmax(0,1fr);gap:16px;margin-top:16px;align-items:start}
.panel,.card{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:14px}
.panel{position:sticky;top:12px;max-height:calc(100vh - 24px);overflow:auto}
.panel-head,.chart-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.btn{border:1px solid var(--line);background:#fff;color:#0f172a;padding:10px 12px;font-weight:900;min-height:40px;font-size:13px}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.danger{border-color:#fecaca;background:#fff5f5;color:#991b1b}
.form-header,.party-row{display:grid;grid-template-columns:42px minmax(0,1fr) 128px 136px 42px;gap:8px;align-items:end}
.form-header{padding:0 10px 6px;color:#64748b;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.02em}
.party-list{display:grid;gap:9px}
.party-row{background:#fff;border:1px solid var(--line);padding:10px}
.color-num{width:42px;height:42px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px}
.field label{display:block;margin-bottom:5px;color:#475569;font-size:11px;font-weight:900}
.field input,.field select{width:100%;height:42px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;padding:8px 10px;font-weight:800;font-size:14px;outline:none}
.field input:focus,.field select:focus,.percent:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,76,129,.14)}
.name-input{font-size:15px!important;font-weight:900!important}
.percent{height:42px;display:grid;grid-template-columns:1fr 38px;border:1px solid #cbd5e1;background:#fff}
.percent input{border:0!important;height:40px;text-align:right;font-size:17px!important;font-weight:900!important;padding-right:8px;box-shadow:none!important}
.percent span{display:flex;align-items:center;justify-content:center;border-left:1px solid #cbd5e1;background:#f8fafc;font-weight:900;font-size:15px}
.delete{width:42px;height:42px;border:1px solid #fecaca;background:#fff5f5;color:#991b1b;font-size:21px;font-weight:900}
.options{display:grid;gap:8px;margin-top:10px}
.options label{display:flex;gap:9px;align-items:flex-start;border:1px solid var(--line);padding:9px;background:#fbfdff;font-weight:800;font-size:13px}
.options input{margin-top:3px;accent-color:var(--primary)}
.actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px}
.content{display:grid;gap:14px;min-width:0}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.metrics div{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:12px}
.metrics span{display:block;color:var(--muted);font-size:12px;font-weight:800}
.metrics strong{display:block;margin-top:4px;font-size:26px}
.alerts{display:grid;gap:8px}
.alert{border:1px solid var(--line);border-left:4px solid var(--primary);background:#fff;padding:11px 13px;font-size:14px}
.alert.warning{border-left-color:#b45309;background:#fff7ed}.alert.danger{border-left-color:#b91c1c;background:#fff1f2}
.svg-wrap{display:block;width:100%;max-width:100%;padding:6px;border:1px solid var(--line);background:#fff;overflow:hidden;-webkit-overflow-scrolling:touch;touch-action:manipulation}
#parliamentSvg{display:block;width:100%;height:auto;background:#fff;min-width:0}#fullscreenSvg{display:block;width:100%;height:auto;background:#fff;min-width:1200px}
.table-scroll{overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);margin-top:12px}
table{width:100%;border-collapse:collapse;min-width:760px}
th,td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}
th{background:#f8fafc;color:#64748b;text-transform:uppercase;font-size:12px}
.badge{display:inline-block;padding:5px 9px;font-size:12px;font-weight:900;background:#ecfdf5;color:#15803d}
.badge.no{background:#fff1f2;color:#b91c1c}.badge.minority{background:#ede9fe;color:#6d28d9}
.tooltip{position:fixed;z-index:20;background:#111827;color:#fff;padding:9px 11px;font-size:13px;pointer-events:none;box-shadow:0 12px 28px rgba(0,0,0,.25)}
.tooltip strong,.tooltip span{display:block}
.modal[hidden]{display:none}.modal{position:fixed;inset:0;z-index:30}
.modal-bg{position:absolute;inset:0;background:rgba(2,6,23,.72)}
.modal-box{position:relative;margin:2vh auto;width:min(96vw,1550px);height:96vh;background:#fff;display:grid;grid-template-rows:auto 1fr}
.modal-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding:12px 16px}
.modal-body{overflow:auto}
.site-footer{margin-top:18px;padding:14px 10px;text-align:center;color:#64748b;font-size:13px;font-weight:800}
@media(max-width:1200px){.app{width:min(100% - 20px,100%)}.main-grid{grid-template-columns:1fr}.panel{position:static;max-height:none}#parliamentSvg{min-width:900px}}
@media(max-width:900px){.topbar{display:grid;grid-template-columns:1fr;gap:14px;padding:16px}h1{font-size:30px}.panel-head,.chart-head{display:grid;grid-template-columns:1fr;gap:10px}.form-header{display:none}.party-row{grid-template-columns:42px minmax(0,1fr) 42px;grid-template-areas:"num name del" "pct pct pct" "type type type"}.color-num{grid-area:num}.name-field{grid-area:name}.percent-field{grid-area:pct}.type-field{grid-area:type}.delete{grid-area:del}.actions{grid-template-columns:1fr 1fr}.actions .danger{grid-column:1/-1}.metrics strong{font-size:22px}#parliamentSvg{min-width:820px}}
@media(max-width:620px){.app{width:100%;padding:8px 6px 22px}.topbar,.panel,.card{border-left:0;border-right:0}.top-stats,.metrics,.actions{grid-template-columns:1fr}.top-stats div{min-width:0}.party-row{grid-template-columns:1fr;grid-template-areas:"num" "name" "pct" "type" "del"}.color-num,.delete{width:100%;height:40px}.btn{width:100%}#parliamentSvg{min-width:720px}table{min-width:680px}th,td{padding:9px 10px;font-size:13px}}
@media(max-width:390px){h1{font-size:22px}#parliamentSvg{min-width:700px}.field input,.field select,.percent{height:42px}}


/* v23 smartphone/tablet compatibility fixes */
.chart-card,.table-card,.panel,.content{min-width:0}
.modal-body{overflow:auto;-webkit-overflow-scrolling:touch}

@media (max-width: 1200px){
  .app{width:min(100% - 18px,100%)}
  .main-grid{grid-template-columns:1fr}
  .panel{position:static;max-height:none}
}

@media (max-width: 900px){
  .topbar{display:grid;grid-template-columns:1fr;gap:14px;padding:16px}
  h1{font-size:30px}
  .panel,.card{padding:12px}
  .panel-head,.chart-head{display:grid;grid-template-columns:1fr;gap:10px}
  .form-header{display:none}
  .party-row{grid-template-columns:42px minmax(0,1fr) 42px;grid-template-areas:"num name del" "pct pct pct" "type type type"}
  .color-num{grid-area:num}.name-field{grid-area:name}.percent-field{grid-area:pct}.type-field{grid-area:type}.delete{grid-area:del}
  .top-stats,.metrics{grid-template-columns:repeat(3,minmax(0,1fr))}
  .actions{grid-template-columns:1fr 1fr}
  .actions .danger{grid-column:1/-1}
  #parliamentSvg{min-width:0;width:100%}
  .svg-wrap{overflow:hidden}
  .modal-box{width:100vw;height:100dvh;margin:0;border-radius:0}
  .modal-head{padding:10px 12px;position:sticky;top:0;background:#fff;z-index:2}
  .modal-head .btn{min-width:110px}
  #fullscreenSvg{min-width:1000px;width:1000px}
}

@media (max-width: 620px){
  .app{width:100%;padding:8px 6px 20px}
  .topbar,.panel,.card{border-left:0;border-right:0}
  h1{font-size:24px}
  .top-stats,.metrics,.actions{grid-template-columns:1fr}
  .top-stats div{min-width:0}
  .party-row{grid-template-columns:1fr;grid-template-areas:"num" "name" "pct" "type" "del"}
  .color-num,.delete,.btn{width:100%;height:40px}
  .name-input{font-size:14px!important}
  .field input,.field select{font-size:14px}
  .percent input{font-size:16px!important}
  #parliamentSvg{min-width:0;width:100%}
  .table-scroll{max-width:100%}
  table{min-width:680px}
  th,td{padding:9px 10px;font-size:13px}
  #fullscreenSvg{min-width:900px;width:900px}
}

@media (max-width: 390px){
  h1{font-size:22px}
  .field input,.field select,.percent{height:42px}
  #fullscreenSvg{min-width:820px;width:820px}
}


/* v25: buttons visible in fullscreen photo on smartphone/tablet */
.modal-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

.modal-head{
  gap:12px;
}

@media (max-width: 900px){
  .modal-box{
    width:100vw;
    height:100dvh;
    margin:0;
  }

  .modal-head{
    position:sticky;
    top:0;
    z-index:5;
    background:#fff;
    display:grid;
    grid-template-columns:1fr;
    align-items:start;
  }

  .modal-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    width:100%;
  }

  .modal-actions .btn{
    width:100%;
    min-height:42px;
  }

  .modal-body{
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }
}

@media (max-width: 420px){
  .modal-actions{
    grid-template-columns:1fr;
  }
}
