@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--text:#6b7280;--text-h:#111;--bg:#fff;--bg-s:#f9fafb;--border:#e5e7eb;--code-bg:#f9fafb;--accent:#ef4444;--accent-bg:#fef2f2;--accent-border:#fecaca;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014, 0 2px 4px #0000000a;--topbar-bg:#111;--sans:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;--heading:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "Cascadia Code", Consolas, monospace;font-family:var(--sans);letter-spacing:0;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.5}body{margin:0}.app-footer{color:#9ca3af;border-top:1px solid var(--border);text-align:center;margin-top:auto;padding:14px 24px;font-size:12px}#root{box-sizing:border-box;flex-direction:column;width:1180px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);margin:0;font-weight:600}p{margin:0}code{font-family:var(--mono);background:var(--code-bg);border:1px solid var(--border);color:var(--text-h);border-radius:4px;padding:2px 6px;font-size:13px}.layout{background:var(--bg);flex-direction:column;min-height:100svh;display:flex}.topbar{background:var(--topbar-bg);flex-shrink:0;align-items:center;gap:4px;height:54px;padding:0 24px;display:flex}.brand-bar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;align-items:center;padding:8px 24px;display:flex}.brand-bar-btn{cursor:pointer;background:0 0;border:none;align-items:center;padding:0;transition:opacity .15s;display:flex}.brand-bar-btn:hover{opacity:.8}.brand-bar-logo{width:auto;height:36px;display:block}.topbar-nav{gap:2px;display:flex}.nav-tab{color:#ffffffa6;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:100px;padding:7px 16px;font-size:14px;font-weight:500;transition:background .15s,color .15s}.nav-tab:hover{color:#fff;background:#ffffff1a}.nav-tab.active{color:#111;background:#fff;font-weight:600}.nav-tab-admin{color:#ffffff8c}.nav-tab-admin.active{color:#111;background:#fff}.breadcrumb{align-items:center;gap:8px;display:flex}.breadcrumb-back{color:#ffffffbf;cursor:pointer;background:0 0;border:none;padding:0;font-size:14px}.breadcrumb-back:hover{color:#fff}.breadcrumb-sep{color:#ffffff40;font-size:16px}.breadcrumb-name{color:#fff;font-size:14px;font-weight:600}.main{box-sizing:border-box;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:28px 24px}.table-header{align-items:baseline;gap:12px;margin-bottom:20px;display:flex}.table-header h1{color:var(--text-h);letter-spacing:-.3px;margin:0;font-size:22px;font-weight:600}.count{color:var(--text);font-size:13px}.table-header-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.product-search-wrap{align-items:center;margin-left:auto;display:flex}.product-search-input{width:240px;padding:6px 10px;font-size:13px}.shelf-meta{background:var(--bg-s);border:1px solid var(--border);border-radius:10px;margin-bottom:4px;padding:12px 18px}.shelf-meta-row{flex-wrap:wrap;gap:20px;display:flex}.meta-item{color:var(--text-h);flex-direction:column;gap:2px;font-size:13px;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.4px;color:var(--text);font-size:11px;font-weight:600}.offline-banner{z-index:9999;text-align:center;justify-content:center;align-items:center;gap:10px;padding:8px 16px;font-size:13px;font-weight:500;display:flex;position:fixed;bottom:0;left:0;right:0}.offline-banner--offline{color:#f5f5f7;background:#1c1c1e}.offline-banner--syncing{color:#fff;background:#1d4ed8}.offline-banner--pending{color:#fef3c7;background:#92400e}.offline-banner--online{color:#f0fdf4;background:#15803d;animation:3s forwards banner-fade}@keyframes banner-fade{0%{opacity:1}70%{opacity:1}to{opacity:0;pointer-events:none}}.offline-badge{background:#fff3;border-radius:100px;padding:2px 8px;font-size:12px;font-weight:600}.banner-offline{color:#f5f5f7;background:#1c1c1e;border:none;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px}.banner.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px}.banner.success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px}.table-wrap{border:1px solid var(--border);background:#fff;border-radius:12px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table thead th{background:var(--bg-s);text-align:left;text-transform:uppercase;letter-spacing:.6px;color:var(--text);border-bottom:1px solid var(--border);white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:600}.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover,.data-table tbody tr.editing{background:#fafafa}.data-table td{color:var(--text-h);padding:11px 14px}.data-table td.muted{color:var(--text)}.data-table td.col-num{color:var(--text);width:40px;font-size:13px}.data-table td.sku{font-family:var(--mono);color:#111;font-size:13px}.data-table td.qty{font-variant-numeric:tabular-nums;font-weight:500}td.empty{text-align:center;color:var(--text);padding:36px;font-size:14px}.col-num{width:48px}.col-prod-img{width:52px;padding:4px 6px!important}.col-sku{width:130px}.col-qty{width:110px}.col-shelves{width:180px}.col-rent{width:110px}.col-date{width:120px}.col-actions{white-space:nowrap;width:auto}.badge-list{flex-wrap:wrap;gap:4px;display:flex}.badge{white-space:nowrap;border:1px solid #0000;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.badge-shelf{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.badge-market{color:#b45309;background:#f59e0b1a;border-color:#f59e0b59}.badge-category{color:#374151;background:#f3f4f6;border-color:#d1d5db}@media (prefers-color-scheme:dark){.badge-market{color:#fbbf24;background:#f59e0b26;border-color:#f59e0b59}.badge-category{color:#e5e7eb;background:#374151;border-color:#4b5563}}.cat-filter-bar{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.cat-chip{cursor:pointer;border:1px solid var(--border);background:var(--bg-s);color:var(--text-h);white-space:nowrap;border-radius:100px;align-items:center;gap:5px;padding:5px 13px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.cat-chip:hover:not(.active){background:#e5e7eb;border-color:#9ca3af}.cat-chip.active{color:#fff;background:#111;border-color:#111}.cat-chip-uncategorized{font-style:italic}.cat-chip-count{background:#0000001a;border-radius:8px;padding:0 6px;font-size:11px;font-style:normal;display:inline-block}.cat-chip.active .cat-chip-count{background:#ffffff40}.col-category{width:130px}.cat-view-seg{border:1px solid var(--border);border-radius:8px;margin-bottom:10px;display:inline-flex;overflow:hidden}.cat-view-seg-btn{background:var(--bg-s);color:var(--text);cursor:pointer;white-space:nowrap;border:none;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,color .15s}.cat-view-seg-btn+.cat-view-seg-btn{border-left:1px solid var(--border)}.cat-view-seg-btn.active{color:#fff;background:#111}.cat-view-seg-btn:not(.active):hover{background:#e5e7eb}.cat-group-header{cursor:pointer;-webkit-user-select:none;user-select:none}.cat-group-header:hover .cat-group-cell{background:#f3f4f6}.cat-group-cell{background:var(--bg-s);border-top:2px solid var(--border);color:var(--text-h);font-size:13px;font-weight:600;padding:10px 14px!important}.cat-group-chevron{color:#9ca3af;margin-right:8px;font-size:12px}.cat-group-name{margin-right:8px}@media (prefers-color-scheme:dark){.cat-view-seg-btn.active{color:#111;background:#e5e7eb}.cat-view-seg-btn:not(.active):hover,.cat-group-header:hover .cat-group-cell{background:#374151}}.cat-add-row{align-items:flex-end;gap:8px;display:flex}.cat-add-field{flex:1;margin:0}.cat-add-btn{flex-shrink:0;margin-bottom:0}@media (width<=480px){.cat-add-row{flex-direction:column;align-items:stretch}.cat-add-btn{width:100%}}.cat-list{border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;max-height:280px;padding:6px;display:flex;overflow-y:auto}.cat-row{background:var(--bg-s);border-radius:7px;align-items:center;gap:8px;padding:7px 10px;display:flex}.cat-row-name{color:var(--text-h);flex:1;font-size:14px;font-weight:500}.col-contact{width:160px}.contact-cell{flex-direction:column;gap:2px;font-size:13px;display:flex}.contact-inputs{flex-direction:column;gap:4px;display:flex}.date-range-inputs{align-items:center;gap:6px;display:flex}.date-sep{color:var(--text);font-size:12px}.date-sep-form{color:var(--text);align-self:center;font-size:14px}.col-dates{width:200px}.cell-input{box-sizing:border-box;border:1px solid var(--accent-border);background:var(--bg);width:100%;color:var(--text-h);border-radius:4px;outline:none;padding:5px 8px;font-size:14px}.cell-input:focus{border-color:#111}.cell-input.qty{width:80px}.actions{align-items:center;gap:6px;display:flex}.btn-edit,.btn-save,.btn-cancel,.btn-products,.btn-report,.btn-expenses{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:7px;padding:5px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s}.btn-products{color:#fff;background:#111;border-color:#111}.btn-report{color:#fff;background:#6366f1;border-color:#6366f1}.btn-expenses{color:#fff;background:#f59e0b;border-color:#f59e0b}.btn-edit{background:var(--bg-s);color:var(--text-h);border-color:var(--border)}.btn-save{color:#fff;background:#111;border-color:#111}.btn-cancel{color:var(--text);border-color:var(--border);background:0 0}.btn-edit:hover,.btn-save:hover,.btn-cancel:hover,.btn-products:hover,.btn-report:hover,.btn-expenses:hover{opacity:.72}.btn-delete{border:1px solid var(--border);color:#9ca3af;cursor:pointer;background:0 0;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-family:inherit;font-size:15px;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-delete:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.shelf-name-btn{font-family:inherit;font-size:inherit;color:var(--text-h);cursor:pointer;text-align:left;text-underline-offset:2px;background:0 0;border:none;padding:0;font-weight:600;-webkit-text-decoration:underline #0000;text-decoration:underline #0000;transition:color .15s,text-decoration-color .15s}.shelf-name-btn:hover{color:#6366f1;text-decoration-color:#6366f1}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:100%;max-width:580px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 20px 60px #00000040}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:var(--text-h);margin:0;font-size:17px;font-weight:700}.modal-close-btn{cursor:pointer;color:var(--text-s);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:16px;transition:background .15s}.modal-close-btn:hover{background:var(--bg-s)}.modal-body{flex-direction:column;gap:14px;padding:20px;display:flex}.modal-actions{gap:10px;padding:0 20px 20px;display:flex}.modal-label{color:var(--text-s);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.modal-field-group{flex-direction:column;flex:1;min-width:0;display:flex}.modal-field-full{flex:none}.modal-row{align-items:flex-end;gap:12px;display:flex}.modal-row .field,.modal-row .commission-field{width:100%}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;gap:10px;padding:16px 20px;display:flex}@media (width<=540px){.modal-row{flex-direction:column}.modal-card{max-height:95vh}}.modal-card--wide{max-width:780px}.modal-body--scroll{max-height:calc(90vh - 130px);padding:0;overflow-y:auto}.picker-table{border-collapse:collapse;width:100%;font-size:13.5px}.picker-table th{background:var(--bg);border-bottom:1px solid var(--border);text-align:left;color:var(--text-s);text-transform:uppercase;letter-spacing:.04em;z-index:1;padding:9px 12px;font-size:11px;font-weight:700;position:sticky;top:0}.picker-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:7px 12px}.picker-table tr:last-child td{border-bottom:none}.picker-table tr.picker-row--disabled td{opacity:.38}.picker-table tr.picker-row--disabled{background:var(--bg-s);cursor:not-allowed}.picker-table tr.picker-row--checked{background:color-mix(in srgb, var(--indigo) 5%, transparent)}.picker-cb{cursor:pointer;width:16px;height:16px;accent-color:var(--indigo)}.picker-cb:disabled{cursor:not-allowed}.picker-qty-input{text-align:center;width:64px;padding:4px 6px;font-size:13px}.picker-price-input{width:88px;padding:4px 6px;font-size:13px}.picker-empty{text-align:center;color:var(--text-s);padding:24px;font-size:14px}.cart-qty-row{align-items:center;gap:8px;display:flex}.cart-line-total{color:var(--text-s);white-space:nowrap;font-size:12px}.cart-cta-bar{background:color-mix(in srgb, var(--indigo) 8%, var(--bg));border:1px solid color-mix(in srgb, var(--indigo) 25%, transparent);border-radius:10px;justify-content:space-between;align-items:center;gap:16px;margin:20px 0 8px;padding:14px 18px;display:flex}.cart-cta-info{color:var(--text);align-items:center;gap:16px;font-size:14px;display:flex}.cart-cta-btn{min-width:180px}.cart-totals{border-top:1px solid var(--border);flex-direction:column;gap:6px;padding:14px 20px;font-size:14px;display:flex}.cart-totals-row{justify-content:space-between;align-items:center;display:flex}.cart-discount-row{gap:12px}.cart-discount-input{text-align:right;width:90px}.cart-totals-discount{color:#16a34a}.cart-totals-final{border-top:1px solid var(--border);margin-top:4px;padding-top:8px;font-size:16px;font-weight:700}@media (width<=600px){.cart-cta-bar{flex-direction:column;align-items:stretch}.cart-cta-btn{width:100%}}.add-form{margin-top:24px}.add-form h2{color:var(--text-h);letter-spacing:-.2px;margin:0 0 12px;font-size:15px;font-weight:600}.add-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.field{border:1px solid var(--border);color:var(--text-h);background:#fff;border-radius:8px;outline:none;padding:9px 13px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.field:focus{border-color:#111;box-shadow:0 0 0 3px #00000012}.field.wide{flex:1;min-width:160px}.field.qty{width:90px}.field:disabled{opacity:.4;cursor:not-allowed}.btn-add{color:#fff;cursor:pointer;white-space:nowrap;background:#111;border:none;border-radius:8px;padding:9px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:opacity .15s}.btn-add:hover:not(:disabled){opacity:.82}.btn-add:disabled{opacity:.35;cursor:not-allowed}.btn-add-secondary{background:var(--bg);color:var(--text-h);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:8px;padding:9px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s,border-color .15s}.btn-add-secondary:hover{background:var(--bg-s);border-color:#9ca3af}.hint{color:var(--text);margin:8px 0 0;font-size:13px}.auth-page{background:var(--bg-s);justify-content:center;align-items:center;min-height:100svh;padding:24px;display:flex;position:relative}.auth-card{border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);background:#fff;border-radius:16px;padding:36px 32px}.auth-logo{color:#111;letter-spacing:-.5px;margin-bottom:24px;font-size:22px;font-weight:700}.auth-logo-img{width:auto;height:48px;margin-bottom:24px;display:block}.auth-tabs{background:var(--bg-s);border:1px solid var(--border);border-radius:10px;gap:2px;margin-bottom:24px;padding:3px;display:flex}.auth-tab{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s,color .15s}.auth-tab:hover{color:var(--text-h)}.auth-tab.active{color:#fff;background:#111}.auth-tabs{gap:8px;margin-bottom:20px;display:flex}.auth-tab{appearance:none;background:var(--bg-s);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;flex:1;padding:9px 0;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.auth-tab.active{color:#fff;background:#111;border-color:#111}.auth-tab:hover:not(.active){background:var(--border);color:var(--text-h)}.auth-divider{color:var(--text);align-items:center;gap:12px;margin:20px 0 16px;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-oauth-btns{flex-direction:column;gap:10px;display:flex}.auth-google-btn{justify-content:center;display:flex}.btn-yandex{appearance:none;color:#fff;cursor:pointer;background:#fc3f1d;border:none;border-radius:8px;justify-content:center;align-items:center;gap:10px;width:100%;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.btn-yandex:hover:not(:disabled){opacity:.88}.btn-yandex:disabled{opacity:.45;cursor:not-allowed}.auth-form{flex-direction:column;gap:6px;display:flex}.auth-label{color:var(--text);text-transform:uppercase;letter-spacing:.4px;margin-top:8px;font-size:12px;font-weight:600}.auth-submit{width:100%;margin-top:16px}.pwd-wrap{align-items:center;display:flex;position:relative}.pwd-wrap .field{width:100%;padding-right:42px}.pwd-toggle{cursor:pointer;color:var(--text);opacity:.5;background:0 0;border:none;justify-content:center;align-items:center;height:100%;padding:0;transition:opacity .15s;display:flex;position:absolute;right:10px}.pwd-toggle:hover{opacity:1}.pwd-toggle:focus{outline:none}.auth-hint{color:var(--text);text-align:center;margin-top:16px;font-size:12px;line-height:1.5}.auth-hint code{font-family:var(--mono);background:var(--bg-s);border:1px solid var(--border);color:var(--text-h);border-radius:4px;padding:1px 5px;font-size:12px}.topbar-user{align-items:center;gap:12px;margin-left:auto;display:flex}.topbar-username{color:#ffffffd9;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-family:inherit;font-size:14px;font-weight:500;display:flex}.role-badge{text-transform:uppercase;letter-spacing:.5px;color:#fff;background:#ffffff26;border:none;border-radius:100px;padding:2px 7px;font-size:10px;font-weight:700}.btn-logout{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:14px;font-weight:500;transition:opacity .15s}.btn-logout:hover{opacity:.75}.sale-layout{align-items:flex-start;gap:24px;display:flex}.sale-form-panel{flex:1}.sale-summary-panel{flex-direction:column;gap:12px;min-width:180px;display:flex}.summary-card{background:#1a1a1a;border:none;border-radius:16px;flex-direction:column;gap:8px;padding:20px 22px;display:flex}.summary-label{text-transform:uppercase;letter-spacing:.6px;color:#ffffff80;font-size:11px;font-weight:600}.summary-value{color:#fff;font-variant-numeric:tabular-nums;font-size:26px;font-weight:700}.summary-card-active{background:#111;outline:2px solid #ffffff26}.sale-form{flex-direction:column;gap:6px;display:flex}.sale-label{color:var(--text);text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.sale-row{flex-wrap:wrap;gap:10px;display:flex}.sale-field{flex-direction:column;gap:4px;display:flex}.stock-hint{color:var(--text);margin:2px 0;font-size:13px}.sale-total-preview{color:var(--text-h);background:var(--bg-s);border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-size:14px;font-weight:500}.venue-selector{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.venue-btn{background:var(--bg-s);border:1px solid var(--border);color:var(--text-h);cursor:pointer;border-radius:100px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,background .15s,color .15s}.venue-btn:hover{color:#111;border-color:#111}.venue-btn.active{color:#fff;background:#ef4444;border-color:#ef4444}.product-cell{flex-direction:column;gap:2px;display:flex}.sku-inline{font-family:var(--mono);color:#6b7280;font-size:12px}.venue-badge{white-space:nowrap;letter-spacing:.2px;border:1px solid #0000;border-radius:100px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.venue-regular{color:#374151;background:#f3f4f6;border-color:#e5e7eb}.venue-shelf{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.venue-market{color:#c2410c;background:#fff7ed;border-color:#fed7aa}.btn-sell{cursor:pointer;color:#c2410c;white-space:nowrap;background:#fff7ed;border:1px solid #fed7aa;border-radius:7px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:opacity .15s}.btn-sell:hover{opacity:.75}.btn-sell-unit{cursor:pointer;color:#fff;white-space:nowrap;background:#111;border:none;border-radius:7px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:opacity .15s}.btn-sell-unit:hover:not(:disabled){opacity:.82}.btn-sell-unit:disabled{opacity:.35;cursor:not-allowed}.confirm-sell{flex-wrap:nowrap;align-items:center;gap:6px;display:flex}.confirm-sell-text,.confirm-sell-prices{color:var(--text-h);white-space:nowrap;font-size:12px}.market-sell-summary{flex-wrap:wrap;gap:16px;margin-top:4px;display:flex}.market-sell-summary .summary-card{flex:1;min-width:160px}.row-out-of-stock td{opacity:.5}.qty-input{text-align:center;width:72px;padding:4px 6px}.input-error{border-color:#ef4444!important}.shelf-sell-actions{justify-content:flex-end;margin:16px 0 32px;display:flex}.shelf-sell-btn{min-width:260px;padding:10px 24px;font-size:15px}.btn-back-market{color:var(--text-h);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:14px;font-weight:500}.btn-back-market:hover{text-decoration:underline}.btn-cancel-sale{cursor:pointer;color:#ef4444;white-space:nowrap;background:0 0;border:1px solid #fca5a5;border-radius:4px;padding:4px 10px;font-size:12px;transition:opacity .15s}.btn-cancel-sale:hover{opacity:.7}.col-price{width:110px}.col-commission{width:90px}.profile-page{flex-direction:column;gap:28px;max-width:680px;display:flex}.profile-section{background:var(--code-bg);border:1px solid var(--border);border-radius:10px;padding:24px 28px}.profile-section-title{color:var(--text-h);letter-spacing:-.2px;margin:0 0 20px;font-size:15px;font-weight:600}.profile-section-desc{color:var(--text);margin:-12px 0 16px;font-size:13px;line-height:1.5}.coauthor-current{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:12px;width:fit-content;min-width:240px;padding:12px 16px;display:flex}.coauthor-info{flex-direction:column;flex:1;gap:3px;display:flex}.coauthor-name{color:var(--text-h);font-size:14px}.coauthor-input-row{gap:8px;display:flex}.coauthor-input-row .field{flex:1}.profile-form{flex-direction:column;gap:10px;display:flex}.profile-label{text-transform:uppercase;letter-spacing:.4px;color:var(--text);margin-bottom:4px;font-size:11px;font-weight:600;display:block}.profile-field{flex-direction:column;flex:1;display:flex}.profile-row{flex-wrap:wrap;gap:16px;display:flex}.profile-save-btn{align-self:flex-start;margin-top:6px}.profile-form-actions{align-items:center;gap:12px;margin-top:4px;display:flex}.prod-img-cell{cursor:pointer;border-radius:6px;flex-shrink:0;width:40px;height:40px;position:relative;overflow:visible}.prod-img-wrap{border-radius:6px;width:40px;height:40px;position:relative;overflow:hidden}.prod-img{object-fit:cover;border:1px solid var(--border);border-radius:6px;width:40px;height:40px;display:block}.prod-img-del{color:#fff;text-align:center;cursor:pointer;z-index:2;background:#c00;border:none;border-radius:50%;width:18px;height:18px;padding:0;font-size:9px;line-height:18px;display:none;position:absolute;top:-6px;right:-6px}.prod-img-wrap:hover .prod-img-del{display:block}.prod-img-placeholder{border:1.5px dashed var(--border);background:var(--bg);border-radius:6px;justify-content:center;align-items:center;width:40px;height:40px;transition:border-color .15s,background .15s;display:flex}.prod-img-cell:hover .prod-img-placeholder{background:var(--code-bg);border-color:#888}.prod-img-spinner{border:2px solid var(--border);border-top-color:var(--text-h);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.prod-img-loading-overlay{background:#fff9;border-radius:6px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.avatar-upload{align-items:center;gap:16px;padding:4px 0 2px;display:flex}.avatar-circle{background:var(--bg);border:2px solid var(--border);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;transition:border-color .15s;display:flex;position:relative;overflow:hidden}.avatar-circle:hover{border-color:#888}.avatar-circle--loading{cursor:default;opacity:.7}.avatar-img{object-fit:cover;width:100%;height:100%;display:block}.avatar-overlay{color:#fff;opacity:0;background:#00000073;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.avatar-circle:hover .avatar-overlay{opacity:1}.avatar-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.avatar-actions{flex-direction:column;gap:6px;display:flex}.avatar-btn{border:1px solid var(--border);color:var(--text-h);cursor:pointer;text-align:left;background:0 0;border-radius:7px;padding:6px 14px;font-size:13px;transition:border-color .15s,background .15s}.avatar-btn:hover{background:var(--code-bg);border-color:#888}.avatar-btn:disabled{opacity:.5;cursor:default}.avatar-btn--remove{color:#c00}.avatar-btn--remove:hover{background:#fff0f0;border-color:#c00}.avatar-error{color:#c00;font-size:12px}.qr-modal-avatar{object-fit:cover;border:2px solid var(--border);border-radius:50%;width:72px;height:72px}.profile-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.profile-section-header .profile-section-title{margin:0}.profile-user-code{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:8px 14px;display:flex}.profile-user-code-label{color:var(--text);opacity:.7;white-space:nowrap;font-size:12px}.profile-user-code-value{letter-spacing:.05em;color:var(--accent);font-family:Courier New,Courier,monospace;font-size:14px;font-weight:700}.btn-qr{color:var(--text-h);background:var(--bg);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:border-color .15s,background .15s;display:inline-flex}.btn-qr:hover{background:#f5f5f5;border-color:#888}.btn-qr--disabled{opacity:.4;cursor:default}.btn-qr--disabled:hover{border-color:var(--border);background:var(--bg)}.qr-modal-card{width:90vw;max-width:380px}.qr-modal-body{flex-direction:column;align-items:center;gap:16px;padding:20px 28px;display:flex}.qr-canvas-wrap{border:1px solid var(--border);background:#fff;border-radius:12px;padding:12px;line-height:0}.qr-img{width:256px;height:256px;display:block}.qr-placeholder{width:256px;height:256px;color:var(--text);justify-content:center;align-items:center;font-size:13px;display:flex}.qr-photo-status{text-align:center;margin:0;font-size:12px;font-weight:500}.qr-photo-status--ok{color:#15803d}.qr-photo-status--warn{color:#b91c1c}.qr-hint{color:var(--text);text-align:center;margin:0;font-size:12px;line-height:1.5}.qr-included{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;width:100%;padding:12px 16px}.qr-included-title{text-transform:uppercase;letter-spacing:.4px;color:var(--text);margin-bottom:8px;font-size:11px;font-weight:600}.qr-included-list{color:var(--text-h);margin:0;padding:0 0 0 16px;font-size:13px;line-height:1.8}.profile-section-divider{align-items:center;gap:10px;margin:10px 0 4px;display:flex}.profile-section-divider:before,.profile-section-divider:after{content:"";background:var(--border);flex:1;height:1px}.profile-section-divider-label{text-transform:uppercase;letter-spacing:.4px;color:var(--text);white-space:nowrap;font-size:11px;font-weight:600}.social-input-wrap{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;display:flex;overflow:hidden}.social-prefix{color:var(--text);background:var(--code-bg);border-right:1px solid var(--border);white-space:nowrap;align-items:center;height:36px;padding:0 10px;font-size:12px;line-height:36px;display:flex}.social-field{flex:1;min-width:0;border:none!important;border-radius:0!important}.social-field:focus{box-shadow:none;outline:none}.social-links-preview{flex-wrap:wrap;gap:8px;padding:4px 0 2px;display:flex}.social-link-badge{border:1.5px solid color-mix(in srgb, var(--social-color) 30%, var(--border));background:color-mix(in srgb, var(--social-color) 6%, var(--bg));color:var(--text-h);cursor:pointer;border-radius:20px;align-items:center;gap:7px;padding:7px 14px 7px 10px;font-size:13px;text-decoration:none;transition:border-color .15s,background .15s,transform .1s;display:inline-flex}.social-link-badge:hover{border-color:var(--social-color);background:color-mix(in srgb, var(--social-color) 12%, var(--bg));transform:translateY(-1px)}.social-link-icon{color:var(--social-color);flex-shrink:0;align-items:center;display:flex}.social-link-label{color:var(--social-color);white-space:nowrap;font-size:12px;font-weight:600}.social-link-handle{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:13px;overflow:hidden}.display-pref-options{flex-direction:column;gap:6px;margin-top:4px;display:flex}.pref-option{border:1px solid var(--border);cursor:pointer;background:var(--bg);border-radius:8px;align-items:center;gap:10px;padding:10px 14px;transition:border-color .15s,background .15s;display:flex}.pref-option input[type=radio]{accent-color:#111;flex-shrink:0}.pref-option.selected{background:#f3f4f6;border-color:#111}.pref-label{color:var(--text-h);flex:1;font-size:14px}.pref-preview{color:var(--text-h);background:var(--bg);border:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;border-radius:6px;max-width:180px;padding:2px 10px;font-size:13px;font-weight:500;overflow:hidden}.topbar-username{cursor:pointer;color:#ffffffd9;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:13px;transition:color .15s;display:flex}.topbar-username:hover{color:#fff}.app-footer{color:var(--text);border-top:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;gap:2px;padding:14px 24px;font-size:12px;display:flex}.app-version{color:var(--text-s);font-variant-numeric:tabular-nums;letter-spacing:.04em;font-size:11px;font-weight:600}.btn-return{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:12px;transition:border-color .15s,color .15s}.btn-return:hover{color:#ef4444;border-color:#ef4444}.return-badge{color:#b91c1c;white-space:nowrap;background:#fef2f2;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.row-returned td{opacity:.55}.row-returned .return-badge{opacity:1}.line-through{text-decoration:line-through}.text-muted{color:var(--text)}.text-danger{color:#ef4444}.return-form-row td{border-top:none;padding:0}.return-form{background:var(--accent-bg);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;flex-direction:column;gap:12px;padding:16px 20px;display:flex}.return-form-title{color:var(--text-h);font-size:13px}.return-form-body{flex-direction:column;gap:10px;display:flex}.return-comment{resize:vertical;box-sizing:border-box;width:100%;max-width:520px;font-size:13px}.return-restock-label{color:var(--text-h);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:flex}.return-restock-label input[type=checkbox]{accent-color:#111;cursor:pointer;width:15px;height:15px}.return-form-actions{align-items:center;gap:8px;display:flex}.table-subheading{color:var(--text-h);margin:0;font-size:16px;font-weight:600}.summary-negative{color:#f87171!important}.summary-accent{color:#4ade80!important}.back-btn-row{margin-top:16px;margin-bottom:20px}.banner-gap{margin-top:16px}.table-header-gap{margin-top:20px}.table-header-lg-gap{margin-top:32px}.add-row-gap{margin-top:8px}.commission-field{align-items:center;gap:4px;display:flex}.commission-input{width:70px}.commission-pct-label{color:var(--text);font-size:13px}.col-txcode{width:110px}.tx-code{color:var(--text);letter-spacing:.08em;opacity:.55;-webkit-user-select:all;user-select:all;font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,monospace;font-size:11px}.nav-tab-admin{border-left:1px solid var(--border);margin-left:8px;padding-left:16px}.admin-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px;display:grid}@media (width<=700px){.admin-stats{grid-template-columns:repeat(2,1fr)}}.admin-stat-card{background:#1a1a1a;border:none;border-radius:16px;flex-direction:column;gap:8px;padding:20px 22px;display:flex}.admin-stat-label{text-transform:uppercase;letter-spacing:.6px;color:#ffffff80;font-size:11px;font-weight:600}.admin-stat-value{color:#fff;font-variant-numeric:tabular-nums;font-size:26px;font-weight:700}.admin-section{margin-top:24px}.admin-section-title{color:var(--text);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:8px;margin-bottom:12px;font-size:13px;font-weight:600;display:flex}.review-badge{color:#fff;letter-spacing:0;text-transform:none;background:#dc2626;border-radius:100px;padding:2px 8px;font-size:11px;font-weight:700}.admin-section-hint{color:var(--text-h);margin-bottom:14px;font-size:13px;line-height:1.5}.row-review td{background:#fffbeb}.user-cell{align-items:center;gap:8px;display:flex}.self-badge{color:#374151;letter-spacing:.03em;background:#f3f4f6;border-radius:100px;padding:2px 7px;font-size:10px;font-weight:700}.role-pill{border-radius:100px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.role-pill-admin{color:#fff;background:#1a1a1a}.role-pill-user{color:#374151;background:#f3f4f6}.role-pill-новый{color:#854d0e;background:#fef9c3}.role-pill-продавец{color:#1d4ed8;background:#dbeafe}.role-pill-премиум{color:#7e22ce;background:#fdf4ff;border:1px solid #e9d5ff}.col-role,.col-date{width:140px}.btn-role-toggle{border:1px solid var(--border);background:var(--bg-s);color:var(--text-h);cursor:pointer;white-space:nowrap;border-radius:7px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:border-color .15s,color .15s}.btn-role-toggle:hover:not(:disabled){color:#111;border-color:#111}.btn-role-toggle:disabled{opacity:.5;cursor:default}.btn-role-readonly{border:1px solid var(--border);background:var(--bg-s);color:#888;cursor:pointer;white-space:nowrap;border-radius:7px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:border-color .15s,color .15s}.btn-role-readonly:hover:not(:disabled){color:#c00;border-color:#c00}.btn-role-readonly:disabled{opacity:.5;cursor:default}.btn-role-delete{border:1px solid var(--border);color:#9ca3af;cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-family:inherit;font-size:14px;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-role-delete:hover:not(:disabled){color:#dc2626;background:#fee2e2;border-color:#fca5a5}.btn-role-delete:disabled{opacity:.4;cursor:default}.btn-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;padding:9px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:default}.role-actions{flex-wrap:wrap;gap:6px;display:flex}.admin-no-action{font-size:12px}.row-self{background:#fafafa}.tx-search-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tx-search-input{letter-spacing:.12em;text-transform:uppercase;width:220px;font-family:SF Mono,Fira Code,Roboto Mono,monospace;font-size:15px}.tx-search-banner{margin-top:12px}.tx-result-card{border:1px solid var(--border);background:var(--bg);border-radius:10px;flex-direction:column;gap:16px;max-width:560px;margin-top:16px;padding:20px 24px;display:flex}.tx-result-header{align-items:center;gap:12px;display:flex}.tx-result-code{letter-spacing:.12em;color:var(--text-h);font-family:SF Mono,Fira Code,Roboto Mono,monospace;font-size:18px;font-weight:700}.tx-status-active{color:#15803d;background:#dcfce7;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.tx-detail-grid{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:0;margin:0;display:flex;overflow:hidden}.tx-detail-row{border-bottom:1px solid var(--border);align-items:baseline;gap:12px;padding:9px 14px;display:flex}.tx-detail-row:last-child{border-bottom:none}.tx-detail-row dt{color:var(--text);flex-shrink:0;width:130px;font-size:12px}.tx-detail-row dd{color:var(--text-h);flex-wrap:wrap;align-items:center;gap:6px;margin:0;font-size:13px;display:flex}.tx-detail-total{background:var(--accent-bg);font-weight:600}.tx-venue-name{color:var(--text);background:var(--accent-bg);border-radius:20px;padding:1px 8px;font-size:12px}.btn-tx-delete{color:#b91c1c;cursor:pointer;background:#fff5f5;border:1px solid #fca5a5;border-radius:7px;align-self:flex-start;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.btn-tx-delete:hover{background:#fee2e2;border-color:#ef4444}.tx-delete-confirm{background:#fff5f5;border:1px solid #fca5a5;border-radius:8px;flex-direction:column;gap:10px;padding:14px 16px;display:flex}.tx-delete-confirm-text{color:#7f1d1d;font-size:13px;line-height:1.5}.tx-delete-confirm-actions{align-items:center;gap:8px;display:flex}.btn-tx-delete-confirm{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:7px;padding:6px 16px;font-size:13px;font-weight:600;transition:background .15s}.btn-tx-delete-confirm:hover:not(:disabled){background:#dc2626}.btn-tx-delete-confirm:disabled{opacity:.6;cursor:default}.time-msk{color:var(--text);opacity:.6;margin-top:2px;font-size:11px}.report-metrics{flex-wrap:wrap;gap:4px;margin-top:16px;display:flex}.metric-tab{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:100px;padding:7px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.metric-tab:hover{color:#111;border-color:#111}.metric-tab.active{color:#fff;background:#111;border-color:#111;font-weight:600}.report-controls{flex-wrap:wrap;align-items:center;gap:16px;margin-top:16px;display:flex}.period-nav{align-items:center;gap:8px;display:flex}.period-btn{border:1px solid var(--border);background:var(--bg);width:34px;height:34px;color:var(--text-h);cursor:pointer;border-radius:100px;justify-content:center;align-items:center;font-family:inherit;font-size:18px;line-height:1;transition:border-color .15s,background .15s;display:flex}.period-btn:hover{background:#f3f4f6;border-color:#111}.period-label{color:var(--text-h);text-align:center;min-width:160px;font-size:15px;font-weight:600}.year-select{width:90px;font-size:13px}.report-drill-label{color:var(--text);font-size:13px}.report-hint{color:var(--text);font-size:12px;font-style:italic}.report-summary{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}.summary-card-active{outline:2px solid #ffffff4d!important}.chart-section{background:var(--bg);border:1px solid var(--border);border-radius:12px;margin-top:20px;padding:16px 12px 8px}.chart-wrap{width:100%;position:relative}.bar-chart-svg{width:100%;height:auto;display:block;overflow:visible}.bar-group rect{transition:opacity .1s}.bar-group:hover rect{opacity:.82}.chart-tooltip{color:#f9fafb;pointer-events:none;z-index:10;white-space:nowrap;background:#1f2937;border-radius:8px;min-width:120px;padding:8px 12px;font-size:12px;position:absolute;top:12px;box-shadow:0 4px 12px #0003}.tooltip-date{color:#9ca3af;margin-bottom:6px;font-size:11px;font-weight:500}.tooltip-row{align-items:center;gap:6px;margin-top:3px;display:flex}.tooltip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tooltip-val{margin-left:auto;padding-left:12px;font-weight:600}.chart-legend{flex-wrap:wrap;justify-content:center;gap:16px;padding:8px 0 4px;display:flex}.legend-item{color:var(--text-h);align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.chart-loading,.chart-empty{height:200px;color:var(--text);justify-content:center;align-items:center;font-size:14px;display:flex}.btn-yearly-toggle{background:var(--bg-s);color:var(--text-h);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.btn-yearly-toggle:hover{border-color:#111}.btn-yearly-toggle.active{color:#fff;background:#111;border-color:#111}.market-costs-panel{border:1px solid var(--border);border-radius:10px;margin-top:16px;overflow:hidden}.market-costs-header{background:var(--bg-s);border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;width:100%;padding:11px 16px;font-family:inherit;display:flex}.market-costs-title{color:var(--text-h);font-size:14px;font-weight:600}.market-costs-toggle{color:var(--text-s);font-size:11px}.market-costs-body{gap:0;display:flex}.market-costs-list{border-right:1px solid var(--border);flex:1;padding:12px 16px}.market-cost-row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:baseline;gap:12px;padding:5px 0;font-size:13px;display:flex}.market-cost-row:last-child{border-bottom:none}.market-cost-row-losses{color:#be123c}.market-cost-label{color:var(--text)}.market-cost-hint{color:var(--text-s);font-size:11px}.market-cost-value{white-space:nowrap;font-weight:600}.market-cost-minus{color:#ef4444}.market-cost-empty{color:var(--text-s);padding:6px 0;font-size:13px}.market-costs-calc{flex-direction:column;flex-shrink:0;justify-content:flex-end;gap:6px;width:260px;padding:12px 16px;display:flex}.market-calc-row{justify-content:space-between;align-items:baseline;gap:12px;padding:4px 0;font-size:13px;display:flex}.market-calc-costs{color:#ef4444;border-top:1px solid var(--border);padding-top:8px}.market-calc-net{border-top:2px solid var(--border);padding-top:8px;font-size:14px}.market-calc-net.net-positive strong{color:#10b981}.market-calc-net.net-negative strong{color:#ef4444}.yearly-stat-net{border-color:#10b981!important}@media (width<=640px){.market-costs-body{flex-direction:column}.market-costs-list{border-right:none;border-bottom:1px solid var(--border)}.market-costs-calc{width:100%}}.yearly-panel{border:1px solid var(--border);border-radius:10px;margin-top:16px;overflow:hidden}.yearly-panel-header{background:var(--bg-s);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;display:flex}.yearly-panel-title{color:var(--text-h);flex:1;font-size:14px;font-weight:600}.yearly-panel-header .year-select{width:auto;padding:4px 8px;font-size:13px}.yearly-stats{grid-template-columns:repeat(3,1fr);gap:12px;padding:20px 16px;display:grid}@media (width<=600px){.yearly-stats{grid-template-columns:1fr}}.yearly-stat-card{background:#1a1a1a;border:none;border-radius:16px;flex-direction:column;gap:8px;padding:20px 22px;display:flex}.yearly-stat-card.yearly-stat-accent{background:#111}.yearly-stat-label{text-transform:uppercase;letter-spacing:.6px;color:#ffffff80;font-size:11px;font-weight:600}.yearly-stat-value{color:#fff;font-variant-numeric:tabular-nums;font-size:26px;font-weight:700}.yearly-stat-accent .yearly-stat-value{color:#4ade80}.report-data-table{margin-top:24px}.col-period{width:140px}.report-period-cell{color:var(--text-h);white-space:nowrap;font-size:12px}.report-totals-row{background:var(--bg-s);border-top:2px solid var(--border)}.report-totals-row td{padding-top:10px;padding-bottom:10px}.detail-trigger{cursor:pointer;font-size:inherit;color:#6366f1;text-underline-offset:3px;font-variant-numeric:tabular-nums;background:0 0;border:none;border-radius:4px;padding:2px 8px;font-family:inherit;font-weight:600;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;transition:background .12s}.detail-trigger:hover{background:#6366f114}.detail-trigger.active{background:#6366f124;text-decoration:none}.detail-trigger-ret{color:#f59e0b}.detail-trigger-ret:hover{background:#f59e0b14}.detail-trigger-ret.active{background:#f59e0b24}.report-detail-panel{border:1px solid var(--border);border-radius:8px;margin-top:16px;overflow:hidden}.report-detail-header{background:var(--bg-s);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.report-detail-title{color:var(--text-h);font-size:13px;font-weight:600}.btn-close-detail{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:4px;padding:3px 7px;font-size:15px;line-height:1}.btn-close-detail:hover{background:var(--border)}.create-user-form{flex-wrap:wrap;align-items:flex-start;gap:10px;display:flex}.create-user-form .field{width:180px}.create-user-form .banner{width:100%;margin-bottom:0}.burger-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;margin-left:auto;padding:0;display:none}.burger-line{background:#fff;border-radius:2px;width:22px;height:2px;transition:transform .22s,opacity .22s;display:block}.burger-btn .burger-line.open:first-child{transform:translateY(7px)rotate(45deg)}.burger-btn .burger-line.open:nth-child(2){opacity:0;transform:scaleX(0)}.burger-btn .burger-line.open:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;display:none;position:fixed;inset:0}.mobile-drawer{background:#111;flex-direction:column;width:min(300px,85vw);display:flex;position:absolute;top:0;bottom:0;right:0;overflow-y:auto}.mobile-drawer-header{border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;height:54px;padding:0 20px;display:flex}.mobile-drawer-logo-img{background:#fff;border-radius:6px;width:auto;height:26px;padding:3px 8px;display:block}.mobile-drawer-close{color:#fff9;cursor:pointer;background:0 0;border:none;padding:8px;font-size:18px;line-height:1}.mobile-drawer-user{cursor:pointer;border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:16px 20px;display:flex}.mobile-drawer-username{color:#ffffffd9;font-size:14px;font-weight:600}.mobile-drawer-nav{flex-direction:column;flex:1;padding:8px 0;display:flex}.mobile-nav-item{color:#ffffffbf;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:16px 20px;font-family:inherit;font-size:16px;font-weight:500;transition:background .15s,color .15s;display:block}.mobile-nav-item:hover{color:#fff;background:#ffffff12}.mobile-nav-item.active{color:#fff;background:#ffffff1a;font-weight:700}.mobile-drawer-footer{border-top:1px solid #ffffff14;flex-shrink:0;padding:16px 20px}.mobile-logout-btn{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #ef444466;border-radius:8px;width:100%;padding:13px;font-family:inherit;font-size:15px;font-weight:600}@media (width<=768px){*,:before,:after{box-sizing:border-box}.burger-btn{display:flex}.mobile-overlay{display:block}.topbar-nav,.topbar-user{display:none!important}.topbar{gap:0;padding:0 16px}.brand-bar{justify-content:center;padding:8px 16px}.brand-bar-logo{height:30px}.breadcrumb{flex:1;margin:0 12px}.breadcrumb-back{padding:8px 0;font-size:15px}.main{padding:16px}.table-header{flex-wrap:wrap;gap:8px;margin-bottom:14px}.table-header h1{font-size:19px}.product-search-wrap{width:100%;margin-left:0}.product-search-input{width:100%}.table-wrap{border-radius:10px}.data-table{min-width:540px}.data-table td,.data-table thead th{padding:12px 10px}.btn-edit,.btn-save,.btn-cancel,.btn-products,.btn-report,.btn-expenses{min-height:40px;padding:9px 14px;font-size:14px}.btn-delete{width:40px;height:40px;font-size:17px}.btn-add{width:100%;padding:12px 20px;font-size:15px}.field{min-height:48px;padding:12px 13px;font-size:16px}.field.wide{width:100%;min-width:unset}.field.qty{width:100%}.add-row,.sale-row{flex-direction:column;gap:10px}.add-row .field,.sale-row .field{width:100%}.sale-layout{flex-direction:column;gap:16px}.sale-summary-panel{min-width:unset;flex-flow:wrap;gap:10px}.summary-card{flex:1;min-width:130px;padding:14px 16px}.summary-value{font-size:20px}.market-sell-summary{gap:10px}.market-sell-summary .summary-card{min-width:120px}.btn-sell{min-height:40px;padding:9px 14px;font-size:13px}.btn-sell-unit{min-height:40px;padding:10px 16px;font-size:13px}.btn-cancel-sale{min-height:40px;padding:8px 12px;font-size:13px}.auth-page{align-items:flex-start;padding:48px 16px 16px}.auth-card{border-radius:12px;padding:28px 20px}.auth-form .btn-add{margin-top:4px}.admin-stats{grid-template-columns:repeat(2,1fr);gap:10px}.admin-stat-card{padding:14px 16px}.admin-stat-value{font-size:20px}.create-user-form{flex-direction:column}.create-user-form .field{width:100%}.report-data-table{min-width:480px}.chart-wrap svg{width:100%!important;height:auto!important}.yearly-stats{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.period-nav,.metric-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.period-nav::-webkit-scrollbar{display:none}.metric-tabs::-webkit-scrollbar{display:none}.tx-search-form{flex-wrap:wrap;gap:8px}.tx-search-input{width:100%}.pref-options{flex-wrap:wrap}.pref-option{flex:1;min-width:100px}.shelf-meta-row{flex-direction:column;gap:10px}.date-range-inputs{flex-direction:column;align-items:stretch}.date-sep-form{display:none}.venue-selector{gap:8px}.venue-btn{min-height:44px;padding:10px 16px;font-size:14px}.app-footer{padding:12px 16px;font-size:11px}}.new-user-wall{background:var(--bg);justify-content:center;align-items:center;min-height:100svh;padding:24px 16px;display:flex}.new-user-card{text-align:center;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:420px;padding:40px 36px;display:flex;box-shadow:0 4px 24px #0000000f}.new-user-logo{width:auto;height:52px;margin-bottom:4px}.new-user-title{color:var(--text-h);margin:0;font-size:22px;font-weight:700}.new-user-badge{color:#92400e;letter-spacing:.01em;background:#fef3c7;border:1px solid #fde68a;border-radius:100px;align-items:center;gap:5px;padding:5px 14px;font-size:13px;font-weight:600;display:inline-flex}.new-user-text{color:var(--text-h);margin:0;font-size:15px;line-height:1.6}.new-user-tg-btn{color:#fff;background:#229ed9;border-radius:100px;align-items:center;gap:8px;padding:12px 24px;font-size:16px;font-weight:600;text-decoration:none;transition:background .15s,transform .1s;display:inline-flex}.new-user-tg-btn:hover{background:#1a8abf;transform:translateY(-1px)}.new-user-tg-btn:active{transform:none}.new-user-hint{color:var(--text);margin:0;font-size:13px;line-height:1.5}.new-user-logout{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:8px;margin-top:8px;padding:8px 20px;font-size:14px;transition:border-color .15s,color .15s}.new-user-logout:hover{color:var(--text-h);border-color:#999}.landing{background:var(--bg);flex-direction:column;min-height:100svh;display:flex}.landing-hero{color:#fff;text-align:center;background:#111;width:100vw;margin-left:calc(50% - 50vw);padding:80px 24px 96px}.landing-hero-inner{max-width:680px;margin:0 auto}.landing-logo-row{justify-content:center;align-items:center;gap:12px;margin-bottom:40px;display:flex;overflow:hidden}.landing-logo-img{object-fit:contain;border-radius:5px;width:auto;max-width:90vw;height:168px}.landing-h1{letter-spacing:-1px;color:#fff;margin:0 0 20px;font-size:clamp(32px,6vw,52px);font-weight:700;line-height:1.15}.landing-br{display:block}.landing-subtitle{color:#ffffffa6;max-width:480px;margin:0 auto 40px;font-size:17px;line-height:1.65}.landing-cta-row{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.landing-btn{cursor:pointer;white-space:nowrap;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;height:48px;padding:0 28px;font-size:15px;font-weight:600;transition:opacity .15s,background .15s;display:inline-flex}.landing-btn--primary{color:#111;background:#fff;border-color:#fff}.landing-btn--primary:hover{opacity:.88}.landing-btn--ghost{color:#fff;background:0 0;border-color:#ffffff59}.landing-btn--ghost:hover{border-color:#ffffffb3}.landing-features{background:var(--bg);flex:1;padding:72px 24px 80px}.landing-section-inner{max-width:960px;margin:0 auto}.landing-h2{letter-spacing:-.4px;color:var(--text-h);text-align:center;margin:0 0 40px;font-size:28px;font-weight:700}.landing-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.landing-card{background:var(--bg-s);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;padding:28px 24px;transition:box-shadow .15s;display:flex}.landing-card:hover{box-shadow:0 4px 16px #00000012}.landing-card-icon{color:#111;flex-shrink:0;width:40px;height:40px}.landing-card-icon svg{width:40px;height:40px}.landing-card-title{color:var(--text-h);margin:0;font-size:16px;font-weight:600}.landing-card-text{color:var(--text);margin:0;font-size:14px;line-height:1.6}.landing-footer{color:#ffffff73;background:#111;justify-content:space-between;align-items:center;width:100vw;margin-left:calc(50% - 50vw);padding:20px 24px;font-size:13px;display:flex}.landing-footer-brand{color:#ffffffb3;font-weight:600}.auth-back-btn{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-size:14px;transition:background .12s,color .12s;position:absolute;top:20px;left:20px}.auth-back-btn:hover{background:var(--bg-s);color:var(--text-h)}.prof-table .col-prod-img{width:44px}.prof-col-roi{text-align:center;width:120px}.prof-row-empty td{opacity:.5}.prof-roi-badge{white-space:nowrap;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.prof-roi-badge.pos{color:#16a34a;background:#dcfce7}.prof-roi-badge.neg{color:#dc2626;background:#fee2e2}.prof-modal{max-width:680px}.prof-section{border-bottom:1px solid var(--border);padding:16px 20px 4px}.prof-section:last-of-type{border-bottom:none}.prof-section-title{color:var(--text-h);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px;font-size:13px;font-weight:600}.prof-stages-table{border-collapse:collapse;width:100%;margin-bottom:8px}.prof-stages-table th,.prof-stages-table td{text-align:left;vertical-align:middle;padding:6px 4px}.prof-stages-table thead th{color:var(--text);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);font-size:11px;font-weight:600}.prof-th-num{width:32px}.prof-th-amount{width:120px}.prof-th-ctrl{width:96px}.prof-td-num{color:var(--text);font-size:12px}.prof-td-ctrl{align-items:center;gap:2px;display:flex}.prof-stage-row:hover{background:var(--accent-bg)}.prof-amount-input{text-align:right;width:110px}.prof-th-type{width:90px}.prof-td-type{text-align:center}.prof-type-toggle{cursor:pointer;white-space:nowrap;border:1px solid;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:600;transition:background .12s,color .12s}.prof-type-toggle.per-unit{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.prof-type-toggle.per-unit:hover{background:#dbeafe}.prof-type-toggle.fixed{color:#7e22ce;background:#fdf4ff;border-color:#e9d5ff}.prof-type-toggle.fixed:hover{background:#f3e8ff}.prof-order-btn{border:1px solid var(--border);cursor:pointer;width:26px;height:26px;color:var(--text);background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:12px;transition:background .1s;display:inline-flex}.prof-order-btn:hover:not(:disabled){background:var(--bg-s)}.prof-order-btn:disabled{opacity:.3;cursor:default}.prof-templates{border-bottom:1px solid var(--border);padding:10px 20px 12px}.prof-templates-label{color:var(--text);margin-bottom:8px;font-size:12px}.prof-template-chips{flex-wrap:wrap;gap:6px;display:flex}.prof-template-chip{border:1px solid var(--border);background:var(--bg-s);border-radius:20px;align-items:center;display:inline-flex;overflow:hidden}.prof-chip-add{cursor:pointer;color:var(--text-h);background:0 0;border:none;padding:4px 10px;font-size:13px;transition:background .1s}.prof-chip-add:hover{background:var(--accent-bg)}.prof-chip-del{border:none;border-left:1px solid var(--border);cursor:pointer;color:var(--text);opacity:.6;background:0 0;padding:4px 7px;font-size:11px;transition:opacity .1s,background .1s}.prof-chip-del:hover{opacity:1;color:#dc2626;background:#fee2e2}.prof-add-stage{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 20px 14px;display:flex}.prof-add-stage .field.wide{flex:1}.prof-section--extra{border-bottom:1px solid var(--border)}.prof-extra-label{color:var(--text);margin-bottom:8px;font-size:13px;display:block}.prof-extra-hint{color:var(--text);opacity:.7;margin:8px 0 12px;font-size:12px}.prof-summary-card{border:1px solid var(--border);border-radius:10px;margin:16px 20px;overflow:hidden}.prof-summary-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 14px;font-size:14px;display:flex}.prof-summary-row:last-child{border-bottom:none}.prof-summary--total{background:#fff1f2;font-weight:600}.prof-summary--subtotal{background:var(--accent-bg);font-weight:600}.prof-summary--profit.pos{color:#16a34a;font-weight:600}.prof-summary--profit.neg{color:#dc2626;font-weight:600}.prof-summary--roi.pos{color:#16a34a}.prof-summary--roi.neg{color:#dc2626}.text-success{color:#16a34a}.col-prof-roi{text-align:center;width:140px;color:var(--text);opacity:.65;font-size:12px}.prof-roi-readonly{text-align:center;color:var(--text);opacity:.7;-webkit-user-select:none;user-select:none;pointer-events:none}.prof-roi-readonly-val{font-size:13px;font-weight:500}.prof-roi-readonly-val.pos{color:#4ade80}.prof-roi-readonly-val.neg{color:#f87171}.btn-report{border:1px solid var(--border);background:var(--bg-s);color:var(--text-h);cursor:pointer;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s}.btn-report:hover{background:var(--accent-bg);border-color:#c4b5fd}.prof-report-screen{padding:0 0 40px}.prof-report-init-loading{text-align:center;color:var(--text);padding:48px}.prof-report-header{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:16px;padding:16px 20px 12px;display:flex}.prof-report-back{border:1px solid var(--border);color:var(--text-h);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:6px 12px;font-size:13px;transition:background .1s}.prof-report-back:hover{background:var(--bg-s)}.prof-report-title{color:var(--text-h);flex:1;margin:0;font-size:18px;font-weight:700}.prof-period-toggle{gap:4px;display:flex}.prof-period-btn{border:1px solid var(--border);background:var(--bg-s);color:var(--text);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:13px;transition:background .1s,color .1s}.prof-period-btn.active{color:#7c3aed;background:#ede9fe;border-color:#c4b5fd;font-weight:600}.prof-report-filters{border-bottom:1px solid var(--border);background:var(--accent-bg);flex-direction:column;gap:10px;padding:14px 20px;display:flex}.prof-filter-row{flex-wrap:wrap;align-items:flex-start;gap:10px;display:flex}.prof-filter-label{color:var(--text);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;min-width:80px;padding-top:4px;font-size:12px;font-weight:600}.prof-filter-chips{flex-wrap:wrap;gap:6px;display:flex}.prof-filter-chip{border:1px solid var(--border);background:var(--bg-s);color:var(--text-h);cursor:pointer;border-radius:20px;padding:4px 12px;font-size:13px;transition:background .1s,border-color .1s,color .1s}.prof-filter-chip:hover{background:var(--bg);border-color:#a78bfa}.prof-filter-chip.active{color:#6d28d9;background:#ede9fe;border-color:#a78bfa;font-weight:600}.prof-filter-chip-clear{color:#dc2626;cursor:pointer;background:#fff1f2;border:1px solid #fecaca;border-radius:20px;padding:4px 10px;font-size:12px;transition:background .1s}.prof-filter-chip-clear:hover{background:#fee2e2}.prof-report-summary{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:6px 24px;padding:14px 20px;display:flex}.prof-report-kpi{flex-direction:column;gap:2px;display:flex}.prof-report-kpi-label{color:var(--text);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.prof-report-kpi-val{color:var(--text-h);font-size:17px;font-weight:700}.prof-report-chart-wrap{padding:20px 12px 8px}.prof-report-chart-placeholder{height:200px;color:var(--text);text-align:center;justify-content:center;align-items:center;padding:0 24px;font-size:14px;display:flex}.prof-report-tooltip{background:var(--bg);border:1px solid var(--border);border-radius:8px;min-width:200px;padding:10px 14px;font-size:13px;box-shadow:0 4px 16px #0000001f}.prof-report-tooltip-title{color:var(--text-h);margin-bottom:8px;font-size:14px;font-weight:700}.prof-report-tooltip-row{align-items:center;gap:6px;margin-bottom:4px;display:flex}.prof-report-tooltip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.prof-report-tooltip-name{color:var(--text);flex:1}.prof-report-tooltip-val{font-weight:600}.prof-report-hint{color:var(--text);opacity:.7;text-align:center;padding:4px 20px 0;font-size:12px}@media (width<=600px){.landing-hero{padding:56px 20px 64px}.landing-h1{font-size:30px}.landing-br{display:none}.landing-features{padding:48px 20px 56px}.landing-grid{grid-template-columns:1fr;gap:14px}.landing-card{padding:22px 18px}.landing-h2{margin-bottom:28px;font-size:22px}.landing-logo-img{border-radius:5px}}.planner-layout{align-items:flex-start;gap:18px;display:flex}.planner-sidebar{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;flex-shrink:0;width:280px;max-height:calc(100vh - 160px);display:flex;overflow:hidden}.planner-sidebar-header{color:var(--text-h);border-bottom:1px solid var(--border);background:var(--bg-s);justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;font-weight:600;display:flex}.planner-sidebar-list{flex:1;overflow-y:auto}.planner-sidebar-empty{text-align:center;color:var(--text);padding:32px 16px;font-size:13px;line-height:1.6}.planner-note-item{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;flex-direction:column;gap:3px;width:100%;padding:10px 14px;font-family:inherit;transition:background .12s;display:flex}.planner-note-item:last-child{border-bottom:none}.planner-note-item:hover{background:var(--bg-s)}.planner-note-item.selected{background:#eff6ff;border-left:3px solid #3b82f6;padding-left:11px}.planner-note-item.past{opacity:.5}.planner-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.planner-rent-item{border-bottom:1px solid var(--border);background:#fffbeb;border-left:3px solid #d97706;flex-direction:column;gap:2px;padding:10px 14px;display:flex}[data-theme=dark] .planner-rent-item{background:#d9770614}.planner-rent-title{color:#92400e;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}[data-theme=dark] .planner-rent-title{color:#fbbf24}.planner-rent-amount{color:#d97706;font-variant-numeric:tabular-nums;font-size:12px;font-weight:700}.planner-rent-period{color:var(--text-s);font-weight:400}.planner-market-item{border-bottom:1px solid var(--border);background:#faf5ff;border-left:3px solid #7c3aed;flex-direction:column;gap:3px;width:100%;padding:10px 14px;display:flex}[data-theme=dark] .planner-market-item{background:#7c3aed14}.planner-market-title{color:#7c3aed;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.planner-dot--market{width:8px!important;height:8px!important}.planner-note-title.done{color:var(--text);opacity:.7;text-decoration:line-through}.planner-status-badge{border:1px solid;border-radius:20px;align-items:center;gap:5px;margin-bottom:10px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.planner-complete-btn{color:#059669;cursor:pointer;white-space:nowrap;background:#ecfdf5;border:1.5px solid #6ee7b7;border-radius:8px;padding:5px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.planner-complete-btn:hover:not(:disabled){color:#fff;background:#059669;border-color:#059669}.planner-complete-btn:disabled{opacity:.5;cursor:default}.planner-undo-btn{border:1.5px solid var(--border);background:var(--bg-s);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;padding:5px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.planner-undo-btn:hover:not(:disabled){background:var(--bg);color:var(--text-h)}.planner-note-date{color:var(--text);text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:600}.planner-note-date.today{color:#3b82f6}.planner-note-title{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.planner-note-preview{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.planner-calendar{border:1px solid var(--border);background:#fff;border-radius:12px;flex:1;padding:20px 22px}.planner-month-nav{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.planner-month-title{color:var(--text-h);letter-spacing:-.3px;font-size:17px;font-weight:700}.planner-nav-btn{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text-h);background:#fff;border-radius:8px;justify-content:center;align-items:center;font-family:inherit;font-size:18px;transition:background .12s;display:flex}.planner-nav-btn:hover{background:var(--bg-s)}.planner-weekdays{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.planner-weekday{text-align:center;text-transform:uppercase;letter-spacing:.5px;color:var(--text);padding:6px 0;font-size:11px;font-weight:700}.planner-weekday.weekend{color:#ef4444}.planner-days{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.planner-day-blank{min-height:56px}.planner-day{cursor:pointer;background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;min-height:56px;padding:8px 4px 6px;font-family:inherit;transition:background .12s;display:flex}.planner-day:hover{background:#eff6ff}.planner-day--today{background:#111827!important}.planner-day--today .planner-day-num{color:#fff}.planner-day--past .planner-day-num{color:var(--text)}.planner-day--weekend .planner-day-num{color:#ef4444}.planner-day-num{color:var(--text-h);margin-bottom:4px;font-size:14px;font-weight:600;line-height:1}.planner-day-dots{flex-wrap:wrap;justify-content:center;align-items:center;gap:3px;display:flex}.planner-dot{background:#3b82f6;border-radius:50%;flex-shrink:0;width:6px;height:6px}.planner-dot-more{color:#3b82f6;font-size:9px;font-weight:700;line-height:1}.planner-legend{border-top:1px solid var(--border);color:var(--text);flex-wrap:wrap;align-items:center;gap:18px;margin-top:16px;padding-top:12px;font-size:12px;display:flex}.planner-legend>span{align-items:center;gap:5px;display:flex}.planner-legend-today{background:#111827;border-radius:5px;width:18px;height:18px;display:inline-block}.planner-legend-weekend{color:#ef4444;font-weight:600}.planner-modal{max-width:480px}.planner-modal-header-text{flex-direction:column;gap:2px;min-width:0;display:flex}.planner-modal-subtitle{text-transform:uppercase;letter-spacing:.5px;color:var(--text);font-size:11px;font-weight:600}.planner-modal-header-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.planner-note-view-title{color:var(--text-h);margin:0 0 8px;font-size:17px;font-weight:700}.planner-note-view-time{color:var(--text);margin:0 0 12px;font-size:13px}.planner-note-view-content{color:var(--text-h);white-space:pre-wrap;word-break:break-word;margin:0;font-size:14px;line-height:1.65}.planner-note-view-empty{color:var(--text);margin:0;font-size:14px;font-style:italic}@media (width<=600px){.planner-modal{max-width:100%}.planner-modal-header-actions .btn-edit,.planner-modal-header-actions .btn-delete{padding:5px 8px;font-size:12px}}@media (width<=768px){.planner-layout{flex-direction:column}.planner-sidebar{width:100%;max-height:280px}.planner-day{min-height:44px;padding:6px 2px 4px}.planner-day-num{font-size:12px}}
