.app-layout{display:flex;min-height:100vh}.topbar{position:fixed;top:0;left:0;right:0;height:56px;background:#fff;display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem;border-bottom:1px solid #E2E8F0;z-index:100}.topbar__left{display:flex;align-items:center;gap:1rem}.topbar__toggle{background:none;border:none;font-size:1.4rem;cursor:pointer;padding:.4rem .6rem;border-radius:6px;color:#2563eb;box-shadow:none;transition:background .2s}.topbar__toggle:hover{background:#f6f8fc;transform:none;box-shadow:none}.topbar__title{color:#2563eb;font-family:Sora,sans-serif;font-size:1.3rem;margin:0;font-weight:700}.topbar__right{display:flex;align-items:center;gap:1rem}.topbar__user{color:#0f172a;font-weight:500;font-size:.9rem}.sidebar{position:fixed;top:56px;left:0;bottom:0;width:220px;background:#111b2e;padding:1rem 0;transition:width .25s ease;z-index:90;overflow-x:hidden}.sidebar--collapsed{width:60px}.sidebar__nav{display:flex;flex-direction:column;gap:.25rem;padding:.5rem}.sidebar__link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#fffc;text-decoration:none;border-radius:8px;font-weight:500;white-space:nowrap;transition:background .2s,color .2s}.sidebar__link:hover{background:#ffffff1a;color:#fff}.sidebar__link--active{background:#2563eb;color:#fff;font-weight:600}.sidebar__icon{font-size:1.2rem;width:24px;text-align:center;flex-shrink:0}.sidebar__label{font-size:.95rem}.sidebar__section-header{padding:.5rem 1rem .25rem;margin-top:.75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff6;white-space:nowrap}.sidebar__section-divider{margin:.75rem .75rem .25rem;border-top:1px solid rgba(255,255,255,.15)}.app-layout__content{margin-top:56px;margin-left:220px;flex:1;padding:2rem;background:#f6f8fc;min-height:calc(100vh - 56px);transition:margin-left .25s ease}.app-layout__content--expanded{margin-left:60px}.page-container{max-width:800px;margin:0 auto}.container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;margin-bottom:1.5rem}h1{font-family:Sora,sans-serif;color:#2563eb;font-size:2rem;margin-bottom:.5rem;font-weight:700}h2{font-family:Sora,sans-serif;color:#0f172a;font-size:1.3rem;margin-bottom:1rem}.subtitle{color:#64748b;font-size:1.1rem;margin-bottom:1.5rem}.card{background:#f8f9fa;padding:1.5rem;border-radius:12px;margin:1.5rem 0}.description{color:#0f172a;font-size:1.05rem;margin-bottom:1rem}.profile-section{margin-bottom:2rem}.profile-info{display:flex;flex-direction:column;gap:.75rem}.profile-field{display:flex;justify-content:space-between;padding:.9rem 1rem;background:#f8f9fa;border-radius:8px}.profile-field strong{color:#0f172a}.profile-field span{color:#64748b;word-break:break-all}.error-message{background:#fee2e2;border:1px solid #FECACA;border-radius:8px;padding:1rem;color:#ef4444}button{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:.8rem 2rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #2563eb66}button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb80}button:active{transform:translateY(0)}.sign-in-button,.sign-out-button{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:.8rem 2rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #2563eb66}.sign-out-button{padding:.5rem 1.2rem;font-size:.85rem}.sign-in-button:hover,.sign-out-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb80}.sign-in-button:active,.sign-out-button:active{transform:translateY(0)}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f6f8fc;padding:20px}.login-page .container{max-width:500px;text-align:center}.login-page h1{font-size:2.5rem}.info{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem}.info p{color:#64748b;font-size:1rem;margin:.3rem 0}.entities-page{max-width:1200px;margin:0 auto}.entities-page>h1{margin-bottom:1.5rem}.crud-section{margin-bottom:2.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{margin-bottom:0}.table-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th,.data-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid #E2E8F0}.data-table th{background:#f8f9fa;font-weight:600;color:#0f172a;white-space:nowrap}.data-table tbody tr:hover{background:#f0f4ff}.data-table tbody tr:last-child td{border-bottom:none}.cell-name{font-weight:500;color:#0f172a}.cell-mono{font-family:monospace;font-size:.85rem}.cell-actions{white-space:nowrap;display:flex;gap:.5rem}.table-empty{text-align:center;color:#94a3b8;padding:2rem!important}.btn{border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s,opacity .15s}.btn--primary{background:#2563eb;color:#fff;padding:.6rem 1.5rem;font-size:.95rem;box-shadow:0 4px 15px #2563eb66}.btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #2563eb80}.btn--primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn--secondary{background:#e2e8f0;color:#0f172a;padding:.6rem 1.5rem;font-size:.95rem;box-shadow:none}.btn--secondary:hover{background:#cbd5e0;transform:none;box-shadow:none}.btn--danger{background:#ef4444;color:#fff;padding:.6rem 1.5rem;font-size:.95rem;box-shadow:none}.btn--danger:hover{background:#dc2626;transform:none;box-shadow:none}.btn--small{padding:.35rem .75rem;font-size:.8rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:700px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal--small{max-width:420px}.modal--wide{max-width:850px}.modal--extra-wide{max-width:1100px}.modal h2{margin-top:0;margin-bottom:1.5rem;color:#2563eb}.modal__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #E2E8F0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group--full{grid-column:1 / -1}.form-group--section{margin-top:.5rem}.form-group--section h3{font-family:Sora,sans-serif;color:#2563eb;font-size:1rem;margin:0;padding-bottom:.5rem;border-bottom:1px solid #E2E8F0}.form-group label{font-size:.85rem;font-weight:500;color:#0f172a}.form-group--checkbox label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer;padding-top:1.2rem}.form-group--checkbox input[type=checkbox]{width:18px;height:18px;accent-color:#2563EB}.form-group input,.form-group select,.form-group textarea{padding:.55rem .75rem;border:1px solid #E2E8F0;border-radius:6px;font-size:.9rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.form-group textarea{resize:vertical}.dashboard-kpi-row{display:flex;gap:1rem;margin-bottom:1.5rem}.dashboard-kpi-card{flex:1;padding:1rem 1.25rem;border-radius:12px;text-align:center}.dashboard-kpi-card__label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.dashboard-kpi-card__value{font-size:1.4rem;font-weight:700;font-family:monospace}.dashboard-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.dashboard-detail-column{display:flex;flex-direction:column;gap:.5rem}.pnl-section-header td{font-weight:700;background:#f1f5f9;color:#2563eb;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}.pnl-total-row td{font-weight:700;border-top:2px solid #E2E8F0}.pnl-net-row td{font-weight:700;border-top:3px double #CBD5E1;font-size:1rem}@media(max-width:768px){.sidebar{width:60px}.sidebar .sidebar__label{display:none}.app-layout__content,.app-layout__content--expanded{margin-left:60px}.topbar__user{display:none}.profile-field{flex-direction:column;gap:.3rem}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.form-grid{grid-template-columns:1fr}.modal{max-height:90vh;padding:1.5rem}.dashboard-kpi-row{flex-direction:column}.dashboard-detail-grid{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#0f172a;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh}h1{line-height:1.2}
