/* ============================================================
   Synergetic LPG Inspection Portal — Stylesheet
   ============================================================ */
:root {
  --green:#4a7c59; --green-dk:#2f5239; --green-lt:#e8f1eb; --green-mid:#c2d9c8;
  --amber:#b45309; --amber-lt:#fef3c7;
  --red:#b91c1c; --red-lt:#fee2e2;
  --blue:#1d4ed8; --blue-lt:#eff6ff;
  --purple:#6d28d9; --purple-lt:#f5f3ff;
  --page:#f5f4f0; --surface:#ffffff;
  --border:#e0ddd6; --border-dk:#c8c4bb;
  --txt:#1c1917; --txt-2:#57534e; --txt-3:#a8a29e;
  --radius:10px; --radius-sm:6px;
  --font:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
body{font-family:var(--font);background:var(--page);color:var(--txt);min-height:100vh}

.ti{display:inline-block;overflow:hidden;max-width:1.5em;vertical-align:middle;line-height:1}

/* ── header ── */
.app-header{background:var(--green-dk);color:#fff;height:56px;display:flex;align-items:center;
  justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:28px;height:28px;background:rgba(255,255,255,.18);border-radius:6px;display:flex;
  align-items:center;justify-content:center;font-size:15px;font-weight:600;letter-spacing:-.5px}
.brand-name{font-size:14px;font-weight:600;letter-spacing:.02em}
.hdr-right{display:flex;align-items:center;gap:10px}
.role-pill{background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:11px;font-weight:600;
  padding:3px 10px;border-radius:20px;letter-spacing:.02em;display:flex;align-items:center;gap:5px}
.role-pill .ti{font-size:13px}
.hdr-btn{background:rgba(255,255,255,.12);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.2);
  font-size:11px;font-weight:500;padding:5px 12px;border-radius:6px;cursor:pointer;
  display:flex;align-items:center;gap:5px;transition:background .15s;font-family:var(--font)}
.hdr-btn:hover{background:rgba(255,255,255,.22)}
.hdr-user{font-size:12px;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:6px}
.hdr-avatar{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;
  align-items:center;justify-content:center;font-size:11px;font-weight:600;letter-spacing:.02em}

/* ── layout ── */
.wrap{max-width:1040px;margin:0 auto;padding:28px 20px}
.screen{display:none}.screen.active{display:block}

/* ── login ── */
.login-wrap{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:40px;width:420px;max-width:100%}
.login-logo{text-align:center;margin-bottom:32px}
.login-logo .logo-mark{width:56px;height:56px;background:var(--green-lt);border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 12px;
  color:var(--green);font-size:28px}
.login-logo .logo-title{font-size:20px;font-weight:600;margin-bottom:4px}
.login-logo .logo-sub{font-size:13px;color:var(--txt-2)}
.login-err{background:var(--red-lt);color:var(--red);border:1px solid #fca5a5;border-radius:var(--radius-sm);
  padding:10px 14px;font-size:13px;margin-bottom:16px;display:none;align-items:center;gap:8px}
.login-err.show{display:flex}

/* ── typography ── */
.page-title{font-size:22px;font-weight:600;color:var(--txt);line-height:1.2}
.page-sub{font-size:13px;color:var(--txt-2);margin-top:4px}

/* ── cards ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:14px;overflow:hidden}
.card-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;
  align-items:center;justify-content:space-between}
.card-head h2{font-size:14px;font-weight:600;color:var(--txt);display:flex;align-items:center;gap:8px}
.card-head h2 .ti{color:var(--green);font-size:16px}
.card-body{padding:20px}
.card-body.tight{padding:0}

/* ── buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);
  border:1px solid transparent;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;
  transition:all .15s;white-space:nowrap;text-decoration:none}
.btn .ti{font-size:15px}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green-dk)}
.btn-primary:hover{background:var(--green-dk)}
.btn-secondary{background:var(--green-lt);color:var(--green-dk);border-color:var(--green-mid)}
.btn-secondary:hover{background:var(--green-mid)}
.btn-ghost{background:transparent;color:var(--txt-2);border-color:var(--border)}
.btn-ghost:hover{background:var(--page);border-color:var(--border-dk)}
.btn-danger{background:var(--red-lt);color:var(--red);border-color:#fca5a5}
.btn-danger:hover{background:#fecaca}
.btn-admin{background:var(--purple-lt);color:var(--purple);border-color:#c4b5fd}
.btn-admin:hover{background:#ede9fe}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-sm .ti{font-size:14px}
.btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}

/* ── form fields ── */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ff label{display:block;font-size:12px;font-weight:500;color:var(--txt-2);margin-bottom:5px}
.ff input,.ff select,.ff textarea{width:100%;padding:9px 12px;border:1px solid var(--border);
  border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;color:var(--txt);
  background:var(--surface);transition:border-color .15s,box-shadow .15s;outline:none}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-lt)}
