:root{--color-bg:#f8f7f4;--color-surface:#fff;--color-surface-raised:#fff;--color-surface-overlay:#ffffffd9;--color-border:#e2e0db;--color-border-strong:#c8c5bf;--color-text-primary:#1c1c1e;--color-text-secondary:#6b6966;--color-text-tertiary:#9b9895;--color-text-inverse:#fff;--color-accent:#2563eb;--color-accent-hover:#1d4ed8;--color-accent-active:#1e40af;--color-accent-subtle:#eff6ff;--color-accent-text:#1d4ed8;--color-success:#16a34a;--color-success-subtle:#f0fdf4;--color-success-border:#bbf7d0;--color-warning:#d97706;--color-warning-subtle:#fffbeb;--color-warning-border:#fde68a;--color-danger:#dc2626;--color-danger-subtle:#fef2f2;--color-danger-border:#fecaca;--color-info:#0284c7;--color-info-subtle:#f0f9ff;--color-info-border:#bae6fd;--font-family:"DM Sans", system-ui, -apple-system, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-md:1.125rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:1.875rem;--font-size-3xl:2.25rem;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.2;--line-height-snug:1.4;--line-height-normal:1.6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000d;--shadow-lg:0 10px 30px #0000001a, 0 4px 8px #0000000f;--shadow-xl:0 20px 50px #0000001f, 0 8px 16px #00000012;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.32s ease;--touch-target:48px;--content-max-width:480px}@media (prefers-color-scheme:dark){:root{--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-raised:#273549;--color-surface-overlay:#0f172ae6;--color-border:#2d3f55;--color-border-strong:#3d5470;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-inverse:#0f172a;--color-accent:#3b82f6;--color-accent-hover:#60a5fa;--color-accent-active:#93c5fd;--color-accent-subtle:#3b82f626;--color-accent-text:#60a5fa;--color-success:#4ade80;--color-success-subtle:#4ade801f;--color-success-border:#4ade8040;--color-warning:#fbbf24;--color-warning-subtle:#fbbf241f;--color-warning-border:#fbbf2440;--color-danger:#f87171;--color-danger-subtle:#f871711f;--color-danger-border:#f8717140;--color-info:#38bdf8;--color-info-subtle:#38bdf81f;--color-info-border:#38bdf840;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 10px 30px #0006;--shadow-xl:0 20px 50px #00000080}}[data-theme=dark]{--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-raised:#273549;--color-surface-overlay:#0f172ae6;--color-border:#2d3f55;--color-border-strong:#3d5470;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-inverse:#0f172a;--color-accent:#3b82f6;--color-accent-hover:#60a5fa;--color-accent-active:#93c5fd;--color-accent-subtle:#3b82f626;--color-accent-text:#60a5fa;--color-success:#4ade80;--color-success-subtle:#4ade801f;--color-success-border:#4ade8040;--color-warning:#fbbf24;--color-warning-subtle:#fbbf241f;--color-warning-border:#fbbf2440;--color-danger:#f87171;--color-danger-subtle:#f871711f;--color-danger-border:#f8717140;--color-info:#38bdf8;--color-info-subtle:#38bdf81f;--color-info-border:#38bdf840;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 10px 30px #0006;--shadow-xl:0 20px 50px #00000080}[data-theme=light]{--color-bg:#f8f7f4;--color-surface:#fff;--color-surface-raised:#fff;--color-surface-overlay:#ffffffd9;--color-border:#e2e0db;--color-border-strong:#c8c5bf;--color-text-primary:#1c1c1e;--color-text-secondary:#6b6966;--color-text-tertiary:#9b9895;--color-text-inverse:#fff;--color-accent:#2563eb;--color-accent-hover:#1d4ed8;--color-accent-active:#1e40af;--color-accent-subtle:#eff6ff;--color-accent-text:#1d4ed8;--color-success:#16a34a;--color-success-subtle:#f0fdf4;--color-success-border:#bbf7d0;--color-warning:#d97706;--color-warning-subtle:#fffbeb;--color-warning-border:#fde68a;--color-danger:#dc2626;--color-danger-subtle:#fef2f2;--color-danger-border:#fecaca;--color-info:#0284c7;--color-info-subtle:#f0f9ff;--color-info-border:#bae6fd;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000d;--shadow-lg:0 10px 30px #0000001a, 0 4px 8px #0000000f;--shadow-xl:0 20px 50px #0000001f, 0 8px 16px #00000012}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}body{background-color:var(--color-bg);min-width:320px;min-height:100dvh;color:var(--color-text-primary);transition:background-color var(--transition-base), color var(--transition-base)}img,video{max-width:100%;height:auto;display:block}a{color:var(--color-accent-text);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-base)}p{color:var(--color-text-secondary);line-height:var(--line-height-normal)}strong,b{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}small{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.mono{font-variant-numeric:tabular-nums;letter-spacing:-.01em}.btn{justify-content:center;align-items:center;gap:var(--space-2);min-height:var(--touch-target);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;line-height:1;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-accent);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--color-accent-hover);box-shadow:var(--shadow-md)}.btn-primary:active{background-color:var(--color-accent-active)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text-primary);border:1.5px solid var(--color-border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background-color:var(--color-bg);border-color:var(--color-border-strong)}.btn-ghost{color:var(--color-accent-text);padding-left:var(--space-2);padding-right:var(--space-2);background-color:#0000}.btn-ghost:hover{background-color:var(--color-accent-subtle)}.btn-danger{background-color:var(--color-danger);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover{opacity:.88}.btn-sm{min-height:36px;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);border-radius:var(--radius-md)}.btn-lg{min-height:56px;padding:var(--space-4) var(--space-8);font-size:var(--font-size-md);border-radius:var(--radius-xl)}.btn-block{width:100%}.input,.textarea,.select{width:100%;min-height:var(--touch-target);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-snug);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;display:block}.input::placeholder,.textarea::placeholder{color:var(--color-text-tertiary)}.input:focus,.textarea:focus,.select:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2563eb26}.textarea{resize:vertical;min-height:100px}.form-label{margin-bottom:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);letter-spacing:.01em;display:block}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-hint{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.form-error{font-size:var(--font-size-sm);color:var(--color-danger)}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm)}.card-raised{background-color:var(--color-surface-raised);box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.card-body{gap:var(--space-4);flex-direction:column;display:flex}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.03em;text-transform:uppercase;line-height:1;display:inline-flex}.badge-accent{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.badge-success{background-color:var(--color-success-subtle);color:var(--color-success);border:1px solid var(--color-success-border)}.badge-warning{background-color:var(--color-warning-subtle);color:var(--color-warning);border:1px solid var(--color-warning-border)}.badge-danger{background-color:var(--color-danger-subtle);color:var(--color-danger);border:1px solid var(--color-danger-border)}.badge-info{background-color:var(--color-info-subtle);color:var(--color-info);border:1px solid var(--color-info-border)}.alert{gap:var(--space-1);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-sm);flex-direction:column;display:flex}.alert strong{font-size:var(--font-size-base)}.alert-success{background-color:var(--color-success-subtle);border:1px solid var(--color-success-border);color:var(--color-success)}.alert-warning{background-color:var(--color-warning-subtle);border:1px solid var(--color-warning-border);color:var(--color-warning)}.alert-danger{background-color:var(--color-danger-subtle);border:1px solid var(--color-danger-border);color:var(--color-danger)}.alert-info{background-color:var(--color-info-subtle);border:1px solid var(--color-info-border);color:var(--color-info)}.divider{background-color:var(--color-border);height:1px;margin:var(--space-4) 0;border:none}.skeleton{background-color:var(--color-border);border-radius:var(--radius-md);position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg, transparent 0%, var(--color-surface-raised) 50%, transparent 100%);animation:1.5s infinite skeleton-shimmer;position:absolute;inset:0;transform:translate(-100%)}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.container{width:100%;max-width:var(--content-max-width);padding-inline:var(--space-4);margin-inline:auto}@media (width>=768px){.container{max-width:720px;padding-inline:var(--space-6)}}@media (width>=1024px){.container{max-width:960px}}.stack{flex-direction:column;display:flex}.stack-2{gap:var(--space-2)}.stack-3{gap:var(--space-3)}.stack-4{gap:var(--space-4)}.stack-6{gap:var(--space-6)}.stack-8{gap:var(--space-8)}.row{flex-direction:row;align-items:center;display:flex}.row-2{gap:var(--space-2)}.row-3{gap:var(--space-3)}.row-4{gap:var(--space-4)}.row-between{justify-content:space-between}.row-center{justify-content:center}.row-end{justify-content:flex-end}.bottom-nav{height:calc(60px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background-color:var(--color-surface);border-top:1px solid var(--color-border);z-index:100;justify-content:space-around;align-items:flex-start;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000f}.bottom-nav-item{justify-content:center;align-items:center;gap:var(--space-1);min-width:60px;height:60px;padding:var(--space-2);color:var(--color-text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;font-family:var(--font-family);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;display:flex}.bottom-nav-item.active{color:var(--color-accent)}.fab{bottom:calc(72px + env(safe-area-inset-bottom));right:var(--space-5);border-radius:var(--radius-full);background-color:var(--color-accent);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:99;transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;font-size:1.5rem;display:flex;position:fixed}.fab:hover{background-color:var(--color-accent-hover);box-shadow:var(--shadow-xl)}.fab:active{transform:scale(.93)}.page-with-nav{padding-bottom:calc(60px + env(safe-area-inset-bottom) + var(--space-4))}.page-header{padding:var(--space-5) var(--space-4) var(--space-4);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:50;position:sticky;top:0}.page-header-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.list-item{align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;color:inherit;text-decoration:none;display:flex}.list-item:hover{background-color:var(--color-accent-subtle);border-color:var(--color-accent)}.list-item-icon{border-radius:var(--radius-md);background-color:var(--color-accent-subtle);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;display:flex}.list-item-content{flex:1;min-width:0}.list-item-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.list-item-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.list-item-end{text-align:right;flex-shrink:0}.list-item-amount{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.stat-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm)}.stat-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;margin-top:var(--space-1);line-height:1.1}.stat-value-accent{color:var(--color-accent)}.stat-value-success{color:var(--color-success)}.stat-value-warning{color:var(--color-warning)}.stat-value-danger{color:var(--color-danger)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent-text)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-center{text-align:center}.text-right{text-align:right}:focus-visible{outline:2.5px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.theme-toggle{cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:var(--radius-full);background:0 0;border:none;align-items:center;padding:0;display:flex}.tt-track{border-radius:var(--radius-full);background-color:var(--color-border-strong);border:1.5px solid var(--color-border);align-items:center;width:52px;height:28px;transition:background-color .25s,border-color .25s;display:flex;position:relative;overflow:hidden}.tt-track--dark{background-color:var(--color-accent);border-color:var(--color-accent)}.tt-thumb{border-radius:var(--radius-full);z-index:1;background-color:#fff;width:18px;height:18px;transition:transform .25s cubic-bezier(.34,1.56,.64,1);position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000002e}.tt-track--dark .tt-thumb{transform:translate(24px)}.tt-icon{z-index:0;justify-content:center;align-items:center;width:18px;height:18px;transition:opacity .2s,color .2s;display:flex;position:absolute}.tt-icon--left{color:var(--color-text-tertiary);opacity:0;left:3px}.tt-icon--right{color:#fff;opacity:0;right:3px}.tt-track:not(.tt-track--dark) .tt-icon--right{color:var(--color-text-secondary);opacity:1}.tt-track--dark .tt-icon--left{color:#ffffffbf;opacity:1}.theme-toggle:hover .tt-track{border-color:var(--color-accent)}.theme-toggle:focus-visible .tt-track{outline:2.5px solid var(--color-accent);outline-offset:2px}.liquid-root{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.liquid-filter{filter:blur(70px);width:130%;height:130%;position:absolute;inset:-15%}.liquid-blob{will-change:transform, border-radius;position:absolute}.landing{background-color:var(--color-bg);min-height:100dvh;overflow-x:hidden}.lnd-nav{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);position:static}.lnd-nav-inner{max-width:1080px;padding:var(--space-3) var(--space-6);align-items:center;gap:var(--space-8);margin-inline:auto;display:flex}.lnd-logo-link{border-radius:var(--radius-md);transition:background-color var(--transition-fast);flex-shrink:0;align-items:center;padding:4px 6px;text-decoration:none;display:flex}.lnd-logo{object-fit:contain;width:auto;height:48px;display:block}.lnd-nav-links{align-items:center;gap:var(--space-6);flex:1;display:flex}.lnd-nav-links a{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.lnd-nav-links a:hover{color:var(--color-text-primary)}.lnd-nav-actions{align-items:center;gap:var(--space-3);margin-left:auto;display:flex}@media (width<=767px){.lnd-nav-links{display:none}.lnd-nav-inner{gap:var(--space-3);padding-inline:var(--space-4)}}.lnd-hero{padding:96px var(--space-6) 80px;isolation:isolate;position:relative;overflow:hidden}.lnd-hero-inner{z-index:1;gap:var(--space-16);grid-template-columns:1fr 1fr;align-items:center;max-width:1080px;margin-inline:auto;display:grid;position:relative}.lnd-hero-text{flex-direction:column;align-items:flex-start;display:flex}.lnd-hero-badge{margin-bottom:var(--space-5)}.lnd-hero-title{font-size:clamp(2.4rem,4.5vw,3.75rem);font-weight:var(--font-weight-bold);letter-spacing:-.035em;color:var(--color-text-primary);margin-bottom:var(--space-5);line-height:1.08}.lnd-hero-accent{color:var(--color-accent)}.lnd-hero-sub{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--space-8);max-width:420px;line-height:1.65}.lnd-hero-ctas{align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.lnd-hero-ghost{color:var(--color-text-primary);align-items:center;gap:var(--space-2);display:inline-flex}.lnd-hero-visual{justify-content:center;align-items:center;display:flex;position:relative}.lnd-hero-float{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-success);align-items:center;gap:var(--space-2);box-shadow:var(--shadow-md);z-index:2;white-space:nowrap;display:flex;position:absolute;bottom:-12px;right:-16px}.lnd-float-dot{border-radius:var(--radius-full);background-color:var(--color-success);width:8px;height:8px;box-shadow:0 0 0 3px var(--color-success-subtle);flex-shrink:0}@media (width<=767px){.lnd-hero{padding:60px var(--space-4) 48px}.lnd-hero-inner{gap:var(--space-10);grid-template-columns:1fr}.lnd-hero-visual{order:-1}.lnd-hero-sub{max-width:100%}.lnd-hero-float{right:0}}.phone-wrap{display:inline-flex;position:relative}.phone-shadow{filter:blur(24px);background:#2563eb40;border-radius:50%;width:75%;height:40px;position:absolute;bottom:-24px;left:50%;transform:translate(-50%)}.phone-frame{background:linear-gradient(160deg,#2a2a2e 0%,#1a1a1e 60%,#111114 100%);border-radius:44px;width:248px;padding:10px;position:relative;box-shadow:inset 0 0 0 1px #ffffff1f,inset 0 1px #ffffff2e,0 40px 80px -20px #32325d40,0 20px 40px -15px #00000038}.phone-btn{background:linear-gradient(90deg,#2a2a2e,#1e1e22);border-radius:3px;position:absolute}.phone-btn--vol-up{width:3px;height:30px;top:88px;left:-3px;box-shadow:inset 1px 0 #ffffff1a}.phone-btn--vol-down{width:3px;height:30px;top:128px;left:-3px;box-shadow:inset 1px 0 #ffffff1a}.phone-btn--power{width:3px;height:44px;top:108px;right:-3px;box-shadow:inset -1px 0 #ffffff1a}.phone-screen-wrap{background-color:var(--color-surface);border-radius:36px;flex-direction:column;display:flex;overflow:hidden}.phone-status-bar{background-color:var(--color-surface);justify-content:space-between;align-items:center;padding:10px 16px 4px;display:flex}.phone-time{font-size:11px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em}.phone-status-icons{color:var(--color-text-primary);align-items:center;gap:4px;display:flex}.phone-screen{background-color:var(--color-bg);flex:1;min-height:440px;overflow:hidden}.phone-home-bar{background-color:var(--color-surface);justify-content:center;align-items:center;height:20px;display:flex}.phone-home-bar:after{content:"";background-color:var(--color-text-primary);border-radius:var(--radius-full);opacity:.2;width:90px;height:4px}.sc-root{background-color:var(--color-bg);flex-direction:column;height:100%;display:flex}.sc-topbar{align-items:center;gap:var(--space-2);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);padding:10px 12px 8px;display:flex}.sc-topbar--noback{justify-content:space-between}.sc-back{color:var(--color-accent);flex-shrink:0}.sc-topbar-title{font-size:13px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-align:center;flex:1}.sc-topbar--noback .sc-topbar-title{text-align:left}.sc-topbar-action{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-accent)}.sc-topbar-action-icon{color:var(--color-text-secondary);flex-shrink:0}.sc-badge-xs{border-radius:4px;padding:2px 5px;font-size:9px}.sc-body{padding:var(--space-3) var(--space-3);gap:var(--space-3);flex-direction:column;flex:1;display:flex;overflow:hidden}.sc-field-group{flex-direction:column;gap:3px;display:flex}.sc-field-label{font-size:9px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.sc-field-value{font-size:11px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:5px 8px}.sc-photo-btn{align-items:center;gap:var(--space-2);background-color:var(--color-accent-subtle);border:1.5px dashed var(--color-accent);border-radius:var(--radius-sm);color:var(--color-accent-text);font-size:11px;font-weight:var(--font-weight-medium);padding:7px 8px;display:flex}.sc-photo-btn--success{background-color:var(--color-success-subtle);border-color:var(--color-success);color:var(--color-success)}.sc-photo-icon{border-radius:var(--radius-sm);background-color:#2563eb1a;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.sc-photo-btn--success .sc-photo-icon{background-color:#16a34a1a}.sc-photo-check{font-size:11px;font-weight:var(--font-weight-bold);margin-left:auto}.sc-section-title{font-size:9px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.sc-lines{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:0;display:flex;overflow:hidden}.sc-line{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:7px 10px;display:flex}.sc-line:last-child{border-bottom:none}.sc-line-name{color:var(--color-text-secondary);font-size:11px}.sc-line-amount{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.sc-line--add{color:var(--color-accent);font-size:11px;font-weight:var(--font-weight-semibold);justify-content:flex-start}.sc-total-row{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.sc-total-label{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.sc-total-sub{color:var(--color-text-tertiary);font-size:9px}.sc-total-amount{font-size:15px;font-weight:var(--font-weight-bold);color:var(--color-accent);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.sc-primary-btn{background-color:var(--color-accent);color:#fff;border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-semibold);text-align:center;padding:9px 12px}.sc-client-card{align-items:center;gap:var(--space-2);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 10px;display:flex}.sc-client-avatar{border-radius:var(--radius-full);background-color:var(--color-accent);color:#fff;width:30px;height:30px;font-size:12px;font-weight:var(--font-weight-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sc-client-name{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.sc-client-date{color:var(--color-text-tertiary);margin-top:1px;font-size:9px}.sc-vf-row{align-items:center;gap:var(--space-2);background-color:var(--color-accent-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:7px 10px;display:flex}.sc-vf-qr{background:repeating-linear-gradient(0deg, var(--color-accent) 0, var(--color-accent) 2px, transparent 2px, transparent 5px), repeating-linear-gradient(90deg, var(--color-accent) 0, var(--color-accent) 2px, transparent 2px, transparent 5px);opacity:.3;border-radius:4px;flex-shrink:0;width:28px;height:28px}.sc-vf-title{font-size:10px;font-weight:var(--font-weight-bold);color:var(--color-accent-text)}.sc-vf-sub{color:var(--color-text-tertiary);margin-top:1px;font-size:9px}.sc-vf-check{color:var(--color-success);flex-shrink:0;margin-left:auto}.sc-stats-row{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.sc-stat-card{border-radius:var(--radius-md);border:1px solid var(--color-border);padding:8px 10px}.sc-stat-card--warning{background-color:var(--color-warning-subtle)}.sc-stat-card--success{background-color:var(--color-success-subtle)}.sc-stat-label{font-size:9px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:2px}.sc-stat-val{font-size:13px;font-weight:var(--font-weight-bold);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.sc-stat-card--warning .sc-stat-val{color:var(--color-warning)}.sc-stat-card--success .sc-stat-val{color:var(--color-success)}.sc-list{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;display:flex;overflow:hidden}.sc-list-item{border-bottom:1px solid var(--color-border);align-items:center;gap:8px;padding:8px 10px;display:flex}.sc-list-item:last-child{border-bottom:none}.sc-list-avatar{border-radius:var(--radius-full);background-color:var(--color-accent);color:#fff;width:28px;height:28px;font-size:11px;font-weight:var(--font-weight-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sc-list-info{flex:1;min-width:0}.sc-list-name{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sc-list-date{color:var(--color-text-tertiary);margin-top:1px;font-size:9px}.sc-list-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;display:flex}.sc-list-amount{font-size:11px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.lnd-stats-bar{justify-content:center;align-items:center;gap:var(--space-12);padding:var(--space-8) var(--space-6);background-color:var(--color-surface);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);flex-wrap:wrap;display:flex}.lnd-stat{text-align:center;flex-direction:column;align-items:center;gap:3px;display:flex}.lnd-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-accent);letter-spacing:-.03em;font-variant-numeric:tabular-nums}.lnd-stat-label{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium)}@media (width<=600px){.lnd-stats-bar{gap:var(--space-8)}}.lnd-features{padding:var(--space-4) 0;overflow:visible}.lnd-feature{padding:80px var(--space-6)}.lnd-feature--alt{background-color:var(--color-surface);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.lnd-feature-inner{grid-template-columns:1fr 1fr;align-items:center;gap:80px;max-width:1080px;margin-inline:auto;display:grid}.lnd-feature-inner--reverse{direction:rtl}.lnd-feature-inner--reverse>*{direction:ltr}.lnd-feature-text{flex-direction:column;align-items:flex-start;display:flex}.lnd-feature-tag{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);margin-bottom:var(--space-3)}.lnd-feature-title{font-size:clamp(1.75rem,2.8vw,2.25rem);font-weight:var(--font-weight-bold);letter-spacing:-.025em;color:var(--color-text-primary);margin-bottom:var(--space-4);line-height:1.12}.lnd-feature-desc{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.7}.lnd-feature-list{gap:var(--space-3);flex-direction:column;list-style:none;display:flex}.lnd-feature-list li{align-items:flex-start;gap:var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);display:flex}.lnd-feature-list li:before{content:"";border-radius:var(--radius-full);background-color:var(--color-accent-subtle);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M2 5l2 2 4-4' stroke='%232563EB' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;flex-shrink:0;width:18px;height:18px;margin-top:1px}.lnd-feature-visual{justify-content:center;align-items:center;display:flex}@media (width<=767px){.lnd-feature{padding:56px var(--space-4)}.lnd-feature-inner,.lnd-feature-inner--reverse{gap:var(--space-10);direction:ltr;grid-template-columns:1fr}.lnd-feature-visual{order:-1}}.lnd-dark-section{padding:80px var(--space-6);background-color:#0f172a}.lnd-dark-inner{grid-template-columns:1fr 1fr;align-items:center;gap:80px;max-width:1080px;margin-inline:auto;display:grid}.lnd-dark-text{flex-direction:column;align-items:flex-start;display:flex}.lnd-dark-tag{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:#60a5fa;margin-bottom:var(--space-3)}.lnd-dark-title{font-size:clamp(1.75rem,2.8vw,2.25rem);font-weight:var(--font-weight-bold);letter-spacing:-.025em;color:#f1f5f9;margin-bottom:var(--space-4);line-height:1.12}.lnd-dark-sub{font-size:var(--font-size-base);color:#94a3b8;margin-bottom:var(--space-6);line-height:1.7}.lnd-dark-items{gap:var(--space-3);flex-direction:column;display:flex}.lnd-dark-item{align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#94a3b8;display:flex}.lnd-dark-dot{border-radius:var(--radius-full);background-color:#3b82f6;flex-shrink:0;width:6px;height:6px}.lnd-dark-card{border-radius:var(--radius-xl);padding:var(--space-5);background-color:#1e293b;border:1px solid #2d3f55;box-shadow:0 20px 50px -15px #03032759,0 10px 25px -10px #00000040}.lnd-dark-card-header{padding-bottom:var(--space-4);margin-bottom:var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#f1f5f9;border-bottom:1px solid #2d3f55;justify-content:space-between;align-items:center;display:flex}.lnd-dark-badge{font-size:var(--font-size-xs);color:#60a5fa;font-weight:var(--font-weight-medium);padding:2px var(--space-2);border-radius:var(--radius-full);background-color:#3b82f626}.lnd-dark-row{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid #2d3f55;display:flex}.lnd-dark-row:last-child{border-bottom:none}.lnd-dark-avatar{border-radius:var(--radius-full);background-color:var(--color-accent);color:#fff;width:36px;height:36px;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.lnd-dark-info{flex-direction:column;flex:1;gap:2px;display:flex}.lnd-dark-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#f1f5f9}.lnd-dark-meta{font-size:var(--font-size-xs);color:#64748b}.lnd-dark-pending{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:#fbbf24;font-variant-numeric:tabular-nums}@media (width<=767px){.lnd-dark-section{padding:56px var(--space-4)}.lnd-dark-inner{gap:var(--space-10);grid-template-columns:1fr}}.lnd-vf-section{background-color:var(--color-accent-subtle);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:80px var(--space-6)}.lnd-vf-inner{text-align:center;flex-direction:column;align-items:center;max-width:700px;margin-inline:auto;display:flex}.lnd-vf-badge{align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent-text);margin-bottom:var(--space-4);display:inline-flex}.lnd-vf-title{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:var(--font-weight-bold);letter-spacing:-.025em;color:var(--color-text-primary);margin-bottom:var(--space-4)}.lnd-vf-sub{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-8);line-height:1.7}.lnd-vf-pills{gap:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.lnd-vf-pill{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);box-shadow:var(--shadow-sm)}@media (width<=767px){.lnd-vf-section{padding:56px var(--space-4)}}.lnd-cta{padding:96px var(--space-6);text-align:center}.lnd-cta-inner{flex-direction:column;align-items:center;max-width:560px;margin-inline:auto;display:flex}.lnd-cta-icon{object-fit:contain;width:96px;height:96px;margin-bottom:var(--space-5)}.lnd-cta-title{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:var(--font-weight-bold);letter-spacing:-.03em;color:var(--color-text-primary);margin-bottom:var(--space-3);line-height:1.1}.lnd-cta-sub{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.lnd-cta-actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}@media (width<=480px){.lnd-cta{padding:56px var(--space-4)}.lnd-cta-actions{flex-direction:column;align-items:stretch}}.lnd-footer{background-color:var(--color-surface);border-top:1px solid var(--color-border);padding:64px var(--space-6) var(--space-8)}.lnd-footer-inner{max-width:1080px;margin-inline:auto;margin-bottom:var(--space-10)}.lnd-footer-brand{gap:var(--space-4);flex-direction:column;display:flex}.lnd-footer-logo{object-fit:contain;width:auto;height:46px;display:block}.lnd-footer-tagline{font-size:var(--font-size-sm);color:var(--color-text-tertiary);max-width:260px;line-height:1.6}.lnd-footer-cols{gap:var(--space-8);text-align:center;grid-template-columns:repeat(3,1fr);max-width:560px;margin-inline:auto;display:grid}.lnd-footer-col{gap:var(--space-3);flex-direction:column;display:flex}.lnd-footer-col-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-primary);margin-bottom:var(--space-1)}.lnd-footer-col a{font-size:var(--font-size-sm);color:var(--color-text-tertiary);transition:color var(--transition-fast);text-decoration:none}.lnd-footer-col a:hover{color:var(--color-text-primary)}.lnd-footer-bottom{max-width:1080px;padding-top:var(--space-6);border-top:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-tertiary);justify-content:center;align-items:center;gap:var(--space-3);text-align:center;flex-wrap:wrap;margin-inline:auto;display:flex}@media (width<=767px){.lnd-footer{padding:48px var(--space-4) var(--space-8)}.lnd-footer-inner{gap:var(--space-8);grid-template-columns:1fr}.lnd-footer-cols{grid-template-columns:repeat(2,1fr)}.lnd-footer-bottom{flex-direction:column;align-items:flex-start}}.auth-page{background-color:var(--color-bg);flex-direction:column;min-height:100dvh;display:flex;position:relative;overflow:hidden}.auth-topbar{z-index:10;padding:var(--space-4) var(--space-6);justify-content:space-between;align-items:center;display:flex;position:relative}.auth-logo-link{align-items:center;text-decoration:none;display:flex}.auth-logo{object-fit:contain;width:auto;height:40px}.auth-center{z-index:10;padding:var(--space-6) var(--space-4) var(--space-10);flex:1;justify-content:center;align-items:center;display:flex;position:relative}.auth-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:460px;padding:var(--space-8);box-shadow:0 20px 50px -15px #32325d1f,0 10px 24px -10px #00000014}.auth-pills{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);margin-bottom:var(--space-6);padding:3px;display:flex}.auth-pill{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1}.auth-pill--active{background-color:var(--color-accent);color:#fff;box-shadow:0 1px 4px #2563eb59}.auth-subtitle{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-5)}.auth-roles{gap:var(--space-3);margin-bottom:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.auth-role-card{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);background-color:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family);text-align:center;flex-direction:column;display:flex}.auth-role-card:hover{border-color:var(--color-accent);background-color:var(--color-accent-subtle)}.auth-role-card--active{border-color:var(--color-accent);background-color:var(--color-accent-subtle);box-shadow:0 0 0 3px #2563eb1f}.auth-role-icon{border-radius:var(--radius-md);background-color:var(--color-surface);width:44px;height:44px;color:var(--color-text-secondary);transition:color var(--transition-fast), background-color var(--transition-fast);justify-content:center;align-items:center;display:flex}.auth-role-card--active .auth-role-icon{color:var(--color-accent);background-color:#2563eb1a}.auth-role-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.auth-role-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:1.3}.auth-form{gap:var(--space-4);margin-bottom:var(--space-5);flex-direction:column;display:flex}.auth-field{gap:var(--space-1);flex-direction:column;display:flex}.auth-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.auth-label-optional{font-weight:var(--font-weight-normal);color:var(--color-text-tertiary)}.auth-error{font-size:var(--font-size-sm);color:var(--color-danger,#dc2626);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background-color:#dc262614;border:1px solid #dc262633;margin:0}.auth-submit{justify-content:center;width:100%}.auth-switch{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0}.auth-switch-btn{font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;text-decoration:underline}@media (width<=480px){.auth-card{padding:var(--space-6);border-radius:var(--radius-lg)}.auth-topbar{padding:var(--space-3) var(--space-4)}}.dashboard{flex-direction:column;gap:36px;width:100%;max-width:900px;margin-inline:auto;display:flex}.dashboard-hero{flex-direction:column;gap:6px;display:flex}.dashboard-date{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.1em}.dashboard-greeting{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.15}.dashboard-greeting-name{color:var(--color-accent-text)}.dashboard-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-top:2px}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=860px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:12px}}.dash-stat{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base), transform var(--transition-base);flex-direction:column;gap:4px;padding:20px 20px 18px;display:flex}.dash-stat:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.dash-stat-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.dash-stat-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;line-height:1.3}.dash-stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.dash-stat-icon--accent{background-color:var(--color-accent-subtle);color:var(--color-accent)}.dash-stat-icon--warning{background-color:var(--color-warning-subtle);color:var(--color-warning)}.dash-stat-icon--success{background-color:var(--color-success-subtle);color:var(--color-success)}.dash-stat-icon--info{background-color:var(--color-info-subtle);color:var(--color-info)}.dash-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1.1}.dash-stat-sub{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.dashboard-section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}.dashboard-actions{flex-wrap:wrap;gap:12px;display:flex}.dash-action{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:112px;height:100px;color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.dash-action:hover{background-color:var(--color-accent-subtle);border-color:var(--color-accent);color:var(--color-accent-text);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.dash-action:active{transform:scale(.97)}.dash-action-icon{justify-content:center;align-items:center;display:flex}.dash-action-label{text-align:center;line-height:1.2}.imodal-btn-icon{vertical-align:middle;margin-right:5px}.imodal-backdrop{z-index:400;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.imodal-panel{background-color:var(--color-surface);width:min(600px,100vw);box-shadow:var(--shadow-xl);z-index:401;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden}.imodal-topbar{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.imodal-close{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.imodal-close:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.imodal-topbar-actions{flex-wrap:wrap;gap:8px;display:flex}.imodal-body{flex-direction:column;flex:1;gap:0;padding:24px 24px 40px;display:flex;overflow-y:auto}.imodal-loading{color:var(--color-text-tertiary);flex-direction:column;align-items:center;gap:12px;padding:64px 0;display:flex}.imodal-spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.imodal-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:16px 0}.imodal-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.imodal-number{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.imodal-from-estimate{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:4px}.imodal-badges{flex-wrap:wrap;flex-shrink:0;gap:6px;display:flex}.imodal-meta{background-color:var(--color-bg);border-radius:var(--radius-lg);flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:16px;display:flex}.imodal-meta-item{flex-direction:column;gap:2px;display:flex}.imodal-meta-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--font-weight-semibold)}.imodal-meta-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.imodal-section{border-top:1px solid var(--color-border);padding:20px 0}.imodal-section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.imodal-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.imodal-section-header .imodal-section-title{margin-bottom:0}.imodal-client-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.imodal-client-sub{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.imodal-items{border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;gap:0;display:flex;overflow:hidden}.imodal-items-head{background-color:var(--color-bg);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;grid-template-columns:1fr 80px 90px 60px 90px;gap:8px;padding:10px 14px;display:grid}.imodal-item-row{border-top:1px solid var(--color-border);font-size:var(--font-size-sm);grid-template-columns:1fr 80px 90px 60px 90px;align-items:start;gap:8px;padding:12px 14px;display:grid}.imodal-item-desc{color:var(--color-text-primary);line-height:1.4}.imodal-item-num{color:var(--color-text-secondary);font-variant-numeric:tabular-nums}@media (width<=480px){.imodal-items-head{display:none}.imodal-item-row{grid-template-rows:auto auto;grid-template-columns:1fr 1fr}.imodal-item-desc{font-weight:var(--font-weight-medium);grid-column:1/-1}}.imodal-totals{flex-direction:column;gap:8px;max-width:300px;margin-left:auto;display:flex}.imodal-totals-row{font-size:var(--font-size-sm);color:var(--color-text-secondary);justify-content:space-between;gap:16px;display:flex}.imodal-totals-row span:last-child{font-variant-numeric:tabular-nums}.imodal-totals-total{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-text-primary);border-top:1px solid var(--color-border);margin-top:4px;padding-top:8px}.imodal-totals-paid span{color:var(--color-success)}.imodal-totals-outstanding span{color:var(--color-warning);font-weight:var(--font-weight-semibold)}.imodal-notes{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal);white-space:pre-wrap}.imodal-upload-btn{border-radius:var(--radius-md);border:1.5px dashed var(--color-border-strong);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);background:0 0;align-items:center;gap:4px;padding:6px 12px;display:inline-flex}.imodal-upload-btn input{display:none}.imodal-upload-btn:hover{border-color:var(--color-accent);color:var(--color-accent-text);background-color:var(--color-accent-subtle)}.imodal-upload-btn--loading{opacity:.6;cursor:not-allowed}.imodal-no-images{font-size:var(--font-size-sm);color:var(--color-text-tertiary);text-align:center;padding:24px 0}.imodal-gallery{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;display:grid}.imodal-gallery-item{border-radius:var(--radius-lg);border:1px solid var(--color-border);background-color:var(--color-bg);overflow:hidden}.imodal-gallery-img{object-fit:cover;cursor:zoom-in;width:100%;height:110px;transition:opacity var(--transition-fast);display:block}.imodal-gallery-img:hover{opacity:.88}.imodal-gallery-footer{justify-content:space-between;align-items:center;padding:6px 8px;display:flex}.imodal-gallery-size{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.imodal-gallery-delete{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.imodal-gallery-delete:hover{background-color:var(--color-danger-subtle);color:var(--color-danger)}.imodal-lightbox{z-index:500;cursor:zoom-out;background:#000000e0;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.imodal-lightbox-img{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:100%}.invoices-page{flex-direction:column;gap:24px;width:100%;max-width:1100px;margin-inline:auto;display:flex}.invoices-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.invoices-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.15}.invoices-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:4px}.invoices-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.invoices-tabs{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:4px;padding:4px;display:flex}.invoices-tab{border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;transition:background-color var(--transition-fast), color var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:6px;padding:6px 14px;display:flex}.invoices-tab:hover{background-color:var(--color-surface);color:var(--color-text-primary)}.invoices-tab--active{background-color:var(--color-surface);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-sm)}.invoices-tab-count{border-radius:var(--radius-full);background-color:var(--color-bg);min-width:20px;height:20px;color:var(--color-text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);justify-content:center;align-items:center;padding:0 5px;display:inline-flex}.invoices-tab--active .invoices-tab-count{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.invoices-search-wrap{flex:1;min-width:180px;max-width:320px;position:relative}.invoices-search-icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.invoices-search{border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background-color:var(--color-surface);width:100%;height:40px;color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;padding:0 12px 0 36px}.invoices-search::placeholder{color:var(--color-text-tertiary)}.invoices-search:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2563eb1f}.invoices-loading{flex-direction:column;gap:10px;display:flex}.invoices-skeleton{border-radius:var(--radius-lg);height:52px}.invoices-error-banner{background-color:var(--color-danger-subtle);border:1px solid var(--color-danger-border);border-radius:var(--radius-lg);color:var(--color-danger);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.invoices-from-est{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:var(--font-weight-regular);margin-top:2px;display:block}.invoices-empty{color:var(--color-text-tertiary);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.invoices-empty p{font-size:var(--font-size-base);color:var(--color-text-tertiary)}.invoices-table-wrap{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.invoices-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.invoices-table thead tr{border-bottom:1px solid var(--color-border)}.invoices-table th{text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:12px 16px}.invoices-table th.text-right{text-align:right}.invoices-row{border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color var(--transition-fast)}.invoices-row:last-child{border-bottom:none}.invoices-row:hover{background-color:var(--color-bg)}.invoices-table td{color:var(--color-text-primary);vertical-align:middle;padding:14px 16px}.invoices-table td.text-right{text-align:right}.invoices-cell-number{font-weight:var(--font-weight-semibold);white-space:nowrap;color:var(--color-accent-text)!important;font-size:var(--font-size-sm)!important}.invoices-cell-client{white-space:nowrap;text-overflow:ellipsis;max-width:200px;color:var(--color-text-primary);overflow:hidden}.invoices-cell-date{white-space:nowrap;color:var(--color-text-secondary)!important}.invoices-cell-amount{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums;white-space:nowrap}.invoices-cell-outstanding{font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--color-warning)!important}.invoices-no-value{color:var(--color-text-tertiary)}.invoices-cards{display:none}@media (width<=860px){.invoices-table-wrap{display:none}.invoices-cards{flex-direction:column;gap:10px;display:flex}.invoices-toolbar{flex-direction:column;align-items:stretch}.invoices-tabs{min-width:0;overflow-x:auto}.invoices-tabs::-webkit-scrollbar{display:none}.invoices-search-wrap{max-width:100%}}.inv-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:background-color var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;padding:16px}.inv-card:hover{background-color:var(--color-bg);box-shadow:var(--shadow-sm)}.inv-card-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.inv-card-number{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-accent-text)}.inv-card-client{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-top:2px}.inv-card-amount{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.inv-card-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.inv-card-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.inv-card-badges{flex-wrap:wrap;gap:6px;display:flex}.inv-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;letter-spacing:.02em;align-items:center;padding:3px 10px;display:inline-flex}.inv-badge--status-draft{background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.inv-badge--status-issued{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.inv-badge--status-voided{background-color:var(--color-danger-subtle);color:var(--color-danger);border:1px solid var(--color-danger-border)}.inv-badge--status-corrected,.inv-badge--pay-pending{background-color:var(--color-warning-subtle);color:var(--color-warning);border:1px solid var(--color-warning-border)}.inv-badge--pay-partial{background-color:var(--color-info-subtle);color:var(--color-info);border:1px solid var(--color-info-border)}.inv-badge--pay-paid{background-color:var(--color-success-subtle);color:var(--color-success);border:1px solid var(--color-success-border)}.inv-badge--pay-overdue{background-color:var(--color-danger-subtle);color:var(--color-danger);border:1px solid var(--color-danger-border)}.qcm-backdrop{z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;position:fixed;inset:0}.qcm-panel{background-color:var(--color-surface);border-radius:var(--radius-2xl);width:min(420px,100vw - 32px);height:fit-content;box-shadow:var(--shadow-xl);z-index:501;margin:auto;position:fixed;inset:0;overflow:hidden}.qcm-header{justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex}.qcm-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.qcm-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.qcm-close:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.qcm-form{flex-direction:column;gap:14px;padding:20px;display:flex}.qcm-field{flex-direction:column;gap:6px;display:flex}.qcm-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.qcm-req{color:var(--color-danger)}.qcm-error{font-size:var(--font-size-sm);color:var(--color-danger)}.qcm-actions{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.new-inv-page{width:100%;max-width:900px;margin-inline:auto}.new-inv-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.new-inv-back{border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:6px;padding:8px 12px;display:flex}.new-inv-back:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.new-inv-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.new-inv-form{flex-direction:column;gap:20px;display:flex}.new-inv-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:24px}.new-inv-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:20px}.new-inv-card-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:-12px;margin-bottom:16px}.new-inv-fields{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width<=600px){.new-inv-fields{grid-template-columns:1fr}}.new-inv-field{flex-direction:column;gap:6px;display:flex}.new-inv-field--wide{grid-column:1/-1}.new-inv-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.new-inv-req{color:var(--color-danger)}.new-inv-client-wrap{position:relative}.new-inv-client-list{background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:50;max-height:220px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.new-inv-client-opt{width:100%;font-family:var(--font-family);cursor:pointer;text-align:left;transition:background-color var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.new-inv-client-opt:hover{background-color:var(--color-accent-subtle)}.new-inv-client-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.new-inv-client-tax{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.new-inv-client-create{border:none;border-top:1px solid var(--color-border);width:100%;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-accent-text);cursor:pointer;text-align:left;transition:background-color var(--transition-fast);background:0 0;align-items:center;gap:7px;padding:10px 14px;display:flex}.new-inv-client-create:hover{background-color:var(--color-accent-subtle)}.new-inv-client-create strong{font-weight:var(--font-weight-semibold);color:var(--color-accent-text)}.new-inv-lines-head{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);grid-template-columns:1fr 70px 70px 100px 65px 65px 100px 32px;gap:8px;margin-bottom:8px;padding:0 0 8px;display:grid}.new-inv-col-desc{min-width:0}.new-inv-line-row{border-bottom:1px solid var(--color-border);grid-template-columns:1fr 70px 70px 100px 65px 65px 100px 32px;align-items:center;gap:8px;padding:8px 0;display:grid}.new-inv-line-row:last-of-type{border-bottom:none}.input-sm{min-height:38px!important;padding:var(--space-2) var(--space-3)!important;font-size:var(--font-size-sm)!important}.new-inv-line-total{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;text-align:right}.new-inv-remove-line{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.new-inv-remove-line:hover:not(:disabled){background-color:var(--color-danger-subtle);color:var(--color-danger)}.new-inv-remove-line:disabled{opacity:.3;cursor:not-allowed}.new-inv-add-line{border-radius:var(--radius-md);border:1.5px dashed var(--color-border-strong);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);background:0 0;align-items:center;gap:6px;margin-top:12px;padding:8px 12px;display:flex}.new-inv-add-line:hover{border-color:var(--color-accent);color:var(--color-accent-text);background-color:var(--color-accent-subtle)}.new-inv-totals{border-top:1px solid var(--color-border);flex-direction:column;gap:8px;max-width:280px;margin-top:20px;margin-left:auto;padding-top:16px;display:flex}.new-inv-totals-row{font-size:var(--font-size-sm);color:var(--color-text-secondary);justify-content:space-between;gap:16px;display:flex}.new-inv-totals-row span:last-child{font-variant-numeric:tabular-nums}.new-inv-totals-total{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-text-primary);border-top:1px solid var(--color-border);margin-top:4px;padding-top:8px}.new-inv-dropzone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-xl);color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--transition-fast), background-color var(--transition-fast), color var(--transition-fast);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 24px;display:flex}.new-inv-dropzone input{display:none}.new-inv-dropzone:hover{border-color:var(--color-accent);background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.new-inv-dropzone span{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.new-inv-dropzone-sub{font-size:var(--font-size-xs)!important;color:var(--color-text-tertiary)!important;font-weight:var(--font-weight-regular)!important}.new-inv-previews{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-top:16px;display:grid}.new-inv-preview{border-radius:var(--radius-lg);border:1px solid var(--color-border);aspect-ratio:1;position:relative;overflow:hidden}.new-inv-preview img{object-fit:cover;width:100%;height:100%;display:block}.new-inv-preview-remove{border-radius:var(--radius-full);color:#fff;cursor:pointer;width:22px;height:22px;transition:background-color var(--transition-fast);background:#0009;border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:4px;right:4px}.new-inv-preview-remove:hover{background:var(--color-danger)}.new-inv-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:0 4px}.new-inv-actions{justify-content:flex-end;gap:12px;padding-bottom:24px;display:flex}@media (width<=860px){.new-inv-lines-head{display:none}.new-inv-line-row{grid-template-rows:auto auto auto;grid-template-columns:1fr 1fr;gap:8px;padding:12px 0}.new-inv-col-desc{grid-column:1/-1}.new-inv-line-total{text-align:left}}.app-layout{background-color:var(--color-bg);min-height:100dvh;display:flex}.sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:200;width:240px;height:100dvh;transition:width var(--transition-slow), transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar--collapsed{width:68px}@media (width<=767px){.sidebar{width:240px;box-shadow:var(--shadow-xl);transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar--collapsed{width:240px}}.sidebar-overlay{z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;position:fixed;inset:0}.sidebar-header{flex-shrink:0;justify-content:space-between;align-items:center;min-height:64px;padding:20px 16px 16px;display:flex}.sidebar-logo{flex:1;align-items:center;display:flex;overflow:hidden}.sidebar-logo-img{object-fit:contain;width:auto;height:28px}.sidebar-icon{object-fit:contain;width:32px;height:32px}.sidebar-toggle{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-toggle:hover{background-color:var(--color-bg);color:var(--color-text-primary)}@media (width<=767px){.sidebar-toggle{display:none}}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 10px;display:flex;overflow-y:auto}.sidebar-nav-item{border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast), color var(--transition-fast);white-space:nowrap;align-items:center;gap:12px;min-height:40px;padding:10px;text-decoration:none;display:flex}.sidebar-nav-item:hover{background-color:var(--color-bg);color:var(--color-text-primary);text-decoration:none}.sidebar-nav-item--active{background-color:var(--color-accent-subtle);color:var(--color-accent-text);font-weight:var(--font-weight-semibold)}.sidebar-nav-item--active:hover{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.sidebar-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-nav-label{text-overflow:ellipsis;overflow:hidden}.sidebar-footer{border-top:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;padding:12px 10px;display:flex}.sidebar-user{flex:1;align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.sidebar-user--collapsed{justify-content:center}.sidebar-avatar{border-radius:var(--radius-full);background-color:var(--color-accent-subtle);width:32px;height:32px;color:var(--color-accent-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex-direction:column;min-width:0;display:flex}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-email{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-logout{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout:hover{background-color:var(--color-danger-subtle);color:var(--color-danger)}.app-main{min-height:100dvh;transition:margin-left var(--transition-slow);flex-direction:column;flex:1;margin-left:240px;display:flex}.sidebar--collapsed~.app-main{margin-left:68px}@media (width<=767px){.app-main{margin-left:0!important}}.app-topbar{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-menu-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:none}@media (width<=767px){.topbar-menu-btn{display:flex}}.topbar-menu-btn:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.topbar-right{align-items:center;gap:8px;margin-left:auto;display:flex}.app-content{flex:1;padding:32px;overflow-x:hidden}@media (width<=767px){.app-content{padding:20px 16px}}.cmodal-backdrop{z-index:400;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.cmodal-panel{background-color:var(--color-surface);width:min(560px,100vw);box-shadow:var(--shadow-xl);z-index:401;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden}.cmodal-topbar{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.cmodal-close{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.cmodal-close:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.cmodal-topbar-actions{flex-wrap:wrap;gap:8px;display:flex}.cmodal-body{flex-direction:column;flex:1;padding:24px 24px 40px;display:flex;overflow-y:auto}.cmodal-loading{color:var(--color-text-tertiary);flex-direction:column;align-items:center;gap:12px;padding:64px 0;display:flex}.cmodal-spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite cmodal-spin}@keyframes cmodal-spin{to{transform:rotate(360deg)}}.cmodal-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:0 0 16px}.cmodal-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.cmodal-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.cmodal-legal-name{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:4px}.cmodal-fields{grid-template-columns:1fr 1fr;gap:20px;display:grid}.cmodal-field{flex-direction:column;gap:3px;display:flex}.cmodal-field--full{grid-column:1/-1}.cmodal-field-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.cmodal-field-value{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5}.cmodal-link{color:var(--color-accent-text);text-decoration:none}.cmodal-link:hover{text-decoration:underline}.cmodal-notes{white-space:pre-wrap;color:var(--color-text-secondary)!important}.cmodal-form{flex-direction:column;gap:20px;display:flex}.cmodal-form-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.cmodal-form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.cmodal-form-group{flex-direction:column;gap:6px;display:flex}.cmodal-form-group--full{grid-column:1/-1}.cmodal-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.cmodal-required{color:var(--color-danger)}.cmodal-input{border-radius:var(--radius-md);border:1.5px solid var(--color-border);background-color:var(--color-bg);width:100%;height:38px;color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;padding:0 12px}.cmodal-input::placeholder{color:var(--color-text-tertiary)}.cmodal-input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2563eb1f}.cmodal-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%236B6B6B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.cmodal-textarea{resize:vertical;height:auto;padding:10px 12px;line-height:1.5}@media (width<=480px){.cmodal-form-grid{grid-template-columns:1fr}.cmodal-form-group--full{grid-column:1}.cmodal-fields{grid-template-columns:1fr}.cmodal-field--full{grid-column:1}}.clients-page{flex-direction:column;gap:24px;width:100%;max-width:1100px;margin-inline:auto;display:flex}.clients-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.clients-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.15}.clients-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:4px}.clients-toolbar{align-items:center;display:flex}.clients-search-wrap{width:100%;max-width:380px;position:relative}.clients-search-icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.clients-search{border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background-color:var(--color-surface);width:100%;height:40px;color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;padding:0 12px 0 36px}.clients-search::placeholder{color:var(--color-text-tertiary)}.clients-search:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2563eb1f}.clients-loading{flex-direction:column;gap:10px;display:flex}.clients-skeleton{border-radius:var(--radius-lg);height:52px}.clients-error-banner{background-color:var(--color-danger-subtle);border:1px solid var(--color-danger-border);border-radius:var(--radius-lg);color:var(--color-danger);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.clients-empty{color:var(--color-text-tertiary);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.clients-empty p{font-size:var(--font-size-base);color:var(--color-text-tertiary)}.clients-table-wrap{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.clients-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.clients-table thead tr{border-bottom:1px solid var(--color-border)}.clients-table th{text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:12px 16px}.clients-row{border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color var(--transition-fast)}.clients-row:last-child{border-bottom:none}.clients-row:hover{background-color:var(--color-bg)}.clients-table td{color:var(--color-text-primary);vertical-align:middle;padding:14px 16px}.clients-cell-name{max-width:220px}.clients-display-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.clients-legal-name{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;display:block;overflow:hidden}.clients-cell-muted{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden;color:var(--color-text-secondary)!important}.clients-no-value{color:var(--color-text-tertiary)}.clients-cards{display:none}@media (width<=860px){.clients-table-wrap{display:none}.clients-cards{flex-direction:column;gap:10px;display:flex}.clients-toolbar{align-items:stretch}.clients-search-wrap{max-width:100%}}.cli-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:background-color var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;padding:16px}.cli-card:hover{background-color:var(--color-bg);box-shadow:var(--shadow-sm)}.cli-card-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.cli-card-info{flex:1;min-width:0}.cli-card-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.cli-card-legal{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.cli-card-bottom{flex-wrap:wrap;gap:6px 16px;display:flex}.cli-card-detail{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.cli-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;letter-spacing:.02em;flex-shrink:0;align-items:center;padding:3px 10px;display:inline-flex}.cli-badge--individual{background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.cli-badge--company{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.emodal-btn-icon{vertical-align:middle;margin-right:5px}.emodal-backdrop{z-index:400;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.emodal-panel{background-color:var(--color-surface);width:min(600px,100vw);box-shadow:var(--shadow-xl);z-index:401;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden}.emodal-topbar{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.emodal-close{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.emodal-close:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.emodal-topbar-actions{flex-wrap:wrap;gap:8px;display:flex}.emodal-body{flex-direction:column;flex:1;gap:0;padding:24px 24px 40px;display:flex;overflow-y:auto}.emodal-loading{color:var(--color-text-tertiary);flex-direction:column;align-items:center;gap:12px;padding:64px 0;display:flex}.emodal-spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite emodal-spin}@keyframes emodal-spin{to{transform:rotate(360deg)}}.emodal-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:16px 0}.emodal-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.emodal-number{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.emodal-meta{background-color:var(--color-bg);border-radius:var(--radius-lg);flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:16px;display:flex}.emodal-meta-item{flex-direction:column;gap:2px;display:flex}.emodal-meta-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--font-weight-semibold)}.emodal-meta-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.emodal-meta-expired{color:var(--color-danger)!important}.emodal-section{border-top:1px solid var(--color-border);padding:20px 0}.emodal-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.emodal-client-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.emodal-client-sub{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.emodal-items{border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;gap:0;display:flex;overflow:hidden}.emodal-items-head{background-color:var(--color-bg);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;grid-template-columns:1fr 80px 90px 60px 90px;gap:8px;padding:10px 14px;display:grid}.emodal-item-row{border-top:1px solid var(--color-border);font-size:var(--font-size-sm);grid-template-columns:1fr 80px 90px 60px 90px;align-items:start;gap:8px;padding:12px 14px;display:grid}.emodal-item-desc{color:var(--color-text-primary);line-height:1.4}.emodal-item-num{color:var(--color-text-secondary);font-variant-numeric:tabular-nums}@media (width<=480px){.emodal-items-head{display:none}.emodal-item-row{grid-template-rows:auto auto;grid-template-columns:1fr 1fr}.emodal-item-desc{font-weight:var(--font-weight-medium);grid-column:1/-1}}.emodal-totals{flex-direction:column;gap:8px;max-width:300px;margin-left:auto;display:flex}.emodal-totals-row{font-size:var(--font-size-sm);color:var(--color-text-secondary);justify-content:space-between;gap:16px;display:flex}.emodal-totals-row span:last-child{font-variant-numeric:tabular-nums}.emodal-totals-total{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-text-primary);border-top:1px solid var(--color-border);margin-top:4px;padding-top:8px}.emodal-notes{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal);white-space:pre-wrap}.emodal-section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.emodal-section-header .emodal-section-title{margin-bottom:0}.emodal-upload-btn{border-radius:var(--radius-md);border:1.5px dashed var(--color-border-strong);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);background:0 0;align-items:center;gap:4px;padding:6px 12px;display:inline-flex}.emodal-upload-btn input{display:none}.emodal-upload-btn:hover{border-color:var(--color-accent);color:var(--color-accent-text);background-color:var(--color-accent-subtle)}.emodal-upload-btn--loading{opacity:.6;cursor:not-allowed}.emodal-no-images{font-size:var(--font-size-sm);color:var(--color-text-tertiary);text-align:center;padding:24px 0}.emodal-gallery{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;display:grid}.emodal-gallery-item{border-radius:var(--radius-lg);border:1px solid var(--color-border);background-color:var(--color-bg);overflow:hidden}.emodal-gallery-img{object-fit:cover;cursor:zoom-in;width:100%;height:110px;transition:opacity var(--transition-fast);display:block}.emodal-gallery-img:hover{opacity:.88}.emodal-gallery-footer{justify-content:space-between;align-items:center;padding:6px 8px;display:flex}.emodal-gallery-size{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.emodal-gallery-delete{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.emodal-gallery-delete:hover{background-color:var(--color-danger-subtle);color:var(--color-danger)}.emodal-lightbox{z-index:500;cursor:zoom-out;background:#000000e0;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.emodal-lightbox-img{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:100%}.estimates-page{flex-direction:column;gap:24px;width:100%;max-width:1100px;margin-inline:auto;display:flex}.estimates-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.estimates-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.15}.estimates-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:4px}.estimates-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.estimates-tabs{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:4px;padding:4px;display:flex}.estimates-tab{border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;transition:background-color var(--transition-fast), color var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:6px;padding:6px 14px;display:flex}.estimates-tab:hover{background-color:var(--color-surface);color:var(--color-text-primary)}.estimates-tab--active{background-color:var(--color-surface);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-sm)}.estimates-tab-count{border-radius:var(--radius-full);background-color:var(--color-bg);min-width:20px;height:20px;color:var(--color-text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);justify-content:center;align-items:center;padding:0 5px;display:inline-flex}.estimates-tab--active .estimates-tab-count{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.estimates-search-wrap{flex:1;min-width:180px;max-width:320px;position:relative}.estimates-search-icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.estimates-search{border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background-color:var(--color-surface);width:100%;height:40px;color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;padding:0 12px 0 36px}.estimates-search::placeholder{color:var(--color-text-tertiary)}.estimates-search:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2563eb1f}.estimates-loading{flex-direction:column;gap:10px;display:flex}.estimates-skeleton{border-radius:var(--radius-lg);height:52px}.estimates-error-banner{background-color:var(--color-danger-subtle);border:1px solid var(--color-danger-border);border-radius:var(--radius-lg);color:var(--color-danger);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.estimates-empty{color:var(--color-text-tertiary);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.estimates-empty p{font-size:var(--font-size-base);color:var(--color-text-tertiary)}.estimates-table-wrap{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.estimates-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.estimates-table thead tr{border-bottom:1px solid var(--color-border)}.estimates-table th{text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:12px 16px}.estimates-table th.text-right{text-align:right}.estimates-row{border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color var(--transition-fast)}.estimates-row:last-child{border-bottom:none}.estimates-row:hover{background-color:var(--color-bg)}.estimates-table td{color:var(--color-text-primary);vertical-align:middle;padding:14px 16px}.estimates-table td.text-right{text-align:right}.estimates-cell-number{font-weight:var(--font-weight-semibold);white-space:nowrap;color:var(--color-accent-text)!important}.estimates-cell-client{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.estimates-cell-date{white-space:nowrap;color:var(--color-text-secondary)!important}.estimates-cell-expired{color:var(--color-danger)!important}.estimates-cell-amount{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums;white-space:nowrap}.estimates-no-value{color:var(--color-text-tertiary)}.estimates-cards{display:none}@media (width<=860px){.estimates-table-wrap{display:none}.estimates-cards{flex-direction:column;gap:10px;display:flex}.estimates-toolbar{flex-direction:column;align-items:stretch}.estimates-tabs{min-width:0;overflow-x:auto}.estimates-tabs::-webkit-scrollbar{display:none}.estimates-search-wrap{max-width:100%}}.est-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:background-color var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;padding:16px}.est-card:hover{background-color:var(--color-bg);box-shadow:var(--shadow-sm)}.est-card-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.est-card-number{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-accent-text)}.est-card-client{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-top:2px}.est-card-amount{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.est-card-bottom{justify-content:space-between;align-items:center;gap:8px;display:flex}.est-card-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.est-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;letter-spacing:.02em;align-items:center;padding:3px 10px;display:inline-flex}.est-badge--draft{background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.est-badge--sent{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.est-badge--accepted{background-color:var(--color-success-subtle);color:var(--color-success);border:1px solid var(--color-success-border)}.est-badge--rejected{background-color:var(--color-danger-subtle);color:var(--color-danger);border:1px solid var(--color-danger-border)}.est-badge--expired{background-color:var(--color-warning-subtle);color:var(--color-warning);border:1px solid var(--color-warning-border)}.est-badge--converted{background-color:var(--color-info-subtle,#eff6ff);color:var(--color-info,#2563eb);border:1px solid var(--color-info-border,#bfdbfe)}.reports-page{flex-direction:column;gap:20px;max-width:1100px;margin-inline:auto;display:flex}.reports-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.reports-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.2}.reports-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:2px}.reports-year-select{width:auto;min-width:100px}.reports-period{flex-wrap:wrap;gap:6px;display:flex}.reports-period-btn{border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;background:0 0;padding:5px 12px}.reports-period-btn:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.reports-period-btn--active{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.reports-period-btn--active:hover{background-color:var(--color-accent);color:#fff}.reports-kpis{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.report-kpi{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;gap:4px;padding:20px 22px;display:flex}.report-kpi--positive{border-left:3px solid var(--color-success)}.report-kpi--warning{border-left:3px solid var(--color-warning,#f59e0b)}.report-kpi-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.report-kpi-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;margin-top:4px;line-height:1.2}.report-kpi-sub{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.report-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:20px 22px}.report-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}.report-chart-wrap{overflow:hidden}.report-chart-svg{display:block;overflow:visible}.report-bar-bg{fill:var(--color-bg);rx:2}.report-bar{fill:var(--color-accent);opacity:.85;transition:opacity .15s}.report-bar:hover{opacity:1}.report-bar-label{fill:var(--color-text-tertiary);font-size:10px;font-family:var(--font-family)}.report-chart-placeholder{border-radius:var(--radius-lg);height:156px}.reports-bottom{grid-template-columns:1fr 360px;align-items:start;gap:16px;display:grid}.report-card--wide{min-width:0}.reports-bottom-right{flex-direction:column;gap:16px;min-width:0;display:flex}.report-table-wrap{margin:0 -4px;padding:0 4px;overflow-x:auto}.report-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.report-table th{text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap;padding:8px 10px}.report-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-primary);vertical-align:middle;padding:10px}.report-table tbody tr:last-child td{border-bottom:none}.report-table tbody tr:hover td{background-color:var(--color-bg)}.report-table-total td{font-weight:var(--font-weight-semibold);border-top:1px solid var(--color-border);padding-top:10px}.report-cell-mono{font-variant-numeric:tabular-nums}.report-cell-danger{color:var(--color-danger)}.report-cell-warning{color:var(--color-warning,#f59e0b)}.report-no-value{color:var(--color-text-tertiary)}.report-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;align-items:center;padding:2px 8px;display:inline-flex}.report-badge--danger{background-color:var(--color-danger-subtle);color:var(--color-danger)}.report-badge--warning{color:#92400e;background-color:#fef3c7}.report-badge--ok{background-color:var(--color-success-subtle,#dcfce7);color:var(--color-success)}.report-badge--neutral{background-color:var(--color-bg);color:var(--color-text-tertiary);border:1px solid var(--color-border)}.report-top-clients{flex-direction:column;gap:0;display:flex}.report-top-client-row{border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);grid-template-columns:22px 1fr auto auto;align-items:center;gap:8px;padding:10px 0;display:grid}.report-top-client-row:last-child{border-bottom:none}.report-top-rank{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-tertiary);text-align:center}.report-top-name{color:var(--color-text-primary);font-weight:var(--font-weight-medium);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.report-top-count{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap}.report-top-amount{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.report-vat-rate{border-radius:var(--radius-full);background-color:var(--color-bg);border:1px solid var(--color-border);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);padding:2px 8px;display:inline-flex}.report-skeleton-rows{flex-direction:column;gap:10px;display:flex}.report-skeleton-row{border-radius:var(--radius-md);height:36px}.report-empty{font-size:var(--font-size-sm);color:var(--color-text-tertiary);text-align:center;padding:24px 0}@media (width<=900px){.reports-kpis{grid-template-columns:repeat(2,1fr)}.reports-bottom{grid-template-columns:1fr}.reports-bottom-right{flex-flow:wrap}.reports-bottom-right .report-card{flex:1;min-width:260px}}@media (width<=560px){.reports-kpis{grid-template-columns:repeat(2,1fr);gap:10px}.report-kpi{padding:16px}.report-kpi-value{font-size:var(--font-size-xl)}.reports-bottom-right{flex-direction:column}.reports-bottom-right .report-card{flex:unset;min-width:unset}}
