body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#78c5d9;--primary-dark:#215d73;--secondary-color:#215d73;--accent-color:#f72585;--success-color:#4cc9f0;--danger-color:#ff3860;--warning-color:#ffd166;--light-color:#f8f9fa;--dark-color:#212529;--gray-100:#f8f9fa;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#6c757d;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #0000001a;--border-radius:12px;--border-radius-sm:8px;--transition:all 0.3s ease}body{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#343a40;color:var(--gray-800);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{color:#212529;color:var(--gray-900);font-weight:700;line-height:1.2;margin-bottom:1rem}h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#78c5d9,#215d73);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;font-size:2.5rem}h2{color:#78c5d9;color:var(--primary-color);font-size:2rem}h3{color:#343a40;color:var(--gray-800);font-size:1.5rem}p{color:#495057;color:var(--gray-700);margin-bottom:1rem}a{color:#78c5d9;color:var(--primary-color);text-decoration:none;transition:all .3s ease;transition:var(--transition)}a:hover{color:#215d73;color:var(--primary-dark)}.container{margin:0 auto;max-width:1400px;padding:0 20px}.page-container{margin:2rem auto;max-width:1200px;padding:0 1.5rem}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;background:#fffffff2;box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar{justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 0;position:relative}.logo a,.navbar{align-items:center;display:flex}.logo a{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#78c5d9,#215d73);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:800;gap:.5rem;padding:.5rem 0}.nav-links{gap:1rem;list-style:none;margin:0;padding:0}.nav-links,.nav-links a{align-items:center;display:flex}.nav-links a{border-radius:8px;border-radius:var(--border-radius-sm);color:#495057;color:var(--gray-700);font-weight:500;gap:.5rem;overflow:hidden;padding:.75rem 1.25rem;position:relative;text-decoration:none}.nav-links a,.nav-links a:before{transition:all .3s ease;transition:var(--transition)}.nav-links a:before{background:#78c5d9;background:var(--primary-color);bottom:0;content:"";height:2px;left:0;position:absolute;width:0}.nav-links a:hover{background:#4361ee0d;color:#78c5d9;color:var(--primary-color)}.nav-links a:hover:before{width:100%}.nav-links a.active{background:#4361ee1a;color:#78c5d9;color:var(--primary-color)}.user-info{align-items:center;background:#f8f9fa;background:var(--gray-100);border-left:4px solid #78c5d9;border-left:4px solid var(--primary-color);border-radius:12px;border-radius:var(--border-radius);display:flex;gap:1rem;padding:.5rem 1rem}.user-avatar{border:2px solid #78c5d9;border:2px solid var(--primary-color);border-radius:50%;height:36px;object-fit:cover;transition:all .3s ease;transition:var(--transition);width:36px}.user-avatar:hover{transform:scale(1.1)}.user-name{color:#343a40;color:var(--gray-800);font-weight:600;white-space:nowrap}.btn{border-radius:var(--border-radius-sm);font-size:.95rem;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:var(--transition)}.btn-primary{background:linear-gradient(135deg,#78c5d9,#215d73);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff}.btn-primary:hover{box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ff3860,#ff2e4d);background:linear-gradient(135deg,var(--danger-color),#ff2e4d);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#ff2e4d,#ff3860);background:linear-gradient(135deg,#ff2e4d,var(--danger-color));transform:translateY(-2px)}.btn-outline{background:#0000;border:2px solid #78c5d9;border:2px solid var(--primary-color);color:#78c5d9;color:var(--primary-color)}.btn-outline:hover{background:#78c5d9;background:var(--primary-color);color:#fff}.logout-btn{align-items:center;background:linear-gradient(135deg,#ff3860,#ff2e4d);background:linear-gradient(135deg,var(--danger-color),#ff2e4d);border:none;border-radius:8px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease;transition:var(--transition)}.logout-btn:hover{box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.card:hover{box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-5px)}.card-header{border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--gray-200);margin-bottom:1.5rem;padding-bottom:1rem}.card-title{color:#78c5d9;color:var(--primary-color);font-size:1.5rem;margin-bottom:.5rem}.page{background-color:#f5f7fa;border-radius:12px;box-shadow:none;margin:0;padding:0}.home-page{padding:4rem 1rem;text-align:center}.hero-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#4361ee1a,#7209b71a);border-radius:12px;border-radius:var(--border-radius);margin-bottom:3rem;padding:4rem 2rem}.hero-title{font-size:3.5rem;margin-bottom:1rem}.hero-subtitle{color:#6c757d;color:var(--gray-600);font-size:1.25rem;margin:0 auto 2rem;max-width:600px}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:3rem 0}.feature-card{background:#fff;border-radius:12px;border-radius:var(--border-radius);border-top:4px solid #78c5d9;border-top:4px solid var(--primary-color);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);padding:2rem;text-align:left;transition:all .3s ease;transition:var(--transition)}.feature-card:hover{box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-5px)}.feature-icon{color:#78c5d9;color:var(--primary-color);font-size:2.5rem;margin-bottom:1rem}.feature-card h3{color:#212529;color:var(--gray-900);margin-bottom:1rem}.dashboard-page{background-color:#f5f7fa}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.stats-card{background:linear-gradient(135deg,#78c5d9,#215d73);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:12px;border-radius:var(--border-radius);color:#fff;padding:2rem}.stats-card h3{color:#fff;font-size:1.25rem;margin-bottom:1rem}.stat-value{font-size:2.5rem;margin:1rem 0}.stat-label{font-size:.95rem;opacity:.9}.quick-actions{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.action-btn{background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius-sm);cursor:pointer;padding:1.5rem;text-align:center;transition:all .3s ease;transition:var(--transition)}.action-btn:hover{border-color:#78c5d9;border-color:var(--primary-color);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.action-btn i{color:#78c5d9;color:var(--primary-color);font-size:2rem;margin-bottom:1rem}.profile-page{padding:2rem 0}.profile-card{margin:0 auto;max-width:800px}.profile-header{align-items:center;border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--gray-200);display:flex;gap:2rem;margin-bottom:3rem;padding-bottom:2rem}.profile-avatar{border:5px solid #78c5d9;border:5px solid var(--primary-color);border-radius:50%;box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);height:150px;object-fit:cover;width:150px}.profile-info h2{margin-bottom:.5rem}.profile-info .email{color:#6c757d;color:var(--gray-600);font-size:1.1rem}.profile-details-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:2rem}.detail-card{background:#f8f9fa;background:var(--gray-100);border-left:4px solid #78c5d9;border-left:4px solid var(--primary-color);border-radius:8px;border-radius:var(--border-radius-sm);padding:1.5rem}.detail-label{color:#495057;color:var(--gray-700);display:block;font-weight:600;margin-bottom:.5rem}.detail-value{color:#212529;color:var(--gray-900);font-size:1.1rem}.settings-page{padding:2rem 0}.settings-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:300px 1fr}.settings-sidebar{background:#fff;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);height:-webkit-fit-content;height:fit-content;padding:2rem}.settings-menu{list-style:none}.settings-menu li{margin-bottom:.5rem}.settings-menu a{border-radius:8px;border-radius:var(--border-radius-sm);color:#495057;color:var(--gray-700);display:block;padding:1rem;transition:all .3s ease;transition:var(--transition)}.settings-menu a.active,.settings-menu a:hover{background:#78c5d9;background:var(--primary-color);color:#fff}.settings-content{background:#fff;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);padding:2rem}.setting-group{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);margin-bottom:2.5rem;padding-bottom:2rem}.setting-group:last-child{border-bottom:none;margin-bottom:0}.setting-item{align-items:center;background:#f8f9fa;background:var(--gray-100);border-radius:8px;border-radius:var(--border-radius-sm);display:flex;justify-content:space-between;margin-bottom:1rem;padding:1.25rem;transition:all .3s ease;transition:var(--transition)}.setting-item:hover{background:#e9ecef;background:var(--gray-200)}.setting-label{color:#343a40;color:var(--gray-800);font-weight:600}.setting-control input[type=email],.setting-control input[type=text],.setting-control select{border:2px solid #dee2e6;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius-sm);font-size:1rem;min-width:200px;padding:.75rem;transition:all .3s ease;transition:var(--transition)}.setting-control input:focus,.setting-control select:focus{border-color:#78c5d9;border-color:var(--primary-color);box-shadow:0 0 0 3px #4361ee1a;outline:none}.toggle-switch{display:inline-block;height:34px;position:relative;width:60px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ced4da;background-color:var(--gray-400);border-radius:34px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.4s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:"";height:26px;left:4px;position:absolute;transition:.4s;width:26px}input:checked+.toggle-slider{background-color:#78c5d9;background-color:var(--primary-color)}input:checked+.toggle-slider:before{transform:translateX(26px)}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-button-container{margin-left:1rem}.login-box{animation:slideUp .5s ease-out;background:#fff;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 20px 25px #0000001a;box-shadow:var(--shadow-xl);max-width:450px;padding:3rem;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-title{color:#212529;color:var(--gray-900);margin-bottom:.5rem}.login-subtitle{color:#6c757d;color:var(--gray-600);margin-bottom:2rem}.google-login-wrapper{margin:2rem 0}.google-btn{align-items:center;background:#fff;border:2px solid #dee2e6;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius-sm);color:#495057;color:var(--gray-700);cursor:pointer;display:flex;font-weight:600;gap:1rem;justify-content:center;padding:1rem;transition:all .3s ease;transition:var(--transition);width:100%}.google-btn:hover{background:#f8f9fa;background:var(--gray-100);border-color:#78c5d9;border-color:var(--primary-color)}.google-btn img{height:20px;width:20px}.login-footer{border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);margin-top:2rem;padding-top:1.5rem}.login-footer p{color:#6c757d;color:var(--gray-600);font-size:.9rem}.alert{align-items:center;border-radius:8px;border-radius:var(--border-radius-sm);display:flex;gap:1rem;margin:1rem 0;padding:1rem 1.5rem}.alert-success{background:#4cc9f01a;border:2px solid #4cc9f0;border:2px solid var(--success-color)}.alert-success,.alert-warning{color:#343a40;color:var(--gray-800)}.alert-warning{background:#ffd1661a;border:2px solid #ffd166;border:2px solid var(--warning-color)}.alert-error{background:#ff38601a;border:2px solid #ff3860;border:2px solid var(--danger-color);color:#343a40;color:var(--gray-800)}.footer{background:#212529;background:var(--gray-900);color:#fff;margin-top:4rem;padding:1rem 0}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1200px;padding:0 1.5rem}.footer-section h3{color:#fff;margin-bottom:1.5rem}.footer-section p{color:#ced4da;color:var(--gray-400)}.footer-links{list-style:none}.footer-links li{margin-bottom:.75rem}.footer-links a{color:#ced4da;color:var(--gray-400);transition:all .3s ease;transition:var(--transition)}.footer-links a:hover{color:#fff;padding-left:.5rem}.copyright{border-top:1px solid #343a40;border-top:1px solid var(--gray-800);color:#adb5bd;color:var(--gray-500);font-size:.9rem;margin-top:0;padding-top:0;text-align:center}@media (max-width:992px){.navbar{padding:1rem}.nav-links{gap:.5rem}.nav-links a{font-size:.95rem;padding:.5rem 1rem}.user-info{gap:.75rem;padding:.5rem}.user-name{display:none}}@media (max-width:768px){.mobile-menu-toggle{display:flex;z-index:1001}.nav-links{align-items:flex-start;background:#fff;box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);flex-direction:column;gap:0;height:100vh;overflow-y:auto;padding:80px 2rem 2rem;position:fixed;right:-100%;top:0;transition:right .3s ease;width:280px;z-index:1000}.nav-links.active{right:0}.nav-links li{margin-bottom:.5rem;width:100%}.nav-links a{border-radius:8px;border-radius:var(--border-radius-sm);justify-content:flex-start;padding:1rem;width:100%}.nav-links a i{text-align:center;width:24px}.user-info{border-left:none;border-top:4px solid #78c5d9;border-top:4px solid var(--primary-color);flex-direction:column;margin:1rem 0;padding:1rem}.user-info,.user-name{text-align:center;width:100%}.user-name{display:block}.logout-btn{justify-content:center;width:100%}.login-button-container{margin-left:0;width:100%}.login-btn{justify-content:center;width:100%}.nav-links.active:before{background:#00000080;content:"";height:100%;left:0;position:fixed;top:0;width:100%;z-index:-1}}@media (max-width:480px){.logo a{font-size:1.5rem}.nav-links{right:-100%;width:100%}.nav-links.active{right:0}.header{padding:.5rem}.container{padding:0 1rem}}body.menu-open{overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.nav-links.active li{animation:slideIn .3s ease forwards}.nav-links.active li:first-child{animation-delay:.1s}.nav-links.active li:nth-child(2){animation-delay:.15s}.nav-links.active li:nth-child(3){animation-delay:.2s}.nav-links.active li:nth-child(4){animation-delay:.25s}.nav-links.active li:nth-child(5){animation-delay:.3s}.nav-links.active li:nth-child(6){animation-delay:.35s}.nav-links.active li:nth-child(7){animation-delay:.4s}.nav-links.active li:nth-child(8){animation-delay:.45s}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-5{margin-top:3rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mb-5{margin-bottom:3rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.p-5{padding:3rem}.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:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:8px;border-radius:var(--border-radius-sm)}.rounded-lg{border-radius:12px;border-radius:var(--border-radius)}.shadow{box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg)}.bg-primary{background:#78c5d9;background:var(--primary-color);color:#fff}.bg-light{background:#f8f9fa;background:var(--light-color)}.bg-dark{background:#212529;background:var(--dark-color);color:#fff}.loading{animation:spin 1s ease-in-out infinite;border:3px solid #dee2e6;border-radius:50%;border-top-color:#78c5d9;border:3px solid var(--gray-300);border-top-color:var(--primary-color);display:inline-block;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#f8f9fa;background:var(--gray-100)}::-webkit-scrollbar-thumb{background:#78c5d9;background:var(--primary-color);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#215d73;background:var(--primary-dark)}@media (min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.md\:flex-row{flex-direction:row}}@media (min-width:1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}.menu-toggle{background:none;border:none;color:#495057;color:var(--gray-700);cursor:pointer;display:none;font-size:1.5rem}@media (max-width:768px){.menu-toggle{display:block}.nav-links{display:none;width:100%}.nav-links.active{background:#fff;box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);display:flex;flex-direction:column;left:0;padding:1rem;position:absolute;right:0;top:100%}}.tech-item{background:#f8f9fa;background:var(--gray-100);border-radius:8px;border-radius:var(--border-radius-sm);padding:1.5rem;text-align:center;transition:all .3s ease;transition:var(--transition)}.tech-item:hover{background:#78c5d9;background:var(--primary-color);color:#fff;transform:translateY(-2px)}.tech-item:hover h4{color:#fff}.tech-item h4{color:#78c5d9;color:var(--primary-color);margin-bottom:.5rem}.tech-item p{color:#6c757d;color:var(--gray-600);font-size:.9rem;margin:0}.tech-item:hover p{color:#ffffffe6}details{background:#f8f9fa;background:var(--gray-100);border-radius:8px;border-radius:var(--border-radius-sm);padding:1rem}details[open]{background:#e9ecef;background:var(--gray-200)}summary{list-style:none;padding-left:1.5rem;position:relative}summary::-webkit-details-marker{display:none}summary:before{content:"▸";left:.5rem;position:absolute;transition:transform .3s}details[open] summary:before{transform:rotate(90deg)}input,select,textarea{transition:all .3s ease;transition:var(--transition)}input:focus,select:focus,textarea:focus{border-color:#78c5d9!important;border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #4361ee1a}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.gap-8{gap:2rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.App{display:flex;flex-direction:column;min-height:100vh}.App>div{display:flex;flex:1 1;flex-direction:column}.container{flex:1 1}.mobile-menu-toggle{align-items:center;background:none;border:none;border-radius:6px;color:#495057;color:var(--gray-700);cursor:pointer;display:none;font-size:1.5rem;height:44px;justify-content:center;transition:all .3s ease;transition:var(--transition);width:44px}.mobile-menu-toggle:hover{background-color:#f8f9fa;background-color:var(--gray-100);color:#78c5d9;color:var(--primary-color)}.dashboard-page{background:linear-gradient(135deg,#f5f7fa,#e4e8f0);min-height:100vh;padding:20px}.dashboard-header{align-items:center;background:#fff;border-left:5px solid #4361ee;border-radius:15px;box-shadow:0 4px 15px #00000014;display:flex;justify-content:space-between;margin-bottom:25px;padding:20px 30px}.header-title h1{color:#212529;font-size:26px;font-weight:700;margin-bottom:8px}.header-title p{color:#6c757d;font-size:15px;margin:0;opacity:.9}.header-actions{gap:25px}.date-time,.header-actions{align-items:center;display:flex}.date-time{border-radius:10px;box-shadow:0 4px 12px #4361ee33;color:#fff;font-size:15px;font-weight:500;gap:10px;min-width:280px;padding:12px 20px}.date-time i{font-size:18px}.dashboard-tabs{background:#fff;border-radius:10px;display:flex;margin-bottom:20px;overflow:hidden}.dashboard-tab{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:14px;font-weight:500;gap:5px;justify-content:center;min-width:0;overflow:hidden;padding:15px 10px;text-align:center;text-overflow:ellipsis;transition:all .3s;white-space:nowrap}.dashboard-tab i{font-size:18px;margin-bottom:5px}.dashboard-tab span{font-size:13px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.dashboard-tab.active{background:#f5f7ff}.dashboard-tab:hover{background:linear-gradient(180deg,#4361ee0d,#4361ee05);color:#4361ee}.dashboard-tab:hover i{transform:translateY(-2px)}.dashboard-tab.active{background:linear-gradient(180deg,#4361ee1a,#4361ee0d);border-bottom:3px solid #4361ee;color:#4361ee}.dashboard-tab.active i{color:#4361ee;transform:scale(1.1)}.dashboard-tab.active:after{border-radius:2px;bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:40px}.dashboard-content{background:#fff;border-radius:15px;box-shadow:0 4px 15px #00000014;margin-bottom:25px;padding:30px}.tab-content-wrapper{animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-cards{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:35px}.card{background:#fff;border-left:4px solid #4361ee;border-radius:12px;box-shadow:0 6px 20px #00000012;cursor:pointer;overflow:hidden;padding:25px;position:relative;transition:all .3s ease}.card:hover{box-shadow:0 12px 30px #0000001f;transform:translateY(-8px)}.card:before{background:linear-gradient(90deg,#4361ee,#3a56d4);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.card:hover:before{opacity:1}.card.drillable:after{content:"🔍";font-size:16px;opacity:.7;position:absolute;right:20px;top:20px}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.card-title{color:#6c757d;flex:1 1;font-size:16px;font-weight:600}.card-icon{align-items:center;border-radius:12px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;flex-shrink:0;font-size:24px;height:55px;justify-content:center;margin-left:15px;width:55px}.card-content{margin-top:15px}.card-value{color:#212529;font-size:36px;font-weight:800;line-height:1.2;margin-bottom:10px}.card-change{align-items:center;color:#6c757d;display:flex;font-size:15px;gap:8px}.card-change.positive{color:#28a745}.card-change.negative{color:#dc3545}.progress-bar{background:#e9ecef;border-radius:5px;height:10px;margin-top:20px;overflow:hidden;position:relative}.progress-bar:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-fill{border-radius:5px;height:100%;position:relative;transition:width 1s ease-in-out;z-index:1}.charts-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr;margin-top:15px}@media (max-width:1200px){.charts-section{grid-template-columns:1fr}}.chart-container,.table-container{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:5px}.section-title{align-items:center;border-bottom:2px solid #e9ecef;color:#212529;display:flex;font-size:20px;gap:15px;margin-bottom:25px;padding-bottom:15px}.section-title i{color:#4361ee;font-size:22px}.status-indicator{align-items:center;border-radius:20px;display:inline-flex;font-size:13px;font-weight:600;padding:4px 10px}.status-high{background-color:#d4edda;color:#155724}.status-medium{background-color:#fff3cd;color:#856404}.status-low{background-color:#f8d7da;color:#721c24}.insights-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:30px}.insight-card{background-color:#fff;border-left:4px solid #4da6ff;border-radius:10px;box-shadow:0 4px 12px #0000000d;padding:20px}.insight-card.warning{border-left-color:#ff9f40}.insight-card.success{border-left-color:#4cd964}.insight-card.danger{border-left-color:#ff6384}.insight-title{align-items:center;color:#0a2c5e;display:flex;font-size:16px;font-weight:600;margin-bottom:10px}.insight-title i{font-size:18px;margin-right:10px}.insight-content{color:#666;font-size:14px;line-height:1.5}.chart-placeholder{align-items:center;background:#fff;border:2px dashed #dee2e6;border-radius:8px;color:#6c757d;display:flex;font-size:16px;height:300px;justify-content:center;padding:10px;text-align:center}.data-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 3px 10px #0000000d;overflow:hidden;width:100%}.data-table th{background:#f8f9fa;border-bottom:2px solid #dee2e6;color:#495057;font-size:15px;font-weight:600;padding:10px;text-align:left}.data-table td{border-bottom:1px solid #e9ecef;color:#212529;font-size:12px;padding:16px 20px}.data-table tr:hover{background:#f8f9fa}.data-table tr:last-child td{border-bottom:none}.badge{border-radius:20px;display:inline-block;font-size:13px;font-weight:600;min-width:80px;padding:6px 14px;text-align:center}.badge.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.badge.warning{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.badge.danger{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.commodity-details{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px;margin-top:25px}.commodity-card{background-color:#fff;border-left:4px solid #4da6ff;border-radius:10px;box-shadow:0 4px 12px #0000000d;cursor:pointer;padding:20px;transition:transform .3s,box-shadow .3s}.commodity-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-5px)}.commodity-header{align-items:center;display:flex;margin-bottom:15px}.commodity-icon{align-items:center;border-radius:10px;color:#fff;display:flex;font-size:22px;height:50px;justify-content:center;margin-right:15px;width:50px}.commodity-name{color:#0a2c5e;font-size:18px;font-weight:600}.commodity-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-top:15px}.ports-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.port-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 6px 20px #00000012;padding:15px;transition:all .3s ease}.port-card:hover{border-color:#4361ee;box-shadow:0 12px 30px #0000001f;transform:translateY(-5px)}.port-card-header{gap:20px;margin-bottom:20px}.port-card-header,.port-icon{align-items:center;display:flex}.port-icon{border-radius:12px;box-shadow:0 4px 12px #00000026;color:#fff;font-size:24px;height:60px;justify-content:center;width:60px}.port-card h4{color:#212529;font-size:20px;font-weight:600;margin:0}.port-location{color:#6c757d;font-size:14px;margin:5px 0 0}.port-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin:25px 0}.stat-item{background-color:#fff;border-radius:8px;padding:0;text-align:center}.stat-value{color:#0a2c5e;font-size:22px;font-weight:700}.stat-label{color:#666;font-size:13px;margin-top:5px}.stat-item:hover{background:#e9ecef;transform:translateY(-3px)}.entity-traffic-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:30px}.entity-card{background-color:#fff;border-left:4px solid #4da6ff;border-radius:10px;box-shadow:0 4px 12px #0000000d;cursor:pointer;padding:10px}.entity-card.maersk{border-left-color:#ff6384}.entity-card.msc{border-left-color:#ff9f40}.entity-card.cma{border-left-color:#4cd964}.entity-card.cosco{border-left-color:#96f}.entity-header{margin-bottom:5px}.entity-header,.entity-logo{align-items:center;display:flex}.entity-logo{border-radius:8px;color:#fff;font-size:16px;font-weight:700;height:40px;justify-content:center;margin-right:15px;width:40px}.entity-name{color:#0a2c5e;font-size:18px;font-weight:600}.port-growth{align-items:center;border-radius:8px;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;padding:12px}.port-growth.positive{background:#d4edda;color:#155724}.dashboard-footer{border-top:1px solid #dee2e6;color:#6c757d;font-size:15px;margin-top:30px;padding-top:20px;text-align:center}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:10px;padding:12px 24px;text-decoration:none;transition:all .3s ease}@media (max-width:1200px){.dashboard-tab span{font-size:13px}}@media (max-width:992px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:20px}.header-actions{justify-content:space-between;width:100%}.date-time{min-width:250px}.dashboard-tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.dashboard-tabs::-webkit-scrollbar{display:none}.dashboard-tab{flex-shrink:0;min-width:150px;padding:18px 12px}.dashboard-cards,.ports-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard-page{padding:15px}.dashboard-cards{grid-template-columns:1fr}.dashboard-tab{min-width:140px;padding:16px 10px}.dashboard-tab i{font-size:18px}.dashboard-tab span{font-size:12px}.header-title h1{font-size:22px}.date-time{font-size:14px;min-width:220px;padding:10px 15px}.card-value{font-size:32px}.port-stats,.ports-grid{grid-template-columns:1fr}}@media (max-width:576px){.dashboard-header{padding:20px}.date-time{margin-bottom:15px;min-width:100%}.header-actions{flex-direction:column;width:100%}.action-buttons,.btn{width:100%}.btn{justify-content:center}.dashboard-tab{min-width:130px;padding:14px 8px}.card,.dashboard-content{padding:20px}}
/*# sourceMappingURL=main.2b309677.css.map*/