.ff input[readonly],.ff input:disabled{background:var(--page);color:var(--txt-2)}

/* ── breadcrumb ── */
.bc{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--txt-3);margin-bottom:20px;flex-wrap:wrap}
.bc a{color:var(--green);cursor:pointer;text-decoration:none;font-weight:500;display:flex;align-items:center;gap:4px}
.bc a:hover{text-decoration:underline}
.bc-sep{color:var(--border-dk)}

/* ── stat grid ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}
.stat-lbl{font-size:11px;font-weight:500;color:var(--txt-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.stat-val{font-size:28px;font-weight:600;color:var(--txt);line-height:1}
.stat-val.green{color:var(--green)}.stat-val.amber{color:var(--amber)}.stat-val.red{color:var(--red)}

/* ── sites grid ── */
.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px}
.site-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px;cursor:pointer;transition:border-color .15s,transform .12s}
.site-card:hover{border-color:var(--green);transform:translateY(-1px)}
.sc-name{font-size:14px;font-weight:600;margin-bottom:3px}
.sc-loc{font-size:12px;color:var(--txt-2);margin-bottom:14px;display:flex;align-items:center;gap:4px}
.sc-loc .ti{font-size:13px;color:var(--txt-3)}
.site-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:5px}
.site-bar-fill{height:100%;border-radius:3px;transition:width .4s}
.sc-pct{font-size:12px;font-weight:600}
.sc-date{font-size:11px;color:var(--txt-3);margin-top:5px}

/* ── inspection list ── */
.ih-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;
  border-bottom:1px solid var(--border);gap:12px}
.ih-row:last-child{border-bottom:none}
.ih-row:hover{background:var(--page)}
.ih-left{flex:1}
.ih-date{font-size:14px;font-weight:600;margin-bottom:3px;display:flex;align-items:center;gap:8px}
.ih-meta{font-size:12px;color:var(--txt-2);display:flex;align-items:center;gap:6px}
.ih-meta .ti{font-size:13px;color:var(--txt-3)}
.ih-acts{display:flex;gap:8px;flex-shrink:0}

/* ── discipline status ── */
.disc-status-row{display:flex;align-items:center;gap:14px;padding:14px 20px;
  border-bottom:1px solid var(--border);flex-wrap:wrap}
.disc-status-row:last-child{border-bottom:none}
.ds-label{font-size:13px;font-weight:600;min-width:200px}
.ds-secs{font-size:12px;color:var(--txt-2);flex:1}
.ds-code{font-family:'Courier New',monospace;font-size:15px;font-weight:700;color:var(--green-dk);
  background:var(--green-lt);padding:4px 10px;border-radius:var(--radius-sm);
  letter-spacing:.1em;min-width:70px;text-align:center}

/* ── discipline group rows ── */
.dg-row{display:flex;align-items:center;gap:12px;padding:13px 20px;
  border-bottom:1px solid var(--border);flex-wrap:wrap}
.dg-row:last-child{border-bottom:none}
.dg-input{padding:7px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-family:var(--font);font-size:13px;font-weight:500;color:var(--txt);
  background:var(--surface);outline:none;transition:border-color .15s}
.dg-input:focus{border-color:var(--green)}
.dg-secs{font-size:12px;color:var(--txt-2);flex:1;min-width:120px}

/* ── badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;
  font-size:11px;font-weight:600;white-space:nowrap}
.badge .ti{font-size:12px}
.b-green{background:var(--green-lt);color:var(--green-dk)}
.b-amber{background:var(--amber-lt);color:var(--amber)}
.b-red{background:var(--red-lt);color:var(--red)}
.b-grey{background:var(--page);color:var(--txt-2);border:1px solid var(--border)}
.b-blue{background:var(--blue-lt);color:var(--blue)}
.b-purple{background:var(--purple-lt);color:var(--purple)}

/* ── admin user table ── */
.user-row{display:flex;align-items:center;gap:14px;padding:12px 20px;
  border-bottom:1px solid var(--border)}
.user-row:last-child{border-bottom:none}
.user-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}
.ua-admin{background:var(--purple-lt);color:var(--purple)}
.ua-coord{background:var(--green-lt);color:var(--green-dk)}
.ua-insp{background:var(--blue-lt);color:var(--blue)}
.user-name{font-size:13px;font-weight:600;flex:1}
.user-meta{font-size:12px;color:var(--txt-2)}
.user-acts{display:flex;gap:6px}

/* ── form (checklist) ── */
.form-layout{display:flex;gap:16px;align-items:flex-start}
.form-nav{width:220px;flex-shrink:0;position:sticky;top:72px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.form-nav .nav-head{padding:12px 16px;font-size:11px;font-weight:600;color:var(--txt-3);
  text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}
.nav-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;
  cursor:pointer;font-size:12px;color:var(--txt-2);border-left:3px solid transparent;
  transition:all .12s;gap:8px}
.nav-item:hover{background:var(--page);color:var(--txt)}
.nav-item.active{background:var(--green-lt);color:var(--green-dk);font-weight:600;border-left-color:var(--green)}
.nav-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;
  background:var(--page);color:var(--txt-3);flex-shrink:0}
.nav-item.active .nav-badge{background:rgba(74,124,89,.15);color:var(--green-dk)}
.form-panels{flex:1;min-width:0}
.prog-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:5px;width:280px}
.prog-fill{height:100%;background:var(--green);border-radius:2px;transition:width .3s}
.sec-panel{display:none}.sec-panel.active{display:block}
.item-group-header{background:var(--green-lt);color:var(--green-dk);font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;padding:6px 16px;border-left:3px solid var(--green)}
.item-row{display:flex;align-items:flex-start;gap:10px;padding:11px 18px;
  border-bottom:1px solid var(--border);background:var(--surface);transition:background .1s}
