:root{
  --bg:#08090a;
  --sidebar:#0d0e10;
  --surface:rgba(255,255,255,.035);
  --surface-strong:rgba(255,255,255,.055);
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.14);
  --text:#f7f8f8;
  --muted:#8a8f98;
  --muted-strong:#d0d6e0;
  --accent:#7170ff;
  --accent-strong:#828fff;
  --success:#10b981;
  --danger:#ef4444;
  --radius-panel:12px;
  --radius-control:8px;
  --radius-small:6px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  background:var(--bg);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-feature-settings:'cv01','ss03';
  letter-spacing:-.01em;
}
.shell,main,.grid,.card,.panel,.hero{min-width:0;max-width:100%}
.sidebar,nav{max-width:100%;min-width:0}
.card strong,.card p{min-width:0;max-width:100%;overflow-wrap:anywhere;word-break:break-word}
#deployaroVersion{font-size:clamp(14px,4.2vw,17px);line-height:1.25}
.shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{
  position:sticky;top:0;height:100vh;padding:24px;
  background:var(--sidebar);
  border-right:1px solid var(--line);
}
.brand{display:flex;gap:12px;align-items:center;margin-bottom:34px}
.brand strong{font-weight:650;letter-spacing:-.03em}
.brand span{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.logo{
  width:40px;height:40px;border-radius:10px;display:grid;place-items:center;
  background:#f7f8f8;color:#08090a;font-weight:800;
  box-shadow:none;
}
.brand-logo{
  width:40px;height:40px;border-radius:10px;display:block;object-fit:contain;
  background:transparent;box-shadow:none;
}
nav{display:grid;gap:4px}
nav a{
  padding:10px 11px;border-radius:var(--radius-control);
  color:var(--muted);text-decoration:none;font-size:14px;font-weight:520;
  border:1px solid transparent;
}
nav a.active,nav a:hover{background:var(--surface);border-color:var(--line);color:var(--text)}
.status-pill{
  position:absolute;bottom:24px;left:24px;right:24px;
  padding:10px 11px;border-radius:var(--radius-control);
  color:var(--success);background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.18);
  font-size:13px;font-weight:560;
}
main{padding:28px;display:grid;gap:18px;max-width:1500px;width:100%}
.glass,.card{
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:none;
  backdrop-filter:none;
}
.hero{
  border-radius:var(--radius-panel);padding:28px;
  display:flex;justify-content:space-between;gap:24px;align-items:center;
}
.eyebrow{margin:0 0 8px;color:var(--accent-strong);font-size:11px;font-weight:650;text-transform:uppercase;letter-spacing:.13em}
.deployaro-title{font-size:clamp(48px,8vw,96px);line-height:1.08;margin:0;font-weight:820;letter-spacing:-.075em;text-transform:lowercase}
.deployaro-subtitle{margin:18px 0 0;color:var(--muted);font-size:clamp(11px,1.4vw,14px);line-height:1.25;font-weight:620;letter-spacing:.08em;text-transform:none}
h1{font-size:38px;line-height:1.03;margin:0 0 12px;max-width:880px;font-weight:620;letter-spacing:-.045em}
h2{margin:0;font-size:20px;font-weight:620;letter-spacing:-.025em}
h3{letter-spacing:-.02em}
p{color:var(--muted);line-height:1.55;margin:0}
button,.primary{
  appearance:none;border-radius:var(--radius-control);padding:10px 14px;
  border:1px solid var(--line-strong);background:var(--surface-strong);
  color:var(--text);font-weight:620;cursor:pointer;box-shadow:none;
}
.primary{background:var(--accent);border-color:var(--accent);color:#fff}
button:hover,.upload-box:hover{border-color:var(--line-strong);background:rgba(255,255,255,.075)}
.primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}
button.danger,.danger{border-color:rgba(239,68,68,.28);color:#fecaca;background:rgba(239,68,68,.08)}
button.danger:hover,.danger:hover{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.42)}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.card{border-radius:var(--radius-panel);padding:18px}
.card span{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:650}
.card strong{display:block;font-size:18px;margin:10px 0 6px;font-weight:630}
.panel{border-radius:var(--radius-panel);padding:20px;background:var(--surface);border:1px solid var(--line);box-shadow:none}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:14px}
.onboarding-panel-head{margin-bottom:0;align-items:stretch;flex-wrap:wrap}
.onboarding-dropdown-toggle{flex:1 1 260px;display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left;background:transparent;border-color:transparent;padding:6px 0;color:var(--text);font-size:21px;font-weight:780;letter-spacing:-.02em}
.onboarding-dropdown-toggle h2{margin:0;font-size:21px;line-height:1.25}
.onboarding-dropdown-toggle:hover,.onboarding-dropdown-toggle:focus{background:rgba(255,255,255,.04);border-color:var(--line);padding-left:10px;padding-right:10px}
.onboarding-chevron{color:var(--muted);transition:transform .18s ease}
.onboarding-dropdown-toggle[aria-expanded="true"] .onboarding-chevron{transform:rotate(180deg)}
.onboarding-section-body{display:grid;gap:14px;margin-top:14px}
.onboarding-dropdown-open{border-color:rgba(113,112,255,.35)}
.modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.module{border:1px solid var(--line);border-radius:var(--radius-panel);padding:14px;background:rgba(255,255,255,.025)}
.module h3{margin:0 0 6px;font-size:16px}
.module p{font-size:14px;margin-bottom:10px}
.module small{color:var(--muted);font-size:12px}
.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.form-grid label{display:grid;gap:7px;color:var(--muted-strong);font-size:13px;font-weight:560}
input,select{
  width:100%;padding:10px 11px;border-radius:var(--radius-control);
  border:1px solid var(--line);background:rgba(0,0,0,.18);color:var(--text);
  outline:none;box-shadow:none;
}
input:focus,select:focus{border-color:rgba(113,112,255,.62);background:rgba(255,255,255,.035)}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{appearance:none;-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield;appearance:textfield}
select option{background:#111214;color:#f7f8f8}
.email-server-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.logo-row,.data-actions{display:flex;gap:12px;align-items:center;margin-top:16px;flex-wrap:wrap}
.data-actions .upload-box,.data-actions button{min-height:42px;padding:10px 14px}
.logo-preview{
  width:180px;min-height:88px;border:1px dashed var(--line-strong);border-radius:var(--radius-panel);
  display:grid;place-items:center;padding:12px;color:var(--muted);background:rgba(0,0,0,.16);
}
.logo-preview img{max-width:140px;max-height:58px;display:block}.logo-preview span{font-size:11px;color:var(--muted);margin-top:6px}
.upload-box{
  display:inline-grid;place-items:center;min-height:42px;border:1px solid var(--line);
  border-radius:var(--radius-control);background:var(--surface);padding:10px 14px;
  color:var(--text);font-weight:620;cursor:pointer;
}
.upload-box input{display:none}
.tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.tab{padding:9px 12px;color:var(--muted-strong)}
.tab.active{background:rgba(113,112,255,.14);border-color:rgba(113,112,255,.42);color:#fff}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.16)}
.sets-master-detail{display:grid;grid-template-columns:minmax(340px,420px) minmax(0,1fr);gap:14px;padding:14px;align-items:start}
.set-list,.set-detail{border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.14);padding:14px;min-width:0}
.set-list{position:sticky;top:18px;align-self:start;max-height:calc(100vh - 150px);overflow:auto}
.set-detail{position:sticky;top:18px;align-self:start;padding-bottom:90px}
.set-list h3,.set-detail h3{margin:0 0 8px}
.set-list-entry{display:grid;gap:8px;margin-bottom:8px}
.set-list-item{width:100%;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;text-align:left;background:rgba(255,255,255,.025)}
.set-panel-detail{display:block}
.set-inline-detail{display:none}
.set-list-item strong{min-width:0;white-space:normal;overflow-wrap:anywhere;line-height:1.25}
.set-list-item small{color:var(--muted);white-space:nowrap;padding-top:2px}
.set-list-item.active{border-color:rgba(113,112,255,.52);background:rgba(113,112,255,.16);color:#fff}
.set-list-empty{padding:12px;color:var(--muted);border:1px dashed var(--line);border-radius:var(--radius-control)}
.set-detail label{display:grid;gap:7px;color:var(--muted-strong);font-size:13px;font-weight:560;margin-bottom:12px}
.set-detail textarea{width:100%;min-height:76px;border:1px solid var(--line);border-radius:var(--radius-control);background:rgba(0,0,0,.18);color:var(--text);padding:10px 11px;resize:vertical}
.set-product-search{display:grid;gap:8px;margin:12px 0 14px}
.dataset-search{display:grid;gap:8px;margin:0 0 12px;padding:12px;border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.14)}
.dataset-search label{display:grid;gap:7px;color:var(--muted-strong);font-size:13px;font-weight:560}
.dataset-search input{width:100%;border:1px solid var(--line);border-radius:var(--radius-control);background:rgba(0,0,0,.18);color:var(--text);padding:10px 11px}
.upload-progress{display:grid;gap:9px;margin:12px 0;padding:12px;border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.18)}
.upload-progress.active{border-color:rgba(113,112,255,.42);background:rgba(113,112,255,.09)}
.upload-progress.done{border-color:rgba(16,185,129,.36);background:rgba(16,185,129,.09)}
.upload-progress.error{border-color:rgba(239,68,68,.42);background:rgba(239,68,68,.09)}
.upload-progress-head{display:flex;justify-content:space-between;gap:12px;align-items:center;color:var(--muted-strong);font-size:13px}
.upload-progress-head span{color:var(--muted);font-weight:750}
.upload-progress-track{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.upload-progress-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-strong));transition:width .25s ease}
.bulk-selection-controls{display:flex;gap:10px;align-items:center;justify-content:space-between;margin:0 0 12px;padding:12px;border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.14);flex-wrap:wrap}
.bulk-select-all{display:flex;gap:8px;align-items:center;color:var(--muted-strong);font-size:13px;font-weight:620}
.bulk-select-all input,.row-select-cell input{width:auto;min-width:18px;height:18px;accent-color:var(--accent)}
.row-select-cell{width:52px;text-align:center}
.row-select-cell input{display:inline-block}
.catalog-search-results{display:grid;gap:8px}
.catalog-search-result{display:grid;grid-template-columns:minmax(86px,auto) minmax(0,1fr) auto;gap:8px;align-items:center;width:100%;text-align:left;background:rgba(255,255,255,.025);border-color:var(--line);padding:10px 12px}
.catalog-search-sku{font-weight:750;letter-spacing:.01em;white-space:nowrap}
.catalog-search-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.catalog-search-source{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}
.catalog-search-empty{padding:12px;color:var(--muted);border:1px dashed var(--line);border-radius:var(--radius-control)}
.set-lines{display:grid;gap:10px;margin:12px 0 14px}
.set-line-card{border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(255,255,255,.02);overflow:hidden}
.set-line-card.open{border-color:rgba(113,112,255,.42);background:rgba(113,112,255,.07)}
.set-line-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left;background:transparent;border:0;border-radius:0;padding:12px}
.set-line-toggle:hover{background:rgba(255,255,255,.045)}
.set-line-summary{display:grid;gap:3px;min-width:0}
.set-line-summary strong{font-size:15px;font-weight:780;letter-spacing:.01em}
.set-line-summary span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);font-weight:620}
.set-line-summary small,.set-line-chevron{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.set-line-fields{display:grid;grid-template-columns:minmax(120px,1fr) minmax(100px,.6fr) minmax(120px,1fr) auto;gap:10px;align-items:end;padding:0 12px 12px}
.set-line-fields label{margin:0}
table{width:100%;min-width:860px;border-collapse:separate;border-spacing:0}
th,td{border-bottom:1px solid var(--line);padding:8px;text-align:left;vertical-align:middle}
th{position:sticky;top:0;background:#101113;color:var(--muted-strong);font-size:11px;text-transform:uppercase;letter-spacing:.09em;font-weight:650;z-index:1}
td{background:rgba(255,255,255,.012)}
tbody tr:hover td{background:rgba(255,255,255,.028)}
td input{border:1px solid transparent;background:transparent;padding:8px;border-radius:var(--radius-small)}
.material-name-column{min-width:320px;width:32%}
td.material-name-column input{font-weight:560}
td input:focus{border-color:rgba(113,112,255,.5);background:rgba(255,255,255,.04)}
pre{white-space:pre-wrap;max-height:360px;overflow:auto;background:rgba(0,0,0,.24);border:1px solid var(--line);border-radius:var(--radius-panel);padding:16px;color:#d0d6e0;font-size:13px;line-height:1.5}
.security-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
.security-list div{padding:12px;border:1px solid rgba(16,185,129,.18);background:rgba(16,185,129,.06);border-radius:var(--radius-control);color:var(--muted-strong)}
.muted{color:var(--muted);font-size:14px;margin-bottom:14px}
.quote-form{display:grid;grid-template-columns:2fr 2fr 1fr auto;gap:12px;align-items:end;margin:16px 0}
.quote-form label{display:grid;gap:7px;color:var(--muted-strong);font-size:13px;font-weight:560}
.quotes-list{display:grid;gap:10px}
.quote-card{border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.14);padding:14px;display:grid;gap:8px}
.quote-card>div:first-child{display:flex;justify-content:space-between;gap:12px;align-items:center}
.quote-card span{color:var(--accent-strong);font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:650}
.quote-card small{color:var(--muted)}
.quote-actions{display:flex;gap:8px;flex-wrap:wrap}
.upload-history{margin-top:18px;display:grid;gap:10px}
.upload-history-toggle{width:100%;text-align:left;justify-content:flex-start;border:1px solid var(--line);background:rgba(255,255,255,.035);color:var(--muted-strong);font-weight:620}
.upload-history-toggle::after{content:'▾';margin-left:auto;float:right;color:var(--muted)}
.upload-history-toggle[aria-expanded="true"]::after{content:'▴'}
.update-card{border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.16);padding:14px;display:grid;gap:8px;color:var(--muted-strong)}
.update-card strong{color:var(--text);font-size:17px}
.update-card pre{margin:0;max-height:220px}
.upload-history h3{margin:0;color:var(--muted-strong);font-size:15px;font-weight:620}
.telegram-allowed-users-list{display:grid;gap:10px;margin-top:12px}
.telegram-user-item{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--line);border-radius:var(--radius-control);padding:12px;background:rgba(0,0,0,.14)}
.telegram-user-item div{display:grid;gap:4px}.telegram-user-item small,.telegram-user-empty{color:var(--muted);font-size:13px}
.telegram-user-form button{align-self:end;min-height:42px}
.backup-list{display:grid;gap:10px;margin-top:12px}
.backup-progress{margin:12px 0 4px;border:1px solid var(--line);border-radius:var(--radius-control);padding:10px;background:rgba(0,0,0,.18);display:grid;gap:8px}
.backup-progress.active{border-color:rgba(99,102,241,.55)}
.backup-progress.done{border-color:rgba(34,197,94,.6)}
.backup-progress.error{border-color:rgba(239,68,68,.7)}
.backup-item{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--line);border-radius:var(--radius-control);padding:12px;background:rgba(0,0,0,.14)}
.backup-item.safety-backup{border-color:rgba(59,130,246,.45);background:rgba(59,130,246,.10)}
.backup-item,.backup-item>div,.backup-actions{min-width:0;max-width:100%}
.backup-label{width:fit-content;max-width:100%;display:inline-flex;border:1px solid rgba(148,163,184,.35);border-radius:999px;padding:2px 8px;color:var(--muted-strong);font-size:12px;font-weight:650;background:rgba(255,255,255,.06)}
.backup-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.backup-item div{display:grid;gap:4px}.backup-item small,.backup-empty{color:var(--muted);font-size:13px}
.backup-item strong,.backup-item small,.backup-label{overflow-wrap:anywhere;word-break:break-word;max-width:100%}
.planning-list{display:grid;gap:12px}
.planning-card{border:1px solid var(--line);border-radius:var(--radius-panel);background:rgba(0,0,0,.16);padding:14px;display:grid;gap:12px}
.planning-card>div:first-child{display:grid;grid-template-columns:auto minmax(180px,1fr) auto;gap:12px;align-items:center}
.planning-status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:750;border:1px solid var(--line-strong);color:var(--muted-strong);background:rgba(255,255,255,.055)}
.planning-status-badge.status-option{color:#fecaca;background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.42)}
.planning-status-badge.status-confirmed{color:#bbf7d0;background:rgba(16,185,129,.14);border-color:rgba(16,185,129,.42)}
.planning-card strong{display:block;color:var(--text);font-size:17px;margin:0}
.planning-card small{color:var(--muted)}
.excel-like-table{width:100%;min-width:720px;border-collapse:separate;border-spacing:0;background:rgba(0,0,0,.14)}
.excel-like-table th,.excel-like-table td{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:9px 10px;vertical-align:top}
.excel-like-table th:first-child,.excel-like-table td:first-child{border-left:1px solid var(--line)}
.excel-like-table thead th{border-top:1px solid var(--line);background:#101113;color:var(--muted-strong);font-size:11px;text-transform:uppercase;letter-spacing:.09em;font-weight:700;position:static}
.excel-like-table tbody tr:nth-child(even) td{background:rgba(255,255,255,.018)}
.excel-like-table tbody tr:hover td{background:rgba(113,112,255,.055)}
.project-details-table-wrap{border-radius:var(--radius-control);overflow:auto}
.planning-shortage{border:1px solid rgba(239,68,68,.32);background:rgba(239,68,68,.08);border-radius:var(--radius-control);padding:12px;color:#fecaca;display:grid;gap:10px}
.planning-shortage strong{color:#fecaca;margin:0}
.planning-empty{border:1px dashed var(--line-strong);border-radius:var(--radius-panel);padding:16px;color:var(--muted);background:rgba(0,0,0,.14)}
.data-footer-actions{display:flex;justify-content:flex-end;margin-top:14px}
.data-footer-actions button{min-width:120px}
.floating-save{
  position:fixed;right:28px;bottom:28px;z-index:50;
  padding:13px 18px;border-radius:999px;
  box-shadow:0 14px 38px rgba(0,0,0,.38);
}
.login-gate{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:rgba(0,0,0,.92);padding:20px}
.login-card{width:min(420px,100%);padding:24px;display:grid;gap:14px;background:#111214;border:1px solid rgba(255,255,255,.18);border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.72)}
.login-card h1{margin:0}.login-card label,.profile-row label{display:grid;gap:6px;color:var(--muted-strong)}
.login-card input{background:#08090a;border-color:rgba(255,255,255,.22);color:#fff}.login-card input:focus{background:#08090a;border-color:rgba(130,143,255,.82)}
.error{color:var(--danger);min-height:1.3em}.profile-menu{position:fixed;top:16px;right:16px;z-index:120;display:grid;justify-items:end;gap:8px}.profile-menu-button{border-radius:999px;background:#111214;border-color:rgba(255,255,255,.18);box-shadow:0 12px 34px rgba(0,0,0,.38)}.profile-menu-panel{width:min(320px,calc(100vw - 32px));display:grid;gap:10px;padding:14px;border-radius:var(--radius-panel);background:#111214;border:1px solid rgba(255,255,255,.16);box-shadow:0 18px 48px rgba(0,0,0,.58)}.profile-menu-panel label{display:grid;gap:6px;color:var(--muted-strong);font-size:13px}.profile-menu-panel input{background:#08090a;border-color:rgba(255,255,255,.18)}.profiles-list{display:grid;gap:12px}.profile-row{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr));gap:12px;align-items:end;padding:12px;border:1px solid var(--line);border-radius:var(--radius-control);background:var(--surface)}.profile-row input,.profile-row select,.login-card input{width:100%}.role-help{color:var(--muted-strong);margin-bottom:12px}
body[data-role="werknemer"] nav a:not([href="/planning.html"]),body[data-role="gebruiker"] nav a[href="/index.html"]{display:none!important}
@media(max-width:1100px){.form-grid,.grid,.security-list{grid-template-columns:1fr 1fr}.quote-form{grid-template-columns:1fr 1fr}.sets-master-detail{grid-template-columns:1fr}.shell{grid-template-columns:230px 1fr}.profile-row{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.shell{grid-template-columns:1fr}.sidebar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px 12px;position:sticky;top:0;height:auto;z-index:40;padding:12px 14px;border-right:0;border-bottom:1px solid var(--line)}.brand{margin-bottom:0;min-width:0}.brand .logo,.brand-logo{width:34px;height:34px;border-radius:9px}.brand span{display:none}nav{grid-column:1/-1;display:flex;overflow-x:auto;gap:8px;padding-bottom:2px;scrollbar-width:none;-webkit-overflow-scrolling:touch}nav::-webkit-scrollbar{display:none}nav a{flex:0 0 auto;min-height:42px;display:inline-flex;align-items:center;white-space:nowrap;background:rgba(255,255,255,.025);border-color:var(--line)}nav a.active{background:rgba(113,112,255,.16);border-color:rgba(113,112,255,.46)}.profile-menu{position:relative;top:auto;right:auto;justify-self:end;align-self:center;padding:0;background:transparent;border-bottom:0;z-index:41}.profile-menu-button{width:auto;max-width:42vw;min-height:34px;padding:7px 10px;font-size:13px;line-height:1.1}.profile-menu-panel{position:absolute;top:calc(100% + 8px);right:0;width:min(320px,calc(100vw - 28px));max-width:none}main{padding:18px}.grid,.form-grid,.security-list,.quote-form{grid-template-columns:1fr}.hero{display:block}h1{font-size:30px}.panel-head{align-items:flex-start;flex-direction:column}}
@media(max-width:600px){
  html{scroll-padding-bottom:88px;-webkit-text-size-adjust:100%}
  body{font-size:16px;overflow-x:hidden}
  .shell{display:block;min-height:100vh;max-width:100%;overflow-x:hidden}
  .login-gate{padding:16px;background:rgba(0,0,0,.94)}
  .login-card{padding:22px 18px;border-radius:16px;max-width:calc(100vw - 32px)}
  main{padding:12px 12px 92px;gap:12px;max-width:100%;overflow-x:hidden}
  .hero,.panel,.card{border-radius:14px;padding:16px}
  .hero{display:grid;gap:14px;align-items:start}
  .hero .primary,.panel-head button{width:100%}
  h1{font-size:24px;line-height:1.16;letter-spacing:-.035em;margin-bottom:10px}
  h2{font-size:18px;line-height:1.25}
  h3{font-size:15px;margin:0 0 8px}
  p,.muted{font-size:14px;line-height:1.45}
  .eyebrow{font-size:11px;letter-spacing:.08em}
  .grid,.form-grid,.security-list,.quote-form,.onboarding-grid{grid-template-columns:1fr;gap:12px}
  .stats{gap:10px}
  .card span{font-size:10px;letter-spacing:.1em}
  .card strong{font-size:17px;margin:8px 0 5px}
  .panel-head{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:14px}
  button,.primary,.upload-box,input,select,textarea{font-size:16px;min-height:44px}
  button,.primary,.upload-box{width:100%;justify-content:center;text-align:center;padding:11px 14px}
  input,select,textarea{padding:11px 12px}
  .form-grid label,.quote-form label{font-size:14px;gap:8px}
  .logo-row{display:grid;grid-template-columns:1fr;gap:10px;align-items:stretch}
  .logo-preview{width:100%;min-height:110px}.logo-preview img{max-width:180px;max-height:74px}
  .tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px}
  .tab{padding:11px 8px;min-height:44px;font-size:14px}
  .data-actions,.data-footer-actions,.quote-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:12px}
  .table-wrap{overflow:visible;border:0;background:transparent;border-radius:0}
  .sets-master-detail{display:grid;grid-template-columns:1fr;gap:10px;padding:0}
  .set-list,.set-detail{position:static;max-height:none;overflow:visible;padding:12px;border-radius:14px}
  .sets-inline-mobile{display:block}
  .set-list-entry{gap:0;margin-bottom:10px}
  .set-panel-detail{display:none}
  .set-inline-detail{display:block;margin-top:8px;padding:12px;border-color:rgba(113,112,255,.34);background:rgba(113,112,255,.06)}
  .set-list-item{min-height:44px}
  .set-detail label{font-size:14px}
  .catalog-search-result{grid-template-columns:1fr;gap:3px;align-items:start;text-align:left;padding:12px}
  .catalog-search-sku,.catalog-search-name,.catalog-search-source{white-space:normal;overflow-wrap:anywhere}
  .catalog-search-name{font-size:14px;line-height:1.25}
  .catalog-search-source{font-size:10px}
  .set-lines{gap:8px}
  .set-line-toggle{align-items:flex-start;padding:12px}
  .set-line-summary span{white-space:normal;overflow-wrap:anywhere;font-size:15px;line-height:1.25}
  .set-line-chevron{white-space:nowrap;padding-top:2px}
  .set-line-fields{grid-template-columns:1fr;gap:8px;padding:0 12px 12px}
  .set-line-fields button{width:100%}
  table.mobile-card-table{min-width:0;width:100%;border-collapse:separate;border-spacing:0 10px}
  table.mobile-card-table thead{display:none}
  table.mobile-card-table tbody,table.mobile-card-table tr,table.mobile-card-table td{display:block;width:100%}
  table.mobile-card-table tr{border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.18);padding:10px;margin-bottom:10px;overflow:hidden}
  table.mobile-card-table tr.empty-row{padding:14px}
  table.mobile-card-table td{display:grid;grid-template-columns:minmax(104px,.8fr) minmax(0,1.4fr);gap:10px;align-items:center;border-bottom:1px solid var(--line);padding:9px 0;background:transparent;min-height:42px}
  table.mobile-card-table td:last-child{border-bottom:0}
  table.mobile-card-table td::before{content:attr(data-label);color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;align-self:center}
  table.mobile-card-table td[colspan]{grid-template-columns:1fr;color:var(--muted-strong);text-align:left}
  table.mobile-card-table td[colspan]::before{display:none}
  td input{min-height:42px;padding:10px;border:1px solid var(--line);background:rgba(255,255,255,.035)}
  .backup-item{display:grid;grid-template-columns:1fr;align-items:start;gap:10px;width:100%;overflow:hidden}
  .backup-actions{display:grid;grid-template-columns:1fr;width:100%;justify-content:stretch;gap:8px}
  .backup-actions button{width:100%}
  .backup-label{justify-self:start}
  .upload-history{margin-top:16px;gap:8px}
  .quote-card>div:first-child{display:grid;grid-template-columns:1fr;align-items:start;gap:6px}.quote-card{padding:13px}
  pre{font-size:12px;max-height:260px;padding:12px}
  .floating-save{left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));width:auto;min-height:52px;padding:14px 18px;border-radius:14px;box-shadow:0 16px 44px rgba(0,0,0,.55);border-color:rgba(113,112,255,.52)}
  .calendar-panel{overflow:visible}
  .calendar-grid.month-grid{display:none}
  .mobile-agenda-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:10px;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035)}
  .mobile-agenda-weekday{color:var(--muted-strong);font-size:11px;font-weight:750;text-align:center;text-transform:uppercase;letter-spacing:.08em;padding:2px 0 5px}
  .mobile-agenda-day{width:100%;min-height:42px;padding:6px 3px;border-radius:11px;border:1px solid transparent;background:rgba(255,255,255,.028);display:grid;gap:3px;place-items:center;color:var(--text);font-size:14px;line-height:1}
  .mobile-agenda-day strong{font-size:14px;font-weight:750}
  .mobile-agenda-day span{display:flex;gap:2px;min-height:5px;align-items:center;justify-content:center}
  .mobile-agenda-day.outside-month{opacity:.38}
  .mobile-agenda-day.today{border-color:rgba(255,255,255,.86);box-shadow:0 0 0 1px rgba(255,255,255,.28) inset}
  .mobile-agenda-day.has-project{border-color:rgba(255,255,255,.14);background:rgba(113,112,255,.18)}
  .mobile-agenda-day.has-project strong{color:#fff}
  .mobile-agenda-day.selected{outline:2px solid #fff;outline-offset:1px}
  .mobile-agenda-dot{width:4px;height:4px;border-radius:999px;display:block;border:1px solid rgba(255,255,255,.25)}
  .mobile-project-list{display:grid;gap:10px;margin-top:12px}
  .mobile-project-card{width:100%;max-width:100%;min-width:0;display:grid;grid-template-columns:1fr;gap:7px;align-items:start;text-align:left;border-radius:14px;padding:12px;border:1px solid rgba(255,255,255,.16);color:#fff;min-height:74px;overflow:hidden}
  .mobile-project-card .planning-status-badge{align-self:start;justify-self:start;font-size:10px;padding:5px 8px;max-width:100%}
  .mobile-project-card strong,.mobile-project-card small,.mobile-project-card em{min-width:0;overflow-wrap:anywhere;white-space:normal}
  .mobile-project-card strong{font-size:15px;line-height:1.2}
  .mobile-project-card small{color:rgba(255,255,255,.82);font-size:12px}
  .mobile-project-card em{font-style:normal;color:rgba(255,255,255,.72);font-size:12px}
  .mobile-project-card.selected{outline:2px solid #fff;outline-offset:1px}
  .mobile-project-inline-details{width:100%;min-width:0;display:grid;gap:10px;margin:-4px 0 8px;padding:0;animation:mobileProjectDetailsIn .16s ease-out}
  .mobile-project-card.selected+.mobile-project-inline-details{border-radius:14px;outline:1px solid rgba(255,255,255,.12);outline-offset:-1px}
  .mobile-project-inline-details .planning-card{border-color:rgba(255,255,255,.18);background:rgba(0,0,0,.22);padding:12px;border-radius:14px}
  .mobile-project-inline-details .planning-actions{display:grid;grid-template-columns:1fr;gap:8px}
  #planningPage{display:none}
  .planning-card>div:first-child{grid-template-columns:1fr;align-items:start}
  .project-details-table-wrap{overflow:visible;border:0;background:transparent;border-radius:0}
  .excel-like-table{min-width:0}
  .planning-lines-table.excel-like-table,.planning-shortage-table.excel-like-table{width:100%;border-collapse:separate;border-spacing:0 8px;background:transparent}
  .planning-lines-table.excel-like-table thead,.planning-shortage-table.excel-like-table thead{display:none}
  .planning-lines-table.excel-like-table tbody,.planning-lines-table.excel-like-table tr,.planning-lines-table.excel-like-table td,.planning-shortage-table.excel-like-table tbody,.planning-shortage-table.excel-like-table tr,.planning-shortage-table.excel-like-table td{display:block;width:100%}
  .planning-lines-table.excel-like-table tr,.planning-shortage-table.excel-like-table tr{border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.18);padding:9px;margin-bottom:8px;overflow:hidden}
  .planning-lines-table.excel-like-table td,.planning-shortage-table.excel-like-table td{display:grid;grid-template-columns:minmax(104px,.85fr) minmax(0,1.4fr);gap:9px;align-items:start;border:0;border-bottom:1px solid var(--line);padding:8px 0;background:transparent;overflow-wrap:anywhere}
  .planning-lines-table.excel-like-table td:last-child,.planning-shortage-table.excel-like-table td:last-child{border-bottom:0}
  .planning-lines-table.excel-like-table td::before,.planning-shortage-table.excel-like-table td::before{content:attr(data-label);color:var(--muted);font-size:10px;font-weight:750;text-transform:uppercase;letter-spacing:.08em}
  .planning-lines-table.excel-like-table td[colspan],.planning-shortage-table.excel-like-table td[colspan]{grid-template-columns:1fr;color:var(--muted-strong)}
  .planning-lines-table.excel-like-table td[colspan]::before,.planning-shortage-table.excel-like-table td[colspan]::before{display:none}
}

.calendar-panel{overflow:hidden}
.mobile-agenda-grid{display:none}
.mobile-project-list{display:none}
.calendar-head{align-items:flex-start}
.calendar-actions{display:flex;gap:8px;flex-wrap:wrap}
.calendar-actions button{min-width:130px}
.calendar-grid.month-grid{
  display:grid;
  grid-template-columns:70px repeat(7,minmax(120px,1fr));
  grid-auto-rows:auto;
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--radius-panel);
  overflow:auto;
  position:relative;
}
.calendar-corner,.calendar-weekday{
  background:rgba(255,255,255,.055);
  padding:10px 12px;
  color:var(--muted-strong);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
  position:sticky;
  top:0;
  z-index:4;
}
.calendar-corner{left:0;z-index:5}
.calendar-week-number{
  background:rgba(255,255,255,.04);
  color:var(--muted-strong);
  padding:12px 10px;
  font-size:12px;
  font-weight:750;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  position:sticky;
  left:0;
  z-index:3;
}
.calendar-day{
  min-height:180px;
  background:rgba(10,11,13,.94);
  padding:10px;
  display:grid;
  align-content:start;
  gap:8px;
  position:relative;
}
.calendar-day.past{background:rgba(0,0,0,.54);color:#6f747d}
.calendar-day.today{outline:2px solid var(--accent-strong);outline-offset:-2px;background:rgba(113,112,255,.11)}
.calendar-date{display:flex;justify-content:space-between;gap:8px;align-items:center}
.calendar-date strong{font-size:18px}
.calendar-date span{font-size:11px;color:var(--muted)}
.calendar-project{color:var(--text);cursor:pointer}
.calendar-project:hover{border-color:var(--accent-strong);filter:brightness(1.08)}
.calendar-project-bar{
  align-self:start;
  height:26px;
  margin:calc(44px + (var(--lane) * 32px)) 8px 0;
  border:1px solid rgba(255,255,255,.2);
  border-radius:999px;
  padding:4px 10px;
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  overflow:hidden;
  text-align:left;
  z-index:2;
  box-shadow:0 8px 20px rgba(0,0,0,.22);
}
.calendar-project-bar strong{font-size:12px;line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.calendar-project-bar span{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.78);white-space:nowrap}
.calendar-project-bar.option{border-style:dashed}
.calendar-project-bar.confirmed{border-style:solid}
.calendar-project-bar.selected{outline:2px solid #fff;outline-offset:1px}
.project-color-1{background:#4f46e5}
.project-color-2{background:#0891b2}
.project-color-3{background:#059669}
.project-color-4{background:#ca8a04}
.project-color-5{background:#dc2626}
.project-color-6{background:#9333ea}
.project-color-7{background:#0d9488}
.project-color-8{background:#ea580c}
.project-color-9{background:#2563eb}
.project-color-10{background:#be185d}
.planning-actions{display:flex;gap:8px;flex-wrap:wrap}
.planning-actions a,.button-link{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--radius-control);padding:8px 10px;color:var(--text);text-decoration:none;background:rgba(255,255,255,.04);font-size:13px;font-weight:620}
.planning-actions a:hover,.button-link:hover{border-color:var(--accent-strong);background:rgba(113,112,255,.12)}
@media(max-width:900px){
  .calendar-grid.month-grid{grid-template-columns:54px repeat(7,minmax(92px,1fr));overflow:auto}
  .calendar-actions{display:grid;grid-template-columns:1fr;width:100%}
  .calendar-day{min-height:150px;padding:8px}
  .calendar-project-bar{height:24px;margin:calc(40px + (var(--lane) * 29px)) 4px 0;padding:4px 8px}
}
@media(max-width:600px){.calendar-panel{overflow:visible}.calendar-grid.month-grid{display:none}.mobile-agenda-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:10px;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035)}.mobile-agenda-weekday{color:var(--muted-strong);font-size:11px;font-weight:750;text-align:center;text-transform:uppercase;letter-spacing:.08em;padding:2px 0 5px}.mobile-agenda-day{width:100%;min-height:42px;padding:6px 3px;border-radius:11px;border:1px solid transparent;background:rgba(255,255,255,.028);display:grid;gap:3px;place-items:center;color:var(--text);font-size:14px;line-height:1}.mobile-agenda-day.has-project{border-color:rgba(255,255,255,.14);background:rgba(113,112,255,.18)}.mobile-agenda-dot{width:4px;height:4px;border-radius:999px;display:block;border:1px solid rgba(255,255,255,.25)}.mobile-project-list{display:grid;gap:10px;margin-top:12px}}
