:root{--bg-main: #0c0c0e;--bg-card: rgba(22, 22, 26, .7);--bg-card-hover: rgba(30, 30, 36, .85);--border-color: rgba(255, 255, 255, .08);--border-color-hover: rgba(255, 255, 255, .15);--color-primary: #0ea5e9;--color-primary-rgb: 14, 165, 233;--color-success: #10b981;--color-success-rgb: 16, 185, 129;--color-warning: #f59e0b;--color-warning-rgb: 245, 158, 11;--color-danger: #ef4444;--color-danger-rgb: 239, 68, 68;--text-primary: #f3f4f6;--text-secondary: #9ca3af;--text-muted: #6b7280;--sidebar-width: 260px;--header-height: 70px;--border-radius-lg: 16px;--border-radius-md: 10px;--border-radius-sm: 6px;--transition-smooth: all .25s cubic-bezier(.4, 0, .2, 1);--shadow-premium: 0 10px 30px -10px rgba(0, 0, 0, .7);--shadow-glow: 0 0 20px rgba(14, 165, 233, .15)}*{margin:0;padding:0;box-sizing:border-box;font-family:Outfit,sans-serif;-webkit-font-smoothing:antialiased}body{background-color:var(--bg-main);color:var(--text-primary);overflow-x:hidden;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}#app{display:flex;min-height:100vh}.app-container{display:flex;width:100%;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding-top:var(--header-height);min-height:100vh;background-color:var(--bg-main);display:flex;flex-direction:column}@media (max-width: 992px){.main-content{margin-left:0}}.view-container{padding:30px;flex:1;animation:fadeIn .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.glass{background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-premium)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.95rem;font-weight:500;margin-bottom:8px;color:var(--text-secondary)}.form-input{width:100%;padding:12px 16px;background:#ffffff08;border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:1.05rem;transition:var(--transition-smooth)}.form-input:focus{outline:none;border-color:var(--color-primary);background:#ffffff0d;box-shadow:0 0 0 3px #0ea5e926}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-weight:600;font-size:1.05rem;border-radius:var(--border-radius-md);border:1px solid transparent;cursor:pointer;transition:var(--transition-smooth)}.btn-primary{background:var(--color-primary);color:#000}.btn-primary:hover{background:#38bdf8;transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn-secondary{background:#ffffff0d;color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:#ffffff1a;border-color:var(--border-color-hover)}.btn-danger{background:#ef44441a;color:var(--color-danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:var(--color-danger);color:#fff}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-primary{background:#0ea5e926;color:var(--color-primary)}.badge-success{background:#10b98126;color:var(--color-success)}.badge-warning{background:#f59e0b26;color:var(--color-warning)}.badge-danger{background:#ef444426;color:var(--color-danger)}.progress-bar-container{width:100%;height:8px;background:#ffffff0d;border-radius:4px;overflow:hidden;margin:8px 0}.progress-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--color-primary),#06b6d4);transition:width .8s cubic-bezier(.16,1,.3,1)}.text-gradient{background:linear-gradient(135deg,var(--color-primary),#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.text-gradient-gold{background:linear-gradient(135deg,var(--color-warning),#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);z-index:100;display:flex;flex-direction:column;padding:24px;border-right:1px solid var(--border-color)}.sidebar-logo{display:flex;align-items:center;gap:12px;margin-bottom:40px;text-decoration:none}.logo-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary),#0284c7);display:flex;align-items:center;justify-content:center;color:#000;font-size:1.25rem;font-weight:700;box-shadow:var(--shadow-glow)}.logo-text{font-size:1.15rem;font-weight:700;color:var(--text-primary);line-height:1.2}.logo-sub{font-size:.8rem;color:var(--text-secondary);font-weight:400;letter-spacing:.05em}.sidebar-menu{list-style:none;display:flex;flex-direction:column;gap:8px;flex:1}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-secondary);text-decoration:none;border-radius:var(--border-radius-md);font-weight:500;font-size:1.05rem;transition:var(--transition-smooth)}.sidebar-link i,.sidebar-link svg{font-size:1.1rem;transition:var(--transition-smooth)}.sidebar-link:hover,.sidebar-link.active{color:var(--text-primary);background:#ffffff0d}.sidebar-link.active{background:#0ea5e91a;color:var(--color-primary);border-left:3px solid var(--color-primary);border-top-left-radius:0;border-bottom-left-radius:0}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid var(--border-color)}.user-profile-mini{display:flex;align-items:center;gap:12px}.avatar{width:38px;height:38px;border-radius:50%;background:#374151;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-primary);border:2px solid var(--border-color)}.user-info-text{flex:1;min-width:0}.user-name{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.85rem;color:var(--text-muted)}.logout-btn{color:var(--color-danger);background:none;border:none;cursor:pointer;font-size:1.1rem;padding:4px;transition:var(--transition-smooth)}.logout-btn:hover{transform:scale(1.1)}.header{position:fixed;top:0;right:0;left:var(--sidebar-width);height:var(--header-height);z-index:90;display:flex;align-items:center;justify-content:space-between;padding:0 30px;border-bottom:1px solid var(--border-color)}@media (max-width: 992px){.header{left:0}}.header-title-container{display:flex;align-items:center;gap:15px}.menu-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:1.25rem;cursor:pointer}@media (max-width: 992px){.menu-toggle{display:block}}.header-actions{display:flex;align-items:center;gap:20px}.btn-icon-badge{position:relative;background:#ffffff08;border:1px solid var(--border-color);color:var(--text-primary);width:40px;height:40px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.btn-icon-badge:hover{background:#ffffff14}.notification-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--color-danger);box-shadow:0 0 10px var(--color-danger)}.login-wrapper{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:radial-gradient(circle at 10% 20%,rgba(14,165,233,.05) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(16,185,129,.03) 0%,transparent 40%),var(--bg-main)}.login-card{width:100%;max-width:480px;padding:40px;border-radius:var(--border-radius-lg);text-align:center}.login-logo{display:inline-flex;flex-direction:column;align-items:center;gap:15px;margin-bottom:35px}.login-logo .logo-icon{width:60px;height:60px;font-size:1.8rem;border-radius:14px}.login-logo .logo-text{font-size:1.6rem}.login-subtitle{font-size:1rem;color:var(--text-muted);margin-top:4px}.login-tabs{display:grid;grid-template-columns:1fr 1fr;background:#ffffff08;border:1px solid var(--border-color);padding:4px;border-radius:var(--border-radius-md);margin-bottom:30px}.login-tab-btn{padding:10px;border:none;background:none;color:var(--text-secondary);font-weight:600;font-size:1rem;cursor:pointer;border-radius:var(--border-radius-sm);transition:var(--transition-smooth)}.login-tab-btn.active{background:var(--color-primary);color:#000}.demo-account-box{margin-top:25px;padding:15px;border-radius:var(--border-radius-md);background:#ffffff05;border:1px dashed var(--border-color);text-align:left;font-size:.95rem}.demo-account-title{font-weight:600;color:var(--text-secondary);margin-bottom:8px;display:flex;align-items:center;gap:6px}.demo-account-item{color:var(--text-muted);margin-bottom:4px}.demo-account-item span{color:var(--text-secondary);font-family:monospace;background:#ffffff0d;padding:2px 6px;border-radius:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:30px}.stat-card{padding:20px;border-radius:var(--border-radius-lg);display:flex;align-items:center;gap:20px;transition:var(--transition-smooth)}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-color-hover)}.stat-icon-wrapper{width:50px;height:50px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-icon-wrapper.primary{background:#0ea5e91a;color:var(--color-primary)}.stat-icon-wrapper.success{background:#10b9811a;color:var(--color-success)}.stat-icon-wrapper.warning{background:#f59e0b1a;color:var(--color-warning)}.stat-info{flex:1}.stat-value{font-size:1.5rem;font-weight:700;margin-bottom:2px}.stat-label{font-size:.95rem;color:var(--text-secondary)}.dashboard-sections{display:grid;grid-template-columns:2fr 1fr;gap:30px}@media (max-width: 1200px){.dashboard-sections{grid-template-columns:1fr}}.section-card{border-radius:var(--border-radius-lg);padding:24px;margin-bottom:30px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-title{font-size:1.15rem;font-weight:600;display:flex;align-items:center;gap:8px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.project-card{border-radius:var(--border-radius-lg);padding:20px;cursor:pointer;transition:var(--transition-smooth)}.project-card:hover{background:var(--bg-card-hover);transform:translateY(-2px);border-color:var(--color-primary)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.project-card-title{font-size:1.1rem;font-weight:600;margin-bottom:4px}.project-card-location{font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.project-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:15px;padding-top:12px;border-top:1px solid var(--border-color)}.project-meta-item{font-size:.9rem;color:var(--text-muted)}.project-meta-item strong{color:var(--text-secondary)}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;gap:12px;position:relative}.activity-icon{width:32px;height:32px;border-radius:50%;background:#ffffff08;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.activity-content{flex:1}.activity-text{font-size:.95rem;color:var(--text-primary);line-height:1.4}.activity-text strong{color:var(--color-primary)}.activity-time{font-size:.85rem;color:var(--text-muted);margin-top:2px}.project-banner{border-radius:var(--border-radius-lg);padding:30px;margin-bottom:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.project-banner-info{display:flex;flex-direction:column;gap:8px}.tab-nav{display:flex;gap:10px;border-bottom:1px solid var(--border-color);margin-bottom:30px;overflow-x:auto}.tab-btn{padding:12px 20px;background:none;border:none;color:var(--text-secondary);font-weight:600;font-size:1.05rem;cursor:pointer;border-bottom:2px solid transparent;transition:var(--transition-smooth);white-space:nowrap}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.phases-timeline{display:flex;flex-direction:column;gap:20px}.phase-card{border-radius:var(--border-radius-lg);padding:20px;transition:var(--transition-smooth)}.phase-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:12px}.phase-title-group{display:flex;align-items:center;gap:12px}.phase-step-number{width:28px;height:28px;border-radius:50%;background:#ffffff0d;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700}.phase-title{font-size:1.05rem;font-weight:600}.phase-body{padding-top:15px;border-top:1px dashed var(--border-color);display:grid;grid-template-columns:2fr 1fr;gap:20px}@media (max-width: 768px){.phase-body{grid-template-columns:1fr}}.checklist-items{display:flex;flex-direction:column;gap:12px}.checklist-item{display:flex;align-items:center;gap:10px;cursor:pointer}.checklist-checkbox{width:20px;height:20px;border-radius:4px;border:1.5px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.checklist-checkbox i{font-size:.75rem;color:#000;opacity:0}.checklist-item.checked .checklist-checkbox{background:var(--color-success);border-color:var(--color-success)}.checklist-item.checked .checklist-checkbox i{opacity:1}.checklist-item.checked span{text-decoration:line-through;color:var(--text-muted)}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:15px}.photo-item{position:relative;border-radius:var(--border-radius-md);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--border-color)}.photo-item img{width:100%;height:100%;object-fit:cover;transition:var(--transition-smooth)}.photo-item:hover img{transform:scale(1.08)}.photo-overlay{position:absolute;bottom:0;left:0;right:0;padding:8px;background:linear-gradient(0deg,rgba(0,0,0,.8) 0%,transparent 100%);font-size:.85rem;color:#fff;display:flex;justify-content:space-between}.photo-upload-card{border:2px dashed var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:8px;color:var(--text-secondary);transition:var(--transition-smooth)}.photo-upload-card:hover{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e905}.finance-table-container{width:100%;overflow-x:auto}.finance-table{width:100%;border-collapse:collapse;margin-bottom:20px}.finance-table th{text-align:left;padding:14px 16px;border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-weight:600}.finance-table td{padding:14px 16px;border-bottom:1px solid var(--border-color);font-size:1.05rem}.finance-table tr:hover td{background:#ffffff03}.finance-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:25px}.finance-summary-box{padding:20px;border-radius:var(--border-radius-lg);text-align:center}.finance-summary-val{font-size:1.5rem;font-weight:700;margin-top:5px}.kanban-board-container{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;overflow-x:auto}@media (max-width: 900px){.kanban-board-container{grid-template-columns:1fr}}.kanban-col{background:#ffffff03;border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:16px;display:flex;flex-direction:column;min-height:400px}.kanban-col-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-weight:600}.kanban-col-count{background:#ffffff0d;padding:2px 8px;border-radius:10px;font-size:.85rem}.kanban-list{display:flex;flex-direction:column;gap:12px;flex:1}.kanban-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:16px;cursor:grab;transition:var(--transition-smooth)}.kanban-card:hover{border-color:var(--color-primary);background:var(--bg-card-hover)}.kanban-card-title{font-size:1rem;font-weight:600;margin-bottom:10px;line-height:1.4}.kanban-card-footer{display:flex;justify-content:space-between;align-items:center}.kanban-card-project{font-size:.85rem;color:var(--text-muted)}.kanban-card-assignee{width:24px;height:24px;border-radius:50%;background:#0ea5e933;color:var(--color-primary);font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.modal-content{width:100%;max-width:500px;border-radius:var(--border-radius-lg);padding:30px;position:relative;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;transition:var(--transition-smooth)}.modal-close:hover{color:var(--text-primary);transform:scale(1.1)}.modal-title{font-size:1.25rem;font-weight:600;margin-bottom:20px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:25px;padding-top:15px;border-top:1px solid var(--border-color)}.toast-container{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:2000}.toast{padding:12px 20px;border-radius:var(--border-radius-md);background:#1e1e24;border-left:4px solid var(--color-primary);box-shadow:0 10px 25px #00000080;display:flex;align-items:center;gap:10px;animation:slideIn .3s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--color-success)}.toast-warning{border-left-color:var(--color-warning)}.toast-danger{border-left-color:var(--color-danger)}.client-timeline{position:relative;padding-left:30px;margin:20px 0}.client-timeline:before{content:"";position:absolute;left:8px;top:5px;bottom:5px;width:2px;background:#ffffff0d}.client-timeline-item{position:relative;margin-bottom:25px}.client-timeline-dot{position:absolute;left:-29px;top:4px;width:18px;height:18px;border-radius:50%;border:3px solid var(--bg-main);background:var(--text-muted)}.client-timeline-item.active .client-timeline-dot{background:var(--color-primary);box-shadow:0 0 10px #0ea5e980}.client-timeline-item.completed .client-timeline-dot{background:var(--color-success);box-shadow:0 0 10px #10b9814d}.client-timeline-header{display:flex;justify-content:space-between;margin-bottom:5px}.client-timeline-title{font-weight:600;font-size:1.05rem}.client-timeline-date{font-size:.9rem;color:var(--text-muted)}.client-timeline-desc{font-size:.95rem;color:var(--text-secondary)}.image-feed{display:flex;flex-direction:column;gap:20px}.feed-item{border-radius:var(--border-radius-lg);overflow:hidden;border:1px solid var(--border-color)}.feed-img-container{width:100%;max-height:250px;overflow:hidden}.feed-img-container img{width:100%;height:100%;object-fit:cover}.feed-body{padding:15px;background:#ffffff03}.feed-meta{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted);margin-bottom:5px}@media (max-width: 992px){.sidebar{transform:translate(-100%);transition:transform .3s cubic-bezier(.16,1,.3,1);box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:10px 0 40px #000c}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:95;display:none;animation:fadeIn .2s ease}.sidebar-overlay.active{display:block}}