.item-row:nth-child(even){background:#fafaf9}
.item-row.flagged{background:#fff5f5}
.item-row:last-child{border-bottom:none}
.item-num{min-width:22px;font-size:11px;color:var(--txt-3);font-weight:500;padding-top:2px;flex-shrink:0}
.item-text{flex:1;font-size:13px;line-height:1.55;color:var(--txt);max-width:680px}
.item-comment{display:none;width:100%;margin-top:8px;padding:7px 10px;border:1px solid var(--border);
  border-radius:var(--radius-sm);font-family:var(--font);font-size:12px;resize:vertical;min-height:38px;outline:none}
.item-comment:focus{border-color:var(--green)}
.item-comment.vis{display:block}
.item-ctrl{display:flex;align-items:center;gap:6px;flex-shrink:0}
.yn-group{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.yn-btn{padding:5px 11px;border:none;background:var(--surface);cursor:pointer;font-size:11px;
  font-weight:600;font-family:var(--font);color:var(--txt-2);transition:all .1s;
  border-right:1px solid var(--border);line-height:1}
.yn-btn:last-child{border-right:none}
.yn-btn:hover{background:var(--page)}
.yn-btn.yes.a{background:var(--green);color:#fff;border-right-color:var(--green-dk)}
.yn-btn.no.a{background:var(--red);color:#fff;border-right-color:#991b1b}
.yn-btn.na.a{background:var(--txt-2);color:#fff;border-right-color:#3c3836}
.comment-btn{background:none;border:none;cursor:pointer;color:var(--txt-3);font-size:16px;
  padding:4px;border-radius:4px;transition:color .12s,background .12s;display:flex;align-items:center}
.comment-btn:hover{color:var(--green);background:var(--green-lt)}
.submit-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 20px;display:flex;align-items:center;justify-content:space-between;margin-top:20px}
.submit-bar-right{display:flex;gap:10px}

/* ── inspector landing ── */
.code-input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius);
  font-family:'Courier New',monospace;font-size:26px;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;text-align:center;color:var(--green-dk);background:var(--surface);
  outline:none;transition:border-color .15s,box-shadow .15s}
.code-input:focus{border-color:var(--green);box-shadow:0 0 0 4px var(--green-lt)}
.pending-item{display:flex;align-items:center;gap:14px;padding:14px 20px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.pending-item:last-child{border-bottom:none}
.pending-item:hover{background:var(--page)}
.pending-icon{width:38px;height:38px;background:var(--green-lt);border-radius:8px;display:flex;
  align-items:center;justify-content:center;color:var(--green);font-size:18px;flex-shrink:0}
.pending-label{font-size:14px;font-weight:600;margin-bottom:2px}
.pending-meta{font-size:12px;color:var(--txt-2)}

/* ── report ── */
.report-score{font-size:48px;font-weight:600;line-height:1}
.report-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;font-size:13px;margin-top:16px}
.rml{font-size:11px;color:var(--txt-3);margin-bottom:2px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}
.rmv{font-weight:600}
.sec-score-row{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}
.sec-score-row:last-child{border-bottom:none}
.sec-score-name{flex:1}.sec-score-insp{font-size:11px;color:var(--txt-3);min-width:130px}
.sec-score-bar{width:100px;height:5px;background:var(--border);border-radius:3px;overflow:hidden;flex-shrink:0}
.sec-score-fill{height:100%;border-radius:3px}
.sec-score-pct{min-width:40px;text-align:right;font-weight:600;font-size:12px}
.flags-table{width:100%;border-collapse:collapse;font-size:13px}
.flags-table th{background:var(--green-dk);color:#fff;padding:9px 14px;text-align:left;font-weight:500;font-size:12px}
.flags-table td{padding:9px 14px;border-bottom:1px solid var(--border);vertical-align:top}
.flags-table tr:last-child td{border-bottom:none}
.flags-table tr:nth-child(even) td{background:var(--page)}
.flag-num{width:28px;height:28px;background:var(--red-lt);color:var(--red);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}

/* ── share code block ── */
.code-block{background:var(--green-lt);border:1.5px solid var(--green-mid);border-radius:var(--radius);
  padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.cb-label{font-size:12px;color:var(--green-dk);font-weight:500}
.cb-code{font-family:'Courier New',monospace;font-size:22px;font-weight:700;color:var(--green-dk);letter-spacing:.15em}
.cb-copy{background:var(--green-dk);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 14px;
  font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:5px;
  font-family:var(--font);transition:background .15s;flex-shrink:0}
.cb-copy:hover{background:#1d3a27}

/* ── modal ── */
.ov{display:none;position:fixed;inset:0;background:rgba(28,25,23,.45);z-index:200;
  align-items:center;justify-content:center;padding:20px}
.ov.open{display:flex}
.mo{background:var(--surface);border-radius:12px;padding:28px;width:500px;max-width:100%;
  max-height:85vh;overflow-y:auto;border:1px solid var(--border)}
.mo h3{font-size:17px;font-weight:600;margin-bottom:6px}
.mo .mo-sub{font-size:13px;color:var(--txt-2);margin-bottom:20px;line-height:1.5}
.mo-act{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}

/* ── alerts ── */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:14px;
  display:flex;align-items:flex-start;gap:10px}
.alert .ti{font-size:16px;flex-shrink:0;margin-top:1px}
.alert-info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}
.alert-success{background:var(--green-lt);color:var(--green-dk);border:1px solid var(--green-mid)}
.alert-warn{background:var(--amber-lt);color:var(--amber);border:1px solid #fcd34d}

/* ── toast ── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--txt);color:#fff;padding:12px 20px;
  border-radius:var(--radius);font-size:13px;font-weight:500;opacity:0;
  transition:opacity .25s,transform .25s;transform:translateY(6px);z-index:300;
  pointer-events:none;display:flex;align-items:center;gap:8px;max-width:320px}
.toast .ti{font-size:16px;color:#86efac}
.toast.show{opacity:1;transform:translateY(0)}

/* ── misc ── */
.page-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-actions-left{display:flex;flex-direction:column}
.page-actions-right{display:flex;gap:8px;flex-wrap:wrap}
.empty-state{padding:40px 20px;text-align:center;color:var(--txt-3)}
.empty-state .ti{font-size:36px;margin-bottom:12px;display:block}
.empty-state p{font-size:14px}
.section-sep{height:1px;background:var(--border);margin:20px 0}
.access-denied{text-align:center;padding:60px 20px;color:var(--txt-3)}
.access-denied .ti{font-size:48px;color:var(--red);margin-bottom:16px;display:block}
.access-denied h2{font-size:18px;font-weight:600;color:var(--txt);margin-bottom:8px}
.access-denied p{font-size:14px}

/* ── session discipline groups ── */
.dg-group-card{border-bottom:1px solid var(--border);padding:16px 20px}
.dg-group-card:last-child{border-bottom:none}
.dg-group-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.dg-sec-picks{background:var(--page);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-top:4px}
.dg-sec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
.dg-sec-summary{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;color:var(--txt-2)}
.dg-sec-hidden{display:none}

/* ── checklist editor ── */
.cl-section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}
.cl-section-head{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--page);flex-wrap:wrap}
.cl-section-title-input{flex:1;padding:7px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;font-weight:600;color:var(--txt);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}
.cl-section-title-input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-lt)}
.cl-items-list{padding:0}
.cl-item-row{display:flex;align-items:flex-start;gap:10px;padding:9px 16px;border-bottom:1px solid var(--border);background:var(--surface);transition:background .1s}
.cl-item-row:nth-child(even){background:transparent}
.cl-item-row:last-child{border-bottom:none}
.cl-item-row.is-header{background:var(--green-lt);padding:7px 16px}
.cl-item-type{font-size:11px;color:var(--txt-3);padding-top:3px;min-width:32px;flex-shrink:0;display:flex;align-items:flex-start}
.cl-item-type.hdr{color:var(--green-dk)}
.cl-item-type.hdr i{font-size:15px;line-height:1}
.cl-item-input{flex:1;padding:6px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;line-height:1.55;color:var(--txt);background:var(--surface);outline:none;resize:none;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.cl-item-input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-lt)}
.cl-item-acts{display:flex;gap:3px;flex-shrink:0;padding-top:2px}
.cl-icon-btn{background:none;border:none;cursor:pointer;color:var(--txt-3);font-size:15px;padding:4px 5px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .12s,background .12s}
.cl-icon-btn:hover{color:var(--red);background:var(--red-lt)}
.cl-icon-btn.add:hover{color:var(--green);background:var(--green-lt)}

/* ── template card ── */
.tpl-card{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .12s}
.tpl-card:last-child{border-bottom:none}
.tpl-card:hover{background:var(--page)}
.tpl-icon{width:36px;height:36px;background:var(--blue-lt);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:17px;flex-shrink:0}
.tpl-name{font-size:13px;font-weight:600;margin-bottom:2px}
.tpl-meta{font-size:12px;color:var(--txt-2)}
.fullsite-banner{background:var(--green-lt);border:1px solid var(--green-mid);
  border-radius:var(--radius-sm);padding:8px 14px;font-size:12px;color:var(--green-dk);
  font-weight:500;display:flex;align-items:center;gap:8px;margin-bottom:12px}

/* ── spinner ── */
.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:700px){
  .fg{grid-template-columns:1fr}
  .form-layout{flex-direction:column}
  .form-nav{width:100%;position:static}
  .stat-grid{grid-template-columns:1fr 1fr}
  .report-meta-grid{grid-template-columns:1fr 1fr}
  .wrap{padding:16px 12px}
}
@media print{
  .app-header,.bc,.btn,.form-nav,.no-print,.submit-bar{display:none!important}
  body{background:#fff}
  .card{box-shadow:none;border:1px solid #ddd}
  .sec-panel{display:block!important}
}
