@import url("https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&family=DM+Serif+Display:ital@0;1&display=swap");:root{--color-primary:#1a3a5c;--color-primary-hover:#142d47;--color-primary-light:#e8f0f8;--color-accent:#c9973a;--color-accent-light:#fdf6e8;--color-white:#ffffff;--color-bg:#f9fafb;--color-surface:#ffffff;--color-border:#e5e7eb;--color-border-strong:#d1d5db;--color-text:#111827;--color-text-secondary:#6b7280;--color-text-inverse:#ffffff;--color-success:#16a34a;--color-success-light:#f0fdf4;--color-warning:#d97706;--color-warning-light:#fffbeb;--color-danger:#dc2626;--color-danger-light:#fef2f2;--color-info:#2563eb;--color-info-light:#eff6ff;--font-display:"DM Serif Display",Georgia,serif;--font-body:"DM Sans",system-ui,sans-serif;--font-mono:"Courier New",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:0.25rem;--radius:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-xs:0 1px 2px 0 rgb(0 0 0/0.05);--shadow-sm:0 1px 3px 0 rgb(0 0 0/0.1),0 1px 2px -1px rgb(0 0 0/0.1);--shadow:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--shadow-md:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--shadow-lg:0 20px 25px -5px rgb(0 0 0/0.1),0 8px 10px -6px rgb(0 0 0/0.1);--transition:150ms ease;--transition-slow:300ms ease;--sidebar-width:240px;--topbar-height:64px;--content-max-width:1100px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background-color:var(--color-bg);line-height:1.6}img,video{max-width:100%;display:block}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--font-body)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-text);line-height:1.2;font-weight:400}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base);font-weight:600}.text-secondary{color:var(--color-text-secondary)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.page-wrapper{min-height:100vh;background:var(--color-bg)}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:var(--sidebar-width);background:#0d0f1e;color:var(--color-text-inverse);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100}.admin-content{margin-left:var(--sidebar-width);flex:1 1;min-width:0}.admin-topbar{height:var(--topbar-height);background:var(--color-white);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--space-8);position:-webkit-sticky;position:sticky;top:0;z-index:50}.admin-page{padding:var(--space-8)}.customer-layout{min-height:100vh;background:var(--color-bg)}.customer-topbar{background:var(--color-white);border-bottom:1px solid var(--color-border);padding:var(--space-4) var(--space-8);display:flex;align-items:center;justify-content:space-between}.customer-content{max-width:780px;margin:0 auto;padding:var(--space-10) var(--space-6)}.sidebar-logo{padding:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo img{width:100%;height:auto;max-height:160px;object-fit:contain;display:block}.sidebar-site-name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text-inverse);font-style:italic}.sidebar-nav{flex:1 1;padding:var(--space-4) 0}.sidebar-section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.45);padding:var(--space-4) var(--space-5) var(--space-2);font-weight:600}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);color:rgba(255,255,255,.75);font-size:var(--text-sm);font-weight:500;transition:background var(--transition),color var(--transition);border-left:3px solid transparent;text-decoration:none;position:relative}.sidebar-link:hover{background:rgba(255,255,255,.08);color:var(--color-text-inverse);text-decoration:none}.sidebar-link.active{background:rgba(255,255,255,.12);color:var(--color-text-inverse);border-left-color:transparent}.sidebar-link.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#ff3d3d,#ff8c00,#ffe600,#39ff14,#00bfff,#bf00ff)}.sidebar-link svg{width:18px;height:18px;flex-shrink:0;opacity:.8}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid rgba(255,255,255,.1);font-size:var(--text-xs);color:rgba(255,255,255,.4)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.card-title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text);font-weight:400}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background:var(--color-bg);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-xs)}.stat-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500;margin-bottom:var(--space-2)}.stat-value{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-primary);line-height:1}.stat-sub{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);font-weight:500;font-family:var(--font-body);border-radius:var(--radius);border:1px solid transparent;transition:all var(--transition);white-space:nowrap;line-height:1.5}.btn,.btn:hover{text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px;flex-shrink:0}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background:var(--color-white);color:var(--color-text);border-color:var(--color-border-strong)}.btn-secondary:hover{background:var(--color-bg)}.btn-accent{background:var(--color-accent);color:var(--color-text-inverse);border-color:var(--color-accent)}.btn-accent:hover{opacity:.9}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse);border-color:var(--color-danger)}.btn-danger:hover{opacity:.9}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-8);font-size:var(--text-base)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.form-label span.required{color:var(--color-danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-body);color:var(--color-text);background:var(--color-white);border:1px solid var(--color-border-strong);border-radius:var(--radius);transition:border-color var(--transition),box-shadow var(--transition);outline:none;line-height:1.5}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(26,58,92,.1)}.form-textarea{resize:vertical;min-height:100px}.form-hint{color:var(--color-text-secondary)}.form-error,.form-hint{font-size:var(--text-xs)}.form-error{color:var(--color-danger)}.form-grid{grid-template-columns:1fr 1fr;grid-gap:var(--space-4)}.form-grid,.form-grid-3{display:grid;gap:var(--space-4)}.form-grid-3{grid-template-columns:1fr 1fr 1fr;grid-gap:var(--space-4)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}thead{background:var(--color-bg)}th{text-align:left;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);white-space:nowrap}td,th{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}td{vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--color-bg)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);text-transform:capitalize}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-neutral{background:var(--color-border);color:var(--color-text-secondary)}.badge-accent{background:var(--color-accent-light);color:var(--color-accent)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8)}.page-header-left h1{font-size:var(--text-3xl);margin-bottom:var(--space-1)}.page-header-left p{color:var(--color-text-secondary);font-size:var(--text-sm)}.dropzone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--color-bg)}.dropzone.active,.dropzone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.dropzone-icon{width:48px;height:48px;margin:0 auto var(--space-3)}.dropzone-icon,.dropzone-text{color:var(--color-text-secondary)}.dropzone-text{font-size:var(--text-sm)}.dropzone-text strong{color:var(--color-primary)}.file-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-white);transition:border-color var(--transition)}.file-item:hover{border-color:var(--color-primary)}.file-icon{width:40px;height:40px;border-radius:var(--radius);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-primary)}.file-info{flex:1 1;min-width:0}.file-name{font-size:var(--text-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:var(--text-xs);color:var(--color-text-secondary)}.download-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;border:none;transition:background var(--transition)}.download-btn,.download-btn:hover{color:var(--color-text-inverse);text-decoration:none}.download-btn:hover{background:var(--color-primary-hover)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-6)}.auth-card{width:100%;max-width:420px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);box-shadow:var(--shadow-md)}.auth-logo{text-align:center;margin-bottom:var(--space-8)}.auth-logo img{height:48px;width:auto;margin:0 auto var(--space-3)}.auth-title{font-family:var(--font-display);font-size:var(--text-2xl);text-align:center;margin-bottom:var(--space-2)}.auth-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;margin-bottom:var(--space-6)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);white-space:normal}.modal{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;overflow-x:hidden}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);justify-content:flex-end}.alert,.modal-footer{display:flex;gap:var(--space-3)}.alert{align-items:flex-start;padding:var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);border:1px solid}.alert-success{background:var(--color-success-light);border-color:#bbf7d0;color:#15803d}.alert-warning{background:var(--color-warning-light);border-color:#fde68a;color:#92400e}.alert-danger{background:var(--color-danger-light);border-color:#fecaca;color:#991b1b}.alert-info{background:var(--color-info-light);border-color:#bfdbfe;color:#1e40af}.empty-state{text-align:center;padding:var(--space-16) var(--space-8);color:var(--color-text-secondary)}.empty-state svg{width:48px;height:48px;margin:0 auto var(--space-4);opacity:.3}.empty-state h3{font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--text-sm);margin-bottom:var(--space-6)}@media print{.no-print{display:none!important}body{background:white}.invoice-page{padding:0}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.w-full{width:100%}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.grid-cols-2{grid-template-columns:1fr 1fr;grid-gap:var(--space-4)}.grid-cols-2,.grid-cols-3{display:grid;gap:var(--space-4)}.grid-cols-3{grid-template-columns:1fr 1fr 1fr;grid-gap:var(--space-4)}.grid-cols-4{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-4);gap:var(--space-4)}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-right{text-align:right}.text-center{text-align:center}.opacity-50{opacity:.5}@media (max-width:768px){.admin-sidebar{transform:translateX(-100%);transition:transform var(--transition-slow)}.admin-sidebar.open{transform:translateX(0)}.admin-content{margin-left:0}.form-grid,.form-grid-3,.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.page-header{flex-direction:column}.admin-page{padding:var(--space-4)}.customer-content{padding:var(--space-6) var(--space-4)}}