@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Manrope:wght@500;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap";:root{color:#1f2933;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eef2f7;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}html,body,#root{min-height:100%;margin:0}body{background:radial-gradient(circle at 0 0,#ffffffe6,#0000 28%),linear-gradient(#dde4ee 0%,#e9eef5 100%)}a{color:inherit;text-decoration:none}:root{--surface:#f8f9fa;--surface-dim:#d9dadb;--surface-bright:#f8f9fa;--surface-container-lowest:#fff;--surface-container-low:#f3f4f5;--surface-container:#edeeef;--surface-container-high:#e7e8e9;--surface-container-highest:#e1e3e4;--on-surface:#191c1d;--on-surface-variant:#45474c;--outline:#76777d;--outline-variant:#c6c6cd;--primary:#000;--on-primary:#fff;--secondary-fixed:#d9e3fb;--tertiary-fixed:#fadeba;--success-bg:#e9f6ee;--success:#137448;--warning-bg:#fff3dc;--warning:#916419;--danger-bg:#ffdad6;--danger:#93000a;--info-bg:#dbe2f9;--info:#3f4759;--brand-orange:#d86f1f;--brand-orange-soft:#fff0e5;color:var(--on-surface);background:var(--surface-container);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{background:var(--surface-container);overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0}h1,h2,h3,p{margin:0}.material-symbols-outlined{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;direction:ltr;font-family:Material Symbols Outlined;font-size:22px;font-style:normal;font-weight:400;line-height:1;display:inline-block}.material-symbols-outlined.filled{font-variation-settings:"FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-container-highest);border-radius:10px}.app-frame{background:var(--surface-container);min-height:100vh;color:var(--on-surface);display:flex}.sidebar{background:var(--surface);border-right:1px solid #c6c6cd52;flex-direction:column;flex:0 0 256px;gap:4px;width:256px;height:100vh;padding:24px 16px;display:flex;box-shadow:0 1px 4px #00000008}.brand{align-items:center;padding:6px 8px 32px;display:flex}.brand-logo{object-fit:contain;width:100%;max-width:214px;height:auto;display:block}.brand-mark{width:40px;height:40px;color:var(--on-primary);background:var(--primary);border-radius:12px;place-items:center;display:grid}.brand h1{letter-spacing:-.01em;color:var(--primary);font-size:24px;font-weight:700;line-height:32px}.brand p,.user-card p,.muted{color:var(--on-surface-variant);font-size:12px;line-height:16px}.nav{gap:4px;display:grid}.nav-button{width:100%;min-height:42px;color:var(--on-surface-variant);text-align:left;background:0 0;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:13px;font-weight:500;line-height:18px;transition:color .16s,transform .16s;display:flex}.nav-button:hover{background:var(--surface-container-low);color:var(--on-surface)}.nav-button.active{color:var(--brand-orange);background:var(--brand-orange-soft);box-shadow:inset -3px 0 0 var(--brand-orange), 0 6px 16px #d86f1f1a;font-weight:700}.nav-button.active .material-symbols-outlined{color:var(--brand-orange)}.sidebar-spacer{flex:1}.user-card{gap:10px;padding:16px 12px;display:grid}.user-card strong{letter-spacing:.05em;color:var(--on-surface-variant);font-size:12px;line-height:16px;display:block}.content-frame{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{z-index:20;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#edeeefd1;justify-content:space-between;align-items:center;gap:24px;height:76px;padding:24px 48px 18px;display:flex;position:sticky;top:0}.search-box{width:min(520px,45vw);position:relative}.search-box .material-symbols-outlined{color:var(--outline);font-size:20px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input,.field-input,.field-select{background:var(--surface-container-low);width:100%;min-height:42px;color:var(--on-surface);box-shadow:none;border:0;border-radius:999px;outline:0;padding:10px 14px 10px 40px;font-size:14px}.field-input,.field-select{background:var(--surface);border-radius:8px;padding-left:12px}.search-box input:focus,.field-input:focus,.field-select:focus{box-shadow:0 0 0 2px #00000014}.top-actions{align-items:center;gap:16px;display:flex}.icon-button{width:40px;height:40px;color:var(--on-surface-variant);background:0 0;border-radius:999px;place-items:center;transition:background .16s,color .16s;display:grid}.icon-button:hover{background:var(--surface-container-low);color:var(--primary)}.avatar{background:var(--primary);width:40px;height:40px;color:var(--on-primary);border:2px solid var(--surface);border-radius:999px;place-items:center;font-size:12px;font-weight:700;display:grid}.canvas{flex:1;padding:0 48px 48px;overflow:auto}.canvas-inner{gap:24px;max-width:1440px;margin:0 auto;display:grid}.page-title{justify-content:space-between;align-items:flex-end;gap:24px;padding-top:4px;display:flex}.page-title h2{letter-spacing:-.02em;color:var(--primary);font-size:32px;font-weight:600;line-height:40px}.page-title p{color:var(--on-surface-variant);max-width:760px;margin-top:4px;font-size:16px;line-height:24px}.actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.primary-button,.ghost-button,.danger-button{border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:10px 16px;font-size:13px;font-weight:600;line-height:18px;transition:opacity .16s,background .16s,transform .16s;display:inline-flex}.primary-button{background:var(--primary);color:var(--on-primary)}.primary-button:hover{opacity:.88}.ghost-button{background:var(--surface-container-low);color:var(--on-surface)}.ghost-button:hover{background:var(--surface-container-high)}.danger-button{background:var(--danger-bg);color:var(--danger)}.small-button{min-height:32px;padding:7px 10px}.card{background:var(--surface-container-lowest);border-radius:24px;padding:24px;box-shadow:0 10px 30px #00000005,0 2px 8px #00000003}.card.compact{border-radius:16px;padding:18px}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;display:grid}.executive-kpi-grid{align-items:stretch}.kpi-card{flex-direction:column;justify-content:space-between;height:160px;display:flex}.kpi-card>div:last-child{gap:6px;display:grid}.kpi-card span{text-transform:uppercase;letter-spacing:.04em;color:var(--on-surface-variant);font-size:13px;font-weight:600;line-height:18px}.kpi-card strong{letter-spacing:-.02em;color:var(--primary);font-size:32px;font-weight:600;line-height:40px}.kpi-card strong span{font:inherit;letter-spacing:inherit;text-transform:none}.kpi-number{color:currentColor}.kpi-state{color:var(--success)}.kpi-success strong{white-space:nowrap;font-size:clamp(28px,2.35vw,32px);display:block}.kpi-success small{font-size:13px;line-height:18px}.kpi-success small .kpi-number{color:var(--on-surface);font-weight:600}.kpi-success small .kpi-state{color:var(--success);font-weight:600}.kpi-card small{color:var(--on-surface-variant);font-size:12px;line-height:16px;display:block}.kpi-card{border:1px solid #c6c6cd59;position:relative;overflow:hidden}.kpi-card:after{content:"";background:#0000000a;border-radius:999px;width:112px;height:112px;position:absolute;inset:auto -24px -46px auto}.kpi-dark{color:#fff;background:#151719;box-shadow:0 18px 44px #0000002e}.kpi-dark span,.kpi-dark small,.kpi-dark .material-symbols-outlined{color:#ffffffb8}.kpi-dark strong{color:#fff}.kpi-warm{background:linear-gradient(135deg,#fff7ea 0%,#f7d8a8 100%);border-color:#9164192e}.kpi-cool{background:linear-gradient(135deg,#eef3ff 0%,#d3def9 100%);border-color:#3f475926}.kpi-success{background:linear-gradient(135deg,#edf8f2 0%,#cfeedd 100%);border-color:#13744826}.dashboard-grid{grid-template-columns:minmax(0,1.45fr) minmax(320px,.55fr);align-items:start;gap:24px;display:grid}.card-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.card-head h3{color:var(--on-surface);font-size:20px;font-weight:600;line-height:28px}.eyebrow{letter-spacing:.05em;text-transform:uppercase;color:var(--on-surface-variant);margin-bottom:4px;font-size:12px;font-weight:600;line-height:16px;display:block}.chip{min-height:28px;color:var(--on-surface-variant);background:var(--surface-container-low);white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:600;line-height:16px;display:inline-flex}.chip.success{color:var(--success);background:var(--success-bg)}.chip.warning{color:var(--warning);background:var(--warning-bg)}.chip.danger{color:var(--danger);background:var(--danger-bg)}.chip.info{color:var(--info);background:var(--info-bg)}.table-wrap{overflow:auto}table{border-collapse:separate;border-spacing:0;width:100%}th{text-align:left;color:var(--on-surface-variant);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-bottom:1px solid #c6c6cd8c;padding:0 14px 14px;font-size:12px;font-weight:600;line-height:16px}td{color:var(--on-surface);vertical-align:middle;border-bottom:1px solid #e1e3e4b8;padding:16px 14px;font-size:14px;line-height:20px}ntd:not(:has(.title-cell)){white-space:nowrap}tbody tr{cursor:pointer;transition:background .14s}tbody tr:hover,.row-selected{background:var(--surface-container-low)}.title-cell{gap:3px;min-width:210px;display:grid}.title-cell strong{color:var(--on-surface);font-size:14px;font-weight:600;line-height:20px}.title-cell small{color:var(--on-surface-variant);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:16px;display:-webkit-box;overflow:hidden}ntd .ghost-button.small-button{min-height:28px;color:var(--on-surface-variant);background:0 0;padding:5px 8px}ntd .ghost-button.small-button:hover{background:var(--surface-container-low);color:var(--primary)}.side-stack{gap:24px;display:grid}.line-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.line-list li{background:var(--surface-bright);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.line-list strong{color:var(--on-surface);font-size:13px;font-weight:600;line-height:18px}.line-list span{color:var(--on-surface-variant);text-align:right;font-size:12px;line-height:16px}.kanban{grid-template-columns:repeat(4,minmax(220px,1fr));gap:16px;padding-bottom:2px;display:grid;overflow-x:auto}.kanban-board-card{min-height:calc(100vh - 210px)}.kanban-full{grid-template-columns:repeat(5,minmax(190px,1fr));align-items:stretch}.kanban-full .lane{min-height:calc(100vh - 330px)}.lane{background:var(--surface-container-low);border-radius:16px;padding:16px;transition:background .16s,box-shadow .16s}.lane-drop-ready{box-shadow:inset 0 0 0 1px #0000000f}.lane-drop-ready:hover{background:#eef0f2;box-shadow:inset 0 0 0 2px #0000001a}.lane-head{border-bottom:1px solid #c6c6cd5c;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;font-size:13px;font-weight:600;display:flex}.job-card{background:var(--surface-container-lowest);cursor:grab;border-radius:14px;gap:9px;margin-bottom:10px;padding:14px;transition:transform .14s,box-shadow .14s,opacity .14s;display:grid;box-shadow:0 1px 4px #00000008}.job-card:hover{transform:translateY(-1px);box-shadow:0 8px 22px #0000000e}.job-card:active{cursor:grabbing}.job-card.dragging{opacity:.45;transform:scale(.985)}.job-card strong{font-size:13px}.job-card p{color:var(--on-surface-variant);font-size:12px;line-height:16px}.job-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.date-pill,.money-pill{border-radius:999px;align-items:center;gap:4px;min-height:26px;padding:5px 8px;font-size:12px;font-weight:600;line-height:16px;display:inline-flex}.date-pill{color:#555f73;background:var(--secondary-fixed)}.date-pill .material-symbols-outlined{font-size:15px}.money-pill{color:#564429;background:var(--tertiary-fixed)}.two-col{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;display:grid}.calendar-shell{grid-template-columns:minmax(0,1fr) 340px;gap:24px;display:grid}.timeline{background:#ffffffb8;border-radius:16px;min-height:560px;overflow:auto}.hour-row{border-bottom:1px solid var(--surface-variant,#e1e3e4);grid-template-columns:64px minmax(0,1fr);gap:12px;min-height:64px;padding:10px 12px;display:grid}.hour-label{color:var(--on-surface-variant);padding-top:6px;font-size:11px;font-weight:700;line-height:16px}.hour-events{align-content:start;gap:8px;display:grid}.empty-hour{color:#45474c61;font-size:12px;line-height:24px}.event-block{border:0;border-left:4px solid var(--primary);background:var(--secondary-fixed);min-height:48px;color:var(--on-surface);text-align:left;cursor:pointer;border-radius:10px;padding:8px 10px;overflow:hidden;box-shadow:0 4px 14px #0000000f}.event-block-alt{background:var(--tertiary-fixed);border-left-color:var(--brand-orange)}.event-block strong,.event-block span{font-size:12px;line-height:16px;display:block}.event-block span{color:var(--on-surface-variant)}.modal-backdrop{z-index:80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#191c1d6b;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border-radius:24px;flex-direction:column;width:min(920px,100%);max-height:min(780px,100vh - 48px);display:flex;overflow:hidden;box-shadow:0 28px 80px #0000002e}.modal-header,.modal-footer{border-bottom:1px solid #c6c6cd61;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.modal-footer{border-top:1px solid #c6c6cd61;border-bottom:0;justify-content:flex-end}.modal-header h3{font-size:20px;font-weight:600;line-height:28px}.modal-header p{color:var(--on-surface-variant);font-size:13px;line-height:18px}.modal-body{padding:24px;overflow:auto}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.form-grid .span-two{grid-column:1/-1}.field{letter-spacing:.04em;text-transform:uppercase;color:var(--on-surface-variant);gap:6px;font-size:12px;font-weight:600;line-height:16px;display:grid}.summary-strip{background:var(--surface-container-low);border-radius:16px;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:14px;display:grid}.summary-strip div{gap:3px;display:grid}.summary-strip span{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.summary-strip strong{color:var(--on-surface);font-size:14px}.segmented-control{background:var(--surface-container-low);border:1px solid #c6c6cd6b;border-radius:999px;gap:4px;padding:4px;display:inline-flex}.segmented-control button{min-height:34px;color:var(--on-surface-variant);background:0 0;border-radius:999px;align-items:center;gap:7px;padding:7px 12px;font-size:13px;font-weight:700;line-height:18px;display:inline-flex}.segmented-control button.active{background:var(--brand-orange);color:#fff;box-shadow:0 8px 18px #d86f1f2e}.segmented-control button.active .material-symbols-outlined{color:#fff}.client-summary-grid{grid-template-columns:1.2fr .8fr .8fr;gap:18px;display:grid}.client-summary-card{border:1px solid #c6c6cd52;align-content:space-between;min-height:138px;display:grid;position:relative;overflow:hidden}.client-summary-card:after{content:"";background:#d86f1f12;border-radius:999px;width:142px;height:142px;position:absolute;bottom:-58px;right:-34px}.client-summary-card.featured{color:#fff;background:linear-gradient(135deg,#161719 0%,#2f241b 100%);box-shadow:0 18px 48px #00000029}.client-summary-card span{z-index:1;letter-spacing:.05em;text-transform:uppercase;color:var(--on-surface-variant);font-size:12px;font-weight:800;line-height:16px;position:relative}.client-summary-card.featured span,.client-summary-card.featured small{color:#ffffffb8}.client-summary-card strong{z-index:1;letter-spacing:-.03em;color:var(--primary);font-size:34px;line-height:40px;position:relative}.client-summary-card.featured strong{color:#fff}.client-summary-card small{z-index:1;color:var(--on-surface-variant);font-size:12px;line-height:16px;position:relative}.client-directory-card{overflow:hidden}.client-table th:last-child,.client-table td:last-child{text-align:right}.client-identity{align-items:center;gap:12px;min-width:260px;display:flex}.client-avatar{background:var(--brand-orange-soft);width:38px;height:38px;color:var(--brand-orange);letter-spacing:.04em;border-radius:12px;flex:0 0 38px;place-items:center;font-size:12px;font-weight:800;display:grid}.client-avatar.large{border-radius:16px;flex-basis:52px;width:52px;height:52px;font-size:14px}.client-contact{gap:3px;min-width:190px;display:grid}.client-contact strong{color:var(--on-surface);font-size:13px;font-weight:650;line-height:18px}.client-contact small,.client-mini-stats small,.client-total small{color:var(--on-surface-variant);font-size:12px;line-height:16px}.client-mini-stats,.client-total{gap:3px;display:grid}.client-mini-stats strong{color:var(--primary);font-size:18px;line-height:22px}.client-total strong{color:var(--brand-orange);letter-spacing:-.02em;font-size:20px;line-height:24px}.client-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.client-profile-card{border:1px solid #c6c6cd52;gap:18px;transition:transform .16s,box-shadow .16s;display:grid}.client-profile-card:hover{transform:translateY(-2px);box-shadow:0 16px 36px #0000000f}.client-card-head{align-items:center;gap:14px;display:flex}.client-card-head h3{letter-spacing:-.02em;font-size:18px;line-height:24px}.client-card-head p{color:var(--on-surface-variant);margin-top:2px;font-size:12px;line-height:16px}.client-billing-hero{background:linear-gradient(135deg, var(--brand-orange-soft), #fff9f3);border:1px solid #d86f1f24;border-radius:18px;gap:4px;padding:16px;display:grid}.client-billing-hero span{text-transform:uppercase;letter-spacing:.06em;color:var(--brand-orange);font-size:11px;font-weight:800;line-height:16px}.client-billing-hero strong{letter-spacing:-.03em;color:var(--primary);font-size:30px;line-height:36px}.client-card-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.client-card-stats div{background:var(--surface-bright);border-radius:14px;gap:2px;padding:12px;display:grid}.client-card-stats span{text-transform:uppercase;letter-spacing:.05em;color:var(--on-surface-variant);font-size:10px;font-weight:800;line-height:14px}.client-card-stats strong{color:var(--primary);font-size:18px;line-height:22px}.client-card-stats small{color:var(--on-surface-variant);font-size:11px;line-height:14px}.client-card-stats small,.client-card-foot span,.client-card-foot small,.client-contact strong,.client-contact small{text-overflow:ellipsis;overflow-wrap:anywhere;overflow:hidden}.client-card-foot{border-top:1px solid #c6c6cd5c;gap:4px;padding-top:4px;display:grid}.client-card-foot span{color:var(--on-surface);font-size:13px;font-weight:700;line-height:18px}.client-card-foot small{color:var(--on-surface-variant);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:16px;display:-webkit-box;overflow:hidden}.invoice-editor{background:var(--surface-container-low);border-radius:18px;grid-template-columns:minmax(360px,520px) minmax(420px,1fr);width:min(1220px,100%);height:min(820px,100vh - 48px);display:grid;overflow:hidden;box-shadow:0 28px 80px #0000002e}.invoice-form{background:var(--surface);border-right:1px solid var(--outline-variant);align-content:start;gap:24px;padding:24px;display:grid;overflow:auto}.invoice-preview-wrap{place-items:start center;padding:32px;display:grid;overflow:auto}.a4-preview{aspect-ratio:1/1.414;background:#fff;flex-direction:column;gap:22px;width:min(520px,100%);padding:42px;display:flex;box-shadow:0 4px 20px #00000014}.a4-preview h3{letter-spacing:-.02em;font-size:24px}.a4-row{border-bottom:1px solid #eef0f2;justify-content:space-between;gap:18px;padding-bottom:12px;font-size:13px;display:flex}.login-shell{background:var(--surface-container);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--surface-container-lowest);border-radius:24px;gap:18px;width:min(440px,100%);padding:28px;display:grid;box-shadow:0 10px 30px #00000008}.login-brand{justify-content:flex-start;align-items:center;padding-bottom:4px;display:flex}.login-logo{object-fit:contain;width:min(260px,100%);height:auto;display:block}.login-card h1{letter-spacing:-.02em;font-size:32px;line-height:40px}.error{color:var(--danger);font-size:13px}@media (width<=1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.calendar-shell,.client-summary-grid{grid-template-columns:1fr}.client-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.invoice-editor{grid-template-columns:1fr;overflow:auto}.invoice-preview-wrap{display:none}}@media (width<=760px){html,body,#root{min-width:0;overflow-x:hidden}body{overflow:auto}.app-frame{width:100%;min-width:0;display:block}.sidebar{z-index:40;border-bottom:1px solid #c6c6cd73;border-right:0;width:100%;max-width:100vw;height:auto;padding:10px 12px;display:block;position:sticky;top:0;overflow:visible}.brand,.user-card,.sidebar-spacer{display:none}.nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;width:100%;min-width:0;display:grid}.nav-button{white-space:normal;text-align:center;border-radius:12px;flex:none;align-content:center;justify-items:center;gap:4px;width:100%;min-height:50px;padding:7px 4px;font-size:10px;line-height:12px;display:grid}.nav-button .material-symbols-outlined{font-size:19px}.nav-button.active{box-shadow:inset 0 -2px 0 var(--brand-orange), 0 4px 12px #d86f1f1a}.content-frame{width:100%;min-width:0;height:auto;min-height:100vh;overflow:visible}.topbar{gap:10px;height:auto;padding:10px 14px;position:static}.search-box{width:100%;display:block}.search-box input{min-height:38px;font-size:13px}.top-actions{gap:6px;margin-left:auto}.top-actions .icon-button{display:none}.top-actions .avatar{width:36px;height:36px}.canvas{width:100%;padding:0 12px 24px;overflow:visible}.canvas-inner{gap:16px;width:100%;max-width:100%}.page-title{align-items:start;gap:12px;padding-top:10px;display:grid}.page-title h2{font-size:25px;line-height:31px}.page-title p{font-size:14px;line-height:20px}.actions,.actions>*,.segmented-control{width:100%}.segmented-control button{flex:1;justify-content:center}.primary-button,.ghost-button,.danger-button{width:100%}.card{border-radius:18px;padding:16px}.card.compact{padding:14px}.card-head{gap:10px;margin-bottom:14px;display:grid}.kpi-grid,.two-col,.form-grid{grid-template-columns:1fr;gap:14px}.kpi-card{height:auto;min-height:132px;padding:18px}.kpi-card strong{font-size:30px;line-height:36px}.kpi-success strong{font-size:30px}.dashboard-grid{gap:14px}.table-wrap{width:100%;max-width:100%;overflow:visible}.responsive-table,.responsive-table thead,.responsive-table tbody,.responsive-table tr,.responsive-table td{width:100%;display:block}.responsive-table{min-width:0}.responsive-table thead{display:none}.responsive-table tr{background:var(--surface-bright);border:1px solid #c6c6cd73;border-radius:16px;margin-bottom:12px;padding:14px}.responsive-table td{white-space:normal;border-bottom:0;grid-template-columns:74px minmax(0,1fr);gap:10px;padding:7px 0;display:grid}.responsive-table td:before{content:attr(data-label);color:var(--on-surface-variant);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:700;line-height:18px}.responsive-table .title-cell{min-width:0}.client-table th:last-child,.client-table td:last-child{text-align:left}.client-table td[data-label=Tipo],.client-table td[data-label=Actividad]{display:none}.client-table tr{padding:12px}.client-table td[data-label=Cliente]{padding-top:0}.client-table td[data-label=Facturado]{border-top:1px solid #c6c6cd5c;margin-top:6px;padding-top:10px}.client-table .client-total strong{font-size:24px;line-height:28px}.client-identity{align-items:flex-start;min-width:0}.client-contact{min-width:0}.client-summary-grid,.client-card-grid{grid-template-columns:1fr;gap:14px}.client-summary-card{min-height:118px}.client-summary-card strong{font-size:30px;line-height:36px}.client-profile-card{gap:14px}.client-card-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.client-card-stats div{padding:10px 8px}.client-card-stats span{font-size:9px;line-height:12px}.client-card-stats strong{font-size:16px;line-height:20px}.client-card-stats small{font-size:10px;line-height:13px}.client-billing-hero strong{font-size:28px;line-height:34px}.side-stack{gap:14px}.line-list li{align-items:flex-start}.kanban-board-card{min-height:0;overflow:hidden}.kanban,.kanban-full{grid-template-columns:1fr;gap:12px;padding:0;display:grid;overflow:visible}.kanban-full .lane,.lane{min-width:0;min-height:auto;padding:14px}.job-card{padding:12px}.summary-strip{grid-template-columns:repeat(2,1fr)}.modal-backdrop{align-items:end;padding:10px}.modal{border-radius:18px 18px 0 0;width:100%;max-height:calc(100vh - 20px)}.modal-header,.modal-footer,.modal-body{padding:16px}.invoice-editor{border-radius:18px 18px 0 0;width:100%;height:calc(100vh - 20px)}.invoice-form{border-right:0;padding:16px}.login-shell{padding:14px}.login-card{border-radius:20px;padding:22px}}@media (width<=420px){.canvas{padding-inline:10px}.kpi-card strong,.kpi-success strong{font-size:28px;line-height:34px}.kpi-success small{font-size:12px;line-height:16px}.nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.nav-button{min-height:48px;font-size:9px;line-height:11px}.responsive-table td{grid-template-columns:68px minmax(0,1fr);gap:8px}}
