.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);display:flex;flex-direction:column;z-index:100;transition:width var(--transition);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(165deg,#223a63 0%,#1b2d4f 38%,#152a45 100%);box-shadow:4px 0 32px #0f172a2e}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-logo{display:flex;align-items:center;gap:12px;height:var(--app-topbar-height);min-height:var(--app-topbar-height);max-height:var(--app-topbar-height);padding:0 16px;flex-shrink:0;box-sizing:border-box;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar.collapsed .sidebar-logo{padding:0 10px;justify-content:center}.sidebar-logo-icon{width:40px;height:40px;background:linear-gradient(145deg,#3d9488 0%,var(--color-accent) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:20px;color:#fff;flex-shrink:0;box-shadow:0 2px 10px #00000040;letter-spacing:.02em}.sidebar-logo-text{display:flex;flex-direction:column;overflow:hidden;gap:1px}.sidebar-logo-name{font-family:var(--font-heading);font-size:20px;font-weight:700;color:#fff;line-height:1.1;letter-spacing:.06em;text-shadow:0 1px 0 rgba(0,0,0,.2)}.sidebar-logo-sub{font-size:10px;font-weight:500;color:#ffffff73;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}.sidebar-nav{flex:1;padding:12px 12px 20px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;margin:0 2px;border-radius:10px;border:1px solid transparent;color:#ffffffb8;font-size:14px;font-weight:500;text-decoration:none;position:relative;white-space:nowrap;overflow:hidden;transition:background .18s ease,color .18s ease,box-shadow .18s ease,border-color .18s ease}.sidebar-nav-item:hover{color:#fff;background:rgba(255,255,255,.1);border-color:#ffffff0f;text-decoration:none}.sidebar-nav-item:focus-visible{outline:2px solid rgba(255,255,255,.45);outline-offset:1px}.sidebar-nav-item.active{color:#fff;background:linear-gradient(90deg,rgba(42,123,111,.25) 0%,rgba(42,123,111,.85) 100%);border-color:#ffffff1f;box-shadow:0 2px 12px #0003;font-weight:600}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:rgba(255,255,255,.85);box-shadow:0 0 8px #ffffff59}.sidebar-nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:22px;color:inherit;opacity:.95}.sidebar-nav-item .sidebar-nav-icon svg{stroke-width:1.85}.sidebar-nav-item.active .sidebar-nav-icon,.sidebar-nav-item:hover .sidebar-nav-icon{opacity:1}.sidebar-nav-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.sidebar-badge{background:linear-gradient(180deg,#f87171 0%,var(--color-danger) 100%);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 1px 4px #ef444473}.sidebar-badge-dot{position:absolute;top:9px;right:10px;width:7px;height:7px;background:var(--color-danger);border-radius:50%;box-shadow:0 0 0 2px #1b2d4f99}.sidebar-bottom{padding:8px 12px 18px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:6px;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.12) 100%)}.sidebar-bottom .sidebar-nav-item{margin:0}.sidebar-user{display:flex;flex-direction:column;align-items:stretch;margin-top:4px;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.07) 0%,rgba(0,0,0,.06) 100%);border:1px solid rgba(255,255,255,.1);box-shadow:0 1px #ffffff0d inset,0 4px 14px #0000001f;overflow:hidden}.sidebar-user--collapsed{margin-top:2px;padding:0;background:rgba(255,255,255,.04)}button.sidebar-user-logout-only{display:flex;align-items:center;justify-content:center;width:100%;margin:0;padding:10px 6px;color:#ffffffb3;background:transparent;border:none;border-radius:8px;cursor:pointer;line-height:0;transition:color .15s ease,background .15s ease}button.sidebar-user-logout-only:hover{color:#fff;background:rgba(255,255,255,.1)}button.sidebar-user-logout-only:focus-visible{outline:1px solid rgba(255,255,255,.45);outline-offset:1px;border-radius:8px}.sidebar-user-body{display:flex;flex-direction:row;align-items:stretch;min-width:0;width:100%;min-height:64px;padding:0;overflow:hidden;border-radius:inherit}.sidebar-user-rail{--user-fill: #2a7b6f;flex:0 0 50px;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);background:linear-gradient(150deg,color-mix(in srgb,var(--user-fill) 32%,#ffffff) 0%,var(--user-fill) 100%);border-right:1px solid rgba(255,255,255,.1);box-shadow:2px 0 8px #0000001a inset}.sidebar-user-rail-initial{font-size:15px;font-weight:700;line-height:1;letter-spacing:.05em;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);-webkit-user-select:none;user-select:none}.sidebar-user-side{flex:1 1 0;min-width:0;display:flex;flex-direction:column;justify-content:center;padding:8px 9px 8px 8px;gap:6px;text-align:left}a.sidebar-user-name,.sidebar-user-name{display:block;min-width:0;max-width:100%;margin:0;font-size:12.5px;font-weight:600;line-height:1.35;color:#fffffff5;text-decoration:none;letter-spacing:.01em;transition:color .15s ease,text-decoration-color .15s ease}.sidebar-user-name-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}a.sidebar-user-name:hover{color:#fff;text-decoration:underline;text-underline-offset:2px;text-decoration-color:#ffffff73}a.sidebar-user-name:focus-visible{outline:1px solid rgba(255,255,255,.45);outline-offset:2px;border-radius:2px}.sidebar-logout{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;margin:0;padding:5px 8px;font-family:var(--font-body);font-size:11.5px;font-weight:500;color:#ffffffa6;background:transparent;border:1px solid rgba(255,255,255,.14);border-radius:5px;cursor:pointer;transition:color .15s ease,background .15s ease,border-color .15s ease}.sidebar-logout .sidebar-logout-svg{display:block;flex-shrink:0;color:currentColor;opacity:.85}.sidebar-logout:hover{color:#fff;background:rgba(255,255,255,.07);border-color:#ffffff38}.sidebar-logout:hover .sidebar-logout-svg{opacity:1}.sidebar.collapsed .sidebar-nav{padding:12px 6px 20px}@media (max-width: 768px){.sidebar-logo{min-height:var(--app-topbar-height);height:auto;max-height:none;padding:10px 12px}.sidebar{transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.mobile-open{transform:translate(0)}}.app-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-height:var(--app-topbar-height);height:var(--app-topbar-height);max-height:var(--app-topbar-height);padding:0 16px 0 8px;box-sizing:border-box;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10;background:rgb(243,244,246);flex-shrink:0}.header-sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid #e2e8f0;border-radius:8px;background:#ffffff;color:var(--color-text-primary, #0f172a);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;flex-shrink:0}.header-sidebar-toggle:hover{background:#f8fafc;border-color:#cbd5e1}.header-sidebar-toggle:focus-visible{outline:2px solid var(--color-accent, #2a7b6f);outline-offset:2px}.header-left{min-width:0;padding-right:8px}.header-greeting{display:flex;flex-wrap:wrap;align-items:baseline;column-gap:.35em;margin:0;font-weight:400;line-height:1.2}.header-greeting-preface{font-family:var(--font-body);font-size:.9375rem;font-weight:500;color:var(--color-text-secondary);letter-spacing:.02em}.header-greeting-name{font-family:var(--font-heading);font-size:26px;font-weight:700;color:var(--color-text-primary);letter-spacing:.02em;line-height:1.2;font-feature-settings:"liga" 1,"kern" 1}.header-date{font-size:13px;color:var(--color-text-secondary);margin-top:4px;font-weight:400;line-height:1.35}.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.header-icon-btn{position:relative;width:40px;height:40px;background:var(--color-surface);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);border:1px solid transparent;box-shadow:var(--shadow-card);transition:all var(--transition);cursor:pointer}.header-icon-btn:hover{background:#f8fafc;border-color:#e2e8f0;color:var(--color-primary)}.header-notif-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}.header-reports-icon{flex-shrink:0;color:var(--color-accent);opacity:.95}.header-reports-btn:hover .header-reports-icon,.header-reports-btn.active .header-reports-icon{color:#245f56;opacity:1}.header-reports{position:relative}.header-reports-btn{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--color-surface);border-radius:var(--radius-md);font-size:14px;font-weight:600;color:var(--color-text-primary);border:1px solid transparent;box-shadow:var(--shadow-card);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.header-reports-btn:hover,.header-reports-btn.active{background:#f8fafc;border-color:#e2e8f0}.header-reports-btn:disabled{cursor:wait;opacity:.72}.header-reports-menu{position:absolute;top:calc(100% + 10px);right:0;z-index:50;width:18rem;padding:.45rem;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);background:#fff;box-shadow:0 20px 50px #0f172a2e}.header-reports-menu:before{content:"";position:absolute;top:-6px;right:18px;width:12px;height:12px;border-left:1px solid rgba(15,23,42,.08);border-top:1px solid rgba(15,23,42,.08);background:#fff;transform:rotate(45deg)}.header-reports-menu__item{position:relative;z-index:1;display:flex;align-items:center;gap:.65rem;width:100%;padding:.7rem;border-radius:var(--radius-sm);color:var(--color-text-primary);background:transparent;text-align:left;transition:background var(--transition),transform var(--transition)}.header-reports-menu__item:hover{background:var(--color-ice-light);transform:translate(2px)}.header-reports-menu__icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:2rem;height:2rem;border-radius:var(--radius-full);color:#fff;background:linear-gradient(135deg,#0f766e,#2dd4bf)}.header-reports-menu__text{display:flex;flex-direction:column;gap:.12rem;min-width:0}.header-reports-menu__text strong{font-size:.88rem}.header-reports-menu__text small{color:var(--color-text-secondary);font-size:.74rem}@media (max-width: 768px){.app-header{min-height:auto;height:auto;max-height:none;padding:8px 12px 8px 6px}.header-greeting-preface{font-size:.8125rem}.header-greeting-name{font-size:20px}.header-reports-label{display:none}.header-reports-menu{right:-4px;width:min(18rem,calc(100vw - 1.5rem))}}.login-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:radial-gradient(circle at 78% 16%,rgba(45,212,191,.16),transparent 28rem),linear-gradient(135deg,#f7f9fc 0%,#eef3f8 100%)}.login-left{position:relative;overflow:hidden;background:radial-gradient(circle at 18% 20%,rgba(45,212,191,.22),transparent 18rem),linear-gradient(165deg,#223a63 0%,#1b2d4f 42%,#10233c 100%);padding:clamp(2rem,4vw,3.5rem);display:flex;flex-direction:column;justify-content:space-between}.login-left:after{content:"";position:absolute;right:-7rem;bottom:-7rem;width:22rem;height:22rem;border-radius:999px;background:rgba(42,123,111,.28);filter:blur(2px)}.login-brand{display:flex;align-items:center;gap:16px}.login-brand-icon{width:52px;height:52px;background:linear-gradient(145deg,#3d9488 0%,var(--color-accent) 100%);border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:26px;font-weight:700;color:#fff;box-shadow:0 16px 36px #0000003d}.login-brand-name{font-family:var(--font-heading);font-size:28px;color:#fff;letter-spacing:2px;line-height:1}.login-brand-sub{font-size:12px;color:#ffffff80;font-weight:400;margin-top:4px}.login-hero{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center;gap:20px;padding:48px 0}.login-hero-title{font-family:var(--font-heading);font-size:clamp(2rem,3.4vw,3.3rem);color:#fff;line-height:1.08;max-width:34rem}.login-hero-text{font-size:1rem;color:#ffffffa6;line-height:1.7;max-width:420px}.login-features{display:flex;flex-direction:column;gap:12px}.login-feature{display:flex;align-items:center;gap:12px;font-size:14px;color:#ffffffbf}.login-feature-dot{width:9px;height:9px;border-radius:50%;background:var(--color-accent);flex-shrink:0}.login-right{display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,5vw,4rem);background:transparent}.login-card{width:100%;max-width:31rem;display:flex;flex-direction:column;gap:0;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:1.35rem;background:rgba(255,255,255,.94);box-shadow:0 24px 70px #0f172a24;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.login-card-header{display:flex;align-items:center;gap:.85rem;min-height:5.3rem;padding:1.1rem 1.25rem;color:#fff;text-align:left;background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.login-card-mark{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:2.55rem;height:2.55rem;border-radius:var(--radius-full);color:#fff;background:rgba(255,255,255,.24);box-shadow:inset 0 1px #ffffff47}.login-card-title{margin:0;font-family:var(--font-body);font-size:1rem;font-weight:800;color:#fff}.login-card-sub{margin:.28rem 0 0;font-size:.74rem;color:#ffffffe6}.login-form{display:flex;flex-direction:column;gap:1rem;padding:1.35rem 1.25rem 0}.login-form .form-group{gap:.45rem}.login-form .form-label{color:#64748b;font-size:.72rem;font-weight:800}.login-form .form-input{width:100%;min-height:2.85rem;padding:.7rem .9rem;border:1.5px solid rgba(42,123,111,.18);border-radius:.75rem;background:#fff;box-shadow:0 1px #fffc inset}.login-form .form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #2a7b6f1f}.password-wrap{position:relative;display:flex;align-items:center;width:100%}.password-wrap .form-input{padding-right:3.2rem}.password-toggle{position:absolute;right:.45rem;top:50%;width:2.2rem;height:2.2rem;transform:translateY(-50%);color:var(--color-text-secondary);display:inline-flex;align-items:center;justify-content:center;background:rgba(234,242,250,.8);border:1px solid transparent;border-radius:var(--radius-full);cursor:pointer;padding:0;transition:color var(--transition),background var(--transition),border-color var(--transition),box-shadow var(--transition)}.password-toggle:hover{color:var(--color-accent);border-color:#2a7b6f2e;background:rgba(42,123,111,.1)}.password-toggle:focus-visible{outline:none;border-color:#2a7b6f52;box-shadow:0 0 0 3px #2a7b6f1f}.login-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#FEE2E2;border-radius:var(--radius-sm);color:#991b1b;font-size:14px}.login-submit{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:3rem;border:0;border-radius:.8rem;color:#fff;font-size:.95rem;font-weight:800;background:linear-gradient(135deg,#0f766e,#2a7b6f);box-shadow:0 16px 30px #0f766e38;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 20px 36px #0f766e42}.login-submit:disabled{cursor:wait;opacity:.72}.login-demo-hint{text-align:center;font-size:.78rem;color:var(--color-text-secondary);padding:1rem 1.25rem 1.25rem;margin:0;background:linear-gradient(180deg,transparent,rgba(234,242,250,.72))}.login-demo-hint code{font-family:var(--font-mono);font-size:12px;color:var(--color-primary);font-weight:600}@media (max-width: 900px){.login-page{grid-template-columns:1fr}.login-left{display:none}.login-right{min-height:100vh;padding:32px 24px}}.kpi-card--no-eyebrow{padding-top:.95rem}.kpi-card--no-eyebrow .kpi-card__value{margin-top:.1rem}.kpi-card--panel.kpi-card--topbar{padding:0;min-height:5.5rem;justify-content:flex-start;border-radius:var(--radius-md);overflow:hidden}.kpi-card__head-row{display:flex;flex-direction:row;align-items:flex-start;width:100%;flex:0 0 auto;min-width:0}.kpi-card__head{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:.55rem .65rem;padding:.55rem .8rem .58rem;box-sizing:border-box;width:100%;min-width:0;flex:0 0 auto;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);border-bottom-left-radius:0;border-bottom-right-radius:0}.kpi-card__head--blue{background:linear-gradient(100deg,#1d4ed8 0%,#3b82f6 100%)}.kpi-card__head--emerald{background:linear-gradient(100deg,#0f766e 0%,#14b8a6 100%)}.kpi-card__head--purple{background:linear-gradient(100deg,#5b21b6 0%,#7c3aed 100%)}.kpi-card__head--rose{background:linear-gradient(100deg,#9f1239 0%,#e11d48 100%)}.kpi-card__head--amber{background:linear-gradient(100deg,#b45309 0%,#f59e0b 100%)}.kpi-card__head--slate{background:linear-gradient(100deg,#334155 0%,#64748b 100%)}.kpi-card__head--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.kpi-card__head--sky{background:linear-gradient(100deg,#0369a1 0%,#0ea5e9 100%)}.kpi-card__head-end{display:flex;align-items:center;justify-content:flex-end;margin-left:auto;flex-shrink:0;padding-left:.4rem}.kpi-card__trend-header{display:inline-flex;align-items:center;gap:.22rem .3rem;font-size:.78rem;font-weight:600;font-family:var(--font-mono, ui-monospace, monospace);font-variant-numeric:tabular-nums;line-height:1.2;white-space:nowrap;padding:.2rem .45rem .22rem;border-radius:9999px;box-shadow:inset 0 1px #fff3;letter-spacing:.02em;color:#fffffff2;background:rgba(15,23,42,.2)}.kpi-card__trend-header--up{color:#ecfdf5;background:rgba(16,185,129,.38);text-shadow:0 0 .35em rgba(6,95,70,.35)}.kpi-card__trend-header--down{color:#fff1f2;background:rgba(248,113,113,.38);text-shadow:0 0 .3em rgba(127,29,29,.25)}.kpi-card__trend-header--flat{color:#fffffff2;background:rgba(15,23,42,.25);text-shadow:none}.kpi-card__head-title{font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;margin:0;color:#fff;letter-spacing:.01em;min-width:0;flex:1 1 auto}.kpi-card__head-mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40;flex-shrink:0}.kpi-card__body{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;gap:.1rem .25rem;min-width:0;width:100%;padding:.8rem .85rem .9rem .95rem;flex:1 1 auto}.kpi-card--topbar .kpi-card__value{padding-right:.25rem;width:100%}.kpi-card--panel{--kpi-icon-bg: #eaf2fa;--kpi-icon: #1b2d4f;position:relative;padding:.85rem .85rem .9rem .95rem;min-width:0;min-height:5.4rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;gap:.1rem .25rem;background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d;transition:box-shadow .2s ease,border-color .2s ease}.kpi-card--panel:hover{box-shadow:0 3px 10px #0f172a14;border-color:#0f172a1a}.kpi-card--panel.kpi-card--topbar:hover{box-shadow:0 3px 10px #0f172a1a;border-color:#0f172a1f}.kpi-card__icon-float{position:absolute;top:.7rem;right:.7rem;z-index:1;pointer-events:none}.kpi-card__icon-circle{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 2px #00000012;border:1px solid rgba(255,255,255,.5)}.kpi-card__eyebrow{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);margin:0;line-height:1.2;padding-right:3rem;max-width:100%}.kpi-card__value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--color-text-primary);line-height:1.1;margin:0;letter-spacing:.02em;word-break:break-word;width:100%;padding-right:2.75rem}.kpi-card__trend{display:inline-flex;flex-wrap:wrap;align-items:center;margin:.1rem 0 0;line-height:1.2;font-size:11px;padding:2px 6px;align-self:flex-start}.kpi-card__trend-label{font-size:10.5px;font-weight:600;margin-left:.1rem;opacity:.95}.kpi-card__desc{font-size:11.5px;font-weight:500;line-height:1.35;color:var(--color-text-secondary);margin:.15rem 0 0;max-width:100%}.loading-wrapper{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px}.loading-label{font-size:14px;color:var(--color-text-secondary)}.page-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:var(--color-text-secondary);font-size:15px}.error-box{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;text-align:center}.error-msg{font-size:14px;color:var(--color-text-secondary);max-width:400px}.dashboard{--dash-gap: clamp(12px, 1.5vh, 24px);display:flex;flex-direction:column;flex:1 1 0%;min-height:0;width:100%;min-width:0;gap:var(--dash-gap)}.dashboard--viewport-fit{flex:1 1 0;min-height:0;max-height:100%;overflow:hidden;--dash-gap: clamp(8px, 1.1vh, 16px)}.dashboard>.dashboard-kpis{flex:0 0 auto;flex-shrink:0}.dashboard--viewport-fit>.dashboard-charts{flex:.95 1 0;min-height:0;max-height:100%;overflow:hidden;align-self:stretch;width:100%}.dashboard--viewport-fit>.dashboard-bottom{flex:.9 1 0;min-height:0;max-height:100%;overflow:hidden}.dashboard-section{display:flex;flex-direction:column;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 1px 3px #0f172a14;min-width:0;flex:0 0 auto}.dashboard-section:last-of-type{flex:1 1 0;min-height:0}.dashboard-section--teal .dashboard-section__head{background:linear-gradient(100deg,#0f766e 0%,#14b8a6 100%)}.dashboard-section--blue .dashboard-section__head{background:linear-gradient(100deg,#1d4ed8 0%,#3b82f6 100%)}.dashboard-section--purple .dashboard-section__head{background:linear-gradient(100deg,#5b21b6 0%,#7c3aed 100%)}.dashboard-section__head{padding:.75rem 1rem .85rem;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);flex:0 0 auto}.dashboard-section__title{font-family:var(--font-body);font-size:1.05rem;font-weight:700;margin:0;line-height:1.2;letter-spacing:.02em;color:#fff}.dashboard-section__sub{font-size:.78rem;font-weight:500;margin:.2rem 0 0;line-height:1.4;color:#ffffffe6;max-width:52rem}.dashboard-section__body{background:#fff;border:1px solid rgba(15,23,42,.1);border-top:none;border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);padding:.9rem .9rem 1rem;min-width:0}.dashboard .dashboard-tile{position:relative;display:flex;flex-direction:column;overflow:hidden;padding:0;border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0a;transition:box-shadow .2s ease}.dashboard .dashboard-tile:hover{box-shadow:0 3px 10px #0f172a14}.dashboard-charts .dashboard-tile--chart:hover{box-shadow:0 4px 18px #2a1d151a;border-color:#5a3d281f}.donut-kpi:hover{box-shadow:0 4px 18px #064e3b1f;border-color:#008c7a2e}.recharts-default-tooltip.dashboard-miete-tooltip{background:linear-gradient(180deg,#fbfcfa 0%,#f2f5ef 100%)!important;border:1px solid #959d90!important;border-radius:10px!important;box-shadow:0 10px 28px #4f574c1f,0 0 0 1px #959d9014!important;padding:12px 14px!important;white-space:normal!important}.recharts-default-tooltip.dashboard-miete-tooltip .recharts-tooltip-label{color:#4f574c!important;font-size:.7rem!important;font-weight:700!important;letter-spacing:.06em;text-transform:uppercase;margin:0 0 .4rem!important;padding-bottom:.5rem!important;border-bottom:1px solid #dce2d8}.recharts-default-tooltip.dashboard-miete-tooltip .recharts-tooltip-item,.recharts-default-tooltip.dashboard-miete-tooltip .recharts-tooltip-item-list,.recharts-default-tooltip.dashboard-miete-tooltip .recharts-tooltip-item-text{color:#4f574c!important;font-size:.875rem!important;font-weight:500}.donut-slice-tooltip{border-radius:10px;padding:.5rem .8rem .55rem;border:1px solid;box-shadow:0 8px 24px #00000038;min-width:6.5rem;max-width:12rem}.donut-slice-tooltip__name{margin:0 0 .2rem;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;line-height:1.2}.donut-slice-tooltip__value{margin:0;font-size:1.05rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.2}.donut-slice-tooltip__unit{font-size:.72rem;font-weight:600;margin-left:.2rem;opacity:.92}.dashboard .dashboard-tile--chart .dashboard-recharts-surface,.dashboard .dashboard-tile--donut .donut-wrapper,.dashboard .dashboard-tile--list .payment-list,.dashboard .dashboard-tile--list .timeline-list,.dashboard .dashboard-tile--list .activity-list{position:relative;z-index:1}.dashboard-kpis{width:100%;margin:0}.folder-tab__row{display:flex;flex-direction:row;align-items:flex-start;width:100%;flex:0 0 auto;min-width:0}.folder-tab{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:.55rem .65rem;padding:.55rem .8rem .58rem;box-sizing:border-box;width:100%;min-width:0;flex:0 0 auto;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);border-bottom-left-radius:0;border-bottom-right-radius:0}.folder-tab--blue{background:linear-gradient(100deg,#1d4ed8 0%,#3b82f6 100%)}.folder-tab--sky{background:linear-gradient(100deg,#0369a1 0%,#0ea5e9 100%)}.folder-tab--purple{background:linear-gradient(100deg,#5b21b6 0%,#7c3aed 100%)}.folder-tab--emerald{background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.folder-tab--rose{background:linear-gradient(100deg,#9f1239 0%,#e11d48 100%)}.folder-tab--brown{background:linear-gradient(100deg,#2a1d15 0%,#5c3d2a 50%,#7a4d2a 100%)}.folder-tab--sage{background:linear-gradient(100deg,#6f766b 0%,#959d90 52%,#b4bcaf 100%)}.folder-tab--amber{background:linear-gradient(100deg,#b45309 0%,#f59e0b 100%)}.folder-tab--slate{background:linear-gradient(100deg,#334155 0%,#64748b 100%)}.folder-tab--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.folder-tab__text{min-width:0;flex:1 1 auto}.folder-tab__title{font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;margin:0;color:#fff;letter-spacing:.01em}.folder-tab__sub{font-size:.65rem;font-weight:500;line-height:1.3;margin:.2rem 0 0;color:#ffffffe6}.folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40;flex-shrink:0}.dashboard-charts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:minmax(0,1fr);align-items:stretch;align-content:stretch;min-height:0;gap:20px;width:100%}.dashboard-charts .dashboard-chart-main{grid-column:1 / span 3;min-width:0;min-height:0;height:100%;display:flex;flex-direction:column}.dashboard-charts>.card.dashboard-tile--chart,.dashboard-charts>.card.dashboard-tile--donut{min-height:0;height:100%}.dashboard-charts .dashboard-chart-donut{grid-column:4;min-width:0}.dashboard-bottom{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;min-height:0;gap:clamp(10px,1.2vw,20px);width:100%}.dashboard-bottom .card.dashboard-tile--list{display:flex;flex-direction:column;min-height:0;height:100%;row-gap:.6rem}.dashboard-tile__head{display:flex;flex-direction:row;align-items:flex-start;gap:.75rem .85rem;padding:.85rem .9rem .55rem .95rem;position:relative;z-index:1;min-width:0;flex-shrink:0}.dashboard-tile__mark{width:40px;height:40px;min-width:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 2px #0000000f;border:1px solid rgba(255,255,255,.65)}.dashboard-tile__head-text{min-width:0;flex:1 1 0;padding-top:.05rem}.dashboard-tile__title{font-family:var(--font-body);font-size:.92rem;font-weight:700;color:var(--color-text-primary);line-height:1.3;margin:0;letter-spacing:.01em}.dashboard-tile__sub{font-size:.78rem;font-weight:500;color:var(--color-text-secondary);line-height:1.35;margin:.2rem 0 0}.dashboard .dashboard-tile--list .payment-list,.dashboard .dashboard-tile--list .timeline-list,.dashboard .dashboard-tile--list .activity-list{padding-left:.5rem;padding-right:.4rem;padding-bottom:.4rem;max-height:min(50dvh,24rem);flex:1 1 0;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.dashboard--viewport-fit .dashboard-tile--list .payment-list,.dashboard--viewport-fit .dashboard-tile--list .timeline-list,.dashboard--viewport-fit .dashboard-tile--list .activity-list{max-height:none}.dashboard-bottom .dashboard-tile--list .payment-list,.dashboard-bottom .dashboard-tile--list .timeline-list,.dashboard-bottom .dashboard-tile--list .activity-list{padding-top:.4rem}.dashboard-bottom .payment-list .payment-item{padding:0 0 8px}.dashboard-bottom .payment-list>.dashboard-section-empty{padding:0 0 .4rem;margin:0}.dashboard-bottom .timeline-list .timeline-item:first-child .timeline-dot{margin-top:0}.dashboard .dashboard-tile--chart .dashboard-recharts-surface{display:flex;flex:1 1 0;flex-direction:column;min-height:0;box-sizing:border-box;padding:.2rem .45rem .8rem}.dashboard .dashboard-tile--chart,.dashboard .dashboard-tile--donut{width:100%;min-width:0}.dashboard-chart-main{min-width:0;min-height:0;display:flex;flex-direction:column;width:100%;max-width:100%;row-gap:.6rem}.dashboard-charts>.card.dashboard-tile .folder-tab{padding:.65rem .95rem .7rem;min-height:4rem;box-sizing:border-box;align-items:center}.dashboard-charts .folder-tab__sub{margin-top:.28rem;line-height:1.35}.dashboard-bottom .dashboard-tile--list .folder-tab{padding:.65rem .95rem .7rem}.dashboard-bottom .dashboard-tile--list .folder-tab__sub{margin-top:.28rem;line-height:1.35}.dashboard-recharts-surface{flex:1 1 0;min-width:0;width:100%;position:relative;min-height:max(0px,max(8rem,12dvh))}.dashboard-recharts-surface .recharts-wrapper{min-height:inherit;max-height:100%;height:100%!important}.dashboard-chart-donut{display:flex;flex-direction:column;min-height:0;height:100%}.dashboard-charts .dashboard-chart-donut.donut-kpi{min-height:0}.donut-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(8px,1.2vh,20px);flex:1 1 0;min-height:0;width:100%}.donut-chart-container{position:relative;display:flex;align-items:center;justify-content:center}.donut-center{position:absolute;display:flex;flex-direction:column;align-items:center;pointer-events:none}.donut-percent{font-family:var(--font-mono);font-size:26px;font-weight:700;color:var(--color-primary);line-height:1}.donut-label{font-size:12px;color:var(--color-text-secondary);margin-top:4px;font-weight:500}.donut-legend{width:100%;display:flex;flex-direction:column;gap:10px}.donut-legend-item{display:flex;align-items:center;gap:10px;font-size:13px}.donut-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.donut-legend-name{flex:1;color:var(--color-text-secondary)}.donut-legend-value{font-family:var(--font-mono);font-weight:700;color:var(--color-primary)}.donut-kpi{background:var(--color-surface, #fff);border-color:#0f172a14;box-shadow:var(--shadow-card, 0 1px 3px rgba(0, 0, 0, .08))}.donut-kpi__body{flex:1 1 0;min-height:0;min-width:0;display:flex;flex-direction:column;align-items:stretch;background:transparent}.donut-kpi__plot{flex:1 1 0;min-height:0;min-width:0;display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:.2rem .3rem;width:100%}.donut-kpi__sizer{flex:1 1 0;min-width:0;min-height:0;width:100%;display:flex;align-items:center;justify-content:center}.donut-kpi__sizer,.donut-kpi__ring{box-sizing:border-box}.donut-kpi__ring{position:relative;flex:0 0 auto;margin:0 auto;filter:drop-shadow(0 3px 12px rgba(27,45,79,.1))}.donut-kpi__chart-surface{position:absolute;z-index:0;left:0;right:0;top:0;bottom:0;display:flex;align-items:center;justify-content:center}.donut-kpi__chart-surface .recharts-responsive-container{max-width:100%}.donut-kpi__chart-surface .recharts-wrapper{max-width:100%;max-height:100%}.donut-kpi__chart-surface .recharts-tooltip-wrapper{z-index:20;pointer-events:none;background:transparent}.donut-kpi__center.donut-center{z-index:0;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-kpi__center{background:transparent;box-shadow:none;border-radius:0;width:auto;height:auto;min-width:0;min-height:0;padding:0;justify-content:center;gap:0}.donut-kpi__center-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;text-align:center}.donut-kpi__percent{font-family:var(--font-mono, ui-monospace, monospace);font-size:clamp(2rem,4.8vmin,2.65rem);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--color-text-primary);line-height:1.05;display:inline-flex;align-items:baseline;justify-content:center;gap:.08rem}.donut-kpi__percent-suffix{font-size:.55em;font-weight:600;color:var(--color-text-secondary);opacity:1}.donut-kpi__label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);margin-top:0}.donut-kpi__footer{flex:0 0 auto;width:100%;padding:.35rem .45rem .6rem;min-width:0;background:transparent}.donut-kpi__legend{list-style:none;margin:0;padding:0;width:100%;display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;column-gap:clamp(.9rem,2.2vw,1.5rem);row-gap:.4rem}.donut-kpi__legend-row{display:inline-flex;flex:0 0 auto;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:.4rem;min-width:0;max-width:100%;padding:.1rem 0;background:transparent;border:none;border-radius:0;box-shadow:none}.donut-kpi__legend .donut-legend-name{flex:0 1 auto;min-width:0;text-align:left;font-size:.8125rem;font-weight:500;line-height:1.3;font-family:var(--font-body, system-ui, -apple-system, sans-serif);color:#64748b;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.donut-kpi__legend .donut-legend-value{flex:0 0 auto;text-align:left;min-width:0;font-size:.8125rem;font-weight:500;color:#5c6370;font-family:var(--font-body, system-ui, -apple-system, sans-serif);font-variant-numeric:tabular-nums;margin-left:.1em}.donut-kpi__legend .donut-legend-dot.donut-kpi__legend-dot{display:block;width:1.1rem;min-width:1.1rem;height:.38rem;min-height:.38rem;border-radius:.2rem;flex-shrink:0;box-shadow:0 0 0 1px #0f172a1a;background-clip:padding-box}.dashboard-section-empty{color:var(--color-text-secondary);font-size:14px;margin:0;padding:.25rem 0 .5rem}.dashboard-section .dashboard-section-list{min-height:0;max-height:min(50dvh,24rem)}.payment-list{display:flex;flex-direction:column;gap:12px;flex:1 1 0;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch}.payment-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--color-ice-light)}.payment-item:last-child{border-bottom:none}.payment-info{flex:1;min-width:0}.payment-name{display:block;font-size:13px;font-weight:600;color:var(--color-text-primary)}.payment-unit{display:block;font-size:11px;color:var(--color-text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-list{display:flex;flex-direction:column;gap:0;flex:1 1 0;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch}.timeline-item{display:flex;gap:12px;position:relative;padding-bottom:20px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:4px;position:relative;z-index:1}.timeline-dot-high,.timeline-dot-critical{background:var(--color-danger)}.timeline-dot-medium{background:var(--color-warning)}.timeline-dot-low{background:var(--color-accent)}.timeline-line{position:absolute;left:5px;top:16px;bottom:0;width:2px;background:var(--color-ice-mid)}.timeline-content{flex:1;display:flex;flex-direction:column;gap:4px}.timeline-title{font-size:13px;font-weight:500;color:var(--color-text-primary);line-height:1.3}.timeline-date{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-secondary);font-family:var(--font-mono)}.activity-list{display:flex;flex-direction:column;gap:14px;flex:1 1 0;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch}.activity-item{display:flex;gap:12px;align-items:flex-start}.activity-icon{font-size:18px;flex-shrink:0;width:32px;height:32px;background:var(--color-ice-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.activity-content{flex:1;min-width:0}.activity-desc{display:block;font-size:13px;color:var(--color-text-primary);line-height:1.4}.activity-time{display:block;font-size:11px;color:var(--color-text-secondary);margin-top:3px}@media (min-width: 700px){.dashboard-chart-donut,.donut-wrapper{flex-direction:row;align-items:center}}@media (max-width: 768px){.dashboard-section__title{font-size:.98rem}.dashboard-section__sub{font-size:.75rem}.dashboard-chart-donut{flex-direction:column;min-height:0}.donut-wrapper{flex-direction:column}}@media (max-width: 480px),(max-height: 500px){.dashboard:not(.dashboard--viewport-fit) .dashboard-recharts-surface{min-height:min(200px,32dvh)}.dashboard:not(.dashboard--viewport-fit) .dashboard-tile--list .payment-list,.dashboard:not(.dashboard--viewport-fit) .dashboard-tile--list .timeline-list,.dashboard:not(.dashboard--viewport-fit) .dashboard-tile--list .activity-list{max-height:min(45dvh,22rem)}}@media (max-width: 1024px){.dashboard-charts{grid-template-columns:1fr;grid-template-rows:minmax(0,1.1fr) minmax(0,1fr);min-height:0}.dashboard-charts .dashboard-chart-main,.dashboard-charts .dashboard-chart-donut{grid-column:auto}}@media (max-width: 1024px){.dashboard-bottom{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.dashboard-bottom{grid-template-columns:1fr}}.properties-page{display:flex;flex-direction:column;flex:1 1 0%;gap:clamp(1rem,2vw,1.5rem);width:100%;height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));max-height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));min-width:0;min-height:0;overflow:hidden;padding-bottom:0}.page-content:has(>.properties-page){overflow:hidden!important;overflow-x:hidden!important;overflow-y:hidden!important}.properties-page .properties-panel.card{display:flex;flex-direction:column;flex:1 1 0%;height:100%;max-height:100%;padding:0;overflow:hidden;min-height:0;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d;row-gap:0}.properties-page .folder-tab__row{display:flex;flex-direction:row;align-items:flex-start;width:calc(100% + 2px);margin:-1px -1px 0;flex:0 0 auto;min-width:0}.properties-page .folder-tab{display:grid;grid-template-columns:minmax(12rem,1fr) minmax(18rem,34rem) auto;align-items:center;gap:.75rem 1rem;padding:.55rem .8rem .58rem;box-sizing:border-box;width:100%;min-width:0;flex:0 0 auto;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);border-bottom-left-radius:0;border-bottom-right-radius:0}.properties-page .properties-panel .folder-tab{padding:.7rem .95rem;min-height:4.75rem;align-items:center}.properties-page .properties-panel .folder-tab__sub{margin-top:.28rem;line-height:1.35}.properties-page .folder-tab--blue{background:linear-gradient(100deg,#1d4ed8 0%,#3b82f6 100%)}.properties-page .folder-tab--sky{background:linear-gradient(100deg,#0369a1 0%,#0ea5e9 100%)}.properties-page .folder-tab--purple{background:linear-gradient(100deg,#5b21b6 0%,#7c3aed 100%)}.properties-page .folder-tab--emerald{background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.properties-page .folder-tab--rose{background:linear-gradient(100deg,#9f1239 0%,#e11d48 100%)}.properties-page .folder-tab--brown{background:linear-gradient(100deg,#2a1d15 0%,#5c3d2a 50%,#7a4d2a 100%)}.properties-page .folder-tab--amber{background:linear-gradient(100deg,#b45309 0%,#f59e0b 100%)}.properties-page .folder-tab--slate{background:linear-gradient(100deg,#334155 0%,#64748b 100%)}.properties-page .folder-tab--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.properties-page .folder-tab__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.properties-page .folder-tab__text{min-width:0;flex:1 1 auto}.properties-page .folder-tab__title{font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;margin:0;color:#fff;letter-spacing:.01em}.properties-page .folder-tab__sub{font-size:.65rem;font-weight:500;line-height:1.3;margin:.2rem 0 0;color:#ffffffe6}.properties-page .folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40;flex-shrink:0}.properties-page .folder-tab__controls{display:contents}.properties-panel__cta{justify-self:end;min-height:2.35rem;padding-inline:.95rem;white-space:nowrap;color:#fff;box-shadow:0 10px 24px #0f172a2e}.properties-panel__cta svg{color:currentColor}.properties-search{display:flex;align-items:center;gap:.5rem;justify-self:center;width:min(100%,34rem);padding:.52rem .8rem .52rem .7rem;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.94);box-shadow:0 10px 28px #0f172a24;transition:border-color var(--transition),box-shadow var(--transition)}.properties-search:focus-within{border-color:#ffffffbd;box-shadow:0 0 0 3px #ffffff2e,0 10px 28px #0f172a29}.properties-search__icon{flex-shrink:0;color:var(--color-text-secondary)}.properties-search__input{flex:1 1 auto;min-width:0;border:none;background:transparent;font-size:.9rem;color:var(--color-text-primary)}.properties-search__input::placeholder{color:var(--color-text-secondary);opacity:.85}.properties-panel__body{padding:1.1rem 1.15rem 1.25rem;flex:1 1 0%;height:0;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable}.properties-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:15rem;gap:1.1rem;list-style:none;margin:0;padding:0}.properties-grid__cell{display:flex;min-width:0;min-height:0}.prop-card{position:relative;display:flex;height:100%;min-height:0;width:100%;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);transition:box-shadow .22s ease,border-color .22s ease,transform .22s ease}.prop-card:hover{border-color:#2a7b6f38;box-shadow:0 8px 28px #1b2d4f1a;transform:translateY(-2px)}.prop-card__actions{position:absolute;top:.55rem;right:.55rem;z-index:3;display:inline-flex;gap:.4rem}.prop-card__icon-action{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid rgba(255,255,255,.52);border-radius:var(--radius-full);color:#fff;box-shadow:0 8px 18px #0f172a2e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:.9;transition:background var(--transition),opacity var(--transition),transform var(--transition)}.prop-card__icon-action--edit{background:rgba(49,46,129,.86)}.prop-card__icon-action--delete{background:rgba(185,28,28,.86)}.prop-card__icon-action:hover:not(:disabled){opacity:1;transform:translateY(-1px)}.prop-card__icon-action--edit:hover:not(:disabled){background:#4f46e5}.prop-card__icon-action--delete:hover:not(:disabled){background:#dc2626}.prop-card__icon-action:disabled{cursor:progress;opacity:.55}.prop-card__layout{display:grid;grid-template-columns:minmax(0,38%) minmax(0,1fr);flex:1 1 auto;width:100%;height:100%;min-height:0}@media (max-width: 640px){.prop-card__layout{grid-template-columns:1fr;min-height:0}}.prop-card__media{position:relative;height:100%;min-height:9.5rem;background:var(--color-ice-light)}@media (max-width: 640px){.prop-card__media{min-height:10.5rem}}.prop-card__img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}.prop-card:hover .prop-card__img{transform:scale(1.05)}.prop-card__placeholder{width:100%;height:100%;min-height:9.5rem;display:flex;align-items:center;justify-content:center;color:#1b2d4f38;background:linear-gradient(145deg,#eaf2fa 0%,#dfeaf5 100%)}.prop-card__media-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 45%,rgba(27,45,79,.55) 100%);pointer-events:none;opacity:.85}.prop-card__chip{position:absolute;left:.65rem;bottom:.65rem;z-index:1;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.28rem .55rem;border-radius:var(--radius-full);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.35)}.prop-card__chip--high{background:rgba(42,123,111,.92);color:#fff}.prop-card__chip--mid{background:rgba(245,158,11,.95);color:#1a1408}.prop-card__chip--low{background:rgba(239,68,68,.92);color:#fff}.prop-card__body{display:flex;flex-direction:column;justify-content:space-between;gap:.55rem;padding:.72rem 1rem .85rem;min-width:0;min-height:0;height:100%}.prop-card__name{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.2;letter-spacing:-.01em}.prop-card__addr{display:flex;align-items:flex-start;gap:.35rem;margin:0;font-size:.8rem;line-height:1.45;color:var(--color-text-secondary)}.prop-card__addr svg{flex-shrink:0;margin-top:.12rem;color:var(--color-accent)}.prop-card__addr-sep{opacity:.65}.prop-card__stats{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin:0;padding:.65rem .7rem;border-radius:var(--radius-sm);background:var(--color-ice-light);border:1px solid rgba(200,220,239,.65)}.prop-card__stat{margin:0;min-width:0}.prop-card__stat-label{font-size:.65rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);margin:0 0 .2rem}.prop-card__stat-value{display:flex;align-items:center;gap:.35rem;margin:0;font-family:var(--font-mono);font-size:.95rem;font-weight:700;color:var(--color-text-primary)}.prop-card__stat-value--accent{color:var(--color-accent)}.prop-card__stat-unit{font-family:var(--font-body);font-size:.68rem;font-weight:600;color:var(--color-text-secondary);margin-left:.1rem}.prop-card__meter-track{display:flex;width:100%;height:7px;border-radius:999px;overflow:hidden;background:rgba(15,23,42,.06)}.prop-card__meter-seg{min-width:0;height:100%;transition:flex-grow .4s ease}.prop-card__meter-seg--rented{background:linear-gradient(90deg,#1f6b5f,#2a7b6f)}.prop-card__meter-seg--vacant{background:linear-gradient(90deg,#c8dcef,#dfeaf5)}.prop-card__foot{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:auto;padding-top:.15rem}.prop-card__value{font-size:.78rem;color:var(--color-text-secondary)}.prop-card__value strong{font-family:var(--font-mono);font-size:.88rem;color:var(--color-text-primary)}.prop-card__link{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;font-weight:700;color:var(--color-accent);text-decoration:none;padding:.35rem .5rem;margin:-.35rem -.5rem;border-radius:var(--radius-sm);transition:gap .2s ease,background .2s ease}.prop-card__link:hover{gap:.5rem;text-decoration:none;background:rgba(42,123,111,.08)}.properties-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2.25rem 1.25rem 2rem;gap:.75rem}.properties-empty--muted{padding:1.75rem 1rem}.properties-empty__icon{display:flex;align-items:center;justify-content:center;width:4.5rem;height:4.5rem;border-radius:50%;background:var(--color-ice-light);color:var(--color-accent);margin-bottom:.25rem}.properties-empty__title{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0}.properties-empty__text{font-size:.9rem;color:var(--color-text-secondary);margin:0;max-width:22rem;line-height:1.5}.new-property-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,3vw,2rem);background:rgba(15,23,42,.42);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.new-property-modal__dialog{width:min(100%,58rem);display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius-lg);background:#fff;box-shadow:0 24px 80px #0f172a47}.new-property-modal__head{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.8rem;padding:.8rem 1rem;color:#fff;background:linear-gradient(100deg,#312e81 0%,#7c3aed 100%)}.new-property-modal__mark{display:flex;align-items:center;justify-content:center;width:2.35rem;height:2.35rem;border-radius:50%;background:rgba(255,255,255,.24)}.new-property-modal__title{margin:0;font-family:var(--font-heading);font-size:1.15rem;line-height:1.2;color:#fff}.new-property-modal__sub{margin:.2rem 0 0;font-size:.74rem;line-height:1.3;color:#ffffffdb}.new-property-modal__close{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-full);color:#fff;background:rgba(255,255,255,.14)}.new-property-modal__close:hover{background:rgba(255,255,255,.22)}.new-property-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.7rem .85rem;padding:.95rem 1rem 1rem;overflow:visible}.new-property-field{display:flex;flex-direction:column;gap:.4rem;min-width:0}.new-property-field--wide{grid-column:span 2}.new-property-field--full{grid-column:1 / -1}.new-property-field>span{font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary)}.new-property-field input,.new-property-field textarea{width:100%;min-width:0;height:2.85rem;box-sizing:border-box;border:1px solid rgba(15,23,42,.12);border-radius:var(--radius-sm);padding:.58rem .72rem;font:inherit;line-height:1.35;color:var(--color-text-primary);background:#fff;transition:border-color var(--transition),box-shadow var(--transition)}.new-property-upload__input{display:none}.new-property-upload{display:flex;align-items:center;gap:.55rem;width:100%;height:2.85rem;box-sizing:border-box;border:1px dashed rgba(99,102,241,.36);border-radius:var(--radius-sm);padding:.45rem .7rem;color:var(--color-text-secondary);background:rgba(99,102,241,.06);cursor:pointer;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition)}.new-property-field:focus-within .new-property-upload,.new-property-upload:hover{border-color:#6366f19e;background:rgba(99,102,241,.1);box-shadow:0 0 0 3px #6366f11a}.new-property-upload__icon,.new-property-upload__preview{flex:0 0 auto;width:1.85rem;height:1.85rem;border-radius:var(--radius-sm)}.new-property-upload__icon{display:inline-flex;align-items:center;justify-content:center;color:#4f46e5;background:#fff}.new-property-upload__preview{object-fit:cover}.new-property-upload__text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:500}.new-property-field textarea{resize:none;min-height:0}.new-property-field input:focus,.new-property-field textarea:focus{outline:none;border-color:#6366f18c;box-shadow:0 0 0 3px #6366f121}.new-property-form__error{grid-column:1 / -1;margin:0;padding:.7rem .8rem;border-radius:var(--radius-sm);background:rgba(239,68,68,.1);color:#b91c1c;font-size:.86rem;font-weight:600}.new-property-form__actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:.7rem;padding-top:.2rem}.new-property-form__spinner{animation:new-property-spin .8s linear infinite}.delete-property-modal__dialog{width:min(100%,28rem);overflow:hidden;border-radius:var(--radius-lg);background:#fff;box-shadow:0 24px 80px #0f172a47}.delete-property-modal__head{position:relative;display:flex;justify-content:center;padding:1.25rem 1.25rem .3rem}.delete-property-modal__mark{display:flex;align-items:center;justify-content:center;width:3.2rem;height:3.2rem;border-radius:50%;color:#fff;background:linear-gradient(135deg,#b91c1c 0%,#ef4444 100%);box-shadow:0 12px 26px #b91c1c40}.delete-property-modal__close{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-full);color:var(--color-text-secondary);background:#fff}.delete-property-modal__close:hover{color:var(--color-text-primary);background:var(--color-ice-light)}.delete-property-modal__body{padding:.8rem 1.5rem .6rem;text-align:center}.delete-property-modal__title{margin:0;font-family:var(--font-heading);font-size:1.25rem;color:var(--color-text-primary)}.delete-property-modal__text{margin:.65rem 0 0;font-size:.92rem;line-height:1.55;color:var(--color-text-secondary)}.delete-property-modal__text strong{color:var(--color-text-primary)}.delete-property-modal__actions{display:flex;justify-content:flex-end;gap:.7rem;padding:1rem 1.25rem 1.25rem}.delete-property-modal__danger{color:#fff;background:#dc2626;border:1px solid #dc2626}.delete-property-modal__danger:hover:not(:disabled){color:#fff;background:#b91c1c;border-color:#b91c1c}@keyframes new-property-spin{to{transform:rotate(360deg)}}@media (max-width: 1180px){.properties-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:16.5rem}.prop-card__layout{grid-template-columns:minmax(0,34%) minmax(0,1fr)}}@media (max-width: 900px){.properties-page .folder-tab{grid-template-columns:1fr}.properties-search,.properties-panel__cta{justify-self:stretch;width:100%}.properties-panel__cta{justify-content:center}.new-property-form{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.properties-grid{grid-template-columns:1fr;grid-auto-rows:27rem}.prop-card{height:100%}.prop-card__layout{grid-template-columns:1fr;height:auto}.new-property-form{grid-template-columns:1fr}.new-property-form__actions{flex-direction:column-reverse}.new-property-form__actions .btn{justify-content:center;width:100%}.delete-property-modal__actions{flex-direction:column-reverse}.delete-property-modal__actions .btn{justify-content:center;width:100%}}.property-detail{display:flex;flex-direction:column;gap:16px;flex:1 1 0%;width:100%;height:100%;min-height:0;overflow:hidden}.page-content:has(>.property-detail){overflow:hidden}.property-detail-header{display:grid;grid-template-columns:260px 1fr;gap:28px;align-items:start}.property-detail-img{width:100%;height:190px;object-fit:cover;border-radius:var(--radius-md)}.property-detail-info{display:flex;flex-direction:column;gap:8px}.property-detail-desc{font-size:14px;color:var(--color-text-secondary);line-height:1.6;margin-top:2px}.property-detail-kpis{display:flex;flex-wrap:wrap;gap:20px;margin-top:6px}.property-detail-kpi{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text-secondary)}.detail-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.detail-card-head .section-title{margin:0}.detail-add-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;align-items:end;padding:14px;margin-bottom:16px;border:1px solid var(--color-ice-mid);border-radius:var(--radius-md);background:var(--color-ice-light)}.detail-add-form--wide{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.detail-add-form--upload{grid-template-columns:minmax(150px,220px) minmax(220px,1fr) auto}.detail-add-form label{display:flex;flex-direction:column;gap:5px;min-width:0}.detail-add-form label span{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-secondary)}.detail-add-form input,.detail-add-form select{width:100%;min-width:0;height:38px;box-sizing:border-box;border:1px solid rgba(15,23,42,.12);border-radius:var(--radius-sm);padding:0 10px;font:inherit;font-size:14px;color:var(--color-text-primary);background:#fff}.detail-add-form input:focus,.detail-add-form select:focus{outline:none;border-color:#2a7b6f80;box-shadow:0 0 0 3px #2a7b6f1f}.detail-add-form__span-2{grid-column:span 2}.detail-add-form__submit{width:100%;height:38px;justify-content:center;text-align:center;padding-inline:.75rem}.detail-panel-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.75rem 1rem;width:100%;box-sizing:border-box;min-height:4rem;padding:.65rem .95rem;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.detail-panel-header--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.detail-panel-header--rose{background:linear-gradient(100deg,#9f1239 0%,#e11d48 100%)}.detail-panel-header--emerald{background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.detail-panel-header__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.detail-panel-header__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;color:#fff;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.detail-panel-header__text{min-width:0}.detail-panel-header__title{margin:0;font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;color:#fff}.detail-panel-header__sub{margin:.25rem 0 0;font-size:.66rem;font-weight:500;line-height:1.3;color:#ffffffe6}.detail-panel-header__actions{display:flex;align-items:center;gap:.65rem;justify-content:flex-end;min-width:0}.detail-panel-header__actions .btn{flex:0 0 auto;color:#fff;border-color:#ffffff3d;box-shadow:0 10px 24px #0f172a29}.detail-header-upload{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:2.35rem;padding:.45rem .8rem;border:1px solid rgba(255,255,255,.24);border-radius:var(--radius-full);color:#ffffffe6;background:rgba(255,255,255,.12);box-shadow:0 10px 24px #0f172a1f;font-size:.84rem;font-weight:700;white-space:nowrap;transition:color var(--transition),background var(--transition),border-color var(--transition),transform var(--transition)}.detail-header-upload:hover,.detail-header-upload--active{color:#fff;border-color:#ffffff6b;background:rgba(255,255,255,.18);transform:translateY(-1px)}.detail-header-search{display:flex;align-items:center;gap:.45rem;width:min(28rem,38vw);min-width:13rem;padding:.45rem .7rem;border:1px solid rgba(255,255,255,.32);border-radius:var(--radius-full);background:rgba(255,255,255,.94);box-shadow:0 10px 24px #0f172a24}.detail-header-search:focus-within{border-color:#ffffffbd;box-shadow:0 0 0 3px #ffffff2e,0 10px 24px #0f172a29}.detail-header-search__icon{flex:0 0 auto;color:var(--color-text-secondary)}.detail-header-search__input{flex:1 1 auto;min-width:0;border:0;outline:0;background:transparent;color:var(--color-text-primary);font:inherit;font-size:.86rem}.detail-header-search__input::placeholder{color:var(--color-text-secondary);opacity:.85}.property-tabs{display:flex;gap:4px;border-bottom:2px solid var(--color-ice-mid);padding-bottom:0;flex-wrap:wrap}.property-tab{display:flex;align-items:center;gap:7px;padding:10px 18px;font-size:14px;font-weight:500;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);background:none;white-space:nowrap}.property-tab:hover{color:var(--color-primary)}.property-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.property-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:700;border-radius:var(--radius-full)}.property-tab-content{flex:1 1 0%;min-height:0;overflow:hidden}.units-panel-card{display:flex;flex-direction:column;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden}.property-detail .units-panel-card.card{padding:0}.units-panel-card .detail-panel-header,.units-panel-card .detail-add-form{flex:0 0 auto}.units-panel-card .detail-add-form,.maintenance-panel-card .detail-add-form{margin:16px 16px 12px}.units-table-wrapper{flex:1 1 auto;height:0;min-height:0;overflow:auto;padding:0 16px 16px;background:#fff;scrollbar-gutter:stable}.units-table{width:100%;border-collapse:separate;border-spacing:0}.units-table th{position:sticky;top:0;z-index:5;text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);border-bottom:1.5px solid var(--color-ice-mid);background:#fff;box-shadow:0 1px 0 var(--color-ice-mid)}.units-table td{padding:12px 14px;font-size:14px;color:var(--color-text-primary);border-bottom:1px solid var(--color-ice-light)}.units-table tbody tr:hover{background:var(--color-ice-light)}.units-table tbody tr:last-child td{border-bottom:none}.units-table__empty{text-align:center;color:var(--color-text-secondary)}.unit-edit-input{width:100%;min-width:72px;height:32px;box-sizing:border-box;border:1px solid rgba(15,23,42,.14);border-radius:var(--radius-sm);padding:0 8px;font:inherit;font-size:13px;color:var(--color-text-primary);background:#fff}.unit-edit-input:focus{outline:none;border-color:#2a7b6f80;box-shadow:0 0 0 3px #2a7b6f1f}.unit-row-actions{display:inline-flex;align-items:center;gap:6px}.unit-row-action{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid rgba(15,23,42,.1);border-radius:var(--radius-full);color:var(--color-text-secondary);background:#fff;transition:color var(--transition),background var(--transition),border-color var(--transition)}.unit-row-action:hover:not(:disabled){color:var(--color-accent);border-color:#2a7b6f40;background:rgba(42,123,111,.08)}.unit-row-action--save{color:#fff;border-color:var(--color-accent);background:var(--color-accent)}.unit-row-action--save:hover:not(:disabled){color:#fff;background:#1f6b5f}.property-maintenance-tab{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;width:100%;height:100%;min-height:0;align-items:stretch;overflow:hidden}.property-financials-tab{display:flex;flex-direction:column;width:100%;height:100%;min-height:0;overflow:hidden}.financial-panel-card,.document-panel-card{display:flex;flex-direction:column;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden}.financial-panel-body{flex:1 1 auto;height:0;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px;scrollbar-gutter:stable}.financial-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.financial-summary-card{position:relative;display:flex;flex-direction:column;gap:18px;min-width:0;padding:18px;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);background:radial-gradient(circle at 100% 0%,rgba(42,123,111,.09),transparent 34%),#fff;box-shadow:0 8px 22px #0f172a0f;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.financial-summary-card:hover{border-color:#2a7b6f38;box-shadow:0 14px 30px #0f172a17;transform:translateY(-1px)}.financial-summary-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--summary-accent, var(--color-accent))}.financial-summary-card--emerald{--summary-accent: #0f766e;--summary-soft: rgba(15, 118, 110, .1);--summary-icon: #0f766e}.financial-summary-card--rose{--summary-accent: #e11d48;--summary-soft: rgba(225, 29, 72, .1);--summary-icon: #be123c}.financial-summary-card--indigo{--summary-accent: #6366f1;--summary-soft: rgba(99, 102, 241, .1);--summary-icon: #4338ca}.financial-summary-card__top{display:flex;align-items:center;gap:.75rem;min-width:0}.financial-summary-card__mark{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:40px;height:40px;border-radius:var(--radius-full);color:var(--summary-icon, var(--color-accent));background:var(--summary-soft, rgba(42, 123, 111, .1))}.financial-summary-card__meta{display:flex;flex-direction:column;gap:4px;min-width:0}.financial-summary-card__label{min-width:0;overflow:hidden;font-size:.86rem;font-weight:700;line-height:1.2;color:var(--color-primary);text-overflow:ellipsis;white-space:nowrap}.financial-summary-card__body{padding-left:52px}.financial-summary-card__value{margin:0;font-family:var(--font-mono);font-size:clamp(1.15rem,2.2vw,1.7rem);font-weight:800;color:var(--color-primary)}.financial-summary-card__sub{margin:0;overflow:hidden;font-size:.78rem;color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap}.financial-panel-empty{margin:0;padding:24px;color:var(--color-text-secondary)}.property-detail .financial-panel-card.card,.property-detail .document-panel-card.card{padding:0}.financial-panel-card .detail-panel-header,.financial-panel-card .detail-add-form,.document-panel-card .detail-panel-header,.document-upload-panel{flex:0 0 auto}.financial-panel-card .detail-add-form,.document-panel-card .detail-add-form{margin:16px}.document-upload-panel{display:flex;align-items:end;gap:12px;flex-wrap:nowrap;padding:12px 16px;border-bottom:1px solid var(--color-ice-light);background:linear-gradient(180deg,rgba(234,242,250,.55),rgba(255,255,255,.95))}.document-upload-panel__controls{display:flex;flex-direction:column;gap:10px;min-width:0}.document-upload-panel__type{display:flex;flex-direction:column;gap:6px;flex:0 0 15rem;min-width:0}.document-upload-panel__type span{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-secondary)}.document-upload-panel__type select{width:100%;height:38px;border:1px solid rgba(15,23,42,.12);border-radius:var(--radius-sm);padding:0 10px;font:inherit;font-size:14px;color:var(--color-text-primary);background:#fff}.document-upload-panel__submit{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;flex:0 0 auto;min-height:2.4rem;padding:.52rem .95rem;border:1px solid rgba(42,123,111,.2);border-radius:var(--radius-full);color:#fff;font-size:.82rem;font-weight:700;background:linear-gradient(135deg,#0f766e,#2dd4bf);box-shadow:0 10px 20px #0f766e33;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.document-upload-panel__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #0f766e3d}.document-upload-panel__submit:disabled{cursor:not-allowed;opacity:.55}.document-upload-dropzone{position:relative;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px;flex:1 1 auto;min-width:14rem;min-height:2.4rem;padding:10px 12px;border:1.5px dashed rgba(42,123,111,.36);border-radius:var(--radius-md);color:var(--color-text-secondary);background:rgba(255,255,255,.82);cursor:pointer;text-align:left;transition:border-color var(--transition),background var(--transition),transform var(--transition)}.document-upload-dropzone:hover{border-color:#2a7b6f9e;background:#fff;transform:translateY(-1px)}.document-upload-dropzone input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.document-upload-dropzone__icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:2.35rem;height:2.35rem;border-radius:var(--radius-full);color:#fff;background:linear-gradient(135deg,#0f766e,#2dd4bf);box-shadow:0 12px 26px #0f766e38}.document-upload-dropzone__copy{display:flex;flex-direction:column;flex:1 1 auto;min-width:0}.document-upload-dropzone__text{font-size:.92rem;font-weight:700;color:var(--color-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-upload-dropzone__hint{margin-top:2px;font-size:.78rem;color:var(--color-text-secondary)}.maintenance-panel-card{display:flex;flex-direction:column;height:100%;max-height:100%;min-height:0;width:100%;padding:0;overflow:hidden}.property-detail .maintenance-panel-card.card{padding:0}.maintenance-panel-card .detail-panel-header,.maintenance-panel-card .detail-add-form{flex:0 0 auto}.maintenance-panel-scroll{flex:1 1 auto;height:0;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:12px 16px 16px;scrollbar-gutter:stable}.issue-list{display:flex;flex-direction:column;gap:0}.issue-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--color-ice-light);transition:background var(--transition)}.issue-row:last-child{border-bottom:none}.issue-row:hover{background:var(--color-bg)}.issue-done{opacity:.5}.issue-priority-icon{font-size:16px;flex-shrink:0;margin-top:2px}.issue-row-content{flex:1;min-width:0}.issue-row-header{display:flex;align-items:center;gap:10px;margin-bottom:4px;flex-wrap:wrap}.issue-row-title{font-size:14px;font-weight:600;color:var(--color-primary)}.issue-status-pill,.issue-status-edit{display:inline-flex;align-items:center;gap:6px}.issue-status-pill__edit{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:1px solid rgba(15,23,42,.1);border-radius:var(--radius-full);color:var(--color-text-secondary);background:#fff;transition:color var(--transition),background var(--transition),border-color var(--transition)}.issue-status-pill__edit:hover{color:var(--color-accent);border-color:#2a7b6f40;background:rgba(42,123,111,.08)}.issue-status-edit__select{height:30px;border:1px solid rgba(15,23,42,.14);border-radius:var(--radius-sm);padding:0 8px;font-size:12px;color:var(--color-text-primary);background:#fff}.issue-status-edit .unit-row-action{width:28px;height:28px}.issue-row-desc{font-size:12px;color:var(--color-text-secondary);line-height:1.5;margin-bottom:6px}.issue-row-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--color-text-secondary)}.schedule-list-compact{display:flex;flex-direction:column;gap:0}.schedule-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--color-ice-light)}.schedule-row:last-child{border-bottom:none}.schedule-row-title{display:block;font-size:14px;font-weight:600;color:var(--color-primary)}.schedule-row-freq{display:block;font-size:11px;color:var(--color-text-secondary);margin-top:2px}.schedule-row-date{font-size:12px;color:var(--color-text-secondary);white-space:nowrap}.schedule-row-delete{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex:0 0 auto;border:1px solid rgba(220,38,38,.16);border-radius:var(--radius-full);color:var(--color-danger);background:rgba(220,38,38,.06);transition:color var(--transition),background var(--transition),border-color var(--transition)}.schedule-row-delete:hover:not(:disabled){color:#fff;border-color:var(--color-danger);background:var(--color-danger)}.schedule-row-delete:disabled{cursor:not-allowed;opacity:.5}.doc-grid-scroll{flex:1 1 auto;height:0;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:16px;scrollbar-gutter:stable}.doc-card-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-auto-rows:minmax(10.25rem,auto);gap:14px}.doc-card{display:flex;flex-direction:column;min-width:0;min-height:0;padding:14px;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);background:#fff;box-shadow:0 8px 22px #0f172a0f;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.doc-card:hover{border-color:#2a7b6f3d;box-shadow:0 14px 30px #0f172a17;transform:translateY(-1px)}.doc-card__icon{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;margin-bottom:12px;border-radius:var(--radius-md);font-size:1.45rem;background:var(--color-ice-light)}.doc-card__body{flex:1 1 auto;min-height:0}.doc-card__name{display:-webkit-box;min-height:2.6em;margin:0;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.88rem;font-weight:700;line-height:1.3;color:var(--color-primary)}.doc-card__meta,.doc-card__date{margin:6px 0 0;font-size:.72rem;color:var(--color-text-secondary)}.doc-card__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.doc-card__action{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid rgba(42,123,111,.16);border-radius:var(--radius-full);color:var(--color-accent);background:rgba(42,123,111,.07);transition:color var(--transition),background var(--transition),border-color var(--transition)}.doc-card__action:hover:not(:disabled){color:#fff;border-color:var(--color-accent);background:var(--color-accent);text-decoration:none}.doc-card__action--delete{border-color:#dc262629;color:var(--color-danger);background:rgba(220,38,38,.06)}.doc-card__action--delete:hover:not(:disabled){border-color:var(--color-danger);background:var(--color-danger)}.doc-card__action:disabled{cursor:not-allowed;opacity:.5}.document-delete-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:rgba(15,23,42,.48);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.document-delete-modal__dialog{width:min(100%,28rem);overflow:hidden;border-radius:var(--radius-lg);background:#fff;box-shadow:0 24px 70px #0f172a47}.document-delete-modal__head{position:relative;display:flex;justify-content:center;padding:1.35rem 1.5rem .4rem}.document-delete-modal__mark{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:999px;color:#fff;background:linear-gradient(135deg,#dc2626,#991b1b);box-shadow:0 14px 30px #dc262647}.document-delete-modal__close{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:var(--radius-full);color:var(--color-text-secondary);background:transparent}.document-delete-modal__close:hover{color:var(--color-text-primary);background:var(--color-ice-light)}.document-delete-modal__body{padding:.8rem 1.5rem .6rem;text-align:center}.document-delete-modal__title{margin:0;font-family:var(--font-heading);font-size:1.25rem;color:var(--color-primary)}.document-delete-modal__text{margin:.65rem 0 0;font-size:.92rem;line-height:1.55;color:var(--color-text-secondary)}.document-delete-modal__text strong{color:var(--color-text-primary)}.document-delete-modal__error{margin:.85rem 0 0;padding:.75rem .85rem;border-radius:var(--radius-sm);color:#991b1b;background:#fee2e2}.document-delete-modal__actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.35rem}.document-delete-modal__danger{color:#fff;background:#dc2626;border-color:#dc2626}.document-delete-modal__danger:hover:not(:disabled){color:#fff;background:#b91c1c}.document-delete-modal__spinner{animation:document-delete-spin .8s linear infinite}@keyframes document-delete-spin{to{transform:rotate(360deg)}}@media (max-width: 1180px){.doc-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 900px){.property-detail-header{grid-template-columns:1fr}.property-detail-img{height:220px}.detail-card-head{align-items:stretch;flex-direction:column}.detail-card-head .btn{justify-content:center}.detail-panel-header{grid-template-columns:1fr}.detail-panel-header__actions{flex-direction:column;align-items:stretch;justify-content:stretch}.detail-panel-header__actions .btn{width:100%;justify-content:center}.detail-header-upload{width:100%}.detail-header-search{width:100%;min-width:0}.detail-add-form,.detail-add-form--upload{grid-template-columns:1fr}.detail-add-form__span-2{grid-column:auto}.financial-summary-grid{grid-template-columns:1fr}.document-upload-panel{flex-wrap:wrap}.document-upload-panel__type{flex:1 1 auto}.document-upload-panel__submit{flex:0 0 auto}.doc-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.property-maintenance-tab{height:100%;grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) minmax(0,1fr)}}@media (max-width: 640px){.property-maintenance-tab{height:100%;gap:14px}.issue-row,.schedule-row{align-items:flex-start}.schedule-row{flex-wrap:wrap}.document-upload-panel{flex-direction:column;align-items:stretch}.document-upload-dropzone{align-items:stretch;flex-direction:column;text-align:center}.document-upload-dropzone__icon{align-self:center}.document-upload-panel__submit{width:100%}.doc-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.document-delete-modal__actions{flex-direction:column-reverse}.document-delete-modal__actions .btn{justify-content:center;width:100%}}@media (max-width: 420px){.doc-card-grid{grid-template-columns:1fr}}.tenants-page{display:flex;flex-direction:column;flex:1 1 0%;width:100%;height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));max-height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));min-width:0;min-height:0;overflow:hidden;padding-bottom:0}.page-content:has(>.tenants-page){overflow:hidden!important;overflow-x:hidden!important;overflow-y:hidden!important}.tenants-panel.card{display:flex;flex-direction:column;flex:1 1 0%;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d}.tenant-folder-tab__row{display:flex;width:calc(100% + 2px);margin:-1px -1px 0;flex:0 0 auto;min-width:0}.tenant-folder-tab{display:grid;grid-template-columns:minmax(12rem,1fr) minmax(18rem,34rem) auto;align-items:center;gap:.75rem 1rem;width:100%;min-height:4.75rem;padding:.7rem .95rem;box-sizing:border-box;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.tenant-folder-tab--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.tenant-folder-tab__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.tenant-folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.tenant-folder-tab__text{min-width:0}.tenant-folder-tab__title{margin:0;font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;color:#fff}.tenant-folder-tab__sub{margin:.28rem 0 0;font-size:.65rem;font-weight:500;line-height:1.35;color:#ffffffe6}.tenant-folder-tab__controls{display:contents}.tenants-header-search{display:flex;align-items:center;gap:.5rem;justify-self:center;width:min(100%,34rem);padding:.52rem .8rem .52rem .7rem;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.94);box-shadow:0 10px 28px #0f172a24}.tenants-header-search:focus-within{border-color:#ffffffbd;box-shadow:0 0 0 3px #ffffff2e,0 10px 28px #0f172a29}.tenants-header-search__icon{flex-shrink:0;color:var(--color-text-secondary)}.tenants-header-search__input{flex:1 1 auto;min-width:0;border:none;outline:none;background:transparent;font-size:.9rem;color:var(--color-text-primary)}.tenants-header-search__input::placeholder{color:var(--color-text-secondary);opacity:.85}.tenants-header-filters{display:flex;align-items:center;justify-content:flex-end;gap:.45rem;flex-wrap:wrap}.tenants-filter-option{display:inline-flex;align-items:center;justify-content:center;min-height:2.35rem;padding:.45rem .8rem;border:1px solid rgba(255,255,255,.24);border-radius:var(--radius-full);color:#ffffffe0;background:rgba(255,255,255,.12);box-shadow:0 10px 24px #0f172a1f;font-size:.84rem;font-weight:700;line-height:1;white-space:nowrap;transition:color var(--transition),background var(--transition),border-color var(--transition),transform var(--transition)}.tenants-filter-option:hover{color:#fff;border-color:#ffffff6b;background:rgba(255,255,255,.18);transform:translateY(-1px)}.tenants-filter-option.active{color:var(--color-primary);border-color:#ffffffc7;background:rgba(255,255,255,.94)}.tenants-panel__body{flex:1 1 0%;height:0;min-height:0;padding:1.1rem 1.15rem 1.25rem;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable}.tenants-filters{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.search-input-wrap{flex:1;max-width:400px}.status-filters{display:flex;gap:8px;flex-wrap:wrap}.tenants-groups{display:flex;flex-direction:column;gap:16px;min-height:0}.property-group{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-card);overflow:hidden}.property-group-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:var(--color-ice-light);cursor:pointer;width:100%;text-align:left;border:none;transition:background var(--transition)}.property-group-header:hover{background:var(--color-ice-mid)}.property-group-title{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700;color:var(--color-primary)}.property-group-count{font-size:12px;font-weight:500;color:var(--color-text-secondary);background:white;padding:2px 8px;border-radius:var(--radius-full)}.property-group-summary{display:flex;align-items:center;gap:8px;flex-shrink:0}.property-group-rent{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--color-accent);margin-left:4px;padding-right:8px}.property-group-body{display:flex;flex-direction:column}.tenant-card{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 20px;border-bottom:1px solid var(--color-ice-light);transition:background var(--transition)}.tenant-card:last-child{border-bottom:none}.tenant-card:hover{background:var(--color-bg)}.tenant-card-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.tenant-info{display:flex;flex-direction:column;gap:5px;min-width:0}.tenant-name{font-size:15px;font-weight:700;color:var(--color-primary);font-family:var(--font-body)}.tenant-contact{display:flex;flex-wrap:wrap;gap:12px}.tenant-contact-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition)}.tenant-contact-item:hover{color:var(--color-accent);text-decoration:none}.tenant-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.tenant-detail{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary)}@media (max-width: 768px){.tenant-folder-tab{grid-template-columns:1fr}.tenant-folder-tab__controls{display:flex;flex-direction:column;gap:.7rem}.tenants-header-search{width:100%}.tenants-header-filters{justify-content:stretch}.tenants-filter-option{flex:1 1 auto;justify-content:center}.tenant-card{flex-direction:column;align-items:flex-start}.tenant-card-right{align-items:flex-start;width:100%;flex-direction:row;flex-wrap:wrap;gap:8px}.property-group-summary{display:none}.search-input-wrap{max-width:100%}}.financials-page{display:flex;flex-direction:column;flex:1 1 0%;width:100%;height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));max-height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));min-height:0;overflow:hidden;padding-bottom:0}.page-content:has(>.financials-page){overflow:hidden!important;overflow-x:hidden!important;overflow-y:hidden!important}.financials-panel.card{display:flex;flex-direction:column;flex:1 1 0%;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d}.financials-folder-tab__row{display:flex;width:calc(100% + 2px);margin:-1px -1px 0;flex:0 0 auto;min-width:0}.financials-folder-tab{display:grid;grid-template-columns:minmax(12rem,1fr) auto;align-items:center;gap:.75rem 1rem;width:100%;min-height:4.75rem;padding:.7rem .95rem;box-sizing:border-box;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.financials-folder-tab--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.financials-folder-tab__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.financials-folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.financials-folder-tab__text{min-width:0}.financials-folder-tab__title{margin:0;font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;color:#fff}.financials-folder-tab__sub{margin:.28rem 0 0;font-size:.65rem;font-weight:500;line-height:1.35;color:#ffffffe6}.financials-year-filter{display:flex;align-items:center;justify-content:flex-end;gap:.45rem;flex-wrap:wrap}.financials-year-option{display:inline-flex;align-items:center;justify-content:center;min-width:4rem;min-height:2.35rem;padding:.45rem .85rem;border-color:#ffffff3d;border:1px solid rgba(255,255,255,.24);border-radius:var(--radius-full);color:#ffffffe0;background:rgba(255,255,255,.12);box-shadow:0 10px 24px #0f172a1f;font-size:.84rem;font-weight:700;line-height:1;transition:color var(--transition),background var(--transition),border-color var(--transition),transform var(--transition)}.financials-year-option:hover{color:#fff;border-color:#ffffff6b;background:rgba(255,255,255,.18);transform:translateY(-1px)}.financials-year-option.active{color:var(--color-primary);border-color:#ffffffc7;background:rgba(255,255,255,.94)}.financials-panel__body{display:grid;grid-template-rows:auto minmax(0,1.15fr) minmax(0,.9fr);gap:clamp(8px,1.35vh,16px);flex:1 1 0%;height:0;min-height:0;padding:clamp(.6rem,1.4vh,1rem) clamp(.75rem,1.2vw,1.15rem);overflow-y:hidden;overflow-x:hidden}.financials-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(8px,1vw,14px);min-height:0}.financials-kpis .kpi-card--panel.kpi-card--topbar{min-height:clamp(4.8rem,11vh,6.2rem)}.financials-kpis .kpi-card__head{min-height:0;padding-block:clamp(.38rem,.8vh,.55rem)}.financials-kpis .kpi-card__head-title{font-size:clamp(.72rem,.82vw,.9rem)}.financials-kpis .kpi-card__body{padding:clamp(.45rem,1vh,.8rem) .85rem clamp(.5rem,1vh,.8rem)}.financials-kpis .kpi-card__value{font-size:clamp(1rem,1.6vw,1.5rem)}.financials-kpis .kpi-card__desc{font-size:clamp(.62rem,.72vw,.72rem)}.financial-chart-card{display:flex;flex-direction:column;min-height:0;padding:0;overflow:hidden}.financials-page .financial-chart-card.card{padding:0!important}.financial-chart-card--wide{min-height:0}.financial-chart-card__body{flex:1 1 auto;min-height:0;height:auto;padding:clamp(8px,1.2vh,14px)}.financial-chart-card--wide .financial-chart-card__body{height:auto}.financial-chart-card__body--list{overflow:hidden}.financial-card-head{display:flex;align-items:center;width:100%;box-sizing:border-box;margin:0;min-height:clamp(3rem,6.6vh,4rem);padding:clamp(.45rem,.9vh,.65rem) .95rem;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);border-bottom-left-radius:0;border-bottom-right-radius:0}.financial-card-head--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.financial-card-head--sage{background:linear-gradient(100deg,#6b8f71 0%,#9caf88 100%)}.financial-card-head--rose{background:linear-gradient(100deg,#9f1239 0%,#e11d48 100%)}.financial-card-head--emerald{background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.financial-card-head__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.financial-card-head__mark{display:flex;align-items:center;justify-content:center;width:clamp(24px,3.8vh,30px);height:clamp(24px,3.8vh,30px);min-width:clamp(24px,3.8vh,30px);border-radius:50%;color:#fff;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.financial-card-head__title{margin:0;font-family:var(--font-body);font-size:clamp(.78rem,.85vw,.9rem);font-weight:700;line-height:1.25;color:#fff}.financial-card-head__sub{margin:.25rem 0 0;font-size:clamp(.58rem,.68vw,.66rem);font-weight:500;line-height:1.3;color:#ffffffe6}.financials-bottom{display:grid;grid-template-columns:1fr 1fr;gap:clamp(8px,1.35vw,16px);align-items:stretch;min-height:0}.expense-categories{display:flex;flex-direction:column;gap:clamp(8px,1.4vh,14px);height:100%;min-height:0;justify-content:space-evenly}.expense-cat-item{display:flex;flex-direction:column;gap:clamp(4px,.8vh,8px)}.expense-cat-header{display:flex;align-items:center;justify-content:space-between}.expense-cat-name{font-size:clamp(.72rem,.82vw,.88rem);font-weight:500;color:var(--color-text-primary)}.expense-cat-pct{font-size:clamp(.65rem,.75vw,.75rem);color:var(--color-text-secondary)}.expense-cat-amount{font-family:var(--font-mono);font-size:clamp(.72rem,.82vw,.88rem);font-weight:700;color:var(--color-primary);min-width:80px;text-align:right}.expense-cat-bar{height:8px;background:var(--color-ice-mid);border-radius:4px;overflow:hidden}.expense-cat-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:4px;transition:width .6s ease}@media (max-width: 900px){.financials-folder-tab{grid-template-columns:1fr}.financials-year-filter{justify-content:stretch}.financials-year-option{flex:1 1 auto;justify-content:center}.financials-bottom{grid-template-columns:1fr 1fr}.financial-chart-card,.financial-chart-card--wide{min-height:0}}@media (max-height: 760px){.financials-folder-tab{min-height:4rem}.financials-panel__body{grid-template-rows:auto minmax(0,1fr) minmax(0,.85fr)}.financials-kpis .kpi-card__head-mark,.financials-kpis .kpi-card__trend-header{display:none}.financials-kpis .kpi-card--panel.kpi-card--topbar{min-height:4.35rem}}.documents-page{display:flex;flex-direction:column;flex:1 1 0%;width:100%;height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));max-height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));min-width:0;min-height:0;overflow:hidden}.page-content:has(>.documents-page){overflow:hidden!important}.documents-panel.card{display:flex;flex-direction:column;flex:1 1 0%;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d}.documents-folder-tab__row{display:flex;width:calc(100% + 2px);margin:-1px -1px 0;flex:0 0 auto;min-width:0}.documents-folder-tab{display:grid;grid-template-columns:minmax(12rem,1fr) minmax(18rem,34rem) auto;align-items:center;gap:.75rem 1rem;width:100%;min-height:4.75rem;padding:.7rem .95rem;box-sizing:border-box;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.documents-folder-tab--emerald{background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.documents-folder-tab__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.documents-folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.documents-folder-tab__text{min-width:0}.documents-folder-tab__title{margin:0;font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;color:#fff}.documents-folder-tab__sub{margin:.28rem 0 0;font-size:.65rem;font-weight:500;line-height:1.35;color:#ffffffe6}.documents-header-search{display:flex;align-items:center;gap:.45rem;justify-self:end;width:min(100%,34rem);padding:.48rem .75rem;border:1px solid rgba(255,255,255,.32);border-radius:var(--radius-full);background:rgba(255,255,255,.94);box-shadow:0 10px 24px #0f172a24}.documents-header-search__icon{flex:0 0 auto;color:var(--color-text-secondary)}.documents-header-search__input{flex:1 1 auto;min-width:0;border:0;outline:0;background:transparent;color:var(--color-text-primary);font:inherit;font-size:.86rem}.documents-header-upload{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:2.55rem;padding:.55rem .95rem;border:1px solid rgba(255,255,255,.32);border-radius:var(--radius-full);color:#fff;font-size:.85rem;font-weight:700;white-space:nowrap;background:rgba(255,255,255,.18);box-shadow:inset 0 1px #ffffff29;transition:background var(--transition),transform var(--transition),box-shadow var(--transition)}.documents-header-upload:hover,.documents-header-upload--active{color:#fff;background:rgba(255,255,255,.28);transform:translateY(-1px);box-shadow:0 10px 22px #0f172a29}.documents-panel__upload{display:flex;align-items:center;gap:12px;flex:0 0 auto;padding:12px 16px;border-bottom:1px solid var(--color-ice-light);background:linear-gradient(180deg,rgba(234,242,250,.55),rgba(255,255,255,.95))}.documents-upload-submit{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;flex:0 0 auto;min-height:2.4rem;padding:.52rem .95rem;border:1px solid rgba(42,123,111,.2);border-radius:var(--radius-full);color:#fff;font-size:.82rem;font-weight:700;background:linear-gradient(135deg,#0f766e,#2dd4bf);box-shadow:0 10px 20px #0f766e33;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.documents-upload-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #0f766e3d}.documents-upload-submit:disabled{cursor:not-allowed;opacity:.55}.documents-upload-property{display:flex;flex-direction:column;gap:5px;flex:0 0 14rem;min-width:0}.documents-upload-property span{font-size:.66rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-secondary)}.documents-upload-property select{width:100%;height:2.4rem;padding:0 .75rem;border:1px solid rgba(15,23,42,.12);border-radius:var(--radius-sm);color:var(--color-text-primary);background:#fff;font:inherit;font-size:.86rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.documents-upload-property select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #2a7b6f1f}.documents-dropzone{display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex:1 1 auto;min-width:0;gap:14px;min-height:4.6rem;padding:12px 14px;border:1.5px dashed rgba(42,123,111,.36);border-radius:var(--radius-md);color:var(--color-text-secondary);background:rgba(255,255,255,.82);cursor:pointer;text-align:left;transition:border-color var(--transition),background var(--transition),transform var(--transition)}.documents-dropzone:hover,.documents-dropzone--active{border-color:#2a7b6f9e;background:#fff;transform:translateY(-1px)}.documents-dropzone__icon{display:inline-flex;align-items:center;justify-content:center;width:2.6rem;height:2.6rem;border-radius:var(--radius-full);color:#fff;background:linear-gradient(135deg,#0f766e,#2dd4bf);box-shadow:0 12px 26px #0f766e38}.documents-dropzone__copy{flex:1 1 auto;min-width:0}.documents-dropzone__text{margin:0;overflow:hidden;font-size:.92rem;font-weight:700;color:var(--color-primary);text-overflow:ellipsis;white-space:nowrap}.documents-dropzone__hint{margin:0;font-size:.78rem;color:var(--color-text-secondary)}.documents-spinner{animation:documents-spin .8s linear infinite}@keyframes documents-spin{to{transform:rotate(360deg)}}.documents-grid-scroll{flex:1 1 auto;height:0;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:16px;scrollbar-gutter:stable}.documents-card-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-auto-rows:minmax(10.25rem,auto);gap:14px}.documents-card{display:flex;flex-direction:column;min-width:0;min-height:0;padding:14px;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);background:#fff;box-shadow:0 8px 22px #0f172a0f;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.documents-card:hover{border-color:#2a7b6f3d;box-shadow:0 14px 30px #0f172a17;transform:translateY(-1px)}.documents-card__icon{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;margin-bottom:12px;border-radius:var(--radius-md);font-size:1.45rem;background:var(--color-ice-light)}.documents-card__body{flex:1 1 auto;min-height:0}.documents-card__name{display:-webkit-box;min-height:2.6em;margin:0;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.88rem;font-weight:700;line-height:1.3;color:var(--color-primary)}.documents-card__type,.documents-card__date{margin:6px 0 0;font-size:.72rem;color:var(--color-text-secondary)}.documents-card__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.documents-card__action{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid rgba(42,123,111,.16);border-radius:var(--radius-full);color:var(--color-accent);background:rgba(42,123,111,.07);transition:color var(--transition),background var(--transition),border-color var(--transition)}.documents-card__action:hover:not(:disabled){color:#fff;border-color:var(--color-accent);background:var(--color-accent);text-decoration:none}.documents-card__action--delete{border-color:#dc262629;color:var(--color-danger);background:rgba(220,38,38,.06)}.documents-card__action--delete:hover:not(:disabled){border-color:var(--color-danger);background:var(--color-danger)}.documents-card__action:disabled{cursor:not-allowed;opacity:.5}.documents-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:12rem;gap:12px;text-align:center;color:var(--color-text-secondary)}.documents-delete-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:rgba(15,23,42,.48);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.documents-delete-modal__dialog{width:min(100%,28rem);overflow:hidden;border-radius:var(--radius-lg);background:#fff;box-shadow:0 24px 70px #0f172a47}.documents-delete-modal__head{position:relative;display:flex;justify-content:center;padding:1.35rem 1.5rem .4rem}.documents-delete-modal__mark{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:999px;color:#fff;background:linear-gradient(135deg,#dc2626,#991b1b);box-shadow:0 14px 30px #dc262647}.documents-delete-modal__close{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:var(--radius-full);color:var(--color-text-secondary);background:transparent}.documents-delete-modal__close:hover{color:var(--color-text-primary);background:var(--color-ice-light)}.documents-delete-modal__body{padding:.8rem 1.5rem .6rem;text-align:center}.documents-delete-modal__title{margin:0;font-family:var(--font-heading);font-size:1.25rem;color:var(--color-primary)}.documents-delete-modal__text{margin:.65rem 0 0;font-size:.92rem;line-height:1.55;color:var(--color-text-secondary)}.documents-delete-modal__text strong{color:var(--color-text-primary)}.documents-delete-modal__error{margin:.85rem 0 0;padding:.75rem .85rem;border-radius:var(--radius-sm);color:#991b1b;background:#fee2e2}.documents-delete-modal__actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.35rem}.documents-delete-modal__danger{color:#fff;background:#dc2626;border-color:#dc2626}.documents-delete-modal__danger:hover:not(:disabled){color:#fff;background:#b91c1c}@media (max-width: 1180px){.documents-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 900px){.documents-folder-tab{grid-template-columns:1fr}.documents-header-search{justify-self:stretch;width:100%}.documents-header-upload{width:100%}.documents-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 640px){.documents-panel__upload{align-items:stretch;flex-direction:column}.documents-upload-submit{width:100%}.documents-upload-property{flex-basis:auto;width:100%}.documents-dropzone{align-items:stretch;flex-direction:column;text-align:center}.documents-dropzone__icon{align-self:center}.documents-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.documents-delete-modal__actions{flex-direction:column-reverse}.documents-delete-modal__actions .btn{justify-content:center;width:100%}}@media (max-width: 420px){.documents-card-grid{grid-template-columns:1fr}}.maintenance-page{display:flex;flex-direction:column;gap:24px}.maintenance-tabs{display:flex;gap:8px;border-bottom:2px solid var(--color-ice-mid);padding-bottom:0}.maintenance-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);background:none}.maintenance-tab:hover{color:var(--color-primary)}.maintenance-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.issues-list{display:flex;flex-direction:column;gap:12px}.issue-card{display:flex;gap:16px;align-items:flex-start;padding:20px 24px}.issue-priority{font-size:20px;flex-shrink:0;margin-top:2px}.issue-content{flex:1;min-width:0}.issue-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.issue-title{font-size:15px;font-weight:600;color:var(--color-primary);font-family:var(--font-body)}.issue-desc{font-size:13px;color:var(--color-text-secondary);line-height:1.5;margin-bottom:10px}.issue-meta{display:flex;flex-wrap:wrap;gap:12px}.issue-meta-item{font-size:12px;color:var(--color-text-secondary)}.schedule-list{display:flex;flex-direction:column;gap:12px}.schedule-card{display:flex;align-items:center;gap:16px;padding:20px 24px}.schedule-icon{width:48px;height:48px;background:var(--color-ice-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.schedule-info{flex:1}.schedule-title{font-size:15px;font-weight:600;color:var(--color-primary);font-family:var(--font-body);margin-bottom:4px}.schedule-type{font-size:12px;color:var(--color-text-secondary)}.schedule-dates{text-align:right}.schedule-next{font-size:13px;color:var(--color-text-primary)}.messages-page{display:flex;flex-direction:column;flex:1 1 0%;width:100%;height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));max-height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));min-width:0;min-height:0;overflow:hidden}.page-content:has(>.messages-page){overflow:hidden!important}.messages-panel.card{display:flex;flex-direction:column;flex:1 1 0%;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d}.messages-folder-tab__row{display:flex;width:calc(100% + 2px);margin:-1px -1px 0;flex:0 0 auto;min-width:0}.messages-folder-tab{display:grid;grid-template-columns:minmax(12rem,1fr) auto;align-items:center;gap:.75rem 1rem;width:100%;min-height:4.75rem;padding:.7rem .95rem;box-sizing:border-box;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.messages-folder-tab--emerald{background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%)}.messages-folder-tab__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.messages-folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.messages-folder-tab__text{min-width:0}.messages-folder-tab__title{margin:0;font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;color:#fff}.messages-folder-tab__sub{margin:.28rem 0 0;font-size:.65rem;font-weight:500;line-height:1.35;color:#ffffffe6}.messages-header-action{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:2.35rem;padding:.45rem .8rem;border:1px solid rgba(255,255,255,.24);border-radius:var(--radius-full);color:#fff;background:rgba(255,255,255,.12);box-shadow:0 10px 24px #0f172a1f;font-size:.84rem;font-weight:700;white-space:nowrap;transition:color var(--transition),background var(--transition),border-color var(--transition),transform var(--transition)}.messages-header-action:hover{color:#fff;border-color:#ffffff6b;background:rgba(255,255,255,.18);transform:translateY(-1px)}.messages-panel__body{flex:1 1 auto;height:0;min-height:0;padding:16px;overflow:hidden}.messages-layout{display:grid;grid-template-columns:360px 1fr;gap:16px;height:100%;min-height:0}.messages-inbox{display:flex;flex-direction:column;min-height:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);background:#fff}.messages-section-head{flex:0 0 auto;padding:16px 18px;border-bottom:1px solid var(--color-ice-light);background:linear-gradient(180deg,rgba(234,242,250,.55),rgba(255,255,255,.95))}.messages-section-head h3{margin:0;font-size:.9rem;font-weight:800;color:var(--color-primary)}.messages-list{display:flex;flex-direction:column;gap:0;flex:1 1 auto;min-height:0;padding:6px 12px 12px;overflow-y:auto;scrollbar-gutter:stable}.messages-preview-panel{display:flex;align-items:center;justify-content:center;min-width:0;min-height:0;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);background:#fff;overflow:hidden}.messages-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;flex:1;color:var(--color-text-secondary);font-size:14px;height:100%}.message-item{padding:14px 8px;border-bottom:1px solid var(--color-ice-light);cursor:pointer;transition:background var(--transition);border-radius:var(--radius-sm)}.message-item:last-child{border-bottom:none}.message-item:hover{background:var(--color-ice-light)}.message-item.unread .message-subject{font-weight:700;color:var(--color-primary)}.message-sender-info{display:flex;justify-content:space-between;margin-bottom:4px}.message-sender{font-size:13px;font-weight:600;color:var(--color-primary)}.message-time{font-size:11px;color:var(--color-text-secondary)}.message-subject{font-size:13px;color:var(--color-text-primary);margin-bottom:4px}.message-preview{font-size:12px;color:var(--color-text-secondary);line-height:1.4}@media (max-width: 900px){.messages-folder-tab{grid-template-columns:1fr}.messages-header-action{width:100%}.messages-layout{grid-template-columns:1fr}.messages-preview-panel{display:none}}.settings-page{display:flex;flex-direction:column;flex:1 1 0%;width:100%;height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));max-height:calc(var(--app-content-vh) - clamp(20px,3vw,48px));min-height:0;overflow:hidden}.page-content:has(>.settings-page){overflow:hidden!important}.settings-panel.card{display:flex;flex-direction:column;flex:1 1 0%;height:100%;max-height:100%;min-height:0;padding:0;overflow:hidden;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d}.settings-folder-tab__row{display:flex;width:calc(100% + 2px);margin:-1px -1px 0;flex:0 0 auto;min-width:0}.settings-folder-tab{display:grid;grid-template-columns:minmax(12rem,1fr) auto;align-items:center;gap:.75rem 1rem;width:100%;min-height:4.75rem;padding:.7rem .95rem;box-sizing:border-box;color:#fff;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.settings-folder-tab--indigo{background:linear-gradient(100deg,#312e81 0%,#6366f1 100%)}.settings-folder-tab__main{display:inline-flex;align-items:center;gap:.65rem;min-width:0}.settings-folder-tab__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.settings-folder-tab__text{min-width:0}.settings-folder-tab__title{margin:0;font-family:var(--font-body);font-size:.9rem;font-weight:700;line-height:1.25;color:#fff}.settings-folder-tab__sub{margin:.28rem 0 0;font-size:.65rem;font-weight:500;line-height:1.35;color:#ffffffe6}.settings-header-tabs{display:flex;align-items:center;justify-content:flex-end;gap:.45rem;flex-wrap:wrap}.settings-header-tab{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:2.35rem;padding:.45rem .75rem;border:1px solid rgba(255,255,255,.24);border-radius:var(--radius-full);color:#ffffffe0;background:rgba(255,255,255,.12);box-shadow:0 10px 24px #0f172a1f;font-size:.84rem;font-weight:700;transition:color var(--transition),background var(--transition),border-color var(--transition),transform var(--transition)}.settings-header-tab:hover{color:#fff;border-color:#ffffff6b;background:rgba(255,255,255,.18);transform:translateY(-1px)}.settings-header-tab.active{color:var(--color-primary);border-color:#ffffffc7;background:rgba(255,255,255,.94)}.settings-panel__body{flex:1 1 auto;height:0;min-height:0;padding:1.1rem 1.15rem 1.25rem;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable}.settings-content-card{max-width:56rem;margin:0 auto;padding:0;overflow:hidden}.settings-panel .settings-content-card.card{padding:0!important}.settings-content-card__head{display:flex;align-items:center;gap:.7rem;min-height:4rem;padding:.8rem 1rem;color:#fff;background:linear-gradient(100deg,#0f766e 0%,#2dd4bf 100%);border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.settings-content-card__mark{display:flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:50%;color:#fff;background:rgba(255,255,255,.28);box-shadow:inset 0 1px #ffffff40}.settings-content-card__title{margin:0;font-family:var(--font-body);font-size:.95rem;font-weight:800;line-height:1.25;color:#fff}.settings-content-card__sub{margin:.25rem 0 0;font-size:.7rem;font-weight:500;line-height:1.35;color:#ffffffe6}.settings-form{display:flex;flex-direction:column;padding:20px}.settings-avatar-section{display:flex;align-items:center;gap:20px;padding:20px;background:var(--color-ice-light);border-radius:var(--radius-md);margin-bottom:24px}.settings-fields{display:grid;grid-template-columns:1fr 1fr;gap:16px}.settings-password-field{position:relative;width:100%;display:flex;align-items:center}.settings-password-field .form-input{width:100%;min-height:2.7rem;padding-right:3.15rem;border-color:#2a7b6f38;border-radius:.65rem}.settings-password-field__toggle{position:absolute;top:50%;right:.45rem;display:inline-flex;align-items:center;justify-content:center;width:2.15rem;height:2.15rem;border:1px solid transparent;border-radius:var(--radius-full);color:var(--color-text-secondary);background:rgba(234,242,250,.72);transform:translateY(-50%);transition:color var(--transition),background var(--transition),border-color var(--transition),box-shadow var(--transition)}.settings-password-field__toggle:hover{color:var(--color-accent);border-color:#2a7b6f2e;background:rgba(42,123,111,.1)}.settings-password-field__toggle:focus-visible{outline:none;border-color:#2a7b6f52;box-shadow:0 0 0 3px #2a7b6f1f}.notif-settings{display:flex;flex-direction:column;gap:16px}.notif-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--color-ice-light)}.notif-item:last-child{border-bottom:none}.notif-label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.toggle{position:relative;display:inline-block;width:46px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--color-ice-mid);border-radius:24px;transition:var(--transition)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:white;border-radius:50%;transition:var(--transition)}.toggle input:checked+.toggle-slider{background:var(--color-accent)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}@media (max-width: 768px){.settings-folder-tab{grid-template-columns:1fr}.settings-header-tabs{justify-content:stretch}.settings-header-tab{flex:1 1 auto}.settings-fields{grid-template-columns:1fr}}:root{--color-primary: #1B2D4F;--color-accent: #2A7B6F;--color-ice-light: #EAF2FA;--color-ice-mid: #C8DCEF;--color-bg: #F7F9FC;--color-surface: #FFFFFF;--color-text-primary: #1B2D4F;--color-text-secondary: #6B7B8D;--color-success: #2A7B6F;--color-warning: #F59E0B;--color-danger: #EF4444;--color-info: #6366F1;--font-heading: "Playfair Display", serif;--font-body: "Plus Jakarta Sans", sans-serif;--font-mono: "DM Mono", monospace;--sidebar-width: 240px;--sidebar-collapsed: 72px;--app-topbar-height: 70px;--app-content-vh: calc(100dvh - var(--app-topbar-height));--app-content-svh: calc(100svh - var(--app-topbar-height));--shadow-card: 0 1px 3px rgba(0,0,0,.08);--shadow-hover: 0 4px 16px rgba(0,0,0,.12);--shadow-lg: 0 8px 32px rgba(0,0,0,.14);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;overflow-x:hidden}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text-primary);line-height:1.6;min-height:100%;min-height:100dvh;margin:0;overflow-x:hidden}#root{min-height:100%;min-height:100dvh;width:100%;overflow-x:hidden}h1,h2,h3{font-family:var(--font-heading);color:var(--color-text-primary);line-height:1.2}h4,h5,h6,p,span,label,button,input,select,textarea{font-family:var(--font-body)}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:none;background:none;font-family:var(--font-body)}input,select,textarea{font-family:var(--font-body);outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-ice-mid);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-layout{display:flex;width:100%;min-height:100%;min-height:100dvh;min-height:100svh;flex:1;align-items:stretch}.app-main{flex:1 1 auto;min-width:0;min-height:0;min-height:100dvh;min-height:100svh;display:flex;flex-direction:column;margin-left:var(--sidebar-width);width:100%;max-width:100%;box-sizing:border-box;overflow:hidden;transition:margin-left var(--transition)}.app-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.page-content{flex:1 1 0%;display:flex;flex-direction:column;min-height:0;width:100%;max-width:100%;margin:0;box-sizing:border-box;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;overflow-wrap:break-word;word-wrap:break-word;padding-top:max(clamp(10px,1.5vw,24px),env(safe-area-inset-top,0px));padding-right:max(clamp(10px,1.5vw,24px),env(safe-area-inset-right,0px));padding-bottom:max(clamp(10px,1.5vw,24px),env(safe-area-inset-bottom,0px));padding-left:max(clamp(10px,1.5vw,24px),env(safe-area-inset-left,0px))}.page-content:has(>.dashboard--viewport-fit){overflow:hidden;overflow-x:hidden;overflow-y:hidden}.card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:24px;transition:box-shadow var(--transition)}.card:hover{box-shadow:var(--shadow-hover)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;white-space:nowrap}.badge-success{background:#DCFCE7;color:#166534}.badge-warning{background:#FEF3C7;color:#92400e}.badge-danger{background:#FEE2E2;color:#991b1b}.badge-info{background:#EDE9FE;color:#4338ca}.badge-neutral{background:var(--color-ice-light);color:var(--color-text-secondary)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:14px;transition:all var(--transition);white-space:nowrap}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:#22665b}.btn-secondary{background:var(--color-ice-light);color:var(--color-primary)}.btn-secondary:hover{background:var(--color-ice-mid)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-ice-light);color:var(--color-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-input{padding:10px 14px;border:1.5px solid var(--color-ice-mid);border-radius:var(--radius-sm);font-size:14px;color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #2a7b6f1f}.avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:12px}.avatar-md{width:40px;height:40px;font-size:14px}.avatar-lg{width:48px;height:48px;font-size:16px}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.stat-value{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--color-text-primary);line-height:1.1}.trend-up{color:var(--color-success);background:#DCFCE7}.trend-down{color:var(--color-danger);background:#FEE2E2}.trend-badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:var(--radius-full);font-size:12px;font-weight:700;font-family:var(--font-mono)}.divider{border:none;border-top:1px solid var(--color-ice-light);margin:16px 0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.section-title{font-family:var(--font-heading);font-size:22px;color:var(--color-text-primary)}.section-subtitle{font-size:14px;color:var(--color-text-secondary);margin-top:4px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}.page-title{font-family:var(--font-heading);font-size:30px;font-weight:700;color:var(--color-text-primary)}.page-subtitle{font-size:15px;color:var(--color-text-secondary);margin-top:4px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-ice-light) 25%,var(--color-ice-mid) 50%,var(--color-ice-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.spinner{width:20px;height:20px;border:2px solid var(--color-ice-mid);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:14px 20px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;min-width:280px;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:white;border-left:4px solid var(--color-success)}.toast-error{background:white;border-left:4px solid var(--color-danger)}.toast-info{background:white;border-left:4px solid var(--color-info)}.back-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;margin-bottom:8px;transition:color var(--transition)}.back-link:hover{color:var(--color-accent);text-decoration:none}.search-input-wrap{position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);pointer-events:none}.search-input{padding-left:38px;width:100%}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.section-title{font-size:clamp(1.1rem,1.5vw + .75rem,1.4rem)}.page-title{font-size:clamp(1.4rem,1.2vw + 1.1rem,1.9rem)}.section-header{flex-wrap:wrap;row-gap:.5rem}.card{padding:20px}}@media (max-width: 768px){.app-main,.app-main.sidebar-collapsed{margin-left:0}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page-content{max-width:100%}.page-header{flex-direction:column;align-items:stretch}.section-header{flex-direction:column;align-items:flex-start}.card{padding:16px}.section-title{font-size:1.125rem}.page-title{font-size:1.5rem}}@media (max-width: 480px){.section-title{font-size:1.05rem}.page-title{font-size:1.35rem}.card{padding:14px}}
