:root{
  --primary:#168447;
  --primary-2:#0f6b38;
  --primary-3:#0b4f2c;
  --accent:#22a65a;
  --accent-soft:#e9f8ef;
  --bg:#f5f7f4;
  --surface:#ffffff;
  --surface-soft:#f8fbf8;
  --line:#dfe7df;
  --line-strong:#c3d2c4;
  --text:#15231a;
  --muted:#66736a;
  --danger:#b42318;
  --ok:#168447;
  --warn:#b7791f;
  --radius:6px;
  --shadow:0 12px 28px rgba(15,77,43,.07);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;background:radial-gradient(circle at top left,rgba(34,166,90,.08),transparent 28rem),var(--bg);color:var(--text);font-family:Arial,"Helvetica Neue",sans-serif;font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button,input,select,textarea{font:inherit;min-width:0}
button{border:1px solid var(--primary);background:var(--primary);color:#fff;padding:9px 13px;border-radius:var(--radius);cursor:pointer;font-weight:700;line-height:1.15;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .12s ease,box-shadow .16s ease}
button:hover{background:var(--primary-2);border-color:var(--primary-2);box-shadow:0 5px 14px rgba(22,132,71,.16);transform:translateY(-1px)}
button:active{transform:translateY(0);box-shadow:none}
button.secondary{background:#fff;color:var(--text);border-color:var(--line-strong)}
button.secondary:hover{background:var(--accent-soft);border-color:#9cc9a9;color:var(--primary-3)}
button.warn{background:var(--danger);border-color:var(--danger);color:#fff}
button.accent,.accent{background:var(--primary);border-color:var(--primary);color:#fff}
button:disabled{opacity:.55;cursor:not-allowed;background:#eef2ee;border-color:#d7dfd7;color:#7a867e;box-shadow:none;transform:none}
a{color:var(--primary);font-weight:700;text-decoration:none}a:hover{text-decoration:underline}
pre{white-space:pre-wrap;background:#f7faf7;border:1px solid var(--line);border-radius:var(--radius);padding:10px;color:#26352a}
.app-shell{min-height:100vh;display:flex;flex-direction:column}
.topbar{background:rgba(255,255,255,.92);backdrop-filter:blur(12px);color:var(--text);padding:14px 22px;display:flex;justify-content:space-between;align-items:center;gap:12px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand{font-weight:800;font-size:16px;display:grid;grid-template-columns:36px 1fr;column-gap:10px;align-items:center;letter-spacing:-.01em;color:var(--text)}
.brand:before{content:"";width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#37bd70);box-shadow:inset 0 0 0 1px rgba(255,255,255,.32);display:block}
.brand small{grid-column:2;font-weight:400;color:var(--muted);font-size:12px;margin-top:1px}.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-chip{border:1px solid var(--line);background:#fff;padding:6px 9px;border-radius:999px;color:var(--muted);font-weight:700}
.layout{display:grid;grid-template-columns:244px 1fr;gap:18px;padding:18px;flex:1;min-height:0}.sidebar{background:rgba(255,255,255,.86);border:1px solid var(--line);padding:12px;border-radius:12px;height:max-content;position:sticky;top:82px;box-shadow:var(--shadow)}.nav-title{font-weight:800;color:var(--primary-3);margin:3px 4px 10px;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.nav{display:flex;flex-direction:column;gap:6px}.nav button{display:block;width:100%;margin:0;text-align:left;border-radius:8px;padding:10px 11px}.nav button.secondary{background:transparent;border-color:transparent;color:#405347}.nav button.secondary:hover{background:var(--accent-soft);border-color:transparent;color:var(--primary-3);box-shadow:none}.nav button.accent{background:var(--accent-soft);border-color:#bfe5cb;color:var(--primary-3);box-shadow:inset 3px 0 0 var(--primary);transform:none}.main{min-width:0}.card{background:rgba(255,255,255,.96);border:1px solid var(--line);padding:16px;margin-bottom:14px;border-radius:12px;box-shadow:var(--shadow)}.card h1,.card h2,.card h3{margin:0 0 11px;color:var(--primary-3);line-height:1.25;letter-spacing:-.015em}.card h1{font-size:22px}.card h2{font-size:18px}.card h3{font-size:15px}.card p{margin-top:0}.subtle{background:linear-gradient(180deg,#fff,var(--surface-soft));box-shadow:none}
.pipeline{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:14px 0 4px}.step{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fbf8);padding:12px;border-radius:10px;min-height:104px}.step b{color:var(--primary-3);font-size:14px}.step p{margin:7px 0 0}.step .num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--accent-soft);color:var(--primary);border:1px solid #bfe5cb;border-radius:8px;margin-right:7px;font-weight:800}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.two-col{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:14px}.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.row.nowrap{flex-wrap:nowrap}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}.field label{font-weight:800;color:#2d3d31;font-size:12px}.field input,.field select,.field textarea{border:1px solid var(--line-strong);padding:9px 10px;border-radius:var(--radius);background:#fff;color:var(--text);width:100%;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.field textarea{min-height:96px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(34,166,90,.14);background:#fff}
.table-wrap{overflow:auto;border:1px solid var(--line);background:#fff;border-radius:10px}table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;min-width:680px}th,td{border:0;border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}th{background:#f2f7f3;color:#314437;font-weight:800;white-space:nowrap;font-size:12px;text-transform:uppercase;letter-spacing:.035em}tbody tr:last-child td{border-bottom:0}tr:hover td{background:#fbfdfb}.compact-table table{min-width:520px}.kv{display:grid;grid-template-columns:150px 1fr;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}.kv div,.kv b{padding:9px;border-bottom:1px solid var(--line)}.kv b{color:var(--primary-3);background:#f7faf7}.kv div:nth-last-child(-n+2),.kv b:nth-last-child(-n+2){border-bottom:0}
.pill{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);padding:3px 8px;border-radius:999px;background:#f8fafc;font-weight:800;font-size:12px;white-space:nowrap}.pill.ok{color:var(--ok);border-color:#addbb9;background:#effaf2}.pill.warn{color:var(--warn);border-color:#ebd08e;background:#fff9e6}.pill.danger{color:var(--danger);border-color:#efb2ad;background:#fff4f2}.muted{color:var(--muted)}.error{color:var(--danger);font-weight:800}.success{color:var(--ok);font-weight:800}.login{max-width:440px;margin:10vh auto}.login.card{padding:24px}.login .logo{font-size:23px;color:var(--primary-3);font-weight:900;letter-spacing:-.02em}.capture-box{border:1px dashed #aacbb4;background:#f8fcf9;padding:12px;border-radius:10px;margin:10px 0}.capture-box input[type=file]{padding:9px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);width:100%}.mobile-only-note{display:none}.record-editor{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:14px}.json-area{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;min-height:190px}.flash{position:sticky;top:76px;z-index:18}.flash>div{background:#fff;border:1px solid currentColor;border-radius:10px;padding:9px 11px;margin-bottom:10px;box-shadow:var(--shadow)}.empty{border:1px dashed var(--line-strong);padding:16px;background:#fbfdfb;color:var(--muted);border-radius:10px;text-align:center}.stat{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f9fcf9);padding:14px;border-radius:12px;box-shadow:var(--shadow)}.stat strong{font-size:15px;color:var(--primary-3);display:block;margin-bottom:8px}.health-line{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
@media (max-width: 860px){
  body{font-size:13px}.topbar{align-items:flex-start;padding:12px}.layout{display:block;padding:10px}.sidebar{position:static;margin-bottom:10px;padding:10px;border-radius:10px}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.nav button{margin:0;text-align:center}.two-col,.record-editor{grid-template-columns:1fr}.pipeline{grid-template-columns:1fr 1fr}.card{padding:13px;margin-bottom:10px;border-radius:10px}.grid{grid-template-columns:1fr}.top-actions{justify-content:flex-end}.user-chip{display:none}.mobile-only-note{display:block}.table-wrap{margin-left:-2px;margin-right:-2px}table{min-width:620px}button{padding:9px 11px}.row.nowrap{flex-wrap:wrap}.flash{top:64px}
}
@media (max-width: 520px){
  .topbar{display:block}.top-actions{margin-top:10px}.brand{font-size:15px;grid-template-columns:32px 1fr}.brand:before{width:32px;height:32px;border-radius:9px}.nav{grid-template-columns:1fr}.pipeline{grid-template-columns:1fr}.login{margin:6vh 10px}.login.card{padding:18px}.card h1{font-size:19px}.card h2{font-size:17px}.kv{grid-template-columns:1fr}.kv b{border-bottom:0}.kv div{border-bottom:1px solid var(--line)}table{min-width:560px}.capture-box{padding:10px}.field input,.field select,.field textarea{font-size:16px}.layout{padding:8px}.topbar{position:static}.flash{top:0}
}


/* Mobile/tablet dashboard polish */
.dashboard{display:flex;flex-direction:column;gap:14px}
.dash-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:16px;background:linear-gradient(135deg,#ffffff 0%,#f0fbf4 100%);padding:20px}
.eyebrow{display:inline-flex;align-items:center;width:max-content;border:1px solid #bfe5cb;background:#eefaf2;color:var(--primary-3);border-radius:999px;padding:4px 9px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.dash-hero h1{font-size:26px;margin-bottom:8px}.dash-hero p{max-width:760px;color:#526158;margin-bottom:0}.hero-actions,.mobile-cta{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow);min-width:0}.metric-label{display:block;color:var(--muted);font-weight:800;font-size:12px}.metric strong{display:block;font-size:28px;line-height:1.05;color:var(--primary-3);margin:7px 0}.metric-desc{font-size:12px;color:var(--muted);font-weight:700}.metric-desc.ok{color:var(--ok)}.metric-desc.warn{color:var(--warn)}.dash-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:14px;align-items:start}.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px}.section-head h2{margin-bottom:3px}.section-head p{margin:0}.campaign-list{display:flex;flex-direction:column;gap:9px}.campaign-card{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;padding:12px;border-radius:12px;background:#fff;border:1px solid var(--line)}.campaign-card:hover{background:#f7fcf8;border-color:#bfe5cb}.campaign-card b{display:block;color:var(--text);font-size:14px;margin-bottom:2px}.campaign-card span.muted{display:block;font-weight:600;font-size:12px}.service-list{display:flex;flex-direction:column;gap:9px;margin:6px 0 14px}.service-row{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid var(--line);background:#fbfdfb;border-radius:10px;padding:9px 10px}.service-row>span{font-weight:800;color:#314437}
@media (min-width: 861px) and (max-width: 1180px){
  .layout{grid-template-columns:210px 1fr;gap:14px;padding:14px}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-grid{grid-template-columns:1fr}.pipeline{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 860px){
  html,body{background:#f6f8f5}.app-shell{padding-bottom:74px}.topbar{position:sticky;top:0;display:flex;align-items:center;background:rgba(255,255,255,.96);box-shadow:0 8px 24px rgba(15,77,43,.06)}.brand small{display:none}.top-actions button{padding:8px 10px}.layout{padding:10px 10px 14px}.sidebar{position:fixed;left:10px;right:10px;bottom:10px;top:auto;z-index:30;margin:0;padding:7px;border-radius:18px;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);box-shadow:0 16px 36px rgba(15,77,43,.16)}.nav-title{display:none}.nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.nav button{padding:10px 6px;border-radius:13px;text-align:center;font-size:12px;min-height:44px;display:flex;align-items:center;justify-content:center}.nav button.accent{box-shadow:inset 0 -3px 0 var(--primary);background:#e8f7ee}.dashboard{gap:10px}.dash-hero{grid-template-columns:1fr;padding:16px;border-radius:16px}.dash-hero h1{font-size:23px}.hero-actions{justify-content:stretch}.hero-actions button,.mobile-cta button{flex:1;min-height:42px}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.metric{padding:12px;border-radius:13px}.metric strong{font-size:24px}.dash-grid{grid-template-columns:1fr;gap:10px}.section-head{align-items:center}.campaign-card{padding:11px}.service-row{padding:10px}.pipeline{display:flex;overflow-x:auto;gap:9px;padding-bottom:2px;scroll-snap-type:x mandatory}.step{min-width:178px;scroll-snap-align:start;min-height:96px}.card{box-shadow:0 8px 22px rgba(15,77,43,.06)}
}
@media (max-width: 520px){
  .topbar{padding:10px 10px}.brand{grid-template-columns:30px 1fr;font-size:14px}.brand:before{width:30px;height:30px}.top-actions{margin-top:0}.layout{padding:8px}.dash-hero{padding:15px}.eyebrow{font-size:10px}.dash-hero h1{font-size:22px}.dash-hero p{font-size:13px}.metric-grid{grid-template-columns:1fr 1fr}.metric{padding:11px}.metric-label{font-size:11px}.metric strong{font-size:22px}.metric-desc{font-size:11px}.section-head{display:block}.section-head button{margin-top:8px;width:100%}.campaign-card{align-items:flex-start}.campaign-card .pill{margin-top:2px}.mobile-cta{display:grid;grid-template-columns:1fr 1fr}.nav{grid-template-columns:repeat(3,minmax(0,1fr))}.nav button{font-size:11px;padding:8px 4px}.nav button:nth-child(4){grid-column:1 / -1}.pipeline{margin-left:-2px;margin-right:-2px}.step{min-width:164px}.card{border-radius:14px}.login{margin:7vh 10px 12vh}
}
