
:root{
  --bg:#f3f6fb;
  --bg-accent:#eef4ff;
  --panel:#ffffff;
  --panel2:#f8fbff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#dbe4f0;
  --primary:#1d4ed8;
  --primary-soft:#dbeafe;
  --success:#15803d;
  --warning:#d97706;
  --danger:#dc2626;
  --shadow:0 18px 40px rgba(15,23,42,.08);
  --shadow-soft:0 8px 22px rgba(15,23,42,.06);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,sans-serif;
  background:radial-gradient(circle at top left, var(--bg-accent), transparent 36%), var(--bg);
  color:var(--text);
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:none}
img{max-width:100%}
/* Layout */
.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:288px;
  background:linear-gradient(180deg,#0f172a 0%,#172554 100%);
  color:#e2e8f0;
  padding:22px 16px;
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;
}
.brand{
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
}
.brand-title{font-weight:800;font-size:20px;letter-spacing:.2px;color:#fff}
.brand-sub{margin-top:4px;font-size:13px;color:#cbd5e1}
.nav{margin-top:18px;display:flex;flex-direction:column;gap:8px}
.nav-link{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:14px;
  text-decoration:none;color:#dbeafe;
  border:1px solid transparent;
  transition:.18s ease;
}
.nav-link:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.08);transform:translateX(2px)}
.nav-link.active{background:#eff6ff;color:#0f172a;border-color:#bfdbfe;font-weight:800}
.nav-sep{height:1px;background:rgba(255,255,255,.08);margin:10px 0}
.sidebar-footer{margin-top:auto;font-size:11px;color:#94a3b8;padding:10px 12px;line-height:1.5}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:rgba(243,246,251,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:18px 24px;position:sticky;top:0;z-index:5;
}
.page-title{font-weight:800;font-size:22px;letter-spacing:-.02em}
.page-subtitle{margin-top:4px;color:var(--muted);font-size:13px}
.topbar-right{display:flex;align-items:center;gap:10px}
.content{padding:24px}
.container{width:1240px;max-width:100%;margin:0 auto}
/* Common */
.h1{font-size:26px;font-weight:800;letter-spacing:-.02em;margin:0}
.h2{font-size:18px;font-weight:800;margin:0}
.muted{color:var(--muted)}
.small{font-size:12px}
.row-between{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.row-gap{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline{display:inline}
.stack{display:flex;flex-direction:column;gap:14px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.page-header p{margin:6px 0 0;color:var(--muted)}
.card{
  background:var(--panel);
  border:1px solid rgba(219,228,240,.95);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}
.card-title{
  padding:16px 18px;
  border-bottom:1px solid var(--border);
  font-weight:800;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.card-body{padding:18px}
.card-actions{padding:16px 18px;border-top:1px solid var(--border);display:flex;gap:10px;flex-wrap:wrap;background:#fcfdff}
.section-note{color:var(--muted);font-size:13px;margin-top:4px}
.alert{border:1px solid var(--border);border-radius:16px;padding:13px 15px;background:var(--panel);box-shadow:var(--shadow-soft)}
.alert-warn{border-color:#fcd34d;background:#fffbeb}
.alert-good{border-color:#86efac;background:#f0fdf4}
.btn{
  appearance:none;border:1px solid var(--border);background:#fff;color:var(--text);
  padding:10px 14px;border-radius:14px;font-weight:700;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;transition:.18s ease;box-shadow:0 1px 0 rgba(255,255,255,.7) inset;
}
.btn:hover{background:var(--panel2);transform:translateY(-1px);box-shadow:var(--shadow-soft)}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:8px 11px;border-radius:12px;font-size:13px}
.btn-primary{background:linear-gradient(180deg,#2563eb,#1d4ed8);border-color:#1d4ed8;color:#fff}
.btn-primary:hover{filter:brightness(.98);background:linear-gradient(180deg,#2563eb,#1d4ed8)}
.btn-danger{background:linear-gradient(180deg,#ef4444,#dc2626);border-color:#dc2626;color:#fff}
.btn-danger:hover{filter:brightness(.98)}
.btn-ghost{background:#f8fafc}
.chip,.pill,.badge{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;border:1px solid var(--border);background:var(--panel2);color:var(--text);font-size:12px;font-weight:800}
.chip{background:#fff}
.pill-success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.pill-warning{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.pill-danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.input,.select,textarea{
  width:100%;padding:12px 13px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);outline:none;
  transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;
}
textarea{resize:vertical;min-height:120px}
.input:focus,.select:focus,textarea:focus{border-color:rgba(37,99,235,.6);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.form label{display:block;font-size:12px;color:var(--muted);margin:0 0 7px 2px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.stat-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--border);box-shadow:var(--shadow-soft)}
.stat-label{font-size:13px;color:var(--muted);font-weight:700}
.big-number{font-size:38px;font-weight:800;line-height:1;margin:10px 0 6px;letter-spacing:-.04em}
.search-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.table-wrap{overflow:auto;border-radius:18px;border:1px solid var(--border);background:#fff}
.table{width:100%;border-collapse:collapse;min-width:840px;background:#fff}
.table th,.table td{padding:12px 14px;border-bottom:1px solid #edf2f7;text-align:left;font-size:14px;vertical-align:middle}
.table th{background:#f8fbff;color:var(--muted);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.table tr:hover td{background:#fbfdff}
.table td.actions{white-space:nowrap}
.kv{display:grid;grid-template-columns:160px 1fr;gap:12px 16px;padding:18px}
.kv-item{display:contents}
.k{color:var(--muted);font-weight:700}
.v{font-weight:700;word-break:break-word}
.client-summary{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.client-photo,.avatar-placeholder{width:84px;height:84px;border-radius:22px;object-fit:cover;background:#eff6ff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--muted)}
.record-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:520px;max-width:100%;background:var(--panel);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow)}
.login-card .head{padding:22px 22px 0}.login-card .body{padding:22px}
.print-wrap{max-width:900px;margin:0 auto}
@media (max-width: 1024px){
  .sidebar{width:230px}
  .stats-grid,.grid3{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .app-shell{display:block}
  .sidebar{position:relative;height:auto;width:auto;border-radius:0}
  .topbar{padding:16px}
  .content{padding:16px}
  .grid2,.kv{grid-template-columns:1fr}
  .kv{padding:16px}
  .page-title{font-size:20px}
  .table{min-width:680px}
}
@media print{
  .sidebar,.topbar,.btn,.card-actions{display:none !important}
  .content,.container{padding:0 !important;width:100% !important;max-width:none !important}
  body{background:#fff}
  .card{box-shadow:none;border:0}
}


.card-header{padding:18px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:14px;background:linear-gradient(180deg,#ffffff,#f8fbff)}
.grid{display:grid;gap:14px}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.placeholder{color:var(--muted);background:#f8fafc}
.pill-ok{background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.pill-bad{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.editor-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(420px,.9fr);gap:18px;align-items:start}
.editor-main,.editor-side{min-width:0}
.sticky-card{position:sticky;top:94px}
.form-editor-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-section{grid-column:1 / -1;padding-top:4px}
.form-section-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);padding-bottom:10px;border-bottom:1px solid var(--border)}
.form-field{min-width:0}
.form-field.is-full{grid-column:1 / -1}
.form-field.is-half{grid-column:span 1}
.form-field textarea{min-height:124px}
.form-editor-actions{grid-column:1 / -1;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;padding-top:4px}
.form-editor-head{margin-bottom:16px}
.draw-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:16px;background:#f8fbff;margin-bottom:14px}
.draw-toolbar .sep{width:1px;align-self:stretch;background:var(--border)}
.tool-inline{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;background:#fff;border:1px solid var(--border);font-size:13px;font-weight:700;color:var(--muted)}
.tool-inline input[type="range"]{width:120px}
.tool-inline input[type="color"]{width:42px;height:34px;padding:0;border:0;background:transparent}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.tab{appearance:none;border:1px solid var(--border);background:#fff;color:var(--muted);padding:10px 14px;border-radius:12px;font-weight:800;cursor:pointer;transition:.18s ease}
.tab:hover{background:#f8fbff;color:var(--text)}
.tab.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 10px 22px rgba(37,99,235,.18)}
.tab-pane{display:none}
.tab-pane.active{display:block}
.form-canvas{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-soft)}
.form-bg{display:block;width:100%;height:auto}
.draw-layer{position:absolute;left:0;top:0;width:100%;height:100%;touch-action:none;cursor:crosshair}
.hint{margin-top:12px;padding:12px 14px;border-radius:14px;background:#f8fbff;border:1px dashed #bfd3f8;color:var(--muted);font-size:13px}
.no-print{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:12px}
.print-page{break-inside:avoid;page-break-inside:avoid}
@media (max-width: 1180px){
  .editor-layout{grid-template-columns:1fr}
  .sticky-card{position:static}
}
@media (max-width: 860px){
  .form-editor-form{grid-template-columns:1fr}
  .form-field.is-half,.form-field.is-full{grid-column:1 / -1}
  .tool-inline input[type="range"]{width:90px}
}

