@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";:root{--primary:#c8102e;--primary-dark:#9b0d22;--primary-light:#e8192e;--primary-bg:#fff0f2;--dark:#0f0f1a;--dark-2:#1a1a2e;--dark-3:#252540;--gray-1:#f7f8fc;--gray-2:#eef0f7;--gray-3:#d8dce8;--gray-4:#9ba3bf;--gray-5:#5b6280;--text:#1a1a2e;--text-2:#5b6280;--white:#fff;--success:#10b981;--success-bg:#ecfdf5;--warning:#f59e0b;--warning-bg:#fffbeb;--error:#ef4444;--error-bg:#fef2f2;--info:#3b82f6;--info-bg:#eff6ff;--sidebar-w:256px;--header-h:64px;--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow:0 1px 3px #0000000f,0 4px 16px #0000000d;--shadow-md:0 4px 6px #0000000f,0 10px 30px #0000001a;--shadow-lg:0 20px 60px #00000026;--transition:.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--gray-1);color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Sans,sans-serif;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:Syne,sans-serif;font-weight:700}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--gray-2)}::-webkit-scrollbar-thumb{background:var(--gray-3);border-radius:99px}.auth-wrap{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-left{background:linear-gradient(145deg,#0f0f1a 0%,#1a1a2e 50%,#2a0f18 100%);flex-direction:column;justify-content:center;align-items:flex-start;padding:64px;display:flex;position:relative;overflow:hidden}.auth-left:before{content:"";background:radial-gradient(circle,#c8102e38 0%,#0000 70%);border-radius:50%;width:450px;height:450px;position:absolute;top:-120px;right:-120px}.auth-left:after{content:"";background:radial-gradient(circle,#c8102e24 0%,#0000 70%);border-radius:50%;width:280px;height:280px;position:absolute;bottom:-80px;left:-60px}.auth-left-content{z-index:1;position:relative}.auth-right{background:#fff;flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex;overflow-y:auto}.auth-form-box{width:100%;max-width:420px}.portal-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);border-right:1px solid var(--gray-2);z-index:100;background:#fff;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid var(--gray-2);align-items:center;gap:10px;padding:20px 20px 16px;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:12px;display:flex;overflow-y:auto}.nav-section{letter-spacing:.1em;text-transform:uppercase;color:var(--gray-4);padding:16px 8px 4px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:var(--gray-5);transition:all var(--transition);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;display:flex}.nav-item:hover{background:var(--gray-1);color:var(--text)}.nav-item.active{background:var(--primary-bg);color:var(--primary)}.nav-item.active svg{color:var(--primary)}.nav-item svg{flex-shrink:0;width:18px;height:18px}.nav-badge{background:var(--primary);color:#fff;border-radius:99px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.sidebar-footer{border-top:1px solid var(--gray-2);padding:12px}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--header-h);border-bottom:1px solid var(--gray-2);z-index:50;background:#fff;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{font-family:Syne,sans-serif;font-size:17px;font-weight:700}.topbar-right{align-items:center;gap:12px;margin-left:auto;display:flex}.page-body{flex:1;padding:24px}.card{border-radius:var(--radius);border:1px solid var(--gray-2);box-shadow:var(--shadow);background:#fff;padding:24px}.card-sm{padding:16px}.card-title{justify-content:space-between;align-items:center;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.stat-card{border-radius:var(--radius);border:1px solid var(--gray-2);box-shadow:var(--shadow);background:#fff;padding:24px;position:relative;overflow:hidden}.stat-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:14px;display:flex}.stat-icon.red{background:var(--primary-bg);color:var(--primary)}.stat-icon.green{background:var(--success-bg);color:var(--success)}.stat-icon.blue{background:var(--info-bg);color:var(--info)}.stat-icon.orange{background:var(--warning-bg);color:var(--warning)}.stat-value{margin-bottom:2px;font-family:Syne,sans-serif;font-size:28px;font-weight:800}.stat-label{color:var(--text-2);font-size:13px}.stat-change{align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600;display:flex}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--error)}.btn{border-radius:var(--radius-sm);transition:all var(--transition);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #c8102e4d}.btn-secondary{background:var(--gray-2);color:var(--text)}.btn-secondary:hover{background:var(--gray-3)}.btn-outline{color:var(--primary);border:1.5px solid var(--primary);background:0 0}.btn-outline:hover{background:var(--primary-bg)}.btn-ghost{color:var(--text-2);background:0 0}.btn-ghost:hover{background:var(--gray-1);color:var(--text)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--error);color:#fff}.btn-dark{background:var(--dark-2);color:#fff}.btn-dark:hover{background:var(--dark)}.btn-sm{padding:7px 14px;font-size:13px}.btn-lg{border-radius:var(--radius);padding:14px 28px;font-size:15px}.btn-full{justify-content:center;width:100%}.btn-icon{border-radius:var(--radius-sm);padding:8px}.form-group{flex-direction:column;gap:6px;margin-bottom:18px;display:flex}.form-label{font-size:13px;font-weight:600}.form-input{border:1.5px solid var(--gray-3);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:all var(--transition);background:#fff;outline:none;padding:10px 14px;font-size:14px}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #c8102e14}.form-input::placeholder{color:var(--gray-4)}.form-input.has-icon{padding-left:40px}.input-wrap{position:relative}.input-icon{color:var(--gray-4);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.form-select{border:1.5px solid var(--gray-3);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:all var(--transition);appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239BA3BF' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") right 12px center no-repeat;outline:none;padding:10px 36px 10px 14px;font-size:14px}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #c8102e14}.form-textarea{border:1.5px solid var(--gray-3);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:all var(--transition);resize:vertical;background:#fff;outline:none;min-height:90px;padding:10px 14px;font-size:14px}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #c8102e14}.form-hint{color:var(--text-2);margin-top:4px;font-size:12px}.badge{border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-active{background:var(--info-bg);color:var(--info)}.badge-transit{color:#2563eb;background:#eff6ff}.badge-delivered{background:var(--success-bg);color:var(--success)}.badge-cancelled{background:var(--error-bg);color:var(--error)}.badge-primary{background:var(--primary-bg);color:var(--primary)}.badge-gray{background:var(--gray-2);color:var(--gray-5)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}thead th{background:var(--gray-1);text-align:left;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--gray-2);padding:10px 16px;font-size:11px;font-weight:700}tbody td{border-bottom:1px solid var(--gray-2);color:var(--text);padding:14px 16px}tbody tr:hover{background:var(--gray-1)}tbody tr:last-child td{border-bottom:none}.tabs{border-bottom:1px solid var(--gray-2);gap:0;margin-bottom:20px;display:flex}.tab{color:var(--text-2);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 18px;font-size:14px;font-weight:500}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:20px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.timeline{flex-direction:column;gap:0;display:flex}.tl-item{gap:14px;padding-bottom:20px;display:flex;position:relative}.tl-item:not(:last-child):before{content:"";background:var(--gray-2);width:2px;position:absolute;top:32px;bottom:0;left:15px}.tl-dot{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.tl-dot.done{background:var(--success-bg);color:var(--success)}.tl-dot.active{background:var(--primary-bg);color:var(--primary)}.tl-dot.pending{background:var(--gray-2);color:var(--gray-4)}.tl-content{flex:1}.tl-title{margin-bottom:2px;font-size:14px;font-weight:600}.tl-time{color:var(--text-2);font-size:12px}.avatar{background:var(--primary-bg);width:36px;height:36px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.avatar-lg{width:48px;height:48px;font-size:16px}.avatar-sm{width:28px;height:28px;font-size:11px}.search-bar{background:var(--gray-1);border:1.5px solid var(--gray-2);border-radius:var(--radius-sm);transition:all var(--transition);align-items:center;gap:8px;min-width:240px;padding:8px 14px;display:flex}.search-bar:focus-within{border-color:var(--primary);background:#fff}.search-bar input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:14px}.search-bar input::placeholder{color:var(--gray-4)}.otp-group{justify-content:center;gap:10px;display:flex}.otp-input{text-align:center;border:2px solid var(--gray-3);border-radius:var(--radius-sm);width:52px;height:56px;transition:all var(--transition);outline:none;font-family:Syne,sans-serif;font-size:24px;font-weight:700}.otp-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #c8102e14}.toggle{cursor:pointer;align-items:center;gap:10px;display:inline-flex;position:relative}.toggle input{display:none}.toggle-track{background:var(--gray-3);width:42px;height:22px;transition:all var(--transition);border-radius:99px;position:relative}.toggle-track:after{content:"";width:18px;height:18px;transition:all var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}.toggle input:checked+.toggle-track{background:var(--primary)}.toggle input:checked+.toggle-track:after{transform:translate(20px)}.steps{align-items:center;margin-bottom:28px;display:flex}.step{flex:1;align-items:center;display:flex}.step:last-child{flex:none}.step-num{border:2px solid var(--gray-3);width:32px;height:32px;color:var(--gray-4);transition:all var(--transition);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.step-num.active{border-color:var(--primary);background:var(--primary);color:#fff}.step-num.done{border-color:var(--success);background:var(--success);color:#fff}.step-text{color:var(--gray-4);margin:0 8px;font-size:12px;font-weight:600}.step-text.active{color:var(--primary)}.step-text.done{color:var(--success)}.step-line{background:var(--gray-3);flex:1;height:2px}.step-line.done{background:var(--success)}.map-box{border-radius:var(--radius);color:var(--gray-5);background:linear-gradient(135deg,#e8ecf5,#d8dce8);flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex;position:relative;overflow:hidden}.map-box:before{content:"";background-image:linear-gradient(#c8102e0a 1px,#0000 1px),linear-gradient(90deg,#c8102e0a 1px,#0000 1px);background-size:36px 36px;position:absolute;inset:0}.divider{background:var(--gray-2);height:1px;margin:20px 0}.divider-or{color:var(--text-2);align-items:center;gap:12px;margin:20px 0;font-size:13px;display:flex}.divider-or:before,.divider-or:after{content:"";background:var(--gray-2);flex:1;height:1px}.notif-btn{position:relative}.notif-dot{background:var(--primary);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:2px;right:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.3s fadeIn}.slide-in{animation:.3s slideIn}.spin{animation:1s linear infinite spin}.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-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.ml-auto{margin-left:auto}.mr-2{margin-right:8px}.w-full{width:100%}.h-full{height:100%}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-lg{font-size:18px}.text-xl{font-size:22px}.text-2xl{font-size:26px}.text-3xl{font-size:32px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-black{font-weight:900}.text-muted{color:var(--text-2)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-error{color:var(--error)}.text-warning{color:var(--warning)}.text-white{color:#fff}.text-right{text-align:right}.text-center{text-align:center}.rounded{border-radius:var(--radius-sm)}.rounded-full{border-radius:99px}.overflow-hidden{overflow:hidden}.relative{position:relative}.pointer{cursor:pointer}
