
:root{
  --bg:#f4f7fb;
  --card:#ffffff;
  --text:#122033;
  --muted:#5c6b80;
  --line:#d9e2ef;
  --primary:#185799;
  --primary-2:#0d4178;
  --danger:#b52929;
  --ok:#1a7f4b;
  --shadow:0 10px 30px rgba(15,35,60,.08);
  --radius:20px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
body{min-height:100vh}
button,input,select,textarea{font:inherit}
.app-shell{max-width:980px;margin:0 auto;padding:env(safe-area-inset-top) 14px env(safe-area-inset-bottom)}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 6px 8px}
.eyebrow{margin:0;color:var(--primary);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}
h1{margin:.15rem 0 0;font-size:1.75rem}
h2{margin:0;font-size:1.2rem}
h3{margin:0;font-size:1rem}
.container{display:grid;gap:14px;padding-bottom:32px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.card-head,.subsection-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.muted{margin:.2rem 0 0;color:var(--muted);font-size:.95rem}
.badge{background:#edf5ff;color:var(--primary);border:1px solid #cfe0f6;border-radius:999px;padding:8px 12px;font-size:.9rem;font-weight:600;white-space:nowrap}
.role-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0 16px}
.role-tab{border:1px solid var(--line);background:#f8fbff;color:var(--text);padding:12px 10px;border-radius:14px;font-weight:700}
.role-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.operators-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
label{display:flex;flex-direction:column;gap:6px}
label span{font-size:.92rem;font-weight:600}
input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px 14px;min-height:48px;color:var(--text)}
textarea{resize:vertical}
input[readonly]{background:#f5f7fa;color:#596579}
.full-width{margin-top:12px}
.sticky-summary{position:sticky;top:8px;z-index:3}
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.summary-grid>div{background:#f8fbff;border:1px solid #d9e8f7;border-radius:16px;padding:12px}
.summary-label{display:block;color:var(--muted);font-size:.85rem;margin-bottom:4px}
.checklist-container{display:grid;gap:12px}
.item-card{border:1px solid var(--line);border-radius:18px;padding:14px;background:#fcfdff}
.item-top{display:flex;gap:10px;align-items:flex-start}
.item-number{width:34px;height:34px;display:grid;place-items:center;border-radius:999px;background:#edf5ff;color:var(--primary);font-weight:800;flex:0 0 auto}
.item-title{margin:0;font-size:1rem}
.item-meta{margin:.2rem 0 0;color:var(--muted);font-size:.86rem}
.item-grid{display:grid;grid-template-columns:170px 1fr 80px;gap:10px;margin-top:12px;align-items:end}
.points-box{background:#f8fbff;border:1px dashed #cbd7ea;border-radius:14px;padding:10px 12px;min-height:48px;display:flex;align-items:center;justify-content:center;font-weight:800}
.actions{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
button{border:none;border-radius:14px;padding:13px 14px;background:#eaf0f7;color:var(--text);font-weight:700;cursor:pointer}
button.primary{background:var(--primary);color:#fff}
button.danger{background:#fdecec;color:var(--danger)}
button.ghost-btn{background:#fff;border:1px solid var(--line)}
button:disabled{opacity:.55;cursor:not-allowed}
.info-box{margin-top:14px;border-left:4px solid var(--primary);background:#f8fbff;padding:12px 14px;border-radius:12px}
.publish-list{margin:0;padding-left:18px;color:var(--text)}
.message{margin-top:14px;padding:12px 14px;border-radius:12px;background:#eff8f1;color:#175936;border:1px solid #cfe7d6}
.message.error{background:#fff1f1;color:#8d2020;border-color:#f0cccc}
.hidden{display:none !important}
code{background:#f2f4f8;padding:2px 6px;border-radius:6px}
@media (max-width: 760px){
  .app-shell{padding-left:10px;padding-right:10px}
  h1{font-size:1.45rem}
  .grid,.operators-grid,.summary-grid,.actions,.item-grid{grid-template-columns:1fr}
  .role-tabs{grid-template-columns:1fr}
  .card{padding:14px}
  .sticky-summary{position:static}
}
