:root{
  --bg:#f5f8f3;
  --bg-soft:#eef5ee;
  --panel:#ffffff;
  --panel-2:#fbfef9;
  --panel-3:#f6fbf4;
  --text:#243229;
  --text-soft:#4b6252;
  --muted:#78907d;
  --line:#d7e4d7;
  --line-strong:#c2d7c2;
  --primary:#6e9b74;
  --primary-strong:#457059;
  --primary-soft:#edf7ee;
  --accent:#cfe7c8;
  --accent-soft:#f3fbef;
  --success:#4c8f63;
  --danger:#b75a5a;
  --warning:#a78745;
  --shadow:0 20px 46px rgba(72, 112, 84, .08);
  --shadow-soft:0 12px 24px rgba(72, 112, 84, .06);
  --radius:24px;
  --radius-sm:18px;
  --radius-xs:12px;
}

*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
body{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at top left, rgba(207,231,200,.35), transparent 22%),
    linear-gradient(180deg, #fbfef9 0%, #f5faf3 45%, #eef5ee 100%);
  color:var(--text);
  font:16px/1.7 "Inter", "Segoe UI", Arial, sans-serif;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0) 18%);
}
a{color:var(--primary-strong);text-decoration:none;transition:all .18s ease}
a:hover{color:#6f8754}

.wrap,.layout{display:flex;min-height:100vh;position:relative;z-index:1}
.side,.sidebar{
  width:308px;
  flex:0 0 308px;
  position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,251,244,.98));
  border-right:1px solid rgba(194,215,194,.86);
  padding:30px 24px;
  box-shadow:
    inset -1px 0 0 rgba(255,255,255,.86),
    14px 0 32px rgba(72,112,84,.04);
}
.side h1,.sidebar .brand{
  margin:0;
  color:var(--primary-strong);
  font-family:Georgia, "Times New Roman", serif;
  font-size:31px;
  line-height:1.1;
  letter-spacing:.01em;
}
.logo{
  display:block;
  max-width:220px;
  height:auto;
}
.side h1{margin-bottom:18px}
.logo small,.sidebar .brand small{display:block;margin-top:10px;font-size:12px;font-family:"Inter","Segoe UI",Arial,sans-serif;color:#8b8a6b;letter-spacing:.14em;text-transform:uppercase}
.brand-shell{display:flex;align-items:center;justify-content:center;width:100%;text-decoration:none}
.brand-shell-side{margin:0 auto 20px;padding:8px 0 2px}
.brand-shell-mobile{margin-left:auto;margin-right:auto;min-width:0}
.app-logo{display:block;width:min(252px,100%);height:auto;filter:drop-shadow(0 12px 22px rgba(46,110,57,.14))}
.app-logo-side{max-width:232px}
.app-logo-mobile{max-width:168px;max-height:72px;width:auto}
.nav-group-main{margin-top:8px}
.nav-group-main>a{display:block;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.88);border:1px solid var(--line);font-weight:700;color:var(--primary-strong);box-shadow:var(--shadow-soft)}
.nav-group-main>a:hover,.nav-group-main>a.active{background:linear-gradient(180deg,#ffffff,var(--primary-soft));border-color:var(--accent)}
.side::before,.sidebar::before{
  content:"";
  position:absolute;
  top:22px;
  right:0;
  width:2px;
  height:72px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(207,231,200,0), rgba(176,209,167,.55), rgba(207,231,200,0));
}
.subtitle,.muted,small.muted{color:var(--muted)}
.subtitle{
  display:block;
  margin:10px 0 0;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(250,245,231,.95), rgba(255,255,255,.94));
  font-size:13px;
  line-height:1.55;
}

