.auth-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#002a5a,#8ecae6);color:#fff;font-size:1.1rem;gap:20px}.auth-loading .spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-login-page{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#002a5a,#8ecae6);padding:20px}.login-container{width:100%;max-width:400px}.login-card{background:#fff;border-radius:0;box-shadow:0 10px 40px #0003;overflow:hidden;display:flex;flex-direction:column;min-height:500px}.login-header{background:linear-gradient(135deg,#002a5a,#8ecae6);color:#fff;padding:40px 30px 30px;text-align:center}.login-header h1{margin:0;font-size:2rem;font-weight:700}.login-header .subtitle{margin:8px 0 0;font-size:.9rem;opacity:.9}.login-content{padding:40px 30px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.login-icon{font-size:3rem;margin-bottom:20px}.login-content h2{margin:0 0 15px;color:var(--primary);font-size:1.5rem}.login-content .description{margin:0 0 30px;color:var(--text-muted);line-height:1.6}.login-button{width:100%;padding:12px 20px;border:none;border-radius:0;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.microsoft-button{background:#0078d4;color:#fff}.microsoft-button:hover{background:#106ebe;transform:translateY(-2px);box-shadow:0 5px 15px #0078d44d}.microsoft-button:active{transform:translateY(0)}.button-icon{font-size:1.2rem}.login-info{margin-top:25px;padding-top:25px;border-top:1px solid #eee;width:100%}.info-text{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.5}.login-footer{background:#f8f9fa;padding:20px;text-align:center;border-top:1px solid #eee}.footer-text{margin:0;font-size:.85rem;color:var(--text-muted)}@media (max-width: 768px){.login-card{min-height:auto}.login-header{padding:30px 20px 20px}.login-header h1{font-size:1.5rem}.login-content{padding:30px 20px}.login-icon{font-size:2.5rem}}.login-title{margin:10px 0 5px;font-size:1.8rem;font-weight:700}.login-subtitle{margin:0;font-size:.9rem;opacity:.9}.login-actions{padding:30px;display:flex;flex-direction:column;align-items:center}.google-button{background:#fff;color:var(--primary);border:2px solid #e0e0e0;box-shadow:0 2px 4px #0000001a}.google-button:hover{background:#f8f9fa;border-color:#4285f4;transform:translateY(-2px);box-shadow:0 4px 12px #4285f433}.google-icon{flex-shrink:0}.google-auth-wrapper{display:flex;flex-direction:column}.google-auth-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#fff;border-bottom:1px solid #e0e0e0;margin-bottom:0}.google-user-info{display:flex;align-items:center;gap:10px}.google-avatar{width:32px;height:32px;border-radius:50%;border:2px solid #4285F4}.google-user-name{font-weight:500;color:var(--primary);font-size:.9rem}.google-logout-btn{padding:8px 16px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:0;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .2s ease}.google-logout-btn:hover{background:#fee2e2;border-color:#ef4444;color:#dc2626}.login-separator{display:flex;align-items:center;width:100%;margin:20px 0}.login-separator:before,.login-separator:after{content:"";flex:1;height:1px;background:#ddd}.login-separator span{padding:0 15px;color:var(--text-muted);font-size:.9rem}.login-form{width:100%;display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:0;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.login-input:focus{outline:none;border-color:#002a5a;box-shadow:0 0 0 3px #667eea1a}.login-input::placeholder{color:var(--text-muted)}.local-button{background:#002a5a;color:#fff;margin-top:8px}.local-button:hover:not(:disabled){background:var(--primary);transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.local-button:disabled{background:var(--text-muted);cursor:not-allowed;transform:none}.login-error{background:#fee2e2;color:#dc2626;padding:10px 16px;border-radius:0;font-size:.9rem;width:100%;box-sizing:border-box;text-align:center}.sidebar{width:280px;height:100vh;background-color:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:1000;border-right:1px solid rgba(255,255,255,.05);transition:width .3s ease}.sidebar.collapsed{width:80px}.sidebar-toggle-btn{position:absolute;right:-12px;top:20px;width:24px;height:24px;background:var(--primary);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;z-index:1001;transition:all .2s ease}.sidebar-toggle-btn:hover{background:var(--primary-dark);transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.sidebar-header{padding:var(--space-xl) var(--space-lg)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md)}.logo-box{width:32px;height:32px;background-color:var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.25rem}.logo-text{color:#fff;font-weight:600;font-size:1.125rem}.sidebar-content{flex:1;overflow-y:auto;padding:0 var(--space-md);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background-color:#ffffff1a;border-radius:0}.sidebar-content:hover::-webkit-scrollbar-thumb{background-color:#fff3}.sidebar-group{margin-bottom:var(--space-xl)}.group-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md);padding-left:var(--space-md);opacity:.5}.group-items{display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--sidebar-text);transition:all .2s ease;position:relative}.sidebar.collapsed .sidebar-item{justify-content:center;padding:var(--space-sm)}.sidebar-item:hover{background-color:var(--sidebar-active-bg);color:#fff}.sidebar-item.active{background-color:var(--sidebar-active-bg);color:var(--sidebar-active)}.sub-items-container{margin-top:var(--space-xs);margin-left:var(--space-lg);display:flex;flex-direction:column;gap:2px;border-left:1px solid rgba(255,255,255,.1);padding-left:var(--space-sm);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sub-sidebar-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);font-size:.8125rem;transition:all .2s ease}.sub-sidebar-item:hover{color:#fff;background-color:#ffffff0d}.sub-sidebar-item.active{color:var(--primary-light);font-weight:500}.sub-item-icon{opacity:.5}.sub-sidebar-item.active .sub-item-icon{opacity:1}.item-icon{opacity:.7}.active .item-icon{opacity:1;color:var(--primary-light)}.active-indicator{position:absolute;right:0;top:50%;transform:translateY(-50%);width:4px;height:20px;background-color:var(--primary);border-radius:0}.sidebar-footer{padding:var(--space-lg);border-top:1px solid rgba(255,255,255,.05)}.user-profile{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.sidebar.collapsed .user-profile{justify-content:center}.user-avatar{width:40px;height:40px;min-width:40px;min-height:40px;border-radius:50%;overflow:hidden;background-color:var(--secondary);display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:600}.user-info{display:flex;flex-direction:column}.user-name{color:#fff;font-size:.875rem;font-weight:600}.user-role{font-size:.75rem;opacity:.6}.logout-button{width:100%;display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:none;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--sidebar-text);font-size:.875rem}.logout-button:hover{background-color:#ef44441a;color:#ef4444;border-color:#ef444433}.sidebar-footer-actions{display:flex;flex-direction:column;gap:var(--space-sm)}.theme-toggle-button{width:100%;display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--sidebar-text);font-size:.875rem;transition:all .2s ease;cursor:pointer}.sidebar.collapsed .theme-toggle-button,.sidebar.collapsed .logout-button{justify-content:center;padding:var(--space-sm)}[data-theme=dark] .theme-toggle-button{background:var(--surface-hover)}.theme-toggle-button:hover{background-color:var(--sidebar-active-bg);color:#fff}.sync-status{display:flex;align-items:center;gap:8px;padding:4px 12px;border-radius:0;background:rgba(var(--primary-rgb, 0, 102, 204),.1);font-size:.8rem;color:var(--text-secondary);transition:all .3s ease;cursor:default;border:1px solid transparent}.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 #4caf5066}.sync-status.syncing .sync-dot{animation:pulse 1.5s infinite}.sync-status.disconnected .sync-dot{background:var(--danger)}.sync-status.disconnected{background:#f443361a;color:var(--danger);border:1px solid rgba(244,67,54,.2)}.sync-info{display:flex;flex-direction:column;line-height:1.1}.sync-details{font-size:.65rem;font-weight:700;color:var(--primary-color)}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #4caf50b3}70%{transform:scale(1);box-shadow:0 0 0 10px #4caf5000}to{transform:scale(.95);box-shadow:0 0 #4caf5000}}[data-theme=dark] .sync-status{background:#ffffff0d}.sync-notification-banner{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:12px 20px;border-radius:0;display:flex;align-items:center;gap:15px;box-shadow:0 4px 15px #0000004d;z-index:9999;animation:slideUp .3s ease-out}.sync-notification-content{display:flex;align-items:center;gap:8px;font-size:14px}.sync-notification-actions{display:flex;gap:8px}.sync-refresh-btn{background:var(--primary-light);color:#fff;border:none;padding:6px 12px;border-radius:0;cursor:pointer;font-weight:600;font-size:13px;transition:background .2s}.sync-refresh-btn:hover{background:var(--primary)}.sync-dismiss-btn{background:transparent;color:var(--text-muted);border:1px solid var(--text-muted);padding:6px 12px;border-radius:0;cursor:pointer;font-size:13px;transition:all .2s}.sync-dismiss-btn:hover{color:#fff;border-color:#fff}@keyframes slideUp{0%{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%);opacity:1}}.layout-container{display:flex;min-height:100vh;background-color:var(--background)}.layout-main{flex:1;margin-left:280px;min-height:100vh;display:flex;flex-direction:column;transition:margin-left .3s ease}.layout-main.sidebar-collapsed{margin-left:80px}.layout-content{padding:var(--space-xl);max-width:1600px;width:100%;margin:0 auto}@media (max-width: 1440px){.layout-content{padding:0}}@media (max-width: 1024px){.layout-main{margin-left:0}}.resume-dashboard-container{display:flex;flex-direction:column;gap:var(--space-xl);min-height:100vh}.dashboard-main-content{flex:1;display:flex;flex-direction:column;gap:var(--space-xl)}.dashboard-sidebar h3{font-size:.9rem;text-transform:uppercase;color:#7f8c8d;margin-bottom:1.5rem;letter-spacing:1px}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;padding:1rem 1.25rem;border-radius:0;color:var(--primary);text-decoration:none;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:1px solid rgba(0,0,0,.1);background:#fff6;width:100%;text-align:left;margin-bottom:.25rem}.nav-item:hover{background:#3498db0d;border-color:var(--primary-light);transform:translate(4px);color:var(--primary-light);box-shadow:0 4px 12px #3498db1a}.nav-item.active{background:var(--primary-light);color:#fff;border-color:#2980b9;box-shadow:0 4px 10px #3498db4d}.dashboard-main-content{flex:1;display:flex;flex-direction:column;gap:3rem}.dashboard-section{scroll-margin-top:100px}@media (max-width: 1024px){.resume-dashboard-container{flex-direction:column}.dashboard-sidebar{width:100%;position:relative;top:0;margin-bottom:1rem}}.initial-loader-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--background);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999}.loader-orb{width:60px;height:60px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:50%;animation:pulse-orb 1.5s infinite ease-in-out;box-shadow:0 0 20px #3498db66}@keyframes pulse-orb{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1;box-shadow:0 0 40px #3498db99}to{transform:scale(.8);opacity:.5}}.loader-text{margin-top:2rem;font-weight:500;color:var(--primary);letter-spacing:.5px;font-family:Inter,sans-serif}.section-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fff9;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:center;align-items:center;z-index:5;border-radius:0;animation:fade-in .3s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.loading-spinner-small{width:30px;height:30px;border:3px solid rgba(52,152,219,.1);border-top-color:var(--primary-light);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-section{position:relative;scroll-margin-top:100px;padding:var(--space-xl);background:var(--background);color:var(--text-main);min-height:calc(100vh - 40px)}@media (max-width: 1440px){.dashboard-section{padding:0}}.dashboard-group-title{display:flex;align-items:center;gap:12px;font-size:1.1rem;font-weight:600;color:#1e293b;letter-spacing:1px;margin:32px 0 16px;padding:12px 20px;background:linear-gradient(90deg,#f1f5f9,#fff);border-left:4px solid #1e40af;border-radius:4px}.dashboard-group-icon{font-size:1.4rem}.dashboard-main-content>.dashboard-group-title:first-of-type{margin-top:16px}.dashboard-section-title{display:flex;align-items:center;gap:10px;font-size:.95rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px;margin:24px 0 12px 4px;padding:6px 0;border-bottom:1px solid #e2e8f0}.dashboard-section-icon{font-size:1.1rem}body{font-family:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--background);color:var(--text-main);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:1000;width:100%}.header-content{width:100%}.app-header h1{font-size:2.25rem;color:var(--text-main);margin-bottom:8px;font-weight:700;text-align:center}.header-subtitle{text-align:center;margin-bottom:15px}.header-subtitle p{color:var(--text-muted);font-size:1rem}.backend-status{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;margin-top:15px;transition:all .3s ease}.backend-status.checking{background:var(--warning-soft);color:var(--warning)}.backend-status.connected{background:var(--success-soft);color:var(--success)}.backend-status.disconnected{background:var(--danger-soft);color:var(--danger)}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.backend-status.checking .status-dot{background:var(--warning);animation:pulse 1.5s ease-in-out infinite}.backend-status.connected .status-dot{background:var(--success)}.backend-status.disconnected .status-dot{background:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.retry-connection{padding:5px 12px;background:var(--surface);color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.retry-connection:hover{background:var(--danger);color:#fff}.app-main{flex:1;padding:0 20px 40px;width:100%;margin:0 auto}.connection-error{background:var(--surface);border-radius:var(--radius-lg);padding:60px 40px;text-align:center;box-shadow:var(--shadow-lg);max-width:600px;margin:40px auto;border:1px solid var(--border)}.error-icon{font-size:64px;margin-bottom:20px}.connection-error h2{color:var(--text-main);margin-bottom:15px;font-size:1.5rem}.connection-error p{color:var(--text-muted);margin-bottom:30px;font-size:1rem;line-height:1.6}.error-actions{margin-bottom:30px}.primary-button{padding:12px 30px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:var(--shadow-md)}.primary-button:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.primary-button:active{transform:translateY(0)}.help-text{background:var(--surface-hover);border-left:4px solid var(--primary);padding:20px;border-radius:var(--radius-sm);text-align:left;margin-top:20px}.help-text p{margin-bottom:10px;font-size:14px;color:var(--text-main)}.help-text code{display:block;background:var(--primary);color:var(--border);padding:12px 16px;border-radius:var(--radius-sm);font-family:monospace;font-size:13px;margin-top:10px;overflow-x:auto}.app-footer{background:var(--surface);color:var(--text-muted);text-align:center;padding:20px;margin-top:40px;border-top:1px solid var(--border)}.app-footer p{font-size:.875rem;opacity:.9}@media (max-width:1440px){.app-main{padding:0}}@media (max-width: 768px){.app-header{padding:20px 15px}.app-header h1{font-size:26px}.header-subtitle p{font-size:14px}.app-main{padding:0 15px 30px}.connection-error{padding:40px 20px;margin:20px auto}.connection-error h2{font-size:20px}.connection-error p{font-size:14px}.help-text code{font-size:11px;padding:10px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-main{animation:fadeIn .5s ease-out}:root{--primary: #002A5A;--primary-dark: #001a3a;--primary-light: #8ECAE6;--primary-soft: rgba(0, 42, 90, .08);--secondary: #8ECAE6;--secondary-soft: rgba(142, 202, 230, .15);--cta: #F55757;--cta-hover: #e04040;--success: #10b981;--success-soft: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .1);--danger: #F55757;--danger-soft: rgba(245, 87, 87, .1);--background: #f1f5f9;--surface: #ffffff;--surface-hover: #f8fafc;--text-main: #002A5A;--text-muted: #5a7a9a;--sidebar-bg: #002A5A;--sidebar-text: #8ECAE6;--sidebar-active: #ffffff;--sidebar-active-bg: rgba(142, 202, 230, .15);--border: #d8e4ef;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--shadow-sm: 0 1px 2px 0 rgb(0 42 90 / .05);--shadow-md: 0 4px 6px -1px rgb(0 42 90 / .08), 0 2px 4px -2px rgb(0 42 90 / .05);--shadow-lg: 0 10px 15px -3px rgb(0 42 90 / .08), 0 4px 6px -4px rgb(0 42 90 / .05);--radius-sm: 0;--radius-md: 0;--radius-lg: 0;--radius-xl: 0;--radius-2xl: 0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:var(--text-main);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}[data-theme=dark]{--background: #001a3a;--surface: #002A5A;--surface-hover: #003366;--text-main: #f1f5f9;--text-muted: #8ECAE6;--border: #003d7a;--sidebar-active-bg: rgba(142, 202, 230, .1);--primary-soft: rgba(142, 202, 230, .15);--success-soft: rgba(16, 185, 129, .2);--warning-soft: rgba(245, 158, 11, .2);--danger-soft: rgba(245, 87, 87, .2)}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}#root{width:100%}h1,h2,h3,h4,h5,h6{color:var(--text-main);font-weight:600;line-height:1.25}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;transition:all .2s ease}.card{background:var(--surface);border-radius:0;box-shadow:var(--shadow-sm);padding:var(--space-md);border:1px solid var(--border)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background-color:var(--primary-light);border-radius:0;border:2px solid var(--background)}::-webkit-scrollbar-thumb:hover{background-color:var(--primary)}*{scrollbar-width:thin;scrollbar-color:var(--primary-light) var(--background)}
