@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=Space+Grotesk:wght@400;500;700&display=swap";.expandable-table-wrapper{margin-top:1.5rem}.table-title{color:var(--ink);margin:0 0 .75rem;font-size:1rem;font-weight:600}.expandable-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:.85rem}.expandable-table col.col-ref{width:140px}.expandable-table col.col-amount{width:110px}.expandable-table col.col-projet{width:auto}.expandable-table col.col-pole{width:120px}.expandable-table col.col-etat{width:125px}.expandable-table col.col-contact{width:140px}.expandable-table col.col-date{width:100px}.expandable-table thead th{text-align:left;color:var(--ink);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--line);white-space:nowrap;background:#0f766e0d;padding:.65rem .75rem;font-size:.75rem;font-weight:600}.expandable-table tbody td,.expandable-table tfoot td{border-bottom:1px solid #d8d2bd66;padding:.6rem .75rem}.group-row{transition:background .1s}.group-row:hover{background:#0f766e08}.group-row td{background:#fefcf699}.invoice-row td{color:#475569;font-size:.82rem}.invoice-row:hover td{background:#0f766e05}.amount-cell{text-align:right;white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:.85rem}.etat-badge{white-space:nowrap;border-radius:8px;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-block}.total-row td{border-top:2px solid var(--line);border-bottom:none;padding-top:.75rem;font-size:.9rem}.expandable-table td.cell-truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.revenue-dashboard{max-width:1400px}.monthly-chart-panel{margin-bottom:1.5rem}.charts-row{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}@media (width<=1024px){.charts-row{grid-template-columns:1fr}}.chart-tooltip strong{margin-bottom:.25rem;font-size:.85rem;display:block}.tooltip-count{color:#94a3b8;margin-top:.15rem;font-size:.7rem}.unpaid-dashboard{max-width:1400px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.page-surtitle{text-transform:uppercase;letter-spacing:.2em;color:var(--brand);margin:0 0 .25rem;font-family:IBM Plex Mono,monospace;font-size:.7rem;font-weight:500}.page-title{color:var(--ink);margin:0;font-size:1.75rem;font-weight:700}.page-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.kpi-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:1.25rem;transition:transform .15s,box-shadow .15s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px -8px #0206171f}.kpi-card.kpi-success{background:linear-gradient(135deg, var(--paper) 0%, #f0fdf4 100%);border-color:#bbf7d0}.kpi-card.kpi-danger{background:linear-gradient(135deg, var(--paper) 0%, #fef2f2 100%);border-color:#fecaca}.kpi-label{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:.5rem;font-size:.75rem;font-weight:600}.kpi-value{color:var(--ink);font-family:IBM Plex Mono,monospace;font-size:1.5rem;font-weight:700}.kpi-card.kpi-success .kpi-value{color:#16a34a}.kpi-card.kpi-danger .kpi-value{color:#dc2626}.chart-panel{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:1.5rem}.chart-panel h3{color:var(--ink);margin:0 0 1rem;font-size:.95rem;font-weight:600}.chart-tooltip{background:var(--ink);color:#f1f5f9;border-radius:10px;padding:.6rem .85rem;font-size:.8rem;box-shadow:0 8px 24px -8px #0000004d}.chart-tooltip strong{margin-bottom:.25rem;display:block}.table-panel{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:1.5rem}.empty-state{text-align:center;color:var(--ink);padding:4rem 2rem}.empty-state p:first-child{margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--paper);border:1px solid var(--line);text-align:center;border-radius:24px;width:100%;max-width:420px;padding:48px 40px;box-shadow:0 24px 60px -20px #02061759}.login-logo{justify-content:center;margin-bottom:8px;display:flex}.login-title{color:var(--ink);margin:0 0 8px;font-size:1.8rem;font-weight:700}.login-subtitle{color:#64748b;margin:0 0 32px;font-family:IBM Plex Mono,monospace;font-size:.9rem}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;margin-bottom:24px;padding:12px 16px;font-size:.85rem}.login-buttons{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.login-btn{cursor:pointer;border:1px solid var(--line);border-radius:14px;justify-content:center;align-items:center;gap:12px;padding:14px 20px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.login-btn-google{color:var(--ink);background:#fff}.login-btn-google:hover{background:#f8fafc;border-color:#94a3b8;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.login-btn-microsoft{color:var(--ink);background:#fff}.login-btn-microsoft:hover{background:#f8fafc;border-color:#94a3b8;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.login-footer{color:#94a3b8;border-top:1px solid var(--line);margin:24px 0 0;padding-top:20px;font-size:.78rem;line-height:1.5}.sidebar{background:var(--ink);border-right:1px solid var(--line);z-index:1000;flex-direction:column;width:260px;height:100vh;transition:width .3s;display:flex;position:fixed;top:0;left:0}.sidebar.collapsed{width:70px}.sidebar-toggle{background:var(--ink);border:1px solid var(--line);color:#fff;cursor:pointer;z-index:10;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;transition:all .2s;display:flex;position:absolute;top:24px;right:-13px}.sidebar-toggle:hover{background:var(--brand);transform:scale(1.15)}.sidebar-header{border-bottom:1px solid #ffffff14;padding:1.25rem}.sidebar.collapsed .sidebar-header{padding:1rem .5rem}.user-badge{align-items:center;gap:.75rem;display:flex}.sidebar.collapsed .user-badge{justify-content:center}.user-avatar{background:linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;font-weight:700;display:flex}.user-info{flex:1;overflow:hidden}.user-name{color:#f1f5f9;white-space:nowrap;text-overflow:ellipsis;text-transform:capitalize;font-size:.85rem;font-weight:600;overflow:hidden}.user-role{color:#ffffff73;font-size:.7rem}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.nav-item{color:#ffffff8c;border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.65rem 1.25rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar.collapsed .nav-item{border-left:none;justify-content:center;padding:.65rem}.nav-item:hover{color:#e2e8f0;background:#ffffff0a}.nav-item.active{color:#5eead4;border-left-color:var(--brand);background:#0f766e1f}.nav-icon-wrapper{flex-shrink:0;align-items:center;display:flex;position:relative}.nav-icon{opacity:.75;flex-shrink:0}.nav-item.active .nav-icon{opacity:1}.nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-footer{border-top:1px solid #ffffff14;padding:1rem 1.25rem}.logout-btn{color:#ffffff80;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:.5rem;width:100%;padding:.55rem .75rem;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .15s;display:flex}.logout-btn:hover{color:#f1f5f9;background:#ffffff14}@media (width<=768px){.sidebar{width:100%;max-width:280px}.sidebar.collapsed{width:70px}}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{border-bottom:1px solid var(--line);background:var(--paper);justify-content:space-between;align-items:center;padding:.75rem 1.5rem .75rem 280px;transition:padding-left .3s;display:flex}.sidebar-collapsed .app-header{padding-left:90px}.app-header h1{color:var(--brand);align-items:center;gap:.5rem;margin:0;font-size:1.5rem;font-weight:700;display:flex}.app-logo-icon{border-radius:6px;width:28px;height:28px}.app-layout{flex-direction:column;flex:1;display:flex;position:relative}.app-main{flex:1;padding:1.5rem 1.5rem 1.5rem 280px;transition:padding-left .3s;overflow-y:auto}.app-layout.sidebar-collapsed .app-main{padding-left:90px}.app-loading{min-height:100vh;color:var(--ink);justify-content:center;align-items:center;font-size:1rem;display:flex}.app-footer{text-align:center;border-top:1px solid var(--line);color:#888;padding:1rem;font-size:.8rem}.app-version{background:var(--line);color:#666;letter-spacing:.03em;border-radius:4px;margin-left:.5rem;padding:.15rem .4rem;font-family:IBM Plex Mono,monospace;font-size:.7rem}.spinner{border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;width:32px;height:32px;margin:2rem auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}select{border:1px solid var(--line);color:var(--ink);cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") right .6rem center no-repeat;border-radius:12px;outline:none;padding:.45rem 2rem .45rem .8rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:border-color .15s,background-color .15s,box-shadow .15s}select:hover{background-color:#fafaf5;border-color:#b8b2a0}select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0f766e14}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#bbb}@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.end{inset-inline-end:var(--spacing)}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#f7f4ea;--ink:#1b1c20;--paper:#fefcf6;--line:#d8d2bd;--brand:#0f766e;--brand-2:#c2410c}body{min-height:100vh;color:var(--ink);background:radial-gradient(circle at 8% 8%,#c2410c1a,#0000 30%),radial-gradient(circle at 88% 16%,#0f766e21,#0000 32%),linear-gradient(165deg,#f5f0e1 0%,#f7f4ea 45%,#fefdf7 100%);margin:0;font-family:Space Grotesk,sans-serif}*{box-sizing:border-box}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
