*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f7f2eb;--color-bg-elevated: #fbf8f3;--color-surface: #fffdf8;--color-surface-strong: #ffffff;--color-text: #28221d;--color-text-secondary: #6f6256;--color-text-muted: #9d8f82;--color-border: #e7ded2;--color-border-strong: #d7cabb;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-soft: #eaf1ff;--color-success: #0f9f7f;--color-success-soft: #e6f7f2;--color-danger: #e85d3f;--color-danger-soft: #fff0eb;--color-warning: #d89b17;--color-warning-soft: #fff6da;--color-transfer: #7c5cdb;--color-transfer-soft: #f0ebff;--color-sidebar: #fff9f0;--radius-sm: 4px;--radius: 8px;--shadow-sm: 0 1px 2px rgba(64, 47, 30, .06);--shadow: 0 12px 30px rgba(64, 47, 30, .08);--shadow-lg: 0 24px 60px rgba(54, 42, 30, .16);--transition: .16s ease;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background:var(--color-bg)}body{min-height:100vh}button,input,select,textarea{font:inherit}button{border:0}.app-shell{display:flex;min-height:100vh;background:linear-gradient(180deg,#fffdf8e6,#f7f2eb00),var(--color-bg)}.app-shell__main{flex:1;min-width:0;min-height:100vh;margin-left:260px;padding:28px 36px 40px}.app-shell__overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:#231b156b;animation:overlay-fade-in .2s ease}.app-state,.state{display:flex;align-items:center;justify-content:center;min-height:180px;padding:32px 20px;color:var(--color-text-secondary);font-weight:600;text-align:center}.app-state--loading{min-height:100vh}.state--empty{border:1px dashed var(--color-border-strong);border-radius:var(--radius);background:#fffdf8b3}.sidebar{position:fixed;inset:0 auto 0 0;z-index:100;display:flex;width:260px;flex-direction:column;border-right:1px solid var(--color-border);background:var(--color-sidebar);box-shadow:10px 0 30px #402f1e0d}.sidebar__brand{display:flex;align-items:center;gap:12px;padding:24px 20px 22px}.sidebar__brand-icon{display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius);background:linear-gradient(135deg,#f2ba4a,#e85d3f);color:#fff;font-size:22px;font-weight:800;box-shadow:0 12px 28px #e85d3f3d}.sidebar__brand-text{max-width:145px;color:var(--color-text);font-size:15px;font-weight:800;line-height:1.2}.sidebar__nav{display:flex;flex:1;flex-direction:column;gap:6px;padding:0 12px}.sidebar__nav-link{position:relative;display:flex;align-items:center;gap:11px;min-height:44px;padding:10px 12px;border-radius:var(--radius);color:var(--color-text-secondary);font-weight:700;text-decoration:none;transition:background var(--transition),color var(--transition),box-shadow var(--transition)}.sidebar__nav-link svg{flex:0 0 auto}.sidebar__nav-link:hover{background:#ffffffb8;color:var(--color-text)}.sidebar__nav-link--active{background:var(--color-surface-strong);color:var(--color-primary);box-shadow:var(--shadow-sm)}.sidebar__nav-link--active:before{position:absolute;left:-4px;width:3px;height:22px;border-radius:99px;background:var(--color-primary);content:""}.sidebar__footer{display:flex;flex-direction:column;gap:12px;margin:12px;padding:14px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fffdf8c7}.sidebar__user-row,.sidebar__meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.sidebar__user{min-width:0;overflow:hidden;color:var(--color-text);font-size:13px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.sidebar__logout{flex:0 0 auto;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:13px;font-weight:700;padding:5px 8px;transition:background var(--transition),color var(--transition)}.sidebar__logout:hover{background:var(--color-danger-soft);color:var(--color-danger)}.sidebar__version,.sidebar__copyright{color:var(--color-text-muted);font-size:10px}.sidebar__version{font-family:ui-monospace,SFMono-Regular,Consolas,monospace}.menu-button{display:none;position:fixed;top:12px;left:12px;z-index:101;width:44px;height:44px;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--color-text);color:#fff;cursor:pointer;box-shadow:var(--shadow)}.page{width:min(100%,1240px);margin:0 auto}.page__header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px}.page__eyebrow{margin-bottom:4px;color:var(--color-text-muted);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.page__title{color:var(--color-text);font-size:28px;font-weight:850;line-height:1.15}.muted-text{color:var(--color-text-muted)}.field{display:flex;min-width:148px;flex-direction:column;gap:6px}.field--wide{flex:1 1 260px}.field--period{min-width:380px}.field--checkbox{min-width:auto;justify-content:flex-end;padding-bottom:4px}.field label{color:var(--color-text-secondary);font-size:12px;font-weight:800}.field--checkbox label{display:flex;align-items:center;gap:8px;color:var(--color-text);cursor:pointer;font-size:14px;font-weight:700}input[type=text],input[type=password],input[type=number],input[type=date],input[type=email],select,textarea{width:100%;min-height:40px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-strong);color:var(--color-text);padding:8px 11px;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}textarea{min-height:84px;resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #2563eb21}input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:9px 16px;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;font-weight:800;line-height:1;text-decoration:none;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition)}.button:hover:not(:disabled){transform:translateY(-1px)}.button:disabled{cursor:not-allowed;opacity:.6}.button--primary{background:var(--color-primary);color:#fff;box-shadow:0 12px 24px #2563eb38}.button--primary:hover:not(:disabled){background:var(--color-primary-hover)}.button--secondary{border-color:var(--color-border);background:var(--color-surface-strong);color:var(--color-text)}.button--secondary:hover:not(:disabled){border-color:var(--color-border-strong);background:var(--color-bg-elevated)}.button--danger{background:var(--color-danger);color:#fff;box-shadow:0 12px 24px #e85d3f2e}.button--small{min-height:34px;padding:7px 11px;font-size:13px}.button--block{width:100%}.button__icon{flex:0 0 auto}.button-group{display:flex;flex-wrap:wrap;gap:8px}.icon-button{display:inline-flex;width:40px;height:40px;flex:0 0 auto;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-strong);color:var(--color-text-secondary);cursor:pointer;font-weight:850;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition)}.icon-button:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary)}.icon-button:disabled{cursor:not-allowed;opacity:.45}.icon-button--touch{width:44px;height:44px}.segmented-control{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--color-border);border-radius:var(--radius);background:#ffffff9e}.segmented-control--compact{width:max-content}.segmented-control__button{min-height:32px;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:13px;font-weight:800;padding:6px 11px;transition:background var(--transition),color var(--transition),box-shadow var(--transition)}.segmented-control__button:hover{color:var(--color-text)}.segmented-control__button--active{background:var(--color-surface-strong);color:var(--color-primary);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;min-height:24px;align-items:center;justify-content:center;border-radius:999px;font-size:12px;font-weight:850;padding:3px 9px}.badge--warning{background:var(--color-warning-soft);color:#9b6b08}.badge--expense{background:var(--color-danger-soft);color:var(--color-danger)}.badge--income{background:var(--color-success-soft);color:var(--color-success)}.badge--transfer{background:var(--color-transfer-soft);color:var(--color-transfer)}.alert{border-radius:var(--radius);font-weight:700;padding:11px 13px}.alert--error{border:1px solid #ffd0c4;background:var(--color-danger-soft);color:#b8321f}.form-divider{height:1px;background:var(--color-border);margin:4px 0}.login{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(120deg,rgba(37,99,235,.08),transparent 42%),linear-gradient(300deg,rgba(232,93,63,.12),transparent 48%),var(--color-bg)}.login__panel{width:min(100%,420px);border:1px solid rgba(231,222,210,.88);border-radius:var(--radius);background:#fffdf8eb;box-shadow:var(--shadow-lg);padding:38px}.login__header{margin-bottom:28px;text-align:center}.login__icon{display:inline-flex;width:58px;height:58px;align-items:center;justify-content:center;margin-bottom:14px;border-radius:var(--radius);background:linear-gradient(135deg,#f2ba4a,#e85d3f);color:#fff;font-size:30px;font-weight:900;box-shadow:0 18px 34px #e85d3f38}.login__header h1{font-size:24px;font-weight:850}.login__header p{color:var(--color-text-secondary);margin-top:4px}.login__form{display:flex;flex-direction:column;gap:16px}.filters,.analytics-panel{display:flex;flex-direction:column;gap:14px;margin-bottom:20px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fffdf8d1;box-shadow:var(--shadow-sm);padding:16px}.filters__row,.analytics-panel__filters{display:flex;align-items:flex-end;flex-wrap:wrap;gap:12px}.filters__date-control,.filters__dates,.filters__sort,.period-picker,.period-picker__nav,.period-picker__dates{display:flex;align-items:center;gap:8px}.filters__dates input,.period-picker__dates input{width:142px}.filters__separator,.period-picker__separator{color:var(--color-text-muted);font-weight:800}.filters__sort select{min-width:128px}.period-picker{justify-content:space-between;flex-wrap:wrap}.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:20px}.summary__card{position:relative;min-height:116px;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-strong);box-shadow:var(--shadow-sm);padding:18px}.summary__card:before{position:absolute;inset:0 auto 0 0;width:5px;background:var(--color-border-strong);content:""}.summary__card--income:before,.summary__card--positive:before{background:var(--color-success)}.summary__card--expense:before,.summary__card--negative:before{background:var(--color-danger)}.summary__card--investments:before{background:var(--color-warning)}.summary__card--top:before{background:var(--color-primary)}.summary__label{margin-bottom:6px;color:var(--color-text-secondary);font-size:12px;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.summary__value{font-size:24px;font-variant-numeric:tabular-nums;font-weight:900;letter-spacing:0}.summary__subvalue{margin-top:8px;color:var(--color-text-secondary);font-size:12px;font-weight:700}.summary__top-list{display:flex;flex-direction:column;gap:7px}.summary__top-item{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;font-size:13px}.summary__top-name{min-width:0;overflow:hidden;color:var(--color-text);font-weight:700;text-overflow:ellipsis;white-space:nowrap}.summary__top-amount{font-variant-numeric:tabular-nums;font-weight:850}.summary__top-share{color:var(--color-text-muted);font-size:12px;font-weight:800}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.chart-card{min-width:0;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-strong);box-shadow:var(--shadow-sm);padding:20px}.chart-card h3{margin-bottom:14px;font-size:16px;font-weight:850}.category-chart{display:flex;flex-direction:column;gap:16px}.category-chart__table{width:100%;border-collapse:collapse}.category-chart__table th,.category-chart__table td{border-bottom:1px solid var(--color-border);padding:7px 9px;text-align:left}.category-chart__table th{color:var(--color-text-secondary);font-size:12px;font-weight:850}.category-chart__cell--center{text-align:center!important}.category-chart__dot{display:inline-block;width:10px;height:10px;margin-right:7px;border-radius:50%;vertical-align:middle}.table-shell{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-strong);box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid var(--color-border);padding:11px 14px;text-align:left;vertical-align:middle}.data-table th,.data-table__head-cell{color:var(--color-text-secondary);font-size:12px;font-weight:850;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:#f7f2ebb8}.data-table tbody tr:last-child td{border-bottom:0}.data-table__row--unconfirmed{background:var(--color-warning-soft)}.data-table__row--inactive{opacity:.54}.data-table__cell--center,.data-table__head-cell--center{text-align:center!important}.data-table__cell--nowrap{white-space:nowrap}.data-table__cell--description{max-width:340px}.data-table__description{word-break:break-word}.data-table__subtext{margin-top:2px;color:var(--color-text-secondary);font-size:12px;font-weight:600}.money-amount{font-variant-numeric:tabular-nums;font-weight:850}.money-amount--income{color:var(--color-success)}.money-amount--expense{color:var(--color-danger)}.money-amount--transfer{color:var(--color-transfer)}.comment-indicator{display:inline-flex;margin-left:6px;color:var(--color-text-muted);cursor:help;vertical-align:middle}.transaction-list{display:none}.transaction-card{border:1px solid var(--color-border);border-left:5px solid var(--color-border-strong);border-radius:var(--radius);background:var(--color-surface-strong);box-shadow:var(--shadow-sm);padding:14px}.transaction-card--unconfirmed{border-left-color:var(--color-warning);background:var(--color-warning-soft)}.transaction-card__header,.transaction-card__footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.transaction-card__date,.transaction-card__meta,.transaction-card__commission{color:var(--color-text-secondary);font-size:12px;font-weight:700}.transaction-card__amount{flex:0 0 auto;font-size:17px}.transaction-card__body{margin:8px 0 10px;color:var(--color-text);font-weight:700;word-break:break-word}.transaction-card__actions{display:flex;align-items:center;gap:6px}.pagination{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:12px}.pagination__info,.pagination__current{color:var(--color-text-secondary);font-size:13px;font-weight:700}.pagination__controls{display:flex;align-items:center;gap:8px}.pagination__size{width:auto;min-height:40px}.pagination__current{min-width:64px;text-align:center}.tabs{display:inline-flex;max-width:100%;gap:4px;margin-bottom:12px;overflow-x:auto;padding:4px;border:1px solid var(--color-border);border-radius:var(--radius);background:#ffffff9e;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabs__button{min-height:36px;flex:0 0 auto;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-weight:850;padding:8px 14px}.tabs__button--active{background:var(--color-surface-strong);color:var(--color-primary);box-shadow:var(--shadow-sm)}.tabs__content{overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-strong);box-shadow:var(--shadow-sm)}.settings-section{overflow-x:auto}.data-section{display:flex;flex-direction:column;gap:24px;padding:22px}.data-section__block h3{margin-bottom:6px;font-size:16px;font-weight:850}.data-section__description{max-width:560px;margin-bottom:14px;color:var(--color-text-secondary)}.switch-button{min-height:28px;border-radius:999px;cursor:pointer;font-size:12px;font-weight:850;padding:5px 11px}.switch-button--on{background:var(--color-success-soft);color:var(--color-success)}.switch-button--off{background:var(--color-bg);color:var(--color-text-muted)}.rules-list__actions{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.rules-list__result{color:var(--color-success);font-size:12px;font-weight:850;white-space:nowrap}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;background:#231b1570}.modal{width:min(100%,540px);max-height:90vh;overflow-y:auto;border-radius:var(--radius);background:var(--color-surface-strong);box-shadow:var(--shadow-lg)}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px 16px;border-bottom:1px solid var(--color-border)}.modal__header h2{font-size:18px;font-weight:850}.modal__close-button{display:flex;width:44px;height:44px;align-items:center;justify-content:center;margin:-10px -10px -10px 0;border-radius:var(--radius);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:24px;line-height:1}.modal__close-button:hover{background:var(--color-bg);color:var(--color-text)}.modal__body{display:flex;flex-direction:column;gap:14px;padding:20px 22px}.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px 20px;border-top:1px solid var(--color-border)}.transaction-preview{display:flex;flex-direction:column;gap:8px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-elevated);padding:12px 14px}.transaction-preview__row{display:flex;gap:12px;font-size:13px}.transaction-preview__label{width:84px;flex:0 0 auto;color:var(--color-text-secondary);font-weight:800}.transaction-preview__description{word-break:break-word}.import-upload{display:grid;gap:14px;justify-items:center;padding:18px 0;text-align:center}.import-upload p{color:var(--color-text-secondary)}.import-upload__input{border:0;min-height:auto;padding:0}.import-upload__loading{color:var(--color-primary);font-weight:850}.import-result{text-align:center}.import-result__icon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;margin-bottom:12px;border-radius:50%;background:var(--color-success-soft);color:var(--color-success);font-size:24px;font-weight:900}.import-result h3{margin-bottom:14px;font-size:17px;font-weight:850}.import-result__stats{width:100%;border-collapse:collapse;text-align:left}.import-result__stats td{border-bottom:1px solid var(--color-border);padding:7px 10px}.import-result__stats td:first-child{color:var(--color-text-secondary)}.import-result__stats td:last-child{font-variant-numeric:tabular-nums;font-weight:850;text-align:right}.import-result__alias{margin-top:16px;text-align:left}.import-result__alias label{display:block;margin-bottom:6px;color:var(--color-text-secondary);font-size:12px;font-weight:850}.import-result__alias-row{display:flex;gap:8px}.import-result__alias-saved{margin-top:12px;color:var(--color-success);font-weight:850}.danger-note{border:1px solid #ffd0c4;border-radius:var(--radius);background:var(--color-danger-soft);color:#9f2d1c;font-weight:800;padding:12px 14px}.danger-note__check{padding-bottom:0}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}@keyframes drawer-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}@media(max-width:1024px){.analytics-grid{grid-template-columns:1fr}}@media(max-width:768px){.menu-button{display:flex}.app-shell__overlay{display:block}.sidebar{width:min(290px,86vw);transform:translate(-100%);transition:transform .25s ease}.sidebar--open{transform:translate(0);animation:drawer-slide-in .25s ease}.app-shell__main{margin-left:0;padding:18px 16px 28px 64px}.page__header{align-items:stretch;flex-direction:column}.page__header .button{width:100%}.filters__row,.analytics-panel__filters{align-items:stretch;flex-direction:column}.field,.field--period,.field--wide{min-width:100%}.filters__date-control,.period-picker,.period-picker__nav{align-items:stretch;flex-direction:column}.filters__dates,.period-picker__dates,.filters__dates input,.period-picker__dates input{width:100%}.segmented-control{max-width:100%;overflow-x:auto}.summary{grid-template-columns:1fr}}@media(max-width:600px){.table-shell--desktop{display:none}.transaction-list--mobile{display:flex;flex-direction:column;gap:12px}}@media(max-width:480px){.app-shell__main{padding:16px 14px 24px 62px}.page__title{font-size:23px}.login__panel{padding:28px 22px}.modal-backdrop{align-items:stretch;padding:0}.modal{display:flex;width:100%;max-height:none;min-height:100dvh;flex-direction:column;border-radius:0}.modal__body{flex:1;overflow-y:auto}.modal__footer{flex-wrap:wrap}.modal__footer .button{flex:1 1 150px}.pagination{align-items:stretch;flex-direction:column}.pagination__controls{justify-content:center}.import-result__alias-row{flex-direction:column}}@supports (padding: env(safe-area-inset-bottom)){.menu-button{top:calc(12px + env(safe-area-inset-top));left:calc(12px + env(safe-area-inset-left))}.app-shell__main{padding-bottom:calc(28px + env(safe-area-inset-bottom))}.modal__footer{padding-bottom:calc(20px + env(safe-area-inset-bottom))}}
