@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@600;700;800&display=swap');

:root{--bg:#f7f7f5;--card:#fff;--ink:#20201e;--muted:#7c7d78;--line:#e8e8e4;--soft:#f2f2ef;--accent:#d9ff43;--danger:#c74b4b;--radius:16px;--side:238px;--shadow:0 8px 28px rgba(29,29,27,.055)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:var(--bg);color:var(--ink);font:14px/1.55 'DM Sans',sans-serif;-webkit-font-smoothing:antialiased}button,input,select{font:inherit}button{color:inherit}svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.hidden{display:none!important}.mobile-only{display:none!important}.sprite{position:absolute;width:0;height:0;overflow:hidden}
.logo-box{width:38px;height:38px;display:grid;place-items:center;flex:0 0 auto;border-radius:11px;background:#1f1f1d;color:#fff;font:800 18px 'Manrope',sans-serif}.wordmark,.mobile-wordmark{display:flex;align-items:center;gap:11px}.wordmark strong,.mobile-wordmark strong{font:800 16px 'Manrope',sans-serif;letter-spacing:-.04em}.boot-screen{position:fixed;inset:0;z-index:300;display:grid;place-content:center;justify-items:center;gap:11px;background:var(--bg)}.boot-screen i{width:20px;height:20px;border:2px solid #ddd;border-top-color:#222;border-radius:50%;animation:spin .7s linear infinite}.boot-screen p{margin:0;color:var(--muted);font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}

/* Auth */
.auth-page{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:1.05fr .95fr;background:#fff}.auth-brand{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(32px,5vw,72px);overflow:hidden;background:#1e1e1c;color:#fff}.auth-brand:after{content:'';position:absolute;width:470px;height:470px;right:-210px;bottom:-220px;border:1px solid rgba(255,255,255,.1);border-radius:50%;box-shadow:0 0 0 75px rgba(255,255,255,.025),0 0 0 150px rgba(255,255,255,.02)}.auth-brand .logo-box{background:var(--accent);color:#1c1c1a}.auth-message{position:relative;z-index:1;max-width:610px;margin:auto 0}.auth-message>p{margin:0 0 15px;color:var(--accent);font-weight:700;font-size:11px;letter-spacing:.17em}.auth-message h1{margin:0;font:800 clamp(38px,5vw,66px)/1.07 'Manrope',sans-serif;letter-spacing:-.06em}.auth-message>span{display:block;max-width:480px;margin-top:22px;color:#aaa;font-size:16px}.auth-panel{display:grid;place-items:center;padding:35px;background:linear-gradient(145deg,#fff,#fafaf8)}.auth-card{width:min(410px,100%)}.mobile-wordmark{display:none}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;border-radius:12px;background:var(--soft)}.auth-tabs button{height:40px;border:0;border-radius:9px;background:transparent;color:var(--muted);font-weight:700;cursor:pointer}.auth-tabs button.active{background:#fff;color:var(--ink);box-shadow:0 2px 8px rgba(0,0,0,.06)}.auth-title{margin:35px 0 24px}.auth-title h2{margin:0;font:800 29px 'Manrope',sans-serif;letter-spacing:-.045em}.auth-title p{margin:7px 0 0;color:var(--muted)}.form-field{display:grid;gap:6px;margin-bottom:14px}.form-field label{font-size:12px;font-weight:700}.form-field small{color:#999;font-size:10px}.form-field input,.form-field select{width:100%;height:45px;padding:10px 12px;border:1px solid #dcdcd7;border-radius:10px;background:#fff;outline:none}.form-field input:focus,.form-field select:focus{border-color:#999;box-shadow:0 0 0 3px rgba(0,0,0,.05)}.password-wrap{position:relative}.password-wrap input{padding-right:60px}.password-wrap button{position:absolute;right:7px;top:7px;height:31px;padding:0 8px;border:0;border-radius:7px;background:var(--soft);font-size:10px;font-weight:700;cursor:pointer}.button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 14px;border:1px solid transparent;border-radius:10px;font-weight:700;cursor:pointer;transition:.15s}.button:hover{transform:translateY(-1px)}.button:disabled{opacity:.55;cursor:wait;transform:none}.button.primary{background:#20201e;color:#fff}.button.primary:hover{background:#000}.button.secondary{border-color:#deded9;background:#fff}.button.secondary:hover{background:#f7f7f4}.button.danger{background:var(--danger);color:#fff}.button.wide{width:100%;min-height:46px}.auth-card>.button.secondary{margin-top:10px}.notice{margin-top:15px;padding:10px 12px;border:1px solid #e8e8e2;border-radius:9px;background:#fafaf7;color:#888;font-size:10px}.notice.ready{border-color:#dbe7bd;background:#f8fce9;color:#68763f}

/* Shell */
.app{min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;z-index:50;width:var(--side);display:flex;flex-direction:column;padding:23px 14px 17px;border-right:1px solid var(--line);background:#fff}.sidebar>.wordmark{padding:0 9px 28px}.sidebar nav{display:grid;gap:5px}.nav-button{width:100%;min-height:45px;display:flex;align-items:center;gap:11px;padding:10px 12px;border:0;border-radius:10px;background:transparent;color:#73746f;font-weight:600;text-align:left;cursor:pointer}.nav-button:hover{background:var(--soft);color:var(--ink)}.nav-button.active{background:#20201e;color:#fff}.sidebar-bottom{margin-top:auto}.user-box{display:flex;align-items:center;gap:10px;padding:11px;border:1px solid var(--line);border-radius:11px;background:#fafaf8}.user-box>span{width:32px;height:32px;display:grid;place-items:center;border-radius:9px;background:var(--accent);font-weight:800}.user-box div{min-width:0}.user-box strong,.user-box small{display:block;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-box strong{font-size:11px}.user-box small{color:var(--muted);font-size:9px}.logout-button{width:100%;display:flex;align-items:center;gap:10px;margin-top:6px;padding:10px 12px;border:0;border-radius:9px;background:transparent;color:#8c6969;cursor:pointer}.logout-button:hover{background:#fff2f2}.content-column{min-height:100vh;margin-left:var(--side)}.topbar{position:sticky;top:0;z-index:35;min-height:76px;display:flex;align-items:center;gap:13px;padding:11px clamp(20px,3vw,40px);border-bottom:1px solid var(--line);background:rgba(247,247,245,.9);backdrop-filter:blur(15px)}.topbar h1{margin:0;font:800 20px 'Manrope',sans-serif;letter-spacing:-.04em}.topbar p{margin:2px 0 0;color:var(--muted);font-size:11px}.top-actions{display:flex;align-items:center;gap:9px;margin-left:auto}.sync-badge{display:flex;align-items:center;gap:6px;padding:6px 9px;border:1px solid #e0e5d1;border-radius:99px;background:#fafced;color:#6f7757;font-size:9px}.sync-badge i{width:6px;height:6px;border-radius:50%;background:#82964b}.sync-badge.loading i{animation:pulse .8s infinite;background:#c38b31}.sync-badge.error{border-color:#f0cece;background:#fff4f4;color:#a74b4b}.sync-badge.error i{background:#c74b4b}@keyframes pulse{50%{opacity:.35}}.icon-button{width:38px;height:38px;display:grid;place-items:center;padding:0;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer}main{width:min(1450px,100%);margin:auto;padding:clamp(24px,3vw,40px)}.page{display:none}.page.active{display:block;animation:fade .2s}@keyframes fade{from{opacity:0;transform:translateY(4px)}}

/* Dashboard */
.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:19px}.section-head>div>span,.panel-head>div>span{color:#999;font-size:9px;font-weight:700;letter-spacing:.13em}.section-head h2{margin:3px 0 0;font:800 26px 'Manrope',sans-serif;letter-spacing:-.045em}.summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.summary-grid article{min-height:137px;display:flex;flex-direction:column;padding:17px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}.summary-grid article>span{color:var(--muted);font-size:11px}.summary-grid article>strong{display:block;margin-top:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font:800 clamp(20px,2vw,27px) 'Manrope',sans-serif;letter-spacing:-.05em}.summary-grid article>small{margin-top:auto;color:#a0a19c;font-size:9px}.summary-grid .dark-card{border-color:#20201e;background:#20201e;color:#fff}.summary-grid .dark-card>span,.summary-grid .dark-card>small{color:#aaa}.simple-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.panel,.table-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}.panel{padding:18px}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.panel-head h3{margin:3px 0 0;font:800 16px 'Manrope',sans-serif}.text-button{padding:4px 0;border:0;background:none;color:#686964;font-size:10px;font-weight:700;cursor:pointer;text-decoration:underline}.simple-list{display:grid;margin-top:11px}.list-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.list-row:last-child{border-bottom:0}.item-mark{width:34px;height:34px;display:grid;place-items:center;flex:0 0 auto;border-radius:9px;background:var(--soft);font-weight:800;font-size:10px}.item-copy{min-width:0;flex:1}.item-copy strong,.item-copy span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-copy strong{font-size:11px}.item-copy span{color:var(--muted);font-size:9px}.item-value{text-align:right}.item-value strong,.item-value span{display:block}.item-value strong{font-size:11px}.item-value span{color:var(--muted);font-size:9px}.empty{padding:26px 10px;text-align:center;color:var(--muted);font-size:11px}

/* Tables */
.page-tools{display:flex;align-items:center;gap:9px;margin-bottom:13px}.search{position:relative;width:min(340px,100%)}.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#989994}.search input,.month-input{width:100%;height:42px;padding:9px 12px;border:1px solid #deded9;border-radius:10px;background:#fff;outline:none}.search input{padding-left:39px}.month-input{width:155px;color:#6f706b}.search input:focus,.month-input:focus{border-color:#999;box-shadow:0 0 0 3px rgba(0,0,0,.04)}.table-card{overflow:hidden}.table-title{display:flex;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.table-title h2{margin:0;font:800 15px 'Manrope',sans-serif}.table-title p{margin:2px 0 0;color:var(--muted);font-size:9px}.table-scroll{overflow:auto}table{width:100%;min-width:910px;border-collapse:collapse}th,td{padding:13px 15px;border-bottom:1px solid var(--line);text-align:left}th{background:#fafaf8;color:#92938e;font-size:9px;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap}td{color:#5e5f5a;font-size:11px}tbody tr:last-child td{border-bottom:0}tbody tr:hover td{background:#fdfdfb}.right{text-align:right}.name-cell strong,.name-cell span{display:block}.name-cell strong{color:var(--ink);font-size:11px}.name-cell span{color:var(--muted);font-size:9px}.category{display:inline-flex;padding:4px 7px;border-radius:99px;background:var(--soft);font-size:9px}.actions{display:flex;justify-content:flex-end;gap:3px}.action{width:30px;height:30px;display:grid;place-items:center;border:0;border-radius:8px;background:transparent;color:#888;cursor:pointer}.action:hover{background:var(--soft);color:#222}.action.danger:hover{background:#fff0f0;color:var(--danger)}.action svg{width:15px}.mobile-cards{display:none}.report-totals{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:13px}.report-totals article{padding:15px 17px;border:1px solid var(--line);border-radius:13px;background:#fff}.report-totals span,.report-totals strong{display:block}.report-totals span{color:var(--muted);font-size:9px;text-transform:uppercase;letter-spacing:.07em}.report-totals strong{margin-top:4px;font:800 20px 'Manrope',sans-serif;letter-spacing:-.04em}

/* Modal */
.modal-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:18px;background:rgba(26,26,24,.48);backdrop-filter:blur(4px)}.modal{width:min(620px,100%);max-height:calc(100dvh - 36px);overflow:auto;border-radius:18px;background:#fff;box-shadow:0 25px 70px rgba(0,0,0,.24)}.modal header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:19px 20px 16px;border-bottom:1px solid var(--line)}.modal header>div>span{color:#999;font-size:9px;letter-spacing:.12em}.modal h2{margin:2px 0 0;font:800 20px 'Manrope',sans-serif}.modal header p{margin:4px 0 0;color:var(--muted);font-size:10px}.modal-body{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:19px 20px}.modal-body .form-field{margin:0}.form-field.full{grid-column:1/-1}.modal footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px 19px;border-top:1px solid var(--line)}.form-note{grid-column:1/-1;padding:10px 11px;border-radius:9px;background:var(--soft);color:#777;font-size:10px}.confirm-box{width:min(360px,100%);padding:24px;border-radius:17px;background:#fff;text-align:center}.confirm-box h2{margin:0;font:800 19px 'Manrope',sans-serif}.confirm-box p{margin:7px 0 20px;color:var(--muted);font-size:11px}.confirm-box>div{display:flex;justify-content:center;gap:8px}.toasts{position:fixed;z-index:200;right:18px;bottom:18px;display:grid;gap:7px}.toast{min-width:250px;max-width:360px;padding:11px 13px;border-radius:10px;background:#20201e;color:#fff;box-shadow:var(--shadow);font-size:11px}.toast.error{background:#8f3e3e}

@media(max-width:1180px){.summary-grid{grid-template-columns:repeat(3,1fr)}.summary-grid .dark-card{grid-column:span 2}}
@media(max-width:880px){.mobile-only{display:grid!important}.desktop-only{display:none!important}.auth-page{grid-template-columns:1fr}.auth-brand{display:none}.auth-panel{min-height:100vh;min-height:100dvh;padding:25px}.mobile-wordmark{display:flex;margin-bottom:48px}.sidebar{width:275px;transform:translateX(-105%);transition:.2s;box-shadow:var(--shadow)}.sidebar.open{transform:translateX(0)}.drawer-backdrop{position:fixed;inset:0;z-index:45;background:rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:.2s}.drawer-backdrop.show{opacity:1;pointer-events:auto}.content-column{margin-left:0}.topbar{padding:10px 16px}main{padding:22px 15px 98px}.bottom-nav{position:fixed;z-index:60;left:12px;right:12px;bottom:max(10px,env(safe-area-inset-bottom));height:64px;display:grid!important;grid-template-columns:repeat(5,1fr);padding:6px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.97);box-shadow:0 12px 38px rgba(0,0,0,.14);backdrop-filter:blur(14px)}.bottom-nav button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:0;border-radius:10px;background:transparent;color:#888;font-size:8px}.bottom-nav button.active{background:var(--soft);color:#111}.bottom-nav .mobile-add{width:46px;height:46px;display:grid;place-items:center;justify-self:center;margin-top:-20px;border:4px solid var(--bg);border-radius:14px;background:#20201e;color:#fff}.simple-grid{grid-template-columns:1fr}}
@media(max-width:680px){.topbar p,.sync-badge{display:none}.section-head h2{font-size:23px}.summary-grid{grid-template-columns:1fr 1fr;gap:9px}.summary-grid article{min-height:120px;padding:14px}.summary-grid article>strong{font-size:20px}.summary-grid .dark-card{grid-column:1/-1}.page-tools{flex-wrap:wrap}.search{width:100%}.page-tools .button{flex:1}.month-input{flex:1}.table-scroll{display:none}.mobile-cards{display:grid;gap:9px;padding:11px}.data-card{padding:13px;border:1px solid var(--line);border-radius:12px}.data-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.data-card-head strong{font-size:12px}.data-card-head span{display:block;color:var(--muted);font-size:9px}.data-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:11px;padding-top:10px;border-top:1px solid var(--line)}.data-stats span,.data-stats strong{display:block}.data-stats span{color:var(--muted);font-size:8px;text-transform:uppercase}.data-stats strong{margin-top:2px;font-size:10px}.data-actions{display:flex;gap:7px;margin-top:11px}.data-actions .button{min-height:34px;flex:1;padding:6px;font-size:9px}.report-totals{grid-template-columns:1fr}.modal-backdrop{align-items:end;padding:0}.modal{width:100%;max-height:92dvh;border-radius:19px 19px 0 0}.modal-body{grid-template-columns:1fr;padding:17px}.form-field.full,.form-note{grid-column:auto}.modal footer{position:sticky;bottom:0;background:#fff;padding-bottom:max(17px,env(safe-area-inset-bottom))}.modal footer .button{flex:1}.confirm-box{margin:auto 15px}.toasts{right:11px;bottom:87px}}
@media(max-width:420px){.summary-grid{grid-template-columns:1fr}.summary-grid .dark-card{grid-column:auto}.auth-title{margin-top:28px}}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