.side-nav,.nav{display:grid;gap:8px;margin-top:22px}
.nav-group{
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.82);
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}
.nav-group summary,
.nav-group-title{
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#8f8a6a;
}
.nav-group summary{display:flex;align-items:center;justify-content:space-between}
.nav-group summary::-webkit-details-marker{display:none}
.nav-group summary::after{content:"▾";font-size:14px;color:var(--primary);transition:transform .2s ease}
.nav-group[open] summary::after{transform:rotate(180deg)}
.nav-items{display:grid;gap:4px;padding:0 10px 12px}
.side a,
.sidebar nav a,
.nav a,
.nav-items a{
  display:block;
  padding:12px 14px;
  border-radius:14px;
  color:var(--text-soft);
  background:transparent;
  border:1px solid transparent;
  font-weight:600;
}
.side a:hover,
.sidebar nav a:hover,
.nav a:hover,
.nav-items a:hover,
.side a.active,
.sidebar nav a.active,
.nav a.active,
.nav-items a.active{
  color:var(--primary-strong);
  background:linear-gradient(180deg, #ffffff, var(--primary-soft));
  border-color:var(--accent);
  box-shadow:0 14px 26px rgba(113,141,87,.12);
  transform:translateY(-1px);
}
.nav-group-last{border:none;background:transparent;padding-top:10px;box-shadow:none}
.nav-group-last a{background:rgba(255,255,255,.56);border:1px solid var(--line)}

.main,.content{
  flex:1;
  min-width:0;
  padding:42px;
  box-sizing:border-box;
}
.content > *:first-child,
.main > *:first-child{margin-top:0}
.topbar,.top,.page-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  flex-wrap:wrap;
  margin:0 0 22px;
}
.top > div,.top-actions,.actions,.row-actions,.compact-form,.inline-form,.template-toolbar,.quick-actions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.top h2,.top h3,.page-head h2,.card h2,.card h3,h1,h2,h3{
  color:var(--primary-strong);
  letter-spacing:.01em;
}
h1,h2,h3{margin:0 0 14px}
h1{font-family:Georgia,"Times New Roman",serif;font-size:36px;line-height:1.12}
h2{font-size:25px;line-height:1.2}
h3{font-size:18px;line-height:1.3}
p{margin:0 0 14px}
.brand-box{display:flex;gap:16px;align-items:center}
.top-logo,.logo-preview,.logo{
  border-radius:18px;
  background:linear-gradient(180deg, #ffffff, #faf7ee);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.top-logo{width:72px;height:72px;padding:8px;object-fit:contain}
.logo-preview{max-width:190px;max-height:92px;padding:10px}

.card,.kpi,.stat,.login-card,.notice,.attachment-pill,.scan-item{
  min-width:0;
  background:linear-gradient(180deg, rgba(255,255,255,.99), rgba(252,252,247,.99));
  border:1px solid rgba(201,214,191,.78);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card{
  padding:32px;
  margin-bottom:24px;
  overflow:hidden;
}
.kpi,.stat{
  padding:22px;
  border-radius:24px;
}
.kpi h3,.stat small{margin:0;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.big,.kpi strong,.stat strong{display:block;margin-top:12px;font-size:34px;font-weight:800;color:var(--primary-strong);line-height:1.1}
.notice{
  padding:16px 18px;
  margin:12px 0;
  color:var(--text-soft);
  background:linear-gradient(180deg, rgba(250,245,231,.95), rgba(255,255,255,.96));
}
.flash,.alert{
  padding:16px 18px;
  border-radius:18px;
  margin:12px 0 18px;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.flash.ok,.flash.success,.alert.ok{background:linear-gradient(180deg, #edf7ea, #ffffff);color:#2b6a37;border-color:#bcd9be}
.flash.err,.flash.error,.alert.err{background:linear-gradient(180deg, #fbefef, #ffffff);color:#8c3030;border-color:#e6c6c6}
.flash.info{background:linear-gradient(180deg, #eef7f2, #ffffff);color:#335f4a;border-color:#cfe2d5}

.grid,.cards,.row2,.row3,.row4,.grid-2,.grid-3,.grid-4,.form-grid,.form-grid-3,.kpi-grid,.cash-grid,.beleg-grid,.scan-meta,.doc-meta,.doc-footer{
  display:grid;
  gap:18px;
}
.cards,.grid-4,.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.row4{grid-template-columns:repeat(4,minmax(0,1fr))}
.row3,.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.row2,.grid-2,.form-grid,.cash-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.form-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.beleg-grid{grid-template-columns:1.15fr .85fr}
.scan-meta{grid-template-columns:repeat(2,minmax(0,1fr));font-size:13px;color:var(--text-soft)}
.cash-grid{grid-template-columns:1.4fr .9fr;align-items:start}
.designer-grid{align-items:start}
.grow-2{grid-column:span 2}

label{
  display:block;
  margin:0 0 7px;
  color:var(--text-soft);
  font-size:14px;
  font-weight:700;
}
input,select,textarea,button{
  width:100%;
  padding:13px 14px;
  border-radius:15px;
  border:1px solid var(--line);
  background:#ffffff;
  color:var(--text);
  box-sizing:border-box;
  font:inherit;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:#b6c79e;
  box-shadow:0 0 0 4px rgba(216,197,143,.18);
  background:#fff;
}
textarea{min-height:110px;resize:vertical}
input::placeholder,textarea::placeholder{color:#99a795}
input[type="checkbox"],input[type="radio"]{width:auto;padding:0}
.checkbox,.checks label{display:flex;align-items:center;gap:10px;color:var(--text-soft)}
.checks{display:grid;gap:10px;margin:12px 0}

.btn,button.btn,a.btn,.menu-btn,.keypad-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:auto;
  min-height:46px;
  padding:11px 16px;
  border-radius:14px;
  border:1px solid transparent;
  background:linear-gradient(180deg, #78a27d, #4f7d61);
  color:#fff;
  font-weight:700;
  letter-spacing:.01em;
  cursor:pointer;
  box-shadow:0 14px 28px rgba(85,113,69,.18);
}
.btn:hover,button.btn:hover,a.btn:hover,.menu-btn:hover,.keypad-btn:hover{transform:translateY(-1px);filter:saturate(1.04)}
.btn.alt,.btn.secondary,.btn.ghost,.btn.light,.small-btn,.keypad-btn.wide{
  background:linear-gradient(180deg, #ffffff, #fbf7ea);
  color:var(--primary-strong);
  border-color:var(--accent);
  box-shadow:var(--shadow-soft);
}
.btn.primary{background:linear-gradient(180deg, var(--primary), var(--primary-strong));color:#fff}
.btn.good,.btn.success{background:linear-gradient(180deg, #5fa15d, #3f7b42);color:#fff}
.btn.danger{background:linear-gradient(180deg, #c76e6e, #a04949);color:#fff}
.btn.small,.small-btn{min-height:36px;padding:8px 12px;border-radius:12px;font-size:13px}
.count-input,.cash-display{text-align:right}
.cash-display{
  padding:16px 18px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  font-size:30px;
  font-weight:800;
  letter-spacing:.02em;
  color:var(--primary-strong);
}
.cash-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.keypad-btn{font-size:18px;font-weight:800}

.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:15px}
.card table{min-width:700px}
.card .doc table,.doc table,.document-page table{min-width:0}
th,td{
  padding:14px 12px;
  border-bottom:1px solid rgba(217,230,210,.92);
  text-align:left;
  vertical-align:top;
}
thead th{
  position:sticky;
  top:0;
  z-index:1;
  background:linear-gradient(180deg, #fbf8ee, #f4f7eb);
  color:var(--primary-strong);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
tbody tr:hover td{background:rgba(250,245,231,.72)}
.text-right,.right,.money-col,.qty-col{text-align:right}
.count-sum{font-weight:700;color:var(--primary-strong)}
.inline-note,.attachment-meta{font-size:12px;color:var(--muted)}
.balance-positive{color:#2d7c3f}.balance-negative{color:#a63d3d}

.badge,.chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid var(--line-strong);
  background:#fbfaf1;
  color:var(--primary-strong);
  font-size:12px;
  font-weight:800;
}
.badge.open{background:#faf3de;color:#8d6f30;border-color:#e4d1a2}
.badge.partial,.badge.overdue,.badge.warning{background:#fbf0d2;color:#8d6f30;border-color:#e4d1a2}
.badge.paid,.badge.success{background:#eef7ee;color:#3f7450;border-color:#c6dbc8}
.badge.cancelled,.badge.danger{background:#fbefef;color:#983a3a;border-color:#e5c1c1}
.badge.invoiced,.badge.info{background:#f0f5ea;color:#526b45;border-color:#d7e1ca}
.ampel-dot{display:inline-block;width:12px;height:12px;border-radius:999px;vertical-align:middle;margin-right:8px;box-shadow:0 0 0 2px rgba(255,255,255,.7) inset}
.ampel-green{background:#5a9b4a}.ampel-yellow{background:#c5a03d}.ampel-red{background:#c45a5a}.ampel-gray{background:#98a38f}

.login{max-width:440px;margin:64px auto}
.login-card{padding:30px}
.login-card h1{margin-bottom:8px}
.login-card p.muted{margin-top:12px}

.code,code{
  display:inline-block;
  background:#f2f8ea;
  color:var(--primary-strong);
  padding:3px 8px;
  border-radius:10px;
  border:1px solid var(--line);
  font-size:13px;
}

.doc,.document-page,.letterpaper,.paper,.receipt-page,.printdoc{
  background:#fff;
  color:#243226;
}
.document-page,.paper,.receipt-page,.printdoc{
  max-width:980px;
  margin:24px auto;
  padding:34px;
  border-radius:28px;
  border:1px solid rgba(201,214,191,.76);
  box-shadow:0 24px 52px rgba(92,111,76,.11);
}
.letterpaper{
  color:#1f2a21;
  padding:var(--doc-margin, 18mm);
  font-family:var(--doc-font, "Georgia", "Times New Roman", serif);
  min-height:1122px;
  position:relative;
  overflow:hidden;
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact;
}
.doc-bg{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.doc-bg-img,.print-page-bg-img{position:absolute;inset:0;display:block;max-width:none;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.doc-content{position:relative;z-index:1}
.doc-topline,.letterhead::before{
  content:"";
  display:block;
  width:100%;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--doc-primary, var(--primary-strong)), var(--doc-accent, var(--accent)), #f7edd0);
  margin-bottom:18px;
}
.letterhead{
  border-bottom:1px solid var(--line);
  padding-bottom:18px;
  margin-bottom:24px;
}
.dochead{display:flex;justify-content:space-between;gap:40px}
.doc h1,.letterhead h1,.printdoc h1,.receipt-page h1{margin:0 0 12px;color:var(--primary-strong);font-family:Georgia,"Times New Roman",serif;font-size:28px;line-height:1.15}
.doc-meta,.recipient-meta-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:26px}
.doc-rightbox,.bank-box{text-align:right}
.doc-rightbox span{color:#5d6a5e}
.window-address,.recipient-box{margin:28px 0 34px;max-width:360px;line-height:1.55}
.sender-line,.small-line{font-size:11px;color:#6d776c;border-bottom:1px solid #ccd9c9;padding-bottom:3px;margin-bottom:8px;display:inline-block}
.doc h1{font-size:24px}
.doc .intro{font-size:15px;margin-bottom:18px;color:#405244}
.doc table,.doc-table,.receipt-table{color:#243226}
.doc th,.doc-table th{background:#f5faec;color:var(--primary-strong);border-bottom:2px solid var(--line-strong)}
.doc td,.doc th,.doc-table td,.doc-table th{padding:10px 10px}
.doc .totals,.totals{margin-top:20px;font-size:16px}
.doc-footer{grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px;padding-top:20px;border-top:1px solid var(--line);font-size:12px;color:#536055}
.footer-note{margin-top:30px;font-size:14px;color:#536055}
.doc-meta-box{margin-top:10px;padding:12px 14px;border-left:4px solid var(--primary);background:#f8fbf5;border-radius:0 14px 14px 0}
.doc-type-small{font-size:18px;font-weight:700;line-height:1.15;margin-bottom:8px;color:var(--primary-strong)}
.receipt-head,.receipt-line,.print-meta{display:flex;justify-content:space-between;gap:20px}
.receipt-sum{font-size:24px;font-weight:800;color:var(--primary-strong)}
.print-tools,.doc-toolbar{display:flex;gap:10px;justify-content:flex-end;margin-bottom:14px}
.preview-doc{position:sticky;top:20px}
.logo-preview-wrap{display:flex;flex-direction:column;gap:10px;justify-content:flex-end}

.attachment-pill{
  justify-content:space-between;
  gap:10px;
  align-items:center;
  padding:10px 12px;
}
.bank-attachments,.attachment-list,.scan-list{display:grid;gap:8px;margin-top:10px}
.scan-item{padding:12px}
.bankkonto-page .main{padding-top:24px}
.page-head{margin-bottom:18px}
.count-input{max-width:110px}
.mobile-topbar,.nav-backdrop,.menu-btn{display:none}
.nav-toggle{position:fixed;left:-9999px}

.nav-builder-form{display:grid;gap:18px}
.nav-builder-board{display:grid;gap:14px}
.nav-entry{border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,#ffffff,#fbfef8);box-shadow:var(--shadow-soft);overflow:hidden}
.nav-entry.dragging,.nav-item.dragging{opacity:.55}
.nav-entry.drop-target,.nav-item-list.drop-target{outline:2px dashed rgba(69,112,89,.38);outline-offset:2px}
.nav-entry-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;background:linear-gradient(180deg,#ffffff,#f6fbf2);border-bottom:1px solid rgba(215,228,215,.88)}
.nav-entry-meta{display:flex;align-items:center;gap:12px;min-width:0}
.nav-entry-order{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:12px;background:var(--accent-soft);border:1px solid var(--line);font-weight:800;color:var(--primary-strong)}
.nav-entry-title{display:grid;gap:2px;min-width:0}
.nav-entry-title strong{font-size:15px;color:var(--primary-strong)}
.nav-entry-title small{color:var(--muted);word-break:break-word}
.drag-handle{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border-radius:12px;border:1px dashed var(--line-strong);background:#fff;color:var(--primary-strong);font-weight:800;cursor:grab;user-select:none;touch-action:none;-webkit-user-select:none}
.drag-handle:active{cursor:grabbing}
.check-line{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--text-soft)}
.check-line.sub{font-weight:600}
.nav-entry-body{padding:16px 18px}
.nav-item-list{display:grid;gap:10px;min-height:18px}
.nav-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.92)}
.nav-item-meta{display:grid;gap:2px;min-width:0}
.nav-item-meta strong{font-size:14px;color:var(--primary-strong)}
.nav-item-meta small{color:var(--muted);word-break:break-word}
.nav-builder-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.nav-builder-note{font-size:13px;color:var(--muted)}
.nav-sort-placeholder{border:2px dashed rgba(69,112,89,.38);background:rgba(248,252,244,.9);min-height:58px;border-radius:20px}
.nav-sort-placeholder-item{min-height:54px;border-radius:16px}
.nav-sort-dragging{user-select:none;cursor:grabbing}
.nav-entry.is-pointer-dragging,.nav-item.is-pointer-dragging{opacity:.96;box-shadow:0 24px 48px rgba(58,87,67,.18)}


@media (max-width:1100px){
  .main,.content{padding:28px}
  .side,.sidebar{width:238px;flex-basis:238px;padding:22px 18px}
}

@media (max-width:960px){
  .row2,.row3,.row4,.cards,.grid-2,.grid-3,.grid-4,.form-grid,.form-grid-3,.kpi-grid,.cash-grid,.beleg-grid,.doc-meta,.doc-footer,.recipient-meta-row,.scan-meta{grid-template-columns:1fr!important}
  .grow-2{grid-column:span 1}
  .preview-doc{position:static}
  .bankkonto-page .main{padding-top:14px}
}

@media (max-width:860px){
  .mobile-topbar{
    min-height:82px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    position:sticky;
    top:0;
    z-index:40;
    background:rgba(255,255,252,.96);
    backdrop-filter:blur(8px);
    padding:10px 0 14px;
    margin:-4px 0 12px;
    border-bottom:1px solid var(--line);
  }
  .mobile-brand{font-weight:700;font-size:18px;color:var(--primary-strong)}
  .mobile-topbar .brand-shell{display:flex;justify-content:center;flex:1}
  .menu-btn{display:inline-flex;white-space:nowrap}
  .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(36,50,38,.18);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:49}
  .side,.sidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:min(84vw,300px);
    max-width:300px;
    transform:translateX(-105%);
    transition:transform .22s ease;
    z-index:50;
    overflow-y:auto;
    padding-top:24px;
  }
  .main,.content{padding:18px}
  .nav-toggle:checked ~ .wrap .side,
  .nav-toggle:checked ~ .wrap .sidebar,
  .nav-toggle:checked ~ .layout .side,
  .nav-toggle:checked ~ .layout .sidebar{transform:translateX(0)}
  .nav-toggle:checked ~ .wrap .nav-backdrop,
  .nav-toggle:checked ~ .layout .nav-backdrop{opacity:1;pointer-events:auto}
  .card{padding:20px;border-radius:20px}
  th,td{padding:10px 8px}
}

@media (max-width:640px){
  body{font-size:15px}
  .main,.content{padding:12px}
  .card,.document-page,.paper,.receipt-page,.printdoc{padding:20px;margin-bottom:16px}
  .big,.kpi strong,.stat strong{font-size:28px}
  h1{font-size:29px}
  h2{font-size:22px}
  h3{font-size:18px}
  .btn{padding:10px 13px}
  .login{margin:24px auto;padding:0 12px;box-sizing:border-box}
  .card table{min-width:620px}
  .receipt-head,.receipt-line,.print-meta,.dochead{display:block}
}

@page{size:A4;margin:0}
@page:first{size:A4;margin:0}
@media print{
  body{background:#fff!important}
  body::before,.no-print,.mobile-topbar,.side,.sidebar{display:none!important}
  .main,.content{padding:0!important}
  .card,.document-page,.paper,.receipt-page,.printdoc{
    box-shadow:none!important;
    border-radius:0!important;
    border:none!important;
    margin:0!important;
    max-width:none!important;
    padding:0!important;
  }
  .letterpaper{padding:8mm 8mm 10mm 8mm!important}
  .doc h1{font-size:20px!important;line-height:1.15!important}
  .recipient-meta-row{
    display:flex!important;
    justify-content:space-between!important;
    align-items:flex-start!important;
    gap:20px!important;
    margin:16px 0 18px!important;
    break-inside:avoid!important;
    page-break-inside:avoid!important;
  }
  .recipient-meta-row .window-address{margin:0!important;max-width:92mm!important;flex:1 1 auto!important}
  .doc-meta-recipient{
    min-width:54mm!important;
    max-width:72mm!important;
    padding-top:2mm!important;
    margin-left:auto!important;
    text-align:right!important;
    align-self:flex-start!important;
  }
  .doc-type-small{font-size:12px!important;line-height:1.1!important;margin-bottom:5px!important;text-align:right!important;letter-spacing:.04em;text-transform:uppercase}
  .doc-rightbox div,.doc-rightbox strong,.doc-rightbox span,.doc-type-small{text-align:right!important}
  .print-page-bg,.doc-bg{display:none!important}
}


.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 12px;
  padding:7px 12px;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--primary-strong);
  border:1px solid var(--accent);
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.company-layout{align-items:start}
.company-summary-box{display:grid;grid-template-columns:132px 1fr;gap:18px;align-items:center;margin-bottom:18px}
.company-logo-preview{width:132px;max-width:132px;max-height:92px;object-fit:contain;padding:10px;background:linear-gradient(180deg,#ffffff,#f8fcf6)}
.company-logo-placeholder{min-height:92px;display:flex;align-items:center;justify-content:center;text-align:center;padding:16px;border-radius:18px;border:1px dashed var(--line-strong);background:var(--panel-3);color:var(--muted);font-weight:700}
.company-summary-lines{display:grid;gap:6px;color:var(--text-soft)}
.info-grid{display:grid;gap:12px}
.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.info-chip{padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffff,#f7fcf6);box-shadow:var(--shadow-soft)}
.info-chip span{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.info-chip strong{display:block;color:var(--primary-strong);font-size:17px}
.system-check-cards{grid-template-columns:repeat(5,minmax(0,1fr))}
.trust-card textarea{min-height:128px}
code{font-family:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace}
@media (max-width:1200px){.system-check-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:900px){.company-summary-box,.compact-grid,.system-check-cards{grid-template-columns:1fr}}

.nav-item-list.is-over,.nav-builder-board.is-over{outline:2px dashed rgba(69,112,89,.35);outline-offset:6px}
.nav-entry.dragging,.nav-item.dragging{opacity:.55;box-shadow:0 24px 48px rgba(58,87,67,.14)}
