/* J+G Angebots-App styles - ausgelagert aus index.html. Keine Funktionsänderung. */
:root{
      --bg:#f3f4f6; --card:#ffffff; --ink:#111827; --muted:#6b7280; --line:#e5e7eb;
      --brand:#111827; --brand2:#374151; --ok:#047857; --danger:#b91c1c; --soft:#f9fafb;
      --radius:18px; --shadow:0 10px 30px rgba(17,24,39,.08);
      --safe-bottom: env(safe-area-inset-bottom, 0px);
      --safe-top: env(safe-area-inset-top, 0px);
      font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    }
    *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
    html,body{margin:0;background:var(--bg);color:var(--ink);min-height:100%;-webkit-text-size-adjust:100%;text-size-adjust:100%}
    body{font-size:16px;line-height:1.35}
    button,input,textarea,select{font:inherit}
    button{cursor:pointer;border:0}
    .app{max-width:980px;margin:0 auto;padding:calc(14px + var(--safe-top)) 14px calc(86px + var(--safe-bottom))}
    .topbar{position:sticky;top:0;z-index:10;margin:-14px -14px 14px;padding:calc(12px + var(--safe-top)) 14px 12px;background:rgba(243,244,246,.9);backdrop-filter: blur(14px);border-bottom:1px solid rgba(229,231,235,.8)}
    .brand{display:flex;align-items:center;gap:10px;justify-content:space-between}
    .brand h1{font-size:18px;margin:0;font-weight:800;letter-spacing:-.02em}
    .brand .sub{font-size:12px;color:var(--muted);margin-top:2px}
    .logo{width:38px;height:38px;border-radius:12px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:900;letter-spacing:-.06em}
    .row{display:flex;gap:10px;align-items:center}.grow{flex:1}
    .pill{font-size:12px;border-radius:999px;background:#e5e7eb;color:#374151;padding:6px 10px;white-space:nowrap}
    .main-tabs{display:block;margin-top:10px}
    .desktop-main-tabs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}
    .main-tab{padding:9px 6px;border-radius:14px;background:#fff;color:#374151;font-size:12px;font-weight:800;box-shadow:0 1px 0 rgba(0,0,0,.04)}
    .main-tab.active{background:var(--brand);color:#fff}
    .mobile-nav-row{display:none}
    .mobile-main-select{width:100%;min-height:42px;border-radius:14px;background:#fff;font-weight:800;color:#111827}
    .mobile-new-btn{white-space:nowrap;min-height:42px}
    .work-actions{display:flex;gap:8px;margin-top:8px}
    .work-action{border-radius:14px;padding:8px 10px;background:#fff;color:#374151;border:1px solid var(--line);font-size:12px;font-weight:800;min-height:38px;flex:1}
    .work-action.active{background:#eef2f7;color:#111827;border-color:#d1d5db}
    .tabs{display:flex;gap:6px;margin-top:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:1px}
    .tabs::-webkit-scrollbar{display:none}
    .tab{flex:1 0 120px;padding:8px 10px;border-radius:14px;background:#fff;color:#374151;font-size:12px;font-weight:700;box-shadow:0 1px 0 rgba(0,0,0,.04);white-space:nowrap}
    .tab.active{background:var(--brand2);color:#fff}
    .mini-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.segmented .btn{min-height:42px}.mini-meta span{font-size:12px;border-radius:999px;background:#f3f4f6;color:#374151;padding:5px 9px}.search-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end}.empty{border:1px dashed var(--line);border-radius:16px;padding:14px;background:#fff;color:var(--muted);font-size:14px}.danger-text{color:var(--danger);font-weight:800}
    .card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:12px}
    .section-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
    .section-title h2{font-size:17px;margin:0;font-weight:850;letter-spacing:-.015em}.section-title p{margin:2px 0 0;color:var(--muted);font-size:13px}
    label{display:block;font-size:12px;font-weight:800;color:#374151;margin:0 0 6px;text-transform:uppercase;letter-spacing:.03em}
    input,textarea,select{width:100%;border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px 12px;outline:none;color:var(--ink)}
    textarea{min-height:88px;resize:vertical}.grid{display:grid;gap:10px}.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:1fr 1fr 1fr}
    .placeholder-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px}.placeholder-copy{border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px;text-align:left;min-height:58px}.placeholder-copy strong{display:block;font-size:13px;color:#111827}.placeholder-copy span{display:block;font-size:12px;color:var(--muted);margin-top:3px}.tpl-row{border:1px solid var(--line);background:#fff;border-radius:16px;padding:12px;margin-top:10px}.tpl-row-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.tpl-row-head strong{font-size:14px}.mini-divider{height:1px;background:var(--line);margin:14px 0}
    @media(max-width:700px){.placeholder-grid{grid-template-columns:1fr}.app{padding:calc(8px + var(--safe-top)) 10px calc(78px + var(--safe-bottom))}.topbar{margin:-8px -10px 10px;padding:calc(8px + var(--safe-top)) 10px 8px}.brand h1{font-size:16px}.brand .sub{font-size:11px}.logo{width:34px;height:34px;border-radius:11px}.pill{font-size:11px;padding:5px 8px}.grid.two,.grid.three{grid-template-columns:minmax(0,1fr)}.grid>div,.card,.app{min-width:0}.hide-mobile{display:none}.desktop-main-tabs,.work-actions{display:none!important}.mobile-nav-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-top:8px}.main-tabs{margin-top:0}.tabs{gap:5px;margin-top:7px}.tab{font-size:11px;flex:1 0 auto;min-width:auto;padding:8px 11px}.main-tab{font-size:11px;padding:8px 3px}.search-row{grid-template-columns:1fr}input,textarea,select{min-width:0;max-width:100%;display:block;-webkit-appearance:none;appearance:none}input[type="date"]{text-align:left;min-height:54px;padding-right:12px}input[type="date"]::-webkit-date-and-time-value{text-align:left}.basis-card{overflow:hidden}}
    .btn{border-radius:14px;padding:12px 14px;background:var(--brand);color:#fff;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px}
    .btn.secondary{background:#fff;color:#111827;border:1px solid var(--line)}.btn.ghost{background:#f3f4f6;color:#111827}.btn.ok{background:var(--ok)}.btn.danger{background:var(--danger)}.btn.small{font-size:13px;min-height:36px;padding:8px 10px;border-radius:12px}
    .actions{display:flex;gap:8px;flex-wrap:wrap}.actions .btn{flex:1}.muted{color:var(--muted)}.hint{font-size:13px;color:var(--muted)}
    .doc-context{border-left:5px solid #111827;background:linear-gradient(135deg,#fff 0%,#f9fafb 100%)}.doc-context.invoice-draft{border-left-color:#f59e0b}.doc-context.invoice-final{border-left-color:#047857}.doc-context.invoice-cancelled{border-left-color:#b91c1c}.doc-context.offer-draft{border-left-color:#1f3f6d}.doc-context.dirty{box-shadow:0 0 0 3px rgba(245,158,11,.14),var(--shadow)}.doc-context-main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.doc-context h2{margin:0;font-size:18px;font-weight:900;letter-spacing:-.02em}.doc-context .doc-sub{margin:4px 0 0;color:#374151;font-size:14px}.status-chip-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.status-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;background:#eef2f7;color:#374151;white-space:nowrap}.status-chip.warn{background:#fef3c7;color:#92400e}.status-chip.ok{background:#d1fae5;color:#065f46}.status-chip.danger{background:#fee2e2;color:#991b1b}.status-chip.info{background:#dbeafe;color:#1e3a8a}.doc-context-note{margin-top:7px;color:#6b7280;font-size:12.5px;line-height:1.35}.doc-context-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.doc-context-actions .btn{flex:0 1 auto}@media(max-width:700px){.doc-context-main{display:block}.status-chip-row{margin-top:10px}.doc-context h2{font-size:16px}.doc-context-actions .btn{flex:1}}

    .desktop-main-tabs{grid-template-columns:repeat(7,minmax(0,1fr))}
    .dash-grid,.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.dash-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}.dash-card.full{grid-column:1 / -1}.dash-metrics,.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:12px}.dash-metric,.metric{border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px;min-height:82px;display:flex;flex-direction:column;justify-content:center}.dash-metric strong,.metric b{display:block;font-size:28px;line-height:1;font-weight:900;letter-spacing:-.03em}.dash-metric span,.metric span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;margin-top:7px}.dashboard-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
    .calendar-wrap{min-width:0}.calendar-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.calendar-title h2{margin:0;font-size:17px;font-weight:850;letter-spacing:-.015em}.calendar-title .hint{margin:3px 0 0}.calendar-controls{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:0 0 auto}.calendar-controls .btn{flex:0 0 auto}.calendar-nav{display:flex;align-items:center;gap:4px;background:#f3f4f6;border:1px solid var(--line);border-radius:16px;padding:4px}.calendar-icon-btn{width:38px;height:38px;border-radius:12px;background:#fff;color:#111827;border:1px solid rgba(229,231,235,.95);font-size:20px;font-weight:900;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 0 rgba(0,0,0,.03)}.calendar-current{height:38px;min-width:118px;border-radius:12px;background:#fff;border:1px solid rgba(229,231,235,.95);display:inline-flex;align-items:center;justify-content:center;padding:0 10px;font-size:13px;font-weight:900;color:#111827;white-space:nowrap}.calendar-icon-btn:active{transform:translateY(1px)}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.calendar-weekday{font-size:11px;font-weight:900;text-align:center;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;padding:4px}.calendar-day{min-height:76px;border:1px solid var(--line);border-radius:14px;background:#fff;color:#111827;padding:7px;text-align:left;display:flex;flex-direction:column;justify-content:space-between;gap:5px;overflow:hidden}.calendar-day.out{opacity:.42;background:#f9fafb}.calendar-day.today{border-color:#111827;box-shadow:inset 0 0 0 1px #111827}.calendar-day.search-match{border-color:#047857;box-shadow:inset 0 0 0 2px rgba(4,120,87,.30)}.calendar-day-num{font-size:13px;font-weight:900}.calendar-dot-row{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.staff-badge{display:inline-grid;place-items:center;min-width:24px;height:24px;border-radius:999px;background:#111827;color:#fff;font-size:11px;font-weight:900;letter-spacing:.02em;padding:0 6px}.staff-badge.light{background:#eef2f7;color:#374151}.calendar-compact .calendar-title h2{font-size:16px}.calendar-compact .calendar-controls{gap:6px}.calendar-compact .calendar-nav{border-radius:14px;padding:3px}.calendar-compact .calendar-icon-btn{width:34px;height:34px;border-radius:11px;font-size:18px}.calendar-compact .calendar-current{height:34px;min-width:106px;border-radius:11px;font-size:12px}.calendar-compact .calendar-grid{gap:5px}.calendar-compact .calendar-weekday{font-size:10px;padding:3px}.calendar-compact .calendar-day{min-height:46px;padding:5px;border-radius:12px}.calendar-compact .calendar-day-num{font-size:12px}.calendar-compact .staff-badge{min-width:19px;height:19px;font-size:9px;padding:0 5px}.dashboard-calendar-card{padding:14px}.dashboard-calendar-layout{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(260px,.82fr);gap:16px;align-items:stretch}.dashboard-calendar-left{min-width:0}.upcoming-panel{border:1px solid var(--line);border-radius:18px;background:#fbfbfc;padding:14px;min-height:100%;display:flex;flex-direction:column}.upcoming-panel .section-title{margin-bottom:12px}.upcoming-panel .section-title h2{font-size:16px}.upcoming-list{align-content:start}.upcoming-list .item{box-shadow:none;background:#fff}.compact-title{align-items:center}.compact-title .btn{flex:0 0 auto;white-space:nowrap}.event-line{display:flex;align-items:flex-start;gap:9px}.event-line.done{opacity:.62}.event-date{font-weight:800;color:#111827}.employee-row{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(80px,.6fr) auto;gap:8px;align-items:end;border:1px solid var(--line);border-radius:16px;background:#fff;padding:10px}.link-help{font-size:12px;color:#6b7280;margin-top:6px;line-height:1.35}
    @media(max-width:860px){.dashboard-calendar-layout{grid-template-columns:1fr}.upcoming-panel{min-height:0}.calendar-head{align-items:flex-start}.calendar-controls{align-self:stretch;justify-content:space-between}.calendar-nav{flex:1}.calendar-current{flex:1;min-width:0}}
    @media(max-width:700px){.dash-grid,.dashboard-grid{grid-template-columns:1fr}.dash-metrics,.metric-grid{grid-template-columns:1fr 1fr}.dash-metric,.metric{min-height:72px;padding:11px}.dashboard-actions{grid-template-columns:1fr}.calendar-head{gap:8px}.calendar-controls{gap:6px}.calendar-wrap:not(.calendar-compact) .calendar-head{display:block}.calendar-wrap:not(.calendar-compact) .calendar-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;width:100%;margin-top:8px;align-items:center}.calendar-wrap:not(.calendar-compact) .calendar-nav{min-width:0;width:100%}.calendar-nav{padding:3px;border-radius:14px}.calendar-icon-btn{width:33px;height:33px;border-radius:11px;font-size:18px}.calendar-current{height:33px;min-width:88px;border-radius:11px;font-size:12px}.calendar-grid{gap:4px}.calendar-day{min-height:56px;padding:5px;border-radius:12px}.calendar-compact .calendar-day{min-height:39px;padding:4px;border-radius:10px}.calendar-compact .calendar-dot-row{gap:2px}.dashboard-calendar-card{padding:12px}.dashboard-calendar-layout{gap:12px}.upcoming-panel{padding:12px;border-radius:16px}.staff-badge{min-width:20px;height:20px;font-size:10px;padding:0 5px}.employee-row{grid-template-columns:1fr}.desktop-main-tabs{grid-template-columns:repeat(7,minmax(0,1fr))}}

    .list{display:grid;gap:10px}.item{border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px}.item.archive-focus{outline:3px solid rgba(4,120,87,.32);box-shadow:0 0 0 6px rgba(4,120,87,.08)}.item-head{display:flex;align-items:flex-start;gap:10px;justify-content:space-between}.item-title{font-weight:850}.price{font-weight:900;white-space:nowrap}.item-desc{white-space:pre-wrap;color:#374151;font-size:14px;margin-top:8px}.drag{width:28px;height:28px;border-radius:10px;background:#f3f4f6;display:grid;place-items:center;color:#6b7280;font-weight:900;flex:0 0 auto}
    
    .photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
    .photo-thumb{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#f9fafb;min-height:96px}
    .photo-thumb img{width:100%;height:120px;object-fit:cover;display:block}
    .photo-thumb button{position:absolute;right:6px;top:6px;background:rgba(17,24,39,.88);color:#fff;border-radius:999px;width:30px;height:30px;font-weight:900}
    .overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
    .overview-box{border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px}
    .overview-box h4{margin:0 0 8px;font-size:15px;font-weight:850;color:#111827}
    .overview-kv{display:grid;grid-template-columns:132px minmax(0,1fr);gap:6px 10px;font-size:14px}
    .overview-kv b{color:#374151;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
    .overview-pre{white-space:pre-wrap;font-size:14px;color:#374151;line-height:1.35;margin:0}
    .overview-photo button{display:block;width:100%;padding:0;border:0;background:transparent;text-align:left}
    .overview-photo img{width:100%;height:145px;object-fit:cover;display:block;border-radius:14px;border:1px solid var(--line)}
    .lightbox-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:90;display:none;align-items:center;justify-content:center;padding:calc(14px + var(--safe-top)) 14px calc(14px + var(--safe-bottom))}
    .lightbox-backdrop.show{display:flex}
    .lightbox-inner{width:100%;height:100%;display:grid;grid-template-rows:auto 1fr auto;gap:10px;align-items:center}
    .lightbox-top{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#fff;font-size:14px;font-weight:800}
    .lightbox-close,.lightbox-arrow{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:999px;font-weight:900}
    .lightbox-close{width:42px;height:42px;font-size:24px;line-height:1}
    .lightbox-stage{position:relative;width:100%;height:100%;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
    .lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.45)}
    .lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;font-size:30px;display:flex;align-items:center;justify-content:center}
    .lightbox-arrow.prev{left:6px}.lightbox-arrow.next{right:6px}
    .lightbox-caption{text-align:center;color:#e5e7eb;font-size:13px;min-height:18px}
    .inspection-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
    .badge{font-size:12px;border-radius:999px;background:#eef2f7;color:#374151;padding:5px 8px}
    @media(max-width:700px){.photo-grid{grid-template-columns:repeat(2,1fr)}.photo-thumb img{height:105px}.overview-grid{grid-template-columns:1fr}.overview-kv{grid-template-columns:1fr}.overview-photo img{height:125px}}
    .template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.template{border:1px solid var(--line);background:#fff;border-radius:16px;padding:12px;text-align:left}.template.active{border-color:#111827;box-shadow:inset 0 0 0 1px #111827}.template strong{display:block;font-size:15px}.template span{display:block;color:var(--muted);font-size:12px;margin-top:4px}
    @media(max-width:700px){.template-grid{grid-template-columns:1fr}}
    .bottom{position:fixed;left:0;right:0;bottom:0;z-index:20;padding:10px 14px calc(10px + var(--safe-bottom));background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line)}.bottom-inner{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:10px}
    .toast{position:fixed;left:50%;bottom:calc(82px + var(--safe-bottom));transform:translateX(-50%);background:#111827;color:white;padding:10px 14px;border-radius:999px;font-size:13px;z-index:50;opacity:0;pointer-events:none;transition:.25s}.toast.show{opacity:1}
    .modal-backdrop{position:fixed;inset:0;background:rgba(17,24,39,.42);z-index:40;display:none;align-items:flex-end}.modal-backdrop.show{display:flex}.modal{background:#fff;width:100%;max-height:92vh;overflow:auto;border-radius:24px 24px 0 0;padding:16px 14px calc(20px + var(--safe-bottom));box-shadow:0 -20px 60px rgba(0,0,0,.25)}.modal-inner{max-width:720px;margin:0 auto}.modal h3{margin:0 0 4px;font-size:19px}.modal .grab{width:42px;height:5px;border-radius:99px;background:#d1d5db;margin:0 auto 12px}

    .preview-wrap{overflow:auto;-webkit-overflow-scrolling:touch;border-radius:16px;border:1px solid var(--line);background:#cfd3d9;padding:14px}
    .page{--pdf-blue:#1f3f6d;--pdf-blue-soft:#eef3f9;--pdf-orange:#f58220;--pdf-gray:#f7f7f7;width:794px;min-height:1123px;background:white;margin:0 auto 12px;padding:42px 52px 34px;box-shadow:0 10px 35px rgba(0,0,0,.16);font-family:Arial, Helvetica, sans-serif;color:#111;font-size:13.2px;line-height:1.25;position:relative}
    .doc-shell{min-height:1047px;display:flex;flex-direction:column}.doc-main{flex:1}.pdf-header{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:start;margin-bottom:16px}.pdf-logo{width:175px;height:auto;display:block;margin:0 0 13px 0}.customer-card{font-size:13px;line-height:1.28;min-height:56px}.pdf-nowrap{white-space:nowrap}.customer-card .block-label{font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:#1f3f6d;margin:0 0 5px}.customer-card .object{margin-top:9px}.company-card{text-align:left;font-size:12.6px;line-height:1.24;border-left:4px solid var(--pdf-orange);padding-left:12px;justify-self:end;width:270px}.company-card b{font-size:13.4px}.right-meta{justify-self:end;width:270px;margin-top:12px;font-size:12.7px}.doc-date{margin:0 0 7px;text-align:left}.meta-box{display:grid;grid-template-columns:max-content minmax(0,1fr);gap:3px 9px;background:#f8f8f8;border:1px solid #e4e4e4;border-radius:8px;padding:8px 10px}.meta-box b{white-space:nowrap}.meta-box div{min-width:0;overflow-wrap:break-word}.doc-title{font-size:20px;font-weight:700;margin:0 0 16px;line-height:1.18;color:#111}.intro-box{white-space:pre-wrap;margin:12px 0 18px;font-size:13.2px;line-height:1.34}.offer-table{width:100%;border-collapse:separate;border-spacing:0;margin:14px 0 12px}.offer-table th{font-size:12.2px;text-align:left;background:var(--pdf-blue);color:#fff;padding:7px 8px;border:0}.offer-table th:first-child{border-radius:7px 0 0 0}.offer-table th:last-child{border-radius:0 7px 0 0}.offer-table td{vertical-align:top;border-bottom:2px solid #fff;padding:8px 8px;font-size:12.8px;line-height:1.25}.offer-table tbody tr:nth-child(odd) td{background:#f3f6fa}.offer-table tbody tr:nth-child(even) td{background:#fbfbfb}.offer-table tbody tr:hover td{background:#eef3f9}.offer-table .num{width:34px;text-align:center;font-weight:700;color:#1f3f6d}.offer-table .qty{width:58px;text-align:center}.offer-table .money{width:112px;text-align:right;white-space:nowrap;font-weight:700}.total-card{margin:13px 0 48px;padding-bottom:0;display:flex;justify-content:flex-end}.total-wrap{max-width:430px;text-align:right}.total-row{display:grid;grid-template-columns:auto auto;gap:24px;align-items:center;border-top:2px solid var(--pdf-orange);padding:7px 0 0;font-size:15.4px;font-weight:700;min-width:255px}.notice{font-size:11.5px;margin:5px 0 0;color:#333;text-align:right;line-height:1.25}.doc-section{margin:16px 0}.doc-section h3{font-size:14.5px;margin:0 0 5px;color:#111}.pre{white-space:pre-wrap}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px;align-items:start}.info-box{background:#fbfbfb;border:1px solid #e8e8e8;border-radius:9px;padding:12px 13px;margin:14px 0;break-inside:avoid}.info-box h3{font-size:14px;margin:0 0 6px;color:#1f3f6d}.info-box .pre{font-size:12.4px;line-height:1.28}.section-list{margin-top:8px}.section-list .doc-section{padding:11px 13px;margin:14px 0;border-left:3px solid #d8e0eb;background:#fbfbfb;border-radius:7px}.footer{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;font-size:10.1px;color:#111;border-top:1px solid #d9d9d9;padding-top:9px;margin-top:auto;text-align:center;justify-items:center}.footer b{color:#1f3f6d}.footer-spacer{flex:0 0 auto}.continuation-head{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid #dfe5ed;padding-bottom:7px;margin-bottom:10px}.continuation-label{font-size:11.4px;letter-spacing:.06em;text-transform:uppercase;color:#1f3f6d;font-weight:700}.continuation-title{font-size:13.2px;font-weight:700;color:#111}.continuation-meta{font-size:11.5px;color:#4b5563;text-align:right}#measureRoot{position:absolute;left:-99999px;top:0;width:794px;visibility:hidden;pointer-events:none}.editable-preview{outline:2px dashed transparent;border-radius:5px}.editable-preview:hover{outline-color:#9ca3af;background:#f9fafb}.watermark{font-size:11px;color:#6b7280;text-align:center;margin-top:6px}
    #mobilePdfRoot{position:fixed;left:-10000px;top:0;width:794px;background:#fff;z-index:-1;pointer-events:none;-webkit-text-size-adjust:100%;text-size-adjust:100%}#mobilePdfRoot *{-webkit-text-size-adjust:100%;text-size-adjust:100%}.pdf-export-root .page,#mobilePdfRoot .page{transform:none!important;margin:0!important;box-shadow:none!important}.pdf-export-root .page + .page,#mobilePdfRoot .page + .page{margin-top:12px!important}#mobilePdfRoot .page{width:794px!important;height:1123px!important;min-height:1123px!important;padding:40px 51px 36px!important;font-size:12.1px!important;line-height:1.24!important;overflow:hidden!important}#mobilePdfRoot .doc-shell{min-height:1047px!important}#mobilePdfRoot .doc-title{font-size:18px!important;margin:0 0 14px!important;line-height:1.16!important}#mobilePdfRoot .intro-box{font-size:12.1px!important;line-height:1.28!important;margin:10px 0 15px!important}#mobilePdfRoot .offer-table{margin:12px 0 10px!important}#mobilePdfRoot .offer-table th{font-size:11.2px!important;padding:6px 8px!important}#mobilePdfRoot .offer-table td{font-size:11.45px!important;line-height:1.19!important;padding:7px 8px!important}#mobilePdfRoot .total-card{margin:11px 0 46px!important;padding-bottom:0!important}#mobilePdfRoot .notice{font-size:10.6px!important;line-height:1.2!important}#mobilePdfRoot .doc-section{margin:14px 0!important}#mobilePdfRoot .info-box{padding:11px 12px!important;margin:13px 0!important}#mobilePdfRoot .info-box .pre{font-size:11.5px!important;line-height:1.24!important}#mobilePdfRoot .footer{font-size:9.3px!important}
    @media(max-width:700px){.preview-wrap{padding:10px;overflow-x:hidden}.preview-wrap #preview{width:100%;transform:none!important;zoom:normal!important}.preview-page-frame{position:relative;overflow:visible;margin:0 auto 14px}.preview-page-scale{position:absolute;left:0;top:0;width:794px;height:1123px;transform-origin:top left}.preview-page-scale .page{transform:none!important;margin:0!important;box-shadow:0 8px 22px rgba(0,0,0,.14)!important}.watermark{text-align:left}#mobilePdfRoot .page{transform:none!important;margin:0!important;box-shadow:none!important}}
    .print-only{display:none}
    @media print{
      html,body{background:#fff!important}.app,.topbar,.bottom,.toast,.modal-backdrop{display:none!important}.print-only{display:block}.page{box-shadow:none;margin:0;width:210mm;min-height:297mm;padding:10.5mm 13.5mm 9.5mm;font-size:9.15pt;overflow:visible;page-break-after:auto}.doc-shell{min-height:277mm}.pdf-header{grid-template-columns:1.05fr .95fr;gap:9mm;margin-bottom:4mm}.pdf-logo{width:45mm;margin:0 0 3mm 0}.customer-card{font-size:8.9pt;line-height:1.2;min-height:14mm}.customer-card .block-label{font-size:7.6pt;margin:0 0 1.3mm}.company-card{font-size:8.3pt;line-height:1.18;width:68mm;padding-left:3mm;border-left-width:1mm}.company-card b{font-size:8.8pt}.right-meta{width:68mm;margin-top:3mm;font-size:8.4pt}.doc-date{margin:0 0 1.8mm}.meta-box{grid-template-columns:max-content minmax(0,1fr);gap:.8mm 2.2mm;padding:2mm 2.4mm;border-radius:2mm}.doc-title{font-size:13.2pt;margin:0 0 3.8mm}.intro-box{font-size:8.9pt;line-height:1.28;margin:3mm 0 4.5mm}.offer-table{margin:3.5mm 0 3.2mm}.offer-table th{font-size:8.1pt;padding:1.7mm 1.9mm}.offer-table td{font-size:8.45pt;line-height:1.2;padding:1.6mm 1.9mm;border-bottom:1mm solid #fff}.offer-table .num{width:8mm}.offer-table .qty{width:14mm}.offer-table .money{width:27mm}.total-card{margin:3mm 0 12mm;padding-bottom:0}.total-wrap{max-width:90mm}.total-row{font-size:10.2pt;gap:6mm;min-width:63mm;padding-top:1.6mm}.notice{font-size:7.4pt;margin:1.1mm 0 0;text-align:right;line-height:1.18}.doc-section{margin:4mm 0}.doc-section h3{font-size:9.7pt;margin:0 0 1.2mm}.info-grid{gap:4mm;margin-top:2.5mm}.info-box{padding:3.2mm 3mm;border-radius:2mm;margin:3.8mm 0}.info-box h3{font-size:9.2pt;margin:0 0 1.3mm}.info-box .pre{font-size:8.1pt;line-height:1.2}.section-list .doc-section{padding:3mm 3mm;margin:3.6mm 0;border-left-width:.8mm;border-radius:1.6mm}.footer{font-size:7pt;gap:4mm;padding-top:2mm;margin-top:auto;text-align:center;justify-items:center}.continuation-head{padding-bottom:2mm;margin-bottom:2.2mm}.continuation-label{font-size:7.5pt}.continuation-title{font-size:9.2pt}.continuation-meta{font-size:7.3pt}.no-break{break-inside:avoid;page-break-inside:avoid}.editable-preview:hover{outline:none;background:transparent}@page{size:A4;margin:0}
    }


    /* PDF-Abstände v14: echte Spacer direkt aus paginateDoc(), nicht nur CSS-Margins. */
    .pdf-force-title-gap{display:block!important;height:72px!important;min-height:72px!important;flex:0 0 72px!important;margin:0!important;padding:0!important;font-size:0!important;line-height:0!important;break-inside:avoid;page-break-inside:avoid}
    .doc-title.pdf-main-title{margin:0 0 16px!important}
    .pdf-total-block{margin:13px 0 0!important;padding-bottom:0!important}
    .pdf-force-after-total-gap{display:block!important;height:48px!important;min-height:48px!important;flex:0 0 48px!important;margin:0!important;padding:0!important;font-size:0!important;line-height:0!important;break-inside:avoid;page-break-inside:avoid}
    #mobilePdfRoot .pdf-force-title-gap{height:72px!important;min-height:72px!important;flex-basis:72px!important}
    #mobilePdfRoot .doc-title.pdf-main-title{margin:0 0 14px!important}
    #mobilePdfRoot .pdf-total-block{margin:11px 0 0!important;padding-bottom:0!important}
    #mobilePdfRoot .pdf-force-after-total-gap{height:46px!important;min-height:46px!important;flex-basis:46px!important}
    #mobilePdfRoot .pdf-right-header{transform:translateX(32px)!important}
    @media(max-width:700px){
      .preview-page-scale .pdf-right-header,
      [data-inline-pdf-viewer] .inline-pdf-page-scale .pdf-right-header{transform:translateX(32px)!important}
    }
    @media print{
      .pdf-force-title-gap{height:18mm!important;min-height:18mm!important;flex-basis:18mm!important}
      .doc-title.pdf-main-title{margin:0 0 3.8mm!important}
      .pdf-total-block{margin:3mm 0 0!important;padding-bottom:0!important}
      .pdf-force-after-total-gap{height:12mm!important;min-height:12mm!important;flex-basis:12mm!important}
    }


    /* Kalender-Modal v22: keine horizontale Verschiebung am iPhone, Uhrzeit löschbar. */
    body.modal-open{overflow:hidden!important}
    .modal-backdrop{overflow:hidden;max-width:100vw}
    .modal{max-width:100vw;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}
    .modal-inner,#modalContent{min-width:0;max-width:100%;overflow-x:hidden}
    #modalContent .grid,#modalContent .actions{min-width:0;max-width:100%}
    #modalContent .grid>div{min-width:0;max-width:100%}
    #modalContent input,#modalContent textarea,#modalContent select{min-width:0;max-width:100%}
    .time-clear-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;min-width:0;max-width:100%}
    .time-clear-btn{width:44px;min-width:44px;height:44px;border-radius:14px;background:#f3f4f6;color:#374151;border:1px solid var(--line);font-size:22px;font-weight:900;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0}
    .time-clear-btn:active{transform:translateY(1px)}
    @media(max-width:700px){
      .modal{width:100vw;padding-left:10px;padding-right:10px}
      .modal-inner{width:100%;margin:0 auto}
      #modalContent .grid.two,#modalContent .grid.three{grid-template-columns:minmax(0,1fr)!important}
      #modalContent .actions{display:grid;grid-template-columns:minmax(0,1fr);gap:8px}
      #modalContent .actions .btn{width:100%;min-width:0}
    }

/* Einstellungen v101: übersichtlichere, kompaktere Verwaltung mit aufklappbaren Bereichen. */
.settings-page{display:grid;gap:12px}
.settings-hero{padding:14px}
.settings-hero-main{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.settings-hero h2{font-size:20px;margin:0;font-weight:900;letter-spacing:-.02em}
.settings-hero p{margin:4px 0 0;color:var(--muted);font-size:13px;max-width:620px}
.settings-hero-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.settings-page .btn{min-height:38px;padding:9px 12px;border-radius:12px}
.settings-page .btn.small{min-height:34px;padding:7px 10px;font-size:12px}
.settings-page .actions .btn{flex:0 1 auto}
.settings-page input,.settings-page textarea,.settings-page select{padding:10px 11px;border-radius:13px}
.settings-page textarea{min-height:74px}
.settings-quicknav{position:sticky;top:118px;z-index:7;display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px;border:1px solid rgba(229,231,235,.8);border-radius:18px;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);box-shadow:0 8px 24px rgba(17,24,39,.06)}
.settings-quicknav::-webkit-scrollbar{display:none}
.settings-quicknav a{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:7px 10px;border-radius:999px;background:#f3f4f6;color:#111827;text-decoration:none;font-size:12px;font-weight:850;white-space:nowrap;border:1px solid rgba(229,231,235,.95)}
.settings-accordion{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);overflow:hidden;scroll-margin-top:160px}
.settings-accordion>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#fff 0%,#fbfbfc 100%)}
.settings-accordion>summary::-webkit-details-marker{display:none}
.settings-summary-main{display:grid;gap:2px;min-width:0}
.settings-summary-main strong{font-size:16px;font-weight:900;letter-spacing:-.015em;color:#111827}
.settings-summary-main small{font-size:12.5px;color:#6b7280;line-height:1.35}
.settings-summary-icon{width:30px;height:30px;flex:0 0 30px;border-radius:999px;background:#f3f4f6;color:#374151;display:inline-flex;align-items:center;justify-content:center;font-weight:900;transition:.18s transform}
.settings-accordion[open]>summary{border-bottom:1px solid var(--line)}
.settings-accordion[open] .settings-summary-icon{transform:rotate(180deg)}
.settings-panel-body{padding:14px 16px 16px;background:#fff}
.settings-panel-body>.card{box-shadow:none;border:0;border-radius:0;padding:0;margin:0;background:transparent}
.settings-panel-body>.card+.card{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.settings-mini-card{border:1px solid var(--line);border-radius:18px;background:#fff;padding:13px;margin-bottom:12px}
.settings-mini-card:last-child{margin-bottom:0}
.settings-compact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.settings-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
.settings-export-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.settings-list-compact{gap:8px}
.settings-list-compact .item{padding:10px;border-radius:14px}
.settings-list-compact .item-title{font-size:14px}
.settings-page .section-title{margin-bottom:9px}
.settings-page .section-title h2{font-size:16px}
.settings-page .section-title p{font-size:12.5px}
.settings-page .hint{font-size:12.5px}
.settings-page .mini-divider{margin:12px 0}
.settings-page .overview-box{box-shadow:none}
@media(max-width:900px){.settings-split,.settings-compact-grid{grid-template-columns:1fr}.settings-export-grid{grid-template-columns:1fr 1fr}.settings-quicknav{top:104px}}
@media(max-width:700px){.settings-page{gap:10px}.settings-hero{padding:12px}.settings-hero h2{font-size:18px}.settings-hero-actions{display:grid;grid-template-columns:1fr;gap:7px}.settings-page .btn,.settings-page .btn.small{width:100%;min-height:40px}.settings-quicknav{top:112px;margin-left:-2px;margin-right:-2px;border-radius:16px;padding:7px}.settings-accordion{border-radius:18px;scroll-margin-top:150px}.settings-accordion>summary{padding:13px}.settings-panel-body{padding:12px}.settings-export-grid{grid-template-columns:1fr}.settings-mini-card{padding:12px;border-radius:16px}.settings-summary-main strong{font-size:15px}}


.role-guard-notice{
  border-left:4px solid #64748b;
  box-shadow:none;
  background:#f8fafc;
}
.role-guard-notice .hint{display:block;margin-top:4px}
