:root{--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--blue-900: #1e3a8a;--navy-950: #0b1530;--navy-900: #111d3e;--navy-800: #1a2a55;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-900: #0f172a;--green-100: #dcfce7;--green-600: #16a34a;--red-100: #fee2e2;--red-600: #dc2626;--amber-100: #fef3c7;--amber-600: #d97706;--radius: 14px;--radius-sm: 10px;--shadow: 0 1px 2px rgba(15, 23, 42, .06), 0 8px 24px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .18);--sidebar-w: 248px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--glass-bg: rgba(255, 255, 255, .72);--glass-border: rgba(255, 255, 255, .55);--glass-blur: blur(14px);--ease-out: cubic-bezier(.22, 1, .36, 1);--transition-fast: .18s var(--ease-out);--transition-med: .32s var(--ease-out)}.lang-switch{position:relative}.lang-switch__btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--gray-200);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);cursor:pointer;font:inherit;font-size:13px;color:var(--gray-700);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.lang-switch__btn:hover{border-color:var(--blue-200);box-shadow:var(--shadow)}.lang-switch__flag{display:inline-flex;align-items:center;line-height:1;flex-shrink:0}.flag-icon{display:block;border-radius:2px;box-shadow:0 0 0 1px #0f172a14}.lang-switch__label{font-weight:600}.lang-switch__menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:8px;z-index:120}.lang-switch__menu-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-400);padding:6px 10px 8px}.lang-switch__option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;font:inherit;font-size:14px;color:var(--gray-700);text-align:left}.lang-switch__option:hover,.lang-switch__option.active{background:var(--blue-50);color:var(--blue-700)}.auth__lang{position:absolute;top:20px;right:20px;z-index:10}.vessel-panel{margin-top:20px}.vessel-events{display:grid;gap:12px}.vessel-event{padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--gray-200);background:#ffffff8c}.vessel-event--high{border-left:4px solid var(--red-600)}.vessel-event--medium{border-left:4px solid var(--amber-600)}.vessel-event--low{border-left:4px solid var(--blue-500)}.vessel-event__head{display:flex;justify-content:space-between;align-items:center;gap:10px}*{box-sizing:border-box;margin:0;padding:0}html{min-height:100%;scroll-behavior:smooth}body,#root{min-height:100vh}body{font-family:var(--font);font-size:14px;color:var(--gray-900);background:radial-gradient(ellipse 80% 60% at 10% -10%,rgba(37,99,235,.12),transparent 55%),radial-gradient(ellipse 60% 50% at 90% 0%,rgba(124,58,237,.08),transparent 50%),linear-gradient(160deg,#eef2ff,#f8fafc 40%,#f1f5f9);-webkit-font-smoothing:antialiased}a{color:var(--blue-600);text-decoration:none}a:hover{text-decoration:underline}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#0b1530f5,#111d3eeb);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-right:1px solid rgba(255,255,255,.06);color:#fff;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:30;padding:20px 14px}.sidebar__logo{display:block;padding:4px 10px 20px}.sidebar__logo img{height:30px;display:block}.sidebar__section{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff6;padding:18px 12px 6px}.sidebar__link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:#ffffffbf;font-weight:500;margin-bottom:2px;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.sidebar__link:hover{background:#ffffff1a;color:#fff;text-decoration:none;transform:translate(2px)}.sidebar__link.active{background:#2563ebd9;color:#fff;box-shadow:0 4px 16px #2563eb59}.sidebar__link svg{width:18px;height:18px;flex-shrink:0}.sidebar__footer{margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}.topbar{height:64px;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid rgba(226,232,240,.7);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:20}.topbar__title{font-size:17px;font-weight:600}.topbar__actions{display:flex;align-items:center;gap:16px}.avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-100);color:var(--blue-700);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #2563eb26}.avatar--img{object-fit:cover;padding:0;background:var(--gray-100)}.content{padding:28px 32px 40px;max-width:1360px;width:100%;margin:0 auto;position:relative}.content:before{content:"";position:absolute;inset:0 0 auto 0;height:220px;background:linear-gradient(180deg,rgba(37,99,235,.06) 0%,transparent 100%);pointer-events:none;border-radius:0 0 24px 24px}.content--fade{animation:fadeSlideIn var(--transition-med) both}@keyframes fadeSlideIn{0%{opacity:0}to{opacity:1}}.bell{position:relative}.bell__btn{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.6);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-600);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.bell__btn:hover{background:#ffffffe6;box-shadow:0 4px 14px #2563eb26;transform:scale(1.04)}.bell__badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:var(--red-600);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px}.bell__dropdown{position:absolute;right:0;top:48px;width:360px;max-height:440px;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--glass-border);overflow:hidden auto;z-index:50;animation:dropdownIn var(--transition-med) both}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.bell__header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--gray-100);font-weight:600}.notif-item{display:block;padding:12px 16px;border-bottom:1px solid var(--gray-100);cursor:pointer}.notif-item:hover{background:var(--gray-50)}.notif-item--unread{background:var(--blue-50)}.notif-item__title{font-weight:600;font-size:13px}.notif-item__msg{color:var(--gray-500);font-size:13px;margin-top:2px}.notif-item__time{color:var(--gray-400);font-size:11px;margin-top:4px}.card{background:linear-gradient(145deg,#ffffffe0,#f8fafcc7);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;position:relative;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 1px #ffffffa6}.card:hover{box-shadow:0 12px 36px #2563eb1a;border-color:#bfdbfea6;transform:translateY(-1px)}.card--accent{border-top:3px solid var(--blue-600)}.card--form{background:linear-gradient(160deg,#fffffff0,#eff6ffb8)}.card--result{background:linear-gradient(160deg,#fffffff5,#f0fdf480);border-color:#bbf7d080}.card+.card{margin-top:20px}.card__title{font-size:15px;font-weight:600;margin-bottom:16px}.grid{display:grid;gap:20px}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1100px){.grid--4{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:1fr}}@media (max-width: 760px){.grid--2,.grid--4{grid-template-columns:1fr}}.stat{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;display:flex;flex-direction:column;gap:6px;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat:hover{transform:translateY(-2px);box-shadow:0 12px 28px #0f172a1a}.stat__label{color:var(--gray-500);font-size:13px;font-weight:500}.stat__value{font-size:26px;font-weight:700;letter-spacing:-.02em}.stat__hint{font-size:12px;color:var(--gray-400)}.stat--accent{border-top:3px solid var(--blue-600)}.stat--danger .stat__value{color:var(--red-600)}.stat--success .stat__value{color:var(--green-600)}.field{margin-bottom:14px}.field label{display:block;font-weight:500;font-size:13px;margin-bottom:6px;color:var(--gray-700)}.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;background:#fff;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-100)}.form-row{display:flex;gap:14px}.form-row>.field{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);border:1px solid transparent;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;box-shadow:0 4px 14px #2563eb59}.btn--primary:hover{background:linear-gradient(135deg,var(--blue-700),#1e40af);box-shadow:0 6px 20px #2563eb73;transform:translateY(-1px)}.btn--ghost{background:var(--glass-bg);border-color:#cbd5e1cc;color:var(--gray-700);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.btn--ghost:hover{background:#ffffffeb;box-shadow:0 4px 12px #0f172a0f}.btn--danger{background:var(--red-600);color:#fff}.btn--sm{padding:6px 12px;font-size:13px}.alert{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:13px}.alert--error{background:var(--red-100);color:var(--red-600)}.alert--success{background:var(--green-100);color:var(--green-600)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);padding:10px 12px;border-bottom:1px solid var(--gray-200)}.table td{padding:12px;border-bottom:1px solid var(--gray-100);vertical-align:middle}.table tr:hover td{background:var(--gray-50)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge--blue{background:var(--blue-100);color:var(--blue-700)}.badge--green{background:var(--green-100);color:var(--green-600)}.badge--red{background:var(--red-100);color:var(--red-600)}.badge--amber{background:var(--amber-100);color:var(--amber-600)}.badge--gray{background:var(--gray-100);color:var(--gray-600)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b153073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:max(20px,4vh) 20px;overflow-y:auto;overscroll-behavior:contain;animation:fadeIn .2s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:min(90vh,calc(100vh - 40px));overflow-y:auto;padding:24px;margin:auto;flex-shrink:0;animation:modalIn var(--transition-med) both}@keyframes modalIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal--lg{max-width:680px}.modal--xl{max-width:860px}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--gray-100)}.modal__title{font-size:18px;font-weight:700;margin:0}.modal__close{width:32px;height:32px;border:none;border-radius:8px;background:var(--gray-100);color:var(--gray-600);font-size:22px;line-height:1;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.modal__close:hover{background:var(--red-100);color:var(--red-600)}.modal__body{padding-top:4px}.modal__footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--gray-100)}.modal__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.data-table{display:flex;flex-direction:column;gap:12px}.data-table__toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.data-table__search{flex:1;min-width:200px;max-width:320px;padding:10px 14px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font:inherit;font-size:14px;background:#ffffffe6;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.data-table__search:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-100)}.data-table__count{font-size:12px}.data-table__wrap{border:1px solid var(--gray-200);border-radius:var(--radius-sm);overflow:hidden;background:#ffffff8c}.data-table__table{margin:0}.data-table__table th{background:linear-gradient(180deg,var(--gray-50),rgba(241,245,249,.9));position:sticky;top:0;z-index:1}.data-table__th--sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table__th--sortable:hover{color:var(--blue-700);background:var(--blue-50)}.data-table__sort{margin-left:6px;font-size:10px;color:var(--blue-600)}.data-table__pager{display:flex;align-items:center;justify-content:flex-end;gap:12px;font-size:13px}.export-menu{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.export-menu__pdf{box-shadow:0 4px 14px #2563eb4d}.form-section{margin-top:18px;padding:16px;border-radius:var(--radius-sm);background:#eff6ff73;border:1px solid rgba(191,219,254,.5)}.form-section__title{font-size:13px;font-weight:700;color:var(--blue-700);margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em}.result-highlight{display:grid;gap:10px;padding:16px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#eff6ffb3,#ffffffe6);border:1px solid var(--blue-100);margin-bottom:14px}.result-highlight__row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:14px}.result-highlight__amount{font-size:22px;font-weight:700;color:var(--navy-900)}.search-select{position:relative;width:100%}.search-select__trigger{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;font:inherit;font-size:14px;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-select__trigger:hover,.search-select__trigger:focus-visible{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-100)}.search-select__trigger--placeholder .search-select__value{color:var(--gray-400)}.search-select__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-select__dropdown{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);overflow:hidden;animation:dropdownIn var(--transition-med) both}.search-select__dropdown--fixed{position:fixed;z-index:1100}.search-select__search{width:100%;padding:10px 12px;border:none;border-bottom:1px solid var(--gray-100);font:inherit;font-size:14px}.search-select__search:focus{outline:none;background:var(--blue-50)}.search-select__list{max-height:240px;overflow-y:auto}.search-select__option{display:block;width:100%;padding:10px 12px;border:none;background:transparent;text-align:left;font:inherit;font-size:13px;color:var(--gray-700);cursor:pointer}.search-select__option:hover,.search-select__option.active{background:var(--blue-50);color:var(--blue-700)}.search-select__empty{padding:20px 12px;text-align:center;color:var(--gray-400);font-size:13px}.search-select__pager{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-top:1px solid var(--gray-100);font-size:12px}.auth{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.auth__brand{background:linear-gradient(150deg,var(--navy-950),var(--blue-900));color:#fff;display:flex;flex-direction:column;justify-content:center;padding:64px}.auth__brand img{height:44px;align-self:flex-start;margin-bottom:32px}.auth__brand h1{font-size:30px;line-height:1.25;font-weight:700;max-width:420px}.auth__brand p{margin-top:14px;color:var(--blue-200);max-width:400px;line-height:1.6}.auth__panel{display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.auth__form{width:100%;max-width:380px}.auth__form h2{font-size:22px;font-weight:700;margin-bottom:6px}.auth__form>p{color:var(--gray-500);margin-bottom:24px}@media (max-width: 900px){.auth{grid-template-columns:1fr}.auth__brand{display:none}}.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:16px;flex-wrap:wrap;position:relative;z-index:1;padding-bottom:14px;border-bottom:1px solid rgba(226,232,240,.8)}.page-head:after{content:"";position:absolute;left:0;bottom:-1px;width:120px;height:3px;border-radius:99px;background:linear-gradient(90deg,var(--blue-600),#7c3aed)}.page-head h1{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--navy-900)}.page-head__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.muted{color:var(--gray-500)}.empty{text-align:center;color:var(--gray-400);padding:48px 20px}.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:40px 20px}.loader--full{min-height:60vh}.loader__ring{width:40px;height:40px;border:3px solid rgba(37,99,235,.15);border-top-color:var(--blue-600);border-radius:50%;animation:spin .75s linear infinite;box-shadow:0 0 20px #2563eb33}.loader__label{font-size:13px;font-weight:500;color:var(--gray-500);animation:pulse 1.5s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.55}50%{opacity:1}}.toast-stack{position:fixed;top:18px;right:18px;z-index:200;display:flex;flex-direction:column;gap:10px;max-width:min(380px,calc(100vw - 36px));pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);font-size:13px;line-height:1.45}.toast--enter{animation:toastIn var(--transition-med) both}@keyframes toastIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.toast--success{border-left:3px solid var(--green-600)}.toast--error{border-left:3px solid var(--red-600)}.toast--info{border-left:3px solid var(--blue-600)}.toast--warning{border-left:3px solid var(--amber-600)}.toast__icon{font-weight:700;flex-shrink:0;width:18px;text-align:center}.toast__msg{flex:1;color:var(--gray-700)}.toast__close{border:none;background:none;color:var(--gray-400);cursor:pointer;font-size:18px;line-height:1;padding:0 2px}.toast__close:hover{color:var(--gray-700)}html.modal-open{overflow:hidden}html.modal-open body{overflow:hidden;touch-action:none}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--gray-200);margin-bottom:20px;flex-wrap:wrap}.tabs--sub{margin-top:16px;padding:4px;background:#eff6ff8c;border:1px solid rgba(191,219,254,.45);border-radius:var(--radius-sm);border-bottom:none}.tabs--sub button{border-radius:8px;border-bottom:none;margin-bottom:0;padding:8px 14px;font-size:13px}.tabs--sub button.active{background:#fff;box-shadow:0 2px 8px #2563eb1f;border-bottom:none}.tabs button{padding:10px 16px;border:none;background:none;font-family:inherit;font-size:14px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tabs button.active{color:var(--blue-600);border-bottom-color:var(--blue-600)}.chart-bars{display:flex;align-items:flex-end;gap:10px;height:180px;padding-top:10px}.chart-bars__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end;min-width:0}.chart-bars__bar{width:100%;max-width:52px;background:var(--blue-500);border-radius:8px 8px 2px 2px;min-height:4px;transition:height .5s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #2563eb40}.chart-bars__label{font-size:11px;color:var(--gray-500);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chart-bars__value{font-size:11px;font-weight:600;color:var(--gray-700)}.donut-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.legend{display:flex;flex-direction:column;gap:8px}.legend__item{display:flex;align-items:center;gap:8px;font-size:13px}.legend__dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.gauge{display:flex;flex-direction:column;align-items:center;gap:12px}.gauge__svg{width:100%;max-width:220px;height:auto}.gauge__stats{display:flex;gap:32px;font-size:13px}.gauge__stats div{display:flex;flex-direction:column;align-items:center;gap:2px}.gauge__stats strong{font-size:18px;color:var(--gray-900)}.h-bars{display:flex;flex-direction:column;gap:10px}.h-bars__row{display:grid;grid-template-columns:90px 1fr 52px;align-items:center;gap:10px}.h-bars__label{font-size:12px;color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.h-bars__track{height:10px;background:var(--gray-100);border-radius:99px;overflow:hidden}.h-bars__fill{height:100%;border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1);min-width:4px}.h-bars__value{font-size:12px;font-weight:600;text-align:right;color:var(--gray-700)}.grouped-bars__legend,.stacked-bars__legend,.area-chart__legend{display:flex;gap:16px;margin-bottom:12px;font-size:12px;color:var(--gray-600)}.grouped-bars__legend span,.stacked-bars__legend span,.area-chart__legend span{display:flex;align-items:center;gap:6px}.grouped-bars__legend i,.stacked-bars__legend i,.area-chart__legend i{display:inline-block;width:10px;height:10px;border-radius:3px}.grouped-bars__grid{display:flex;align-items:flex-end;gap:8px;height:160px}.grouped-bars__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end;min-width:0}.grouped-bars__pair{display:flex;align-items:flex-end;gap:3px;height:130px;width:100%;justify-content:center}.grouped-bars__bar{width:14px;border-radius:4px 4px 0 0;min-height:3px;transition:height .5s ease}.grouped-bars__bar--light{background:#93c5fd}.grouped-bars__bar--dark{background:#2563eb}.grouped-bars__label{font-size:10px;color:var(--gray-500);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stacked-bars__grid{display:flex;align-items:flex-end;gap:10px;height:170px}.stacked-bars__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%;justify-content:flex-end;min-width:0}.stacked-bars__stack{display:flex;flex-direction:column;width:100%;max-width:44px;border-radius:6px 6px 2px 2px;overflow:hidden;min-height:4px;transition:height .5s ease}.stacked-bars__seg{min-height:2px}.stacked-bars__seg--dem{background:linear-gradient(180deg,#f87171,#dc2626)}.stacked-bars__seg--des{background:linear-gradient(180deg,#4ade80,#16a34a)}.stacked-bars__total{font-size:10px;font-weight:600;color:var(--gray-600)}.stacked-bars__label{font-size:11px;color:var(--gray-500)}.area-chart__svg{width:100%;height:auto;display:block}.sparkline{display:block;opacity:.85}.charts-section{margin-top:20px}.charts-section__title{font-size:13px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--gray-200)}.chart-card{position:relative;overflow:hidden}.chart-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-500),#7c3aed);border-radius:var(--radius) var(--radius) 0 0}.chart-card .card__title{padding-top:4px}.chart-empty{padding:32px;text-align:center;color:var(--gray-400);font-size:13px}
