@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:16px;line-height:1.55;color:var(--color-ink);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{font-size:48px;font-weight:700;line-height:1.15}h2{font-size:32px;font-weight:700;line-height:1.2}h3{font-size:24px;font-weight:600;line-height:1.25}h4{font-size:20px;font-weight:600;line-height:1.3}h5{font-size:18px;font-weight:600;line-height:1.35}h6{font-size:16px;font-weight:600;line-height:1.4}p{line-height:1.7}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}img{display:block;max-width:100%;height:auto}ul,ol{list-style:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.text-muted{color:var(--color-ink-muted)}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-info{color:var(--color-info)}.text-sm{font-size:14px}.text-xs{font-size:12px}.text-lg{font-size:18px}.text-xl{font-size:20px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-right{text-align:right}.mt-auto{margin-top:auto}.ml-auto{margin-left:auto}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.divider{height:1px;background-color:var(--color-border);border:none;margin:var(--space-5) 0}.page-wrapper{min-height:100vh;display:flex;flex-direction:column}.page-main{flex:1}.section{padding:var(--space-8) 0}.section-sm{padding:var(--space-6) 0}.breadcrumbs{display:flex;align-items:center;gap:var(--space-2);font-size:14px;color:var(--color-ink-muted);margin-bottom:var(--space-5)}.breadcrumbs a{color:var(--color-ink-muted)}.breadcrumbs a:hover{color:var(--color-primary)}.breadcrumbs .sep{color:var(--color-border)}.breadcrumbs .current{color:var(--color-ink)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-5);text-align:center;gap:var(--space-4)}.empty-state__icon{width:64px;height:64px;color:var(--color-border)}.empty-state__title{font-size:20px;font-weight:600;color:var(--color-ink)}.empty-state__description{color:var(--color-ink-muted);max-width:320px}#toast-container{position:fixed;bottom:var(--space-5);right:var(--space-5);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3)}.toast{background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-lg);font-size:14px;max-width:320px;animation:slideIn var(--transition-normal) forwards}.toast--success{border-left-color:var(--color-success)}.toast--warning{border-left-color:var(--color-warning)}.toast--danger{border-left-color:var(--color-danger)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 480px){h1{font-size:32px}h2{font-size:24px}h3{font-size:20px}}.container{width:100%;max-width:1200px;margin-inline:auto;padding-inline:var(--space-5)}.container--wide{max-width:1400px}.container--narrow{max-width:760px}.customer-header{position:sticky;top:0;z-index:var(--z-header);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.customer-header__inner{display:flex;align-items:center;gap:var(--space-5);height:68px}.customer-header__logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;flex-shrink:0}.customer-header__logo img{height:44px;width:44px;object-fit:contain;border-radius:50%}.customer-header__logo-text{font-size:18px;font-weight:700;color:var(--color-ink);line-height:1.2}.customer-header__logo-sub{font-size:11px;color:var(--color-ink-muted);font-weight:400}.customer-header__nav{display:flex;align-items:center;gap:var(--space-1);margin-inline:auto}.customer-header__nav-link{font-size:14px;font-weight:500;color:var(--color-ink-muted);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast)}.customer-header__nav-link:hover,.customer-header__nav-link.active{color:var(--color-primary);background:#e85a2c0f}.customer-header__actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.header-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);color:var(--color-ink-muted);transition:color var(--transition-fast),background var(--transition-fast)}.header-icon-btn:hover{color:var(--color-ink);background:var(--color-surface-alt)}.header-icon-btn .badge-count{position:absolute;top:4px;right:4px;min-width:18px;height:18px;background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;padding:0 4px}.header-auth-links{display:flex;align-items:center;gap:var(--space-2)}.header-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);color:var(--color-ink)}.mobile-nav{display:none;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);background:var(--color-surface)}.mobile-nav.open{display:flex}.mobile-nav__link{font-size:15px;font-weight:500;color:var(--color-ink);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.customer-footer{background:var(--color-accent);color:#ffffffd9;padding:var(--space-7) 0 var(--space-5)}.customer-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:var(--space-7);padding-bottom:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:var(--space-5)}.customer-footer__brand-logo{height:52px;width:52px;object-fit:contain;border-radius:50%;margin-bottom:var(--space-3)}.customer-footer__tagline{font-size:14px;line-height:1.7;margin-bottom:var(--space-4);opacity:.8}.customer-footer__social{display:flex;gap:var(--space-3)}.customer-footer__social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:#ffffff1a;color:#fff;transition:background var(--transition-fast)}.customer-footer__social-link:hover{background:var(--color-primary)}.customer-footer__col-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff;margin-bottom:var(--space-4)}.customer-footer__links{display:flex;flex-direction:column;gap:var(--space-2)}.customer-footer__link{font-size:14px;color:#ffffffb3;transition:color var(--transition-fast)}.customer-footer__link:hover{color:#fff}.customer-footer__contact-item{display:flex;gap:var(--space-3);font-size:14px;color:#ffffffb3;margin-bottom:var(--space-3);align-items:flex-start}.customer-footer__contact-item svg{flex-shrink:0;margin-top:2px;color:var(--color-primary)}.customer-footer__bottom{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#ffffff80}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:256px;flex-shrink:0;background:var(--color-admin-sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:var(--z-sidebar);transition:width var(--transition-normal);overflow:hidden}.admin-sidebar.collapsed{width:64px}.admin-sidebar__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-4);border-bottom:1px solid rgba(255,255,255,.06);height:68px;flex-shrink:0}.admin-sidebar__logo{width:36px;height:36px;object-fit:contain;border-radius:50%;flex-shrink:0}.admin-sidebar__brand{overflow:hidden;white-space:nowrap}.admin-sidebar__brand-name{font-size:15px;font-weight:700;color:#fff}.admin-sidebar__brand-sub{font-size:11px;color:#fff6}.admin-sidebar__nav{flex:1;padding:var(--space-3) 0;overflow-y:auto;scrollbar-width:none}.admin-sidebar__nav::-webkit-scrollbar{display:none}.admin-nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#ffffff4d;padding:var(--space-3) var(--space-4) var(--space-2)}.admin-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:#ffffff8c;font-size:14px;font-weight:500;text-decoration:none;transition:color var(--transition-fast),background var(--transition-fast);position:relative;white-space:nowrap;border-left:3px solid transparent}.admin-nav-item:hover{color:#ffffffe6;background:#ffffff0d}.admin-nav-item.active{color:#fff;background:#e85a2c1f;border-left-color:var(--color-primary)}.admin-nav-item svg{flex-shrink:0}.admin-nav-item__badge{margin-left:auto;background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:var(--radius-pill)}.admin-sidebar__footer{padding:var(--space-4);border-top:1px solid rgba(255,255,255,.06)}.admin-sidebar__collapse-btn{display:flex;align-items:center;gap:var(--space-3);color:#fff6;font-size:13px;padding:var(--space-2) 0;transition:color var(--transition-fast);white-space:nowrap}.admin-sidebar__collapse-btn svg{transition:transform var(--transition-normal)}.admin-sidebar__collapse-btn:hover{color:#fffc}.admin-sidebar.collapsed .admin-sidebar__header{justify-content:center;padding:var(--space-4) 0}.admin-sidebar.collapsed .admin-sidebar__brand{display:none}.admin-sidebar.collapsed .admin-nav-item{justify-content:center;padding:var(--space-3) 0}.admin-sidebar.collapsed .admin-nav-item span{display:none}.admin-sidebar.collapsed .admin-nav-item__badge{display:none!important}.admin-sidebar.collapsed .admin-nav-section-label{display:none}.admin-sidebar.collapsed .admin-sidebar__collapse-btn{justify-content:center}.admin-sidebar.collapsed .admin-sidebar__collapse-btn span{display:none}.admin-sidebar.collapsed .admin-sidebar__collapse-btn svg{transform:rotate(180deg)}.admin-topbar{position:fixed;top:0;left:256px;right:0;height:68px;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-4);padding:0 var(--space-5);z-index:var(--z-header);transition:left var(--transition-normal)}.admin-topbar.sidebar-collapsed{left:64px}.admin-topbar__breadcrumbs{flex:1;font-size:14px}.admin-topbar__search{position:relative;width:260px}.admin-topbar__search input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 36px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);font-size:14px;color:var(--color-ink)}.admin-topbar__search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-ink-muted)}.admin-topbar__actions{display:flex;align-items:center;gap:var(--space-3)}.admin-topbar__user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);position:relative}.admin-topbar__user:hover{background:var(--color-surface-alt)}.admin-topbar__avatar{width:34px;height:34px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.admin-topbar__user-name{font-size:14px;font-weight:600;color:var(--color-ink)}.admin-topbar__user-role{font-size:12px;color:var(--color-ink-muted)}.admin-user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;padding:var(--space-2);z-index:var(--z-modal);display:none}.admin-user-dropdown.open{display:block}.admin-user-dropdown a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);font-size:14px;color:var(--color-ink);border-radius:var(--radius-md);transition:background var(--transition-fast)}.admin-user-dropdown a:hover{background:var(--color-surface-alt)}.admin-user-dropdown .divider-item{height:1px;background:var(--color-border);margin:var(--space-2) 0}.admin-content{margin-left:256px;margin-top:68px;padding:var(--space-5) var(--space-6);min-height:calc(100vh - 68px);transition:margin-left var(--transition-normal);box-sizing:border-box;width:calc(100% - 256px)}.admin-content.sidebar-collapsed{margin-left:64px;width:calc(100% - 64px)}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.admin-page-title{font-size:24px;font-weight:700;color:var(--color-ink)}.admin-page-subtitle{font-size:14px;color:var(--color-ink-muted);margin-top:var(--space-1)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.drawer-overlay{position:fixed;inset:0;background:#00000059;z-index:var(--z-drawer);display:none;animation:fadeIn var(--transition-normal) forwards}.drawer-overlay.open{display:block}.drawer{position:fixed;top:0;right:0;height:100vh;width:560px;max-width:95vw;background:var(--color-surface);z-index:calc(var(--z-drawer) + 1);display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition-normal);box-shadow:var(--shadow-lg)}.drawer.open{transform:translate(0)}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer__title{font-size:18px;font-weight:700}.drawer__body{flex:1;overflow-y:auto;padding:var(--space-5)}.drawer__footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);flex-shrink:0}.modal-overlay{position:fixed;inset:0;background:#00000059;z-index:var(--z-modal);display:none;align-items:center;justify-content:center;padding:var(--space-5)}.modal-overlay.open{display:flex}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--color-border)}.modal__title{font-size:18px;font-weight:700}.modal__body{padding:var(--space-5)}.modal__footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--space-3)}.role-switcher{position:fixed;bottom:var(--space-5);right:var(--space-5);z-index:var(--z-toast);background:var(--color-admin-sidebar);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;font-size:13px}.role-switcher__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:#ffffff14;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff80;cursor:pointer;gap:var(--space-3)}.role-switcher__body{padding:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.role-switcher__btn{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#ffffffb3;font-size:13px;font-weight:500;text-align:left;transition:all var(--transition-fast)}.role-switcher__btn:hover{background:#ffffff14;color:#fff}.role-switcher__btn.active{background:var(--color-primary);color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.customer-header__nav{display:none}.header-menu-btn{display:flex}.customer-footer__grid{grid-template-columns:1fr 1fr;gap:var(--space-5)}.admin-sidebar{transform:translate(-100%)}.admin-sidebar.mobile-open{transform:translate(0)}.admin-topbar{left:0}.admin-content{margin-left:0;width:100%}}@media (max-width: 480px){.customer-footer__grid{grid-template-columns:1fr}.admin-content{padding:var(--space-4)}}:root{--color-bg: #F5F1E8;--color-surface: #FFFFFF;--color-surface-alt: #FAF6EC;--color-ink: #1E1E1E;--color-ink-muted: #6B6B6B;--color-border: #E5DFD0;--color-primary: #E85A2C;--color-primary-hover: #D14A1F;--color-accent: #1F3A5F;--color-admin-sidebar: #1A1A1A;--color-success: #2E7D4F;--color-success-bg: rgba(46, 125, 79, .12);--color-warning: #C88A2C;--color-warning-bg: rgba(200, 138, 44, .12);--color-danger: #C0392B;--color-danger-bg: rgba(192, 57, 43, .12);--color-info: #2C6FB0;--color-info-bg: rgba(44, 111, 176, .12);--color-neutral: #6B6B6B;--color-neutral-bg: rgba(107, 107, 107, .12);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Inter", system-ui, sans-serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .08);--transition-fast: .15s ease;--transition-normal: .25s ease;--z-header: 100;--z-sidebar: 200;--z-drawer: 300;--z-modal: 400;--z-toast: 500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 20px;font-size:15px;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;border:1px solid transparent;white-space:nowrap;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn svg{flex-shrink:0}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.btn-secondary{background:var(--color-surface);color:var(--color-ink);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-surface-alt);border-color:var(--color-ink-muted);color:var(--color-ink)}.btn-accent{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-accent:hover{opacity:.88}.btn-ghost{background:transparent;color:var(--color-ink);border-color:transparent}.btn-ghost:hover{background:var(--color-surface-alt);color:var(--color-ink)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover{opacity:.88}.btn-danger-outline{background:transparent;color:var(--color-danger);border-color:var(--color-danger)}.btn-danger-outline:hover{background:var(--color-danger-bg)}.btn-sm{padding:7px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.btn-icon-sm{width:30px;height:30px;padding:0;border-radius:var(--radius-sm)}.btn-block{width:100%}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.card--hover{transition:box-shadow var(--transition-fast),transform var(--transition-fast);cursor:pointer}.card--hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);gap:var(--space-3)}.card__title{font-size:16px;font-weight:600;color:var(--color-ink)}.card__subtitle{font-size:13px;color:var(--color-ink-muted);margin-top:2px}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.kpi-card__label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-ink-muted);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.kpi-card__value{font-size:32px;font-weight:700;color:var(--color-ink);line-height:1;margin-bottom:var(--space-2)}.kpi-card__delta{font-size:13px;display:flex;align-items:center;gap:var(--space-1)}.kpi-card__delta--up{color:var(--color-success)}.kpi-card__delta--down{color:var(--color-danger)}.kpi-card__icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:#e85a2c1a;color:var(--color-primary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-neutral{background:var(--color-neutral-bg);color:var(--color-neutral)}.badge-primary{background:#e85a2c1f;color:var(--color-primary)}.badge-payment{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:700;white-space:nowrap;border:1.5px solid currentColor}.badge-payment:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.badge-payment--unpaid{color:#991b1b;border-color:#dc2626;background:#fef2f2}.badge-payment--deposit{color:#92400e;border-color:#d97706;background:#fffbeb}.badge-payment--paid{color:#166534;border-color:#16a34a;background:#f0fdf4}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:14px;font-weight:500;color:var(--color-ink)}.form-label--required:after{content:" *";color:var(--color-danger)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;color:var(--color-ink);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);appearance:none;-webkit-appearance:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-ink-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #e85a2c26}.form-input--error,.form-select--error,.form-textarea--error{border-color:var(--color-danger)}.form-input--error:focus,.form-select--error:focus{box-shadow:0 0 0 3px #c0392b26}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-select option{color:var(--color-ink);background:var(--color-surface)}.form-textarea{resize:vertical;min-height:100px}.form-hint{font-size:13px;color:var(--color-ink-muted);margin-top:var(--space-1)}.form-error{font-size:13px;color:var(--color-danger);display:flex;align-items:center;gap:var(--space-1)}.form-check{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.form-check input[type=checkbox],.form-check input[type=radio]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.form-check__label{font-size:15px;color:var(--color-ink);cursor:pointer}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-stack{display:flex;flex-direction:column;gap:var(--space-4)}.table-container{width:100%;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface)}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-ink-muted);background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-ink);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:nth-child(2n) td{background:var(--color-surface-alt)}.table tbody tr:hover td{background:#e85a2c08}.table .actions-cell{white-space:nowrap;text-align:right}.table tr.row-danger td{background:#c0392b0d!important}.table tr.row-warning td{background:#c88a2c0d!important}.tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--space-5)}.tab-btn{padding:var(--space-3) var(--space-5);font-size:14px;font-weight:600;color:var(--color-ink-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color var(--transition-fast),border-color var(--transition-fast);cursor:pointer;white-space:nowrap}.tab-btn:hover{color:var(--color-ink)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-panel{display:none}.tab-panel.active{display:block}.product-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.product-card__image-wrap{aspect-ratio:1;overflow:hidden;background:var(--color-surface-alt)}.product-card__image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.product-card:hover .product-card__image{transform:scale(1.04)}.product-card__body{padding:var(--space-4)}.product-card__category{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);margin-bottom:var(--space-2)}.product-card__name{font-size:15px;font-weight:600;color:var(--color-ink);margin-bottom:var(--space-2);line-height:1.3}.product-card__variants{font-size:12px;color:var(--color-ink-muted);margin-bottom:var(--space-3)}.product-card__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.product-card__price{font-size:18px;font-weight:700;color:var(--color-ink)}.product-card__price span{font-size:13px;font-weight:400;color:var(--color-ink-muted)}.stepper{display:flex;align-items:flex-start;justify-content:space-between;position:relative;margin-bottom:var(--space-7)}.stepper:before{content:"";position:absolute;top:16px;left:24px;right:24px;height:2px;background:var(--color-border);z-index:0}.stepper-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);position:relative;z-index:1;flex:1}.stepper-step__circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-surface);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--color-ink-muted);transition:all var(--transition-fast);flex-shrink:0}.stepper-step--done .stepper-step__circle{background:var(--color-success);border-color:var(--color-success);color:#fff}.stepper-step--active .stepper-step__circle{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.stepper-step__label{font-size:11px;font-weight:500;color:var(--color-ink-muted);text-align:center;max-width:80px;line-height:1.3}.stepper-step--done .stepper-step__label,.stepper-step--active .stepper-step__label{color:var(--color-ink)}.timeline{display:flex;flex-direction:column}.timeline-item{display:flex;gap:var(--space-4);padding-bottom:var(--space-5);position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:11px;top:24px;bottom:0;width:2px;background:var(--color-border)}.timeline-item__dot{width:24px;height:24px;border-radius:50%;background:var(--color-success);border:2px solid var(--color-success);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;margin-top:2px}.timeline-item__content{flex:1}.timeline-item__status{font-size:15px;font-weight:600;color:var(--color-ink);margin-bottom:var(--space-1)}.timeline-item__timestamp{font-size:12px;color:var(--color-ink-muted);margin-bottom:var(--space-2)}.timeline-item__note{font-size:14px;color:var(--color-ink-muted);background:var(--color-surface-alt);padding:var(--space-3);border-radius:var(--radius-md);border-left:3px solid var(--color-border)}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-7) var(--space-5);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.upload-zone:hover,.upload-zone.dragover{border-color:var(--color-primary);background:#e85a2c0a}.upload-zone__icon{color:var(--color-ink-muted);margin:0 auto var(--space-3)}.upload-zone__title{font-size:16px;font-weight:600;color:var(--color-ink);margin-bottom:var(--space-1)}.upload-zone__hint{font-size:13px;color:var(--color-ink-muted)}.upload-zone__hint strong{color:var(--color-primary)}.file-list{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.file-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md)}.file-item__preview{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;background:var(--color-border);flex-shrink:0}.file-item__info{flex:1;min-width:0}.file-item__name{font-size:14px;font-weight:500;color:var(--color-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-item__size{font-size:12px;color:var(--color-ink-muted)}.category-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;text-decoration:none;transition:all var(--transition-fast)}.category-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.category-card__icon{width:52px;height:52px;border-radius:var(--radius-md);background:#e85a2c1a;color:var(--color-primary);display:flex;align-items:center;justify-content:center}.category-card__name{font-size:14px;font-weight:600;color:var(--color-ink)}.category-card__count{font-size:12px;color:var(--color-ink-muted)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-6)}.pagination__btn{min-width:36px;height:36px;padding:0 var(--space-2);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--color-ink-muted);border:1px solid var(--color-border);background:var(--color-surface);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.pagination__btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.pagination__btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination__btn:disabled{opacity:.4;pointer-events:none}.qty-stepper{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.qty-stepper__btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--color-ink-muted);background:var(--color-surface-alt);transition:all var(--transition-fast);flex-shrink:0}.qty-stepper__btn:hover{background:var(--color-border);color:var(--color-ink)}.qty-stepper__input{width:50px;height:34px;text-align:center;border:none;border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);font-size:15px;font-weight:600;color:var(--color-ink);background:var(--color-surface)}.qty-stepper__input:focus{outline:none}.filter-sidebar{width:240px;flex-shrink:0}.filter-group{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border)}.filter-group:last-child{border-bottom:none}.filter-group__title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-ink-muted);margin-bottom:var(--space-3)}.filter-option{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;margin-bottom:var(--space-2)}.filter-option input{accent-color:var(--color-primary)}.filter-option__label{font-size:14px;color:var(--color-ink)}.filter-option__count{font-size:12px;color:var(--color-ink-muted);margin-left:auto}.color-swatches{display:flex;flex-wrap:wrap;gap:var(--space-2)}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast)}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--color-ink)}.range-slider{width:100%;accent-color:var(--color-primary);cursor:pointer}.range-slider-labels{display:flex;justify-content:space-between;font-size:13px;color:var(--color-ink-muted);margin-top:var(--space-2)}.search-box{position:relative;flex:1;max-width:320px}.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-ink-muted);pointer-events:none}.search-box input{width:100%;padding:9px 12px 9px 38px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:14px;color:var(--color-ink)}.search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #e85a2c1f}.toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.toolbar__left{display:flex;align-items:center;gap:var(--space-3);flex:1;flex-wrap:wrap}.toolbar__right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.alert{display:flex;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);font-size:14px;border:1px solid}.alert svg{flex-shrink:0;margin-top:1px}.alert-info{background:var(--color-info-bg);border-color:#2c6fb033;color:var(--color-info)}.alert-success{background:var(--color-success-bg);border-color:#2e7d4f33;color:var(--color-success)}.alert-warning{background:var(--color-warning-bg);border-color:#c88a2c33;color:var(--color-warning)}.alert-danger{background:var(--color-danger-bg);border-color:#c0392b33;color:var(--color-danger)}.chip-filters{display:flex;gap:var(--space-2);flex-wrap:wrap}.chip{padding:5px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:500;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-ink-muted);cursor:pointer;transition:all var(--transition-fast)}.chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.stats-row{display:flex;gap:var(--space-5);padding:var(--space-4) var(--space-5);background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-wrap:wrap}.stat-item__label{font-size:12px;color:var(--color-ink-muted);margin-bottom:var(--space-1)}.stat-item__value{font-size:20px;font-weight:700;color:var(--color-ink)}.variant-chips{display:flex;gap:var(--space-2);flex-wrap:wrap}.variant-chip{padding:6px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--color-ink);cursor:pointer;transition:all var(--transition-fast);background:var(--color-surface)}.variant-chip:hover{border-color:var(--color-primary)}.variant-chip.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.variant-chip:disabled{opacity:.4;text-decoration:line-through;cursor:not-allowed}.order-summary-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);position:sticky;top:88px}.order-summary-line{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;font-size:14px;color:var(--color-ink)}.order-summary-line--total{font-size:18px;font-weight:700;border-top:2px solid var(--color-border);padding-top:var(--space-3);margin-top:var(--space-2)}.design-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast)}.design-card:hover{box-shadow:var(--shadow-md)}.design-card__preview{aspect-ratio:4/3;background:var(--color-surface-alt);overflow:hidden}.design-card__preview img{width:100%;height:100%;object-fit:cover}.design-card__body{padding:var(--space-3)}.design-card__filename{font-size:13px;font-weight:600;color:var(--color-ink);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.design-card__meta{font-size:12px;color:var(--color-ink-muted)}.design-card__actions{display:flex;gap:var(--space-2);padding:var(--space-3);border-top:1px solid var(--color-border)}.auth-page{min-height:100vh;background:var(--color-bg);display:flex;align-items:center;justify-content:center;padding:var(--space-5)}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-7) var(--space-6);width:100%;max-width:420px;box-shadow:var(--shadow-md)}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.auth-logo img{width:64px;height:64px;object-fit:contain;border-radius:50%}.stock-bar{width:100%;height:6px;background:var(--color-border);border-radius:var(--radius-pill);overflow:hidden}.stock-bar__fill{height:100%;border-radius:var(--radius-pill);transition:width var(--transition-normal)}.stock-bar__fill--healthy{background:var(--color-success)}.stock-bar__fill--low{background:var(--color-warning)}.stock-bar__fill--out{background:var(--color-danger)}.popover{position:absolute;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-modal);padding:var(--space-4);min-width:220px;display:none}.popover.open{display:block}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.filter-sidebar{width:100%}.stepper{overflow-x:auto;padding-bottom:var(--space-3)}.stepper-step__label{display:none}}@media (max-width: 480px){.auth-card{padding:var(--space-5) var(--space-4)}.drawer{width:100%}}
