:root{font-family:Space Grotesk,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#1f1f1f;background-color:#efefee;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--surface: #f9f9f7;--ink-strong: #1f1f1f;--ink-soft: #585858;--accent: #2f6b4d;--accent-hover: #4a8f6c;--success: #22c55e;--warning: #fbbf24;--error: #dc2626;--info: #3b82f6}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top,#f0f0f0e6,#e9e9e966),linear-gradient(120deg,#efefee 10%,#f4f3f1 50%,#e7e6e3)}a{color:inherit;text-decoration:none}#root{min-height:100vh}.tooltip-trigger{position:relative}.tooltip-trigger:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);padding:6px 10px;background:#0f172aeb;color:#fff;font-size:.72rem;font-weight:600;white-space:nowrap;border-radius:6px;opacity:0;visibility:hidden;transition:all .15s ease;pointer-events:none;z-index:100;box-shadow:0 4px 12px #00000026}.tooltip-trigger:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#0f172aeb;opacity:0;visibility:hidden;transition:all .15s ease;pointer-events:none;z-index:100}.tooltip-trigger:hover:after,.tooltip-trigger:hover:before{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.tooltip-trigger:hover:before{transform:translate(-50%)}.filter{display:grid;gap:6px;font-size:.875rem;color:var(--ink-soft)}.filter span{font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.filter select,.filter input{padding:10px 12px;border-radius:10px;border:1px solid rgba(31,31,31,.12);background:#ffffffe6;color:var(--ink-strong);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease}.filter select:focus,.filter input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f6b4d1f}.filter-clear{padding:10px 16px;border-radius:10px;border:1px solid rgba(31,31,31,.12);background:transparent;color:var(--ink-strong);font-weight:600;font-size:.875rem;cursor:pointer;transition:background-color .2s ease}.filter-clear:hover{background:#1f1f1f0a}.pager{display:flex;align-items:center;justify-content:center;gap:16px}.pager__button{border:1px solid rgba(31,31,31,.12);border-radius:999px;padding:8px 16px;background:#fff;font-weight:600;cursor:pointer}.pager__button:disabled{opacity:.5;cursor:not-allowed}.pager__info{color:var(--ink-soft);font-size:.9rem}@media(max-width:1024px){.quotes__table-header,.invoices__row--header,.orders__row--header{display:none!important}.quotes__table-header,.quote-row,.orders__row,.orders__row--with-creator,.invoices__row,.invoices__row--with-creator,.invoices__row--selectable,.invoices__row--selectable.invoices__row--with-creator{min-width:unset}.quote-row,.orders__row,.invoices__row{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;padding:14px 16px;align-items:start;border-radius:12px;border-bottom:none;background:#ffffffb3;border:1px solid rgba(31,31,31,.08);margin-bottom:6px}.quote-row>.quote-row__cell,.orders__row:not(.orders__row--header)>.orders__cell,.invoices__row>.invoices__cell{display:flex;flex-direction:column;white-space:normal;overflow:visible;text-overflow:unset;min-width:0}.quote-row>.quote-row__cell--actions,.orders__row:not(.orders__row--header)>.orders__cell--actions,.invoices__row>.invoices__cell--actions{flex-direction:row;align-items:center;justify-content:flex-end;overflow:visible}.quote-row>.quote-row__cell:before,.orders__row:not(.orders__row--header)>.orders__cell:before,.invoices__row>.invoices__cell:before{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);opacity:.65;margin-bottom:3px;line-height:1.2;white-space:nowrap}.quotes__table,.invoice-list__items{overflow-x:visible}.orders__row:not(.orders__row--header)>.orders__cell--number{text-align:left}}@media(max-width:768px){.quotes,.orders,.invoices{padding:8px;overflow-x:hidden;max-width:100%}.quotes__filters,.orders__filters,.invoice-list__filters{display:grid;grid-template-columns:1fr 1fr;gap:8px}.quotes__filters .filter--wide,.invoice-list__filters .filter--wide,.invoice-list__filters .filter--search{grid-column:span 2;min-width:unset;flex:unset}.quotes__filters .filter select,.quotes__filters .filter input,.invoice-list__filters .filter select,.invoice-list__filters .filter input{width:100%;max-width:100%;box-sizing:border-box;min-width:0;padding:5px 7px;font-size:.8rem}.quotes__filters .filter span,.invoice-list__filters .filter span,.orders .filter span{font-size:.7rem}.orders .filter__select,.orders .filter__input{width:100%;max-width:100%;box-sizing:border-box;min-width:0;padding:5px 7px;font-size:.8rem}.quote-row,.orders__row,.orders__row--with-creator,.invoices__row,.invoices__row--selectable,.invoices__row--with-creator,.invoices__row--selectable.invoices__row--with-creator{padding:10px 8px;gap:4px 8px;min-width:0;max-width:100%}.quote-row>.quote-row__cell:before,.orders__row:not(.orders__row--header)>.orders__cell:before,.invoices__row>.invoices__cell:before{white-space:normal}.quote-action-btn,.invoice-action-btn,.credit-note-action-btn{width:26px!important;height:26px!important;min-width:26px!important;padding:0!important}.quotes .pager,.invoices .pager{gap:6px;padding:10px 4px}.quotes .pager__button,.invoices .pager__button{padding:7px 12px;font-size:.8rem}.quotes .pager__info,.invoices .pager__info{padding:7px 10px;font-size:.8rem}.orders__list{padding:6px;gap:6px;overflow-x:hidden}}.primary-button{border-radius:999px;padding:10px 16px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;background:var(--accent);color:var(--surface);box-shadow:0 8px 18px #365e4a33;transition:background .2s ease,box-shadow .2s ease,transform .15s ease}.primary-button:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 10px 22px #365e4a40;transform:translateY(-1px)}.primary-button:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 10px #365e4a2e}.primary-button:disabled{opacity:.55;cursor:not-allowed}.primary-button--full{width:100%}.ghost-button{border-radius:999px;padding:10px 14px;font-size:.95rem;font-weight:600;cursor:pointer;border:1px solid rgba(31,31,31,.18);background:transparent;color:var(--ink-strong);transition:background .15s ease,opacity .15s ease}.ghost-button:hover:not(:disabled){background:#1f1f1f0a}.ghost-button:disabled{opacity:.4;cursor:not-allowed}.ghost-button--small{padding:4px 10px;font-size:.8rem;border-radius:8px}.ghost-button--icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border-radius:10px;font-size:1rem;flex-shrink:0}.clients__tabs,.projects__tabs,.reports__tabs{display:flex;gap:8px;flex-wrap:wrap}.clients__tab,.projects__tab,.reports__tab{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:9px 18px;font-size:.9rem;font-weight:600;cursor:pointer;border:1px solid rgba(31,31,31,.12);background:#ffffffd9;color:var(--ink-soft);transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}.clients__tab:hover:not(.clients__tab--active),.projects__tab:hover:not(.projects__tab--active),.reports__tab:hover:not(.reports__tab--active){background:#2f6b4d0f;border-color:#2f6b4d40;color:var(--ink-strong)}.clients__tab--active,.projects__tab--active,.reports__tab--active{background:var(--accent);border-color:transparent;color:#fff;box-shadow:0 3px 10px #2f6b4d4d}.clients__tab-icon,.projects__tab-icon,.reports__tab-icon{font-size:.95rem;line-height:1;opacity:.85}.clients__tab-badge,.projects__tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.01em;background:#2f6b4d1a;color:var(--accent)}.clients__tab--active .clients__tab-badge,.projects__tab--active .projects__tab-badge{background:#ffffff40;color:#fff}.client-form,.client-list,.project-form,.project-list{background:#ffffffbf;border:1px solid rgba(31,31,31,.08);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:12px}.client-form,.project-form{max-height:calc(100vh - 260px);overflow-y:auto}.client-list,.project-list{max-height:calc(100vh - 260px);overflow:hidden}.client-list__header,.project-list__header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.client-list__title-row,.project-list__title-row{display:flex;align-items:baseline;gap:10px}.client-list__count,.project-list__count{font-size:.75rem;font-weight:600;padding:2px 10px;border-radius:999px;background:#2f6b4d1a;color:var(--accent);letter-spacing:.02em}.client-list__filters,.project-list__filters{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.client-list__filters .filter,.project-list__filters .filter{display:grid;gap:6px;font-size:.875rem;color:var(--ink-soft)}.client-list__filters .filter span,.project-list__filters .filter span{font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.client-list__filters .filter__select,.client-list__filters .filter__input,.project-list__filters .filter__select,.project-list__filters .filter__input{padding:10px 12px;border-radius:10px;border:1px solid rgba(31,31,31,.12);background:#ffffffe6;font-size:.9rem}.client-list__items,.project-list__items{flex:1;min-height:0;overflow-y:auto;display:grid;gap:10px;padding-right:4px}.client-list__items::-webkit-scrollbar,.project-list__items::-webkit-scrollbar{width:6px}.client-list__items::-webkit-scrollbar-track,.project-list__items::-webkit-scrollbar-track{background:#1f1f1f0a;border-radius:3px}.client-list__items::-webkit-scrollbar-thumb,.project-list__items::-webkit-scrollbar-thumb{background:#1f1f1f26;border-radius:3px}.client-list__items::-webkit-scrollbar-thumb:hover,.project-list__items::-webkit-scrollbar-thumb:hover{background:#1f1f1f40}.field{display:grid;gap:8px}.field__label{font-weight:600;color:var(--ink-strong)}.field__input{border-radius:12px;border:1px solid rgba(36,54,42,.12);padding:10px 12px;background:#ffffffe6;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}.field__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f6b4d1f}.field__hint{font-size:.8rem;color:var(--ink-soft)}.field__hint--searching{animation:pulse-opacity 1.2s ease-in-out infinite;color:var(--accent)}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.4}}.field__row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.field__row .field{flex:1;min-width:200px}.field__input--textarea{min-height:90px;resize:vertical}.field__input--select{appearance:none}.field__input--calculated{background:#0f172a0a;color:var(--ink-soft);cursor:default}.field--discount .field__label{color:#b45309}.field--discount .field__input{background:#b453090d;border-color:#b453092e}.field--tax .field__label{color:#2563eb}.field--tax .field__input{background:#2563eb0a;border-color:#2563eb2e}.field--total .field__label{color:var(--accent);font-weight:700}.field--total .field__input{background:#2f6b4d0f;border-color:#2f6b4d59;font-weight:600}.field--total .field__input:focus{border-color:#2f6b4d99;box-shadow:0 0 0 3px #2f6b4d26}.field--paid .field__label{color:#059669}.field--paid .field__input{background:#0596690d;border-color:#05966940}.field--balance .field__label{color:var(--ink-soft)}.field--balance .field__input{background:#0f172a0a;border-color:#0f172a14;color:var(--ink-soft);font-weight:600}.toast-container{position:fixed;top:80px;right:20px;z-index:9999;max-width:420px;pointer-events:none}.toast-container .toast{width:100%;min-width:350px;margin-bottom:16px;padding:0;border:none;border-radius:12px;box-shadow:0 10px 40px #00000026;overflow:hidden;pointer-events:all;animation:slideInRight .3s cubic-bezier(.4,0,.2,1);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}@keyframes slideInRight{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.toast-container .toast:hover{transform:translate(-5px);box-shadow:0 15px 50px #0003}.toast-container .toast:after{content:"";position:absolute;bottom:0;left:0;height:3px;width:100%;background:#ffffff4d;animation:progress var(--toast-duration, 10s) linear forwards;transform-origin:left}@keyframes progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.toast-container .wrapper{display:flex;align-items:flex-start;padding:16px;cursor:pointer;position:relative;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-container .wrapper:after{content:"x";position:absolute;top:12px;right:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#9ca3af;opacity:0;transition:opacity .2s}.toast-container .wrapper:hover:after{opacity:1}.toast-container .icon-container{width:44px;height:44px;min-width:44px;margin-right:16px;display:flex;align-items:center;justify-content:center;border-radius:10px;position:relative;overflow:hidden;color:#fff;font-size:20px}.toast-container .icon-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.toast-container .info-container{flex:1;margin-right:8px}.toast-container .info-container span{display:block}.toast-container .info-container .title{font-size:15px;font-weight:600;line-height:20px;color:#1f2937;margin-bottom:4px}.toast-container .info-container .description{font-size:13px;line-height:18px;color:#6b7280}.toast-container .toast.bg-success .wrapper{border-left:4px solid #10b981}.toast-container .toast.bg-success .icon-container{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.toast-container .toast.bg-success:after{background:#10b981}.toast-container .toast.bg-info .wrapper{border-left:4px solid #3b82f6}.toast-container .toast.bg-info .icon-container{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 12px #3b82f64d}.toast-container .toast.bg-info:after{background:#3b82f6}.toast-container .toast.bg-warning .wrapper{border-left:4px solid #f59e0b}.toast-container .toast.bg-warning .icon-container{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #f59e0b4d}.toast-container .toast.bg-warning:after{background:#f59e0b}.toast-container .toast.bg-danger .wrapper{border-left:4px solid #ef4444}.toast-container .toast.bg-danger .icon-container{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d}@media print{.toast-container{display:none!important}}.toast-container .toast.bg-danger:after{background:#ef4444}.toast-container .toast.hide{animation:slideOutRight .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(120%);opacity:0}}@media(max-width:480px){.toast-container{top:70px;left:10px;right:10px;max-width:none}.toast-container .toast{min-width:unset;width:100%}}@media(prefers-color-scheme:dark){.toast-container .toast .wrapper{background:#1e1e1ef2}.toast-container .toast .info-container .title{color:#f3f4f6}.toast-container .toast .info-container .description{color:#9ca3af}.toast-container .toast .wrapper:after{color:#e5e7eb}}.toast-container .toast:not(:last-child){margin-bottom:12px}.toast-container .toast:not(:first-child){animation:moveUp .3s cubic-bezier(.4,0,.2,1)}@keyframes moveUp{0%{transform:translateY(20px);opacity:.8}to{transform:translateY(0);opacity:1}}@keyframes badge-pop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes ntf-slide-down{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-bell{position:relative}.notification-bell__button{position:relative;border:1px solid rgba(31,31,31,.15);background:#fff;border-radius:12px;width:36px;height:36px;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-strong);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.notification-bell__button:hover,.notification-bell__button--open{border-color:#2f6b4d66;box-shadow:0 6px 12px #2f6b4d26}.notification-bell__button--open{background:#2f6b4d0f}.notification-bell__icon{display:flex;align-items:center;color:var(--ink-soft);transition:color .2s ease}.notification-bell__button--open .notification-bell__icon,.notification-bell__button:hover .notification-bell__icon{color:var(--accent)}.notification-bell__badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;border-radius:999px;background:#dc2626;color:#fff;font-size:.58rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 5px #dc262673;border:1.5px solid white;animation:badge-pop .3s cubic-bezier(.34,1.56,.64,1) both}.notification-dropdown{position:absolute;right:0;top:calc(100% + 10px);width:340px;background:var(--surface);border-radius:16px;border:1px solid rgba(31,31,31,.1);box-shadow:0 20px 48px #0f172a2e,0 4px 12px #0f172a14;z-index:120;overflow:hidden;animation:ntf-slide-down .2s cubic-bezier(.16,1,.3,1) both;transform-origin:top right}@media(max-width:600px){.notification-dropdown{width:min(320px,90vw);right:0}}.notification-dropdown__header{padding:16px;border-bottom:1px solid rgba(31,31,31,.08);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.notification-dropdown__header strong{display:block;font-size:1rem}.notification-dropdown__header span{font-size:.8rem;color:var(--ink-soft)}.notification-dropdown__action{border:none;background:transparent;color:var(--accent);font-weight:600;font-size:.75rem;cursor:pointer}.notification-dropdown__list{max-height:320px;overflow-y:auto}.notification-dropdown__item{width:100%;text-align:left;border:none;background:transparent;padding:12px 16px;display:flex;gap:12px;align-items:flex-start;cursor:pointer;border-bottom:1px solid rgba(31,31,31,.05);transition:background .15s ease;position:relative}.notification-dropdown__item:hover{background:#1f1f1f0a}.notification-dropdown__item--unread{background:#2f6b4d0d}.notification-dropdown__item--unread:hover{background:#2f6b4d17}.notification-dropdown__item--unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.notification-dropdown__type{width:34px;height:34px;border-radius:10px;background:#2f6b4d1a;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.notification-dropdown__content{display:flex;flex-direction:column;gap:4px}.notification-dropdown__title{font-weight:700;font-size:.85rem;color:var(--ink-strong)}.notification-dropdown__message{font-size:.8rem;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-dropdown__time{font-size:.7rem;color:var(--ink-soft)}.notification-dropdown__empty{padding:20px 16px;font-size:.85rem;color:var(--ink-soft);text-align:center}.notification-dropdown__footer{padding:12px 16px;border-top:1px solid rgba(31,31,31,.08);display:flex;justify-content:flex-end}.notification-dropdown__link{border:none;background:transparent;color:var(--accent);font-weight:600;font-size:.8rem;cursor:pointer;transition:opacity .15s ease}.notification-dropdown__link:hover{opacity:.75}@media(max-width:768px){.notification-dropdown{right:0;left:auto;width:min(300px,calc(100vw - 32px))}}.sidebar{position:fixed;left:0;top:0;width:280px;height:100vh;display:flex;flex-direction:column;gap:24px;padding:24px 16px;background:linear-gradient(180deg,#fffffff2,#ffffffeb);border-right:1px solid rgba(31,31,31,.08);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:2px 0 20px #00000008;transition:transform .3s ease;z-index:100}.sidebar__header{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;background:#365e4a0f;border:1px solid rgba(54,94,74,.12)}.sidebar__logo{width:48px;height:48px;border-radius:12px;object-fit:cover;border:2px solid rgba(54,94,74,.2);box-shadow:0 2px 8px #365e4a26}.sidebar__brand{display:flex;flex-direction:column;gap:2px}.sidebar__title{margin:0;font-size:1.1rem;font-weight:700;color:var(--ink-strong);letter-spacing:-.02em}.sidebar__subtitle{margin:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.sidebar__nav{flex:1;display:flex;flex-direction:column;gap:24px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(31,31,31,.2) transparent}.sidebar__nav::-webkit-scrollbar{width:6px}.sidebar__nav::-webkit-scrollbar-track{background:transparent}.sidebar__nav::-webkit-scrollbar-thumb{background:#1f1f1f33;border-radius:3px}.sidebar__nav::-webkit-scrollbar-thumb:hover{background:#1f1f1f4d}.sidebar__nav-section{display:flex;flex-direction:column;gap:4px}.sidebar__nav-label{padding:8px 12px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);opacity:.8}.sidebar__nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;background:transparent;border:1px solid transparent;text-decoration:none;color:var(--ink-strong);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.sidebar__nav-item:hover{background:#365e4a14;border-color:#365e4a26;transform:translate(4px)}.sidebar__nav-item--active{background:linear-gradient(135deg,#365e4a26,#365e4a1a);border-color:#365e4a40;color:#2f6b4d;font-weight:700;box-shadow:0 2px 8px #365e4a1f}.sidebar__nav-item--active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:60%;background:#2f6b4d;border-radius:0 4px 4px 0}.sidebar__nav-icon{font-size:1.2rem;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.sidebar__nav-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__footer{display:flex;flex-direction:column;gap:12px;padding-top:16px;border-top:1px solid rgba(31,31,31,.08)}.sidebar__user{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;background:#fff9;border:1px solid rgba(31,31,31,.08)}.sidebar__user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#2f6b4d,#4a8f6c);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0;box-shadow:0 2px 8px #365e4a33}.sidebar__user-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.sidebar__user-name{font-weight:700;font-size:.9rem;color:var(--ink-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.sidebar__logout{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:10px;border:1px solid rgba(220,38,38,.2);background:#dc26260d;color:#991b1b;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;width:100%;justify-content:center}.sidebar__logout:hover{background:#dc26261a;border-color:#dc26264d;transform:translateY(-2px);box-shadow:0 4px 12px #dc262626}.sidebar__logout:active{transform:translateY(0)}.sidebar__logout-icon{font-size:1.1rem}.sidebar__logout-text{font-weight:700}@media(max-width:1024px){.sidebar{width:240px}}.sidebar__close{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);box-shadow:none;z-index:200}.sidebar--open{transform:translate(0);box-shadow:4px 0 24px #00000026}.sidebar__close{display:flex;align-items:center;justify-content:center;position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;border:1px solid rgba(31,31,31,.12);background:#ffffffe6;color:var(--ink-strong);font-size:1rem;cursor:pointer;transition:all .2s ease;z-index:10}.sidebar__close:hover{background:#dc262614;border-color:#dc262633;color:#991b1b}.sidebar__close:active{transform:scale(.95)}}@media print{.sidebar{display:none}}.app-layout{min-height:100vh;background:linear-gradient(135deg,#f8faf9,#f0f4f2,#e8f0ec);display:flex;flex-direction:column}.app-layout--with-sidebar{margin-left:280px}.app-layout--with-sidebar .modal{padding-left:280px}.app-main{flex:1;padding:32px;min-height:100vh;width:100%;max-width:100%;overflow-x:hidden}.app-layout__bell{position:fixed;top:20px;right:24px;z-index:160}.app-content-container{max-width:1400px;margin:0 auto;width:100%}@media(max-width:1024px){.app-layout--with-sidebar{margin-left:240px}.app-layout--with-sidebar .modal{padding-left:240px}.app-main{padding:24px}}.app-layout__menu-toggle,.app-layout__overlay{display:none}@media(max-width:768px){.app-layout--with-sidebar{margin-left:0}.app-layout--with-sidebar .modal{padding-left:20px}.app-main{padding:72px 16px 16px;overflow-x:hidden;max-width:100vw}.app-layout__bell{top:16px;right:16px}.app-layout__menu-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:16px;left:16px;width:48px;height:48px;border-radius:12px;border:1px solid rgba(31,31,31,.12);background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 12px #00000014;cursor:pointer;z-index:150;transition:all .2s ease}.app-layout__menu-toggle:hover{background:#fff;box-shadow:0 4px 16px #0000001f}.app-layout__menu-toggle:active{transform:scale(.95)}.app-layout__menu-icon{position:relative;width:20px;height:2px;background:var(--ink-strong);border-radius:2px;transition:background .2s ease}.app-layout__menu-icon:before,.app-layout__menu-icon:after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink-strong);border-radius:2px;transition:transform .2s ease,top .2s ease}.app-layout__menu-icon:before{top:-6px}.app-layout__menu-icon:after{top:6px}.app-layout__menu-toggle--open .app-layout__menu-icon{background:transparent}.app-layout__menu-toggle--open .app-layout__menu-icon:before{top:0;transform:rotate(45deg)}.app-layout__menu-toggle--open .app-layout__menu-icon:after{top:0;transform:rotate(-45deg)}.app-layout__overlay{display:block;position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}@media print{.app-layout{background:#fff;padding:0;margin:0}.app-layout--with-sidebar{margin-left:0}.app-main{padding:0}}
