@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";:root{--primary:#0f4c81;--primary-light:#1a6fb8;--primary-dark:#0a3459;--accent:#10b981;--accent-light:#34d399;--accent-dark:#059669;--warning:#f59e0b;--danger:#ef4444;--success:#10b981;--info:#3b82f6;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--bg-input:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-light:#cbd5e1;--border:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-md:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-lg:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--transition:all .2s cubic-bezier(.4, 0, .2, 1);--transition-slow:all .3s cubic-bezier(.4, 0, .2, 1);--font-display:"Space Grotesk", sans-serif;--font-body:"Plus Jakarta Sans", sans-serif;--safe-area-top:env(safe-area-inset-top);--safe-area-bottom:env(safe-area-inset-bottom)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.6}#root{min-height:100dvh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.3}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}.header{z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);position:fixed;top:0;left:0;right:0}.header-inner{justify-content:space-between;align-items:center;max-width:100%;padding:12px 16px;display:flex}.header-back{width:40px;height:40px;color:var(--text-primary);transition:var(--transition);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:flex}.header-title{font-family:var(--font-display);color:var(--text-primary);text-align:center;flex:1;font-size:18px;font-weight:600}.page-content{padding-bottom:calc(var(--safe-area-bottom));flex:1;overflow-y:auto}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:var(--transition)}.card:hover{box-shadow:var(--shadow)}.card-elevated{box-shadow:var(--shadow-md)}.btn{border-radius:var(--radius);transition:var(--transition);cursor:pointer;border:none;outline:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);color:#fff;box-shadow:0 4px 14px #0f4c8159}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0f4c8173}.btn-primary:active{transform:translateY(0)scale(.98)}.btn-accent{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-light) 100%);color:#fff;box-shadow:0 4px 14px #10b98159}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 6px 20px #10b98173}.btn-outline{color:var(--primary);border:2px solid var(--primary);background:0 0}.btn-outline:hover{background:var(--primary);color:#fff}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-input);color:var(--text-primary)}.btn-block{width:100%}.btn-sm{padding:8px 16px;font-size:13px}.btn-lg{padding:16px 32px;font-size:17px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.input-group{margin-bottom:16px}.input-label{color:var(--text-secondary);margin-bottom:8px;font-size:14px;font-weight:500;display:block}.input{border:2px solid var(--border);border-radius:var(--radius);background:var(--bg-input);width:100%;color:var(--text-primary);transition:var(--transition);outline:none;padding:14px 16px;font-size:15px}.input:focus{border-color:var(--primary);background:var(--bg-secondary);box-shadow:0 0 0 4px #0f4c811a}.input::placeholder{color:var(--text-muted)}.input-error{border-color:var(--danger)}.error-text{color:var(--danger);margin-top:6px;font-size:13px}.badge{border-radius:20px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-pending{color:#b45309;background:#f59e0b1a}.badge-picked_up{color:#1d4ed8;background:#3b82f61a}.badge-in_transit{color:#6d28d9;background:#8b5cf61a}.badge-signed{color:#047857;background:#10b9811a}.badge-cancelled{color:#4b5563;background:#6b72801a}.skeleton{background:linear-gradient(90deg, var(--bg-input) 25%, var(--border-light) 50%, var(--bg-input) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.fade-in{animation:.3s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:.4s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.scale-in{animation:.3s cubic-bezier(.16,1,.3,1) scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{opacity:.5;width:80px;height:80px;margin-bottom:16px}.empty-state-title{color:var(--text-secondary);margin-bottom:8px;font-size:18px;font-weight:600}.empty-state-desc{color:var(--text-muted);font-size:14px}.divider{background:var(--border);height:1px;margin:16px 0}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-center{text-align:center}.text-right{text-align:right}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.p-3{padding:12px}.p-4{padding:16px}.rounded{border-radius:var(--radius)}.rounded-full{border-radius:9999px}.overflow-hidden{overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.header{background:var(--bg-secondary);z-index:50;border-bottom:1px solid var(--border-light);position:fixed;top:0;left:0;right:0}.header-title{font-family:var(--font-display);color:var(--text-primary);font-size:20px;font-weight:700}.header-back{border-radius:var(--radius);width:40px;height:40px;color:var(--text-primary);transition:var(--transition);cursor:pointer;justify-content:center;align-items:center;display:flex}.header-back:hover{background:var(--bg-input)}.header-back svg{width:24px;height:24px}.header-action{border-radius:var(--radius);width:40px;height:40px;color:var(--text-secondary);transition:var(--transition);cursor:pointer;justify-content:center;align-items:center;display:flex}.header-action:hover{background:var(--bg-input);color:var(--text-primary)}.header-action svg{width:22px;height:22px}.page-header{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);color:#fff;border-radius:0 0 var(--radius-xl) var(--radius-xl);margin-bottom:16px;padding:20px 16px}.page-header-title{font-family:var(--font-display);margin-bottom:4px;font-size:24px;font-weight:700}.page-header-subtitle{opacity:.8;font-size:14px}.section-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:12px;font-size:16px;font-weight:600}.loading-overlay{z-index:1000;background:#ffffffe6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast{background:var(--text-primary);color:#fff;border-radius:var(--radius);z-index:1001;box-shadow:var(--shadow-lg);padding:12px 20px;font-size:14px;font-weight:500;animation:.3s ease-out toastIn;position:fixed;top:60px;left:50%;transform:translate(-50%)}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warning)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.error-boundary{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.error-boundary-content{text-align:center;max-width:400px;animation:.3s ease-out fadeIn}.error-boundary-icon{width:72px;height:72px;color:var(--warning);margin:0 auto 20px}.error-boundary-icon svg{width:100%;height:100%}.error-boundary-title{color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.error-boundary-message{color:var(--text-secondary);margin-bottom:24px;font-size:15px;line-height:1.5}.bottom-nav{background:var(--bg-secondary);border-top:1px solid var(--border);padding-bottom:var(--safe-area-bottom);z-index:100;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000d}.bottom-nav-inner{justify-content:space-around;align-items:center;max-width:500px;height:64px;margin:0 auto;display:flex}.nav-item{color:var(--text-muted);transition:var(--transition);cursor:pointer;border-radius:var(--radius);flex-direction:column;justify-content:center;align-items:center;padding:8px 16px;display:flex;position:relative}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--primary)}.nav-item.active:before{content:"";background:var(--primary);border-radius:0 0 3px 3px;width:24px;height:3px;position:absolute;top:-1px;left:50%;transform:translate(-50%)}.nav-icon{width:24px;height:24px;margin-bottom:4px}.nav-icon svg{width:100%;height:100%}.nav-label{font-size:11px;font-weight:500}.app-container{background:var(--bg-primary);flex-direction:column;min-height:100dvh;display:flex}.home-page{padding-top:0}.admin-layout{background:#f8fafc;min-height:100vh;display:flex}.admin-sidebar{z-index:100;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:260px;transition:width .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 10px #00000008}.sidebar-collapsed .admin-sidebar{width:72px}.admin-sidebar-header{border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;min-height:72px;padding:20px;display:flex}.admin-logo{flex-shrink:0;width:40px;height:40px}.admin-logo img{object-fit:contain;border-radius:8px;width:100%;height:100%}.admin-logo-text{font-family:var(--font-display);color:#0f172a;white-space:nowrap;font-size:18px;font-weight:700}.admin-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex;overflow-y:auto}.admin-nav-item{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:14px;text-decoration:none;transition:all .2s;display:flex}.admin-nav-item:hover{color:#334155;background:#f1f5f9}.admin-nav-item.active{color:#4338ca;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);box-shadow:0 2px 8px #6366f126}.admin-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.admin-nav-icon svg{width:100%;height:100%}.admin-nav-label{white-space:nowrap}.sidebar-collapsed .admin-nav-item{justify-content:center;padding:12px}.sidebar-collapsed .admin-nav-label{display:none}.admin-sidebar-footer{border-top:1px solid #f1f5f9;padding:16px 12px}.logout-btn{color:#ef4444}.logout-btn:hover{background:#ef444414}.admin-main{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-collapsed .admin-main{margin-left:72px}.admin-header{z-index:50;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:72px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #0000000d}.admin-toggle{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.admin-toggle:hover{color:#334155;background:#e2e8f0}.admin-toggle svg{width:20px;height:20px}.admin-header-right{align-items:center;gap:16px;display:flex}.admin-user{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:12px;padding:8px 12px;display:flex}.admin-user-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.admin-user-info{flex-direction:column;display:flex}.admin-user-name{color:#1e293b;font-size:14px;font-weight:500}.admin-user-role{color:#94a3b8;font-size:12px}.admin-content{flex:1;padding:24px}@media (width<=768px){.admin-sidebar{transform:translate(-100%)}.admin-main{margin-left:0}.admin-layout.sidebar-open .admin-sidebar{transform:translate(0)}}.toast-container{top:calc(var(--safe-area-top,0px) + 16px);z-index:9999;pointer-events:none;flex-direction:column;gap:8px;width:360px;max-width:calc(100vw - 32px);display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-lg);pointer-events:auto;border:1px solid var(--border);align-items:center;gap:10px;padding:14px 18px;animation:.3s ease-out toastSlideIn;display:flex}.toast-success{border-left:4px solid var(--success)}.toast-error{border-left:4px solid var(--danger)}.toast-warning{border-left:4px solid var(--warning)}.toast-info{border-left:4px solid var(--info)}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--danger)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--info)}.toast-icon svg{width:100%;height:100%}.toast-message{color:var(--text-primary);flex:1;font-size:14px;line-height:1.4}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{z-index:10000;background:#00000073;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:340px;box-shadow:var(--shadow-lg);padding:28px 24px 20px;animation:.25s cubic-bezier(.16,1,.3,1) modalScaleIn}.modal-title{color:var(--text-primary);margin-bottom:10px;font-size:18px;font-weight:700}.modal-message{color:var(--text-secondary);margin-bottom:24px;font-size:15px;line-height:1.5}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.modal-actions .btn{padding:10px 22px;font-size:14px}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.login-page{background:linear-gradient(#f0f4f8 0%,#fff 100%);justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.login-bg-circle{opacity:.6;border-radius:50%;position:absolute}.login-bg-circle-1{background:radial-gradient(circle,#0f4c8114 0%,#0000 70%);width:400px;height:400px;animation:20s ease-in-out infinite float;top:-100px;right:-100px}.login-bg-circle-2{background:radial-gradient(circle,#10b98114 0%,#0000 70%);width:300px;height:300px;animation:25s ease-in-out infinite reverse float;bottom:-50px;left:-50px}.login-bg-circle-3{background:radial-gradient(circle,#0f4c810d 0%,#0000 70%);width:200px;height:200px;animation:10s ease-in-out infinite pulse;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}.login-content{z-index:1;width:100%;max-width:400px;position:relative}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:72px;height:72px;margin:0 auto 16px;animation:.6s cubic-bezier(.16,1,.3,1) logoIn}.login-logo img{object-fit:contain;filter:drop-shadow(0 8px 24px #0f4c8140);border-radius:12px;width:100%;height:100%}@keyframes logoIn{0%{opacity:0;transform:scale(.8)translateY(-20px)}to{opacity:1;transform:scale(1)translateY(0)}}.login-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:15px}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-light);padding:24px;animation:.5s cubic-bezier(.16,1,.3,1) .1s both cardIn;box-shadow:0 4px 6px -1px #0000000d,0 20px 40px -10px #00000014}@keyframes cardIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-tabs{background:var(--bg-input);border-radius:var(--radius);margin-bottom:24px;padding:4px;display:flex}.login-tab{color:var(--text-secondary);border-radius:calc(var(--radius) - 4px);transition:var(--transition);cursor:pointer;flex:1;padding:12px 16px;font-size:14px;font-weight:600}.login-tab:hover{color:var(--text-primary)}.login-tab.active{background:var(--bg-secondary);color:var(--primary);box-shadow:var(--shadow-sm)}.login-form{animation:.3s ease-out fadeIn}.email-input-group{gap:8px;display:flex}.email-input-group .input{flex:1}.btn-send-code{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;min-width:100px;padding:0 16px;font-size:14px;font-weight:500;transition:all .2s}.btn-send-code:hover:not(:disabled){opacity:.9}.btn-send-code:disabled{opacity:.5;cursor:not-allowed;background:var(--border);color:var(--text-muted)}.login-error{color:var(--danger);border-radius:var(--radius);background:#ef44441a;margin-bottom:16px;padding:12px 16px;font-size:14px;animation:.4s ease-out shake}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.loading-spinner-small{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}.login-footer{text-align:center;color:var(--text-muted);margin-top:24px;font-size:12px}.login-admin-link{border-top:1px dashed var(--border-light);text-align:center;margin-top:20px;padding-top:20px}.admin-link{color:var(--text-secondary);transition:var(--transition);border-radius:var(--radius);align-items:center;gap:6px;padding:8px 16px;font-size:14px;text-decoration:none;display:inline-flex}.admin-link:hover{color:var(--primary);background:#0f4c810d}.admin-link svg{width:16px;height:16px}
