:root{--primary: #003333;--primary-mid: #004040;--primary-light: #004d4d;--primary-xlight: #006666;--primary-dark: #002626;--primary-color: var(--primary);--bg-gradient: linear-gradient(135deg, #003333 0%, #004d4d 100%);--primary-gradient: linear-gradient(135deg, #003333 0%, #004d4d 100%);--primary-gradient-hover: linear-gradient(135deg, #004d4d 0%, #006666 100%);--primary-gradient-h: linear-gradient(180deg, #003333 0%, #004d4d 100%);--accent: #db5a36;--accent-light: #e86e47;--accent-dark: #c74a28;--accent-gradient: linear-gradient(135deg, #db5a36 0%, #e86e47 100%);--accent-color: var(--accent);--white: #ffffff;--g50: #f7f9fc;--g100: #eef2f7;--g200: #dde3ed;--g300: #b8c2d1;--g400: #8895a7;--g500: #5f6d80;--g600: #3e4c5e;--g700: #283546;--navy: #0a1628;--navy-mid: #12203b;--navy-light: #1b2d4f;--bg-light: var(--g50);--border-color: var(--g200);--text-muted: var(--g500);--secondary-color: var(--g500);--success: #0cce6b;--success-light: #edfcf2;--success-color: #198754;--warning: #ffb020;--warning-light: #fff8eb;--warning-color: #ffc107;--danger: #ef4444;--danger-light: #fef2f2;--danger-color: #dc3545;--info-color: #0dcaf0;--amber: #ffb020;--amber-light: #fff8eb;--coral: #ff6154;--coral-light: #fff1ef;--emerald: #0cce6b;--emerald-light: #edfcf2;--red: var(--danger);--red-bg: var(--danger-light);--font-heading: "Sora", -apple-system, sans-serif;--font-body: "Poppins", -apple-system, sans-serif;--font-family: var(--font-body);--font-mono: "JetBrains Mono", "Fira Code", Consolas, monospace;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 16px rgba(0, 51, 51, .12);--shadow-lg: 0 8px 24px rgba(0, 51, 51, .15);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-glow: 0 0 40px rgba(0, 51, 51, .18);--shadow-glow-accent: 0 0 40px rgba(219, 90, 54, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);background-color:var(--g50);color:var(--g700);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,button,select,textarea{font-family:inherit}html{--mat-sys-background: light-dark(#f7faf9, #101414);--mat-sys-error: light-dark(#ba1a1a, #ffb4ab);--mat-sys-error-container: light-dark(#ffdad6, #93000a);--mat-sys-inverse-on-surface: light-dark(#eff1f0, #2d3131);--mat-sys-inverse-primary: light-dark(#00dddd, #006a6a);--mat-sys-inverse-surface: light-dark(#2d3131, #e0e3e2);--mat-sys-on-background: light-dark(#191c1c, #e0e3e2);--mat-sys-on-error: light-dark(#ffffff, #690005);--mat-sys-on-error-container: light-dark(#93000a, #ffdad6);--mat-sys-on-primary: light-dark(#ffffff, #003737);--mat-sys-on-primary-container: light-dark(#004f4f, #00fbfb);--mat-sys-on-primary-fixed: light-dark(#002020, #002020);--mat-sys-on-primary-fixed-variant: light-dark(#004f4f, #004f4f);--mat-sys-on-secondary: light-dark(#ffffff, #1b3534);--mat-sys-on-secondary-container: light-dark(#324b4b, #cce8e7);--mat-sys-on-secondary-fixed: light-dark(#051f1f, #051f1f);--mat-sys-on-secondary-fixed-variant: light-dark(#324b4b, #324b4b);--mat-sys-on-surface: light-dark(#191c1c, #e0e3e2);--mat-sys-on-surface-variant: light-dark(#3f4948, #dae5e4);--mat-sys-on-tertiary: light-dark(#ffffff, #502400);--mat-sys-on-tertiary-container: light-dark(#723600, #ffdcc7);--mat-sys-on-tertiary-fixed: light-dark(#311300, #311300);--mat-sys-on-tertiary-fixed-variant: light-dark(#723600, #723600);--mat-sys-outline: light-dark(#6f7979, #889392);--mat-sys-outline-variant: light-dark(#bec9c8, #3f4948);--mat-sys-primary: light-dark(#006a6a, #00dddd);--mat-sys-primary-container: light-dark(#00fbfb, #004f4f);--mat-sys-primary-fixed: light-dark(#00fbfb, #00fbfb);--mat-sys-primary-fixed-dim: light-dark(#00dddd, #00dddd);--mat-sys-scrim: light-dark(#000000, #000000);--mat-sys-secondary: light-dark(#4a6363, #b0cccb);--mat-sys-secondary-container: light-dark(#cce8e7, #324b4b);--mat-sys-secondary-fixed: light-dark(#cce8e7, #cce8e7);--mat-sys-secondary-fixed-dim: light-dark(#b0cccb, #b0cccb);--mat-sys-shadow: light-dark(#000000, #000000);--mat-sys-surface: light-dark(#f7faf9, #101414);--mat-sys-surface-bright: light-dark(#f7faf9, #363a39);--mat-sys-surface-container: light-dark(#ebefed, #1c2020);--mat-sys-surface-container-high: light-dark(#e6e9e7, #272b2a);--mat-sys-surface-container-highest: light-dark(#e0e3e2, #313635);--mat-sys-surface-container-low: light-dark(#f1f4f3, #191c1c);--mat-sys-surface-container-lowest: light-dark(#ffffff, #0b0f0e);--mat-sys-surface-dim: light-dark(#d7dbd9, #101414);--mat-sys-surface-tint: light-dark(#006a6a, #00dddd);--mat-sys-surface-variant: light-dark(#dae5e4, #3f4948);--mat-sys-tertiary: light-dark(#964900, #ffb787);--mat-sys-tertiary-container: light-dark(#ffdcc7, #723600);--mat-sys-tertiary-fixed: light-dark(#ffdcc7, #ffdcc7);--mat-sys-tertiary-fixed-dim: light-dark(#ffb787, #ffb787);--mat-sys-neutral-variant20: #293232;--mat-sys-neutral10: #191c1c;--mat-sys-level0: 0px 0px 0px 0px rgba(0, 0, 0, .2), 0px 0px 0px 0px rgba(0, 0, 0, .14), 0px 0px 0px 0px rgba(0, 0, 0, .12);--mat-sys-level1: 0px 2px 1px -1px rgba(0, 0, 0, .2), 0px 1px 1px 0px rgba(0, 0, 0, .14), 0px 1px 3px 0px rgba(0, 0, 0, .12);--mat-sys-level2: 0px 3px 3px -2px rgba(0, 0, 0, .2), 0px 3px 4px 0px rgba(0, 0, 0, .14), 0px 1px 8px 0px rgba(0, 0, 0, .12);--mat-sys-level3: 0px 3px 5px -1px rgba(0, 0, 0, .2), 0px 6px 10px 0px rgba(0, 0, 0, .14), 0px 1px 18px 0px rgba(0, 0, 0, .12);--mat-sys-level4: 0px 5px 5px -3px rgba(0, 0, 0, .2), 0px 8px 10px 1px rgba(0, 0, 0, .14), 0px 3px 14px 2px rgba(0, 0, 0, .12);--mat-sys-level5: 0px 7px 8px -4px rgba(0, 0, 0, .2), 0px 12px 17px 2px rgba(0, 0, 0, .14), 0px 5px 22px 4px rgba(0, 0, 0, .12);--mat-sys-body-large: 400 1rem / 1.5rem Roboto;--mat-sys-body-large-font: Roboto;--mat-sys-body-large-line-height: 1.5rem;--mat-sys-body-large-size: 1rem;--mat-sys-body-large-tracking: .031rem;--mat-sys-body-large-weight: 400;--mat-sys-body-medium: 400 .875rem / 1.25rem Roboto;--mat-sys-body-medium-font: Roboto;--mat-sys-body-medium-line-height: 1.25rem;--mat-sys-body-medium-size: .875rem;--mat-sys-body-medium-tracking: .016rem;--mat-sys-body-medium-weight: 400;--mat-sys-body-small: 400 .75rem / 1rem Roboto;--mat-sys-body-small-font: Roboto;--mat-sys-body-small-line-height: 1rem;--mat-sys-body-small-size: .75rem;--mat-sys-body-small-tracking: .025rem;--mat-sys-body-small-weight: 400;--mat-sys-display-large: 400 3.562rem / 4rem Roboto;--mat-sys-display-large-font: Roboto;--mat-sys-display-large-line-height: 4rem;--mat-sys-display-large-size: 3.562rem;--mat-sys-display-large-tracking: -.016rem;--mat-sys-display-large-weight: 400;--mat-sys-display-medium: 400 2.812rem / 3.25rem Roboto;--mat-sys-display-medium-font: Roboto;--mat-sys-display-medium-line-height: 3.25rem;--mat-sys-display-medium-size: 2.812rem;--mat-sys-display-medium-tracking: 0;--mat-sys-display-medium-weight: 400;--mat-sys-display-small: 400 2.25rem / 2.75rem Roboto;--mat-sys-display-small-font: Roboto;--mat-sys-display-small-line-height: 2.75rem;--mat-sys-display-small-size: 2.25rem;--mat-sys-display-small-tracking: 0;--mat-sys-display-small-weight: 400;--mat-sys-headline-large: 400 2rem / 2.5rem Roboto;--mat-sys-headline-large-font: Roboto;--mat-sys-headline-large-line-height: 2.5rem;--mat-sys-headline-large-size: 2rem;--mat-sys-headline-large-tracking: 0;--mat-sys-headline-large-weight: 400;--mat-sys-headline-medium: 400 1.75rem / 2.25rem Roboto;--mat-sys-headline-medium-font: Roboto;--mat-sys-headline-medium-line-height: 2.25rem;--mat-sys-headline-medium-size: 1.75rem;--mat-sys-headline-medium-tracking: 0;--mat-sys-headline-medium-weight: 400;--mat-sys-headline-small: 400 1.5rem / 2rem Roboto;--mat-sys-headline-small-font: Roboto;--mat-sys-headline-small-line-height: 2rem;--mat-sys-headline-small-size: 1.5rem;--mat-sys-headline-small-tracking: 0;--mat-sys-headline-small-weight: 400;--mat-sys-label-large: 500 .875rem / 1.25rem Roboto;--mat-sys-label-large-font: Roboto;--mat-sys-label-large-line-height: 1.25rem;--mat-sys-label-large-size: .875rem;--mat-sys-label-large-tracking: .006rem;--mat-sys-label-large-weight: 500;--mat-sys-label-large-weight-prominent: 700;--mat-sys-label-medium: 500 .75rem / 1rem Roboto;--mat-sys-label-medium-font: Roboto;--mat-sys-label-medium-line-height: 1rem;--mat-sys-label-medium-size: .75rem;--mat-sys-label-medium-tracking: .031rem;--mat-sys-label-medium-weight: 500;--mat-sys-label-medium-weight-prominent: 700;--mat-sys-label-small: 500 .688rem / 1rem Roboto;--mat-sys-label-small-font: Roboto;--mat-sys-label-small-line-height: 1rem;--mat-sys-label-small-size: .688rem;--mat-sys-label-small-tracking: .031rem;--mat-sys-label-small-weight: 500;--mat-sys-title-large: 400 1.375rem / 1.75rem Roboto;--mat-sys-title-large-font: Roboto;--mat-sys-title-large-line-height: 1.75rem;--mat-sys-title-large-size: 1.375rem;--mat-sys-title-large-tracking: 0;--mat-sys-title-large-weight: 400;--mat-sys-title-medium: 500 1rem / 1.5rem Roboto;--mat-sys-title-medium-font: Roboto;--mat-sys-title-medium-line-height: 1.5rem;--mat-sys-title-medium-size: 1rem;--mat-sys-title-medium-tracking: .009rem;--mat-sys-title-medium-weight: 500;--mat-sys-title-small: 500 .875rem / 1.25rem Roboto;--mat-sys-title-small-font: Roboto;--mat-sys-title-small-line-height: 1.25rem;--mat-sys-title-small-size: .875rem;--mat-sys-title-small-tracking: .006rem;--mat-sys-title-small-weight: 500;--mat-sys-corner-extra-large: 28px;--mat-sys-corner-extra-large-top: 28px 28px 0 0;--mat-sys-corner-extra-small: 4px;--mat-sys-corner-extra-small-top: 4px 4px 0 0;--mat-sys-corner-full: 9999px;--mat-sys-corner-large: 16px;--mat-sys-corner-large-end: 0 16px 16px 0;--mat-sys-corner-large-start: 16px 0 0 16px;--mat-sys-corner-large-top: 16px 16px 0 0;--mat-sys-corner-medium: 12px;--mat-sys-corner-none: 0;--mat-sys-corner-small: 8px;--mat-sys-dragged-state-layer-opacity: .16;--mat-sys-focus-state-layer-opacity: .12;--mat-sys-hover-state-layer-opacity: .08;--mat-sys-pressed-state-layer-opacity: .12}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--g300);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--g400)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOpacity{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes pulseDot{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}.animate-fade-in{animation:fadeIn var(--transition-base) forwards}.animate-fade-out{animation:fadeOut var(--transition-base) forwards}.animate-slide-up{animation:slideUp var(--transition-base) forwards}.animate-slide-down{animation:slideDown var(--transition-base) forwards}.animate-slide-left{animation:slideLeft var(--transition-base) forwards}.animate-slide-right{animation:slideRight var(--transition-base) forwards}.animate-scale-in{animation:scaleIn var(--transition-base) forwards}.animate-scale-out{animation:scaleOut var(--transition-base) forwards}.animate-pulse{animation:pulse 2s infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce 1s infinite}.fade-in{animation:slideUp .4s cubic-bezier(.16,1,.3,1) forwards}.fade-opacity{animation:fadeOpacity .4s ease-out forwards}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.hover-scale{transition:transform var(--transition-base)}.hover-scale:hover{transform:scale(1.02)}.hover-glow{transition:box-shadow var(--transition-base)}.hover-glow:hover{box-shadow:var(--shadow-glow)}.hover-orange-shadow{transition:var(--transition-smooth)}.hover-orange-shadow:hover{box-shadow:0 12px 30px #db5a364d!important;transform:translateY(-5px);border-color:var(--accent)!important}.glass,.card-glass{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3)}.glass-dark{background:#003333a6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1)}.glass-teal{background:#004d4d26;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12)}.shimmer{background:linear-gradient(90deg,var(--g100) 25%,var(--g200) 50%,var(--g100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.gradient-text{background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gradient-text-accent{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-premium{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);transition:all var(--transition-base);border:1px solid var(--g200)}.card-premium:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.card-glass{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.card{border:1px solid var(--border-color);border-radius:var(--radius-md)!important;box-shadow:var(--shadow-sm);transition:var(--transition-smooth);background:var(--white)}.card:hover{box-shadow:var(--shadow-md)}.card-header{background:linear-gradient(135deg,#0033330d,#db5a3608);border-bottom:2px solid var(--border-color);font-weight:600;color:var(--primary);border-radius:var(--radius-md) var(--radius-md) 0 0;padding:16px 20px}.card-body{padding:20px}.tile-card{background:var(--white);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:12px;transition:var(--transition-smooth)}.tile-card:hover{box-shadow:0 12px 30px #db5a364d!important;transform:translateY(-5px);border-color:var(--accent)!important}.tile-card:hover .tile-icon{transform:scale(1.1)}.tile-card .tile-icon{font-size:3rem;margin-bottom:8px;transition:var(--transition-smooth)}.tile-card h3{margin:0;color:var(--primary);font-size:1.25rem;font-weight:600}.tile-card p{margin:0;color:var(--text-muted);font-size:.95rem}.btn{border-radius:var(--radius-sm);font-weight:600;font-family:var(--font-family);transition:var(--transition-smooth);border:none;position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff40;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:hover:before{width:300px;height:300px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--primary-gradient);color:var(--white);border:none;padding:.75rem 1.5rem;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition-smooth)}.btn-primary:hover:not(:disabled){background:var(--primary-gradient-hover);transform:translateY(-2px);box-shadow:0 10px 20px #00333340}.btn-primary:disabled{background:var(--g300);cursor:not-allowed}.btn-secondary{background:var(--g100);color:var(--g600);border:none;padding:.75rem 1.5rem;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition-smooth)}.btn-secondary:hover:not(:disabled){background:var(--g200);color:var(--navy);transform:translateY(-1px)}.btn-secondary:disabled{background:var(--g100);cursor:not-allowed}.btn-accent,.btn-orange{background:var(--accent-gradient);color:var(--white);border:none;padding:.75rem 1.5rem;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition-smooth)}.btn-accent:hover:not(:disabled),.btn-orange:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-dark) 0%,var(--accent) 100%);transform:translateY(-2px);box-shadow:0 10px 20px #db5a364d}.btn-outline-primary{color:var(--primary);border:2px solid var(--primary);background:transparent;padding:.65rem 1.4rem;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition-smooth)}.btn-outline-primary:hover:not(:disabled){background:var(--primary);color:var(--white);box-shadow:0 8px 20px #0333!important;transform:translateY(-2px)}.btn-outline-secondary{color:var(--g500);border:2px solid var(--g300);background:transparent;padding:.65rem 1.4rem;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition-smooth)}.btn-outline-secondary:hover:not(:disabled){background:var(--g100);color:var(--navy);transform:translateY(-1px)}.btn-ghost{color:var(--primary);background:transparent;border:none;padding:.65rem 1.2rem;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition-smooth)}.btn-ghost:hover:not(:disabled){background:#00333314;transform:translateY(-1px)}.btn-common{padding:12px 24px;border-radius:var(--radius-sm);font-weight:600;transition:var(--transition-smooth);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-common:hover{box-shadow:0 8px 20px #db5a3666!important;transform:translateY(-2px)}.btn-ripple{position:relative;overflow:hidden}.btn-ripple:after{content:"";position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.3) 10%,transparent 10.01%);background-repeat:no-repeat;background-position:50%;transform:scale(10);opacity:0;transition:transform .5s,opacity 1s}.btn-ripple:active:after{transform:scale(0);opacity:.3;transition:0s}.form-control,.form-select,.form-input{width:100%;padding:12px 16px;border:1.5px solid var(--g200);border-radius:var(--radius-sm);background:var(--white);font-family:var(--font-family);font-size:14.5px;color:var(--navy);transition:all .25s;outline:none}.form-control::placeholder,.form-select::placeholder,.form-input::placeholder{color:var(--g400)}.form-control:focus,.form-select:focus,.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #00333314}.form-control:disabled,.form-select:disabled,.form-input:disabled{background:var(--g50);cursor:not-allowed}.form-control.is-invalid,.form-select.is-invalid,.form-input.is-invalid{border-color:var(--danger)}.form-control.is-invalid:focus,.form-select.is-invalid:focus,.form-input.is-invalid:focus{box-shadow:0 0 0 4px #ef44441a}.form-label,label{font-size:13px;font-weight:650;color:var(--navy);display:block;margin-bottom:6px}.form-group{margin-bottom:1.5rem}.required:after{content:" *";color:var(--coral)}.field-group{margin-bottom:24px;display:flex;flex-direction:column;gap:8px}.field-group-inline{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}@media(max-width:640px){.field-group-inline{grid-template-columns:1fr;gap:16px}}.error-message{display:block;font-size:.85rem;color:var(--danger);font-weight:600;margin-top:.4rem}.section{background:var(--white);padding:32px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0033330f;margin-bottom:32px}.section h2{font-size:20px;font-weight:800;color:var(--primary);margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--accent)}.buttons{display:flex;justify-content:flex-end;gap:16px;margin-top:40px}.modal-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s ease-out}.modal-content-card{background:var(--white);border-radius:24px;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:650px;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.mat-mdc-dialog-container .mdc-dialog__surface{border-radius:24px!important;background:var(--white)!important;box-shadow:0 25px 50px -12px #00000040!important;padding:0!important;overflow:hidden!important}.mat-dialog-custom .mat-mdc-dialog-surface{border-radius:20px!important;padding:0!important;overflow-y:auto!important;max-height:100vh}.intake-dialog-panel .mat-mdc-dialog-surface{border-radius:20px!important;padding:0!important;overflow:hidden!important;max-height:92vh!important}.dialog-header{padding:32px 40px;background:var(--g50);border-bottom:1px solid var(--g100);display:flex;justify-content:space-between;align-items:flex-start}.dialog-header .m-text h3{font-size:20px;font-weight:850;color:var(--navy);margin:0}.dialog-header .m-text p{font-size:13px;color:var(--g500);margin:4px 0 0;font-weight:550}.dialog-header .close-x{background:var(--g100);border:none;font-size:24px;color:var(--g400);cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.dialog-header .close-x:hover{background:var(--g200);color:var(--navy)}.dialog-body{padding:40px;max-height:70vh;overflow-y:auto}.dialog-subtitle{color:var(--text-muted);font-size:1.1rem;margin-bottom:24px;line-height:1.6}.dialog-footer{padding:24px 40px;background:var(--white);border-top:1px solid var(--g100);display:flex;justify-content:flex-end;gap:16px}.modal-content{border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);background:var(--white)}.modal-header{border-bottom:2px solid var(--border-color);background:linear-gradient(135deg,#0033330d,#db5a3608);padding:20px 24px}.modal-title{font-weight:700;color:var(--primary);font-size:1.25rem}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-color);padding:16px 24px;background:#00333305}.modal-backdrop{background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-container{display:flex;min-height:100vh;font-family:var(--font-family)}@media(max-width:991.98px){.login-container{flex-direction:column}}.login-branding{flex:1;background:var(--bg-gradient);display:flex;align-items:center;justify-content:center;padding:4rem;position:relative;overflow:hidden}@media(max-width:1024px){.login-branding{display:none}}.login-branding:before{content:"";position:absolute;top:-10%;right:-10%;width:40%;height:40%;background:#db5a361f;border-radius:50%;filter:blur(80px)}.login-branding .branding-content{max-width:500px;z-index:1;color:var(--white)}.branding-title{font-size:2.5rem;font-weight:850;margin-bottom:1.5rem;line-height:1.2;color:var(--white)}.branding-title .branding-accent{color:var(--accent);display:inline-block}.branding-description{font-size:1.05rem;margin-bottom:2rem;line-height:1.6;color:#ffffffe6;font-weight:400}.badge-custom{display:inline-flex;align-items:center;gap:8px;background:#ffffff1a;padding:10px 20px;border-radius:100px;font-size:.95rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fffffff2;transition:var(--transition-smooth)}.badge-custom:hover{background:#ffffff26;border-color:#ffffff4d}.badge-custom .dot{width:10px;height:10px;background:var(--accent);border-radius:50%;box-shadow:0 0 10px var(--accent);flex-shrink:0;animation:pulseDot 2s infinite}.login-form-container{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem 2rem;background:var(--white)}@media(max-width:991.98px){.login-form-container{padding:2rem 1.5rem}}.login-form{width:100%;max-width:420px}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-gradient);position:relative;overflow-y:auto;padding:20px}.login-card{width:100%;max-width:480px;background:#fffffff5;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.8);border-radius:var(--radius-2xl);padding:56px;box-shadow:0 40px 100px -20px #0333;z-index:10;animation:fadeInUp .7s cubic-bezier(.16,1,.3,1) forwards}@media(max-width:640px){.login-card{padding:32px 24px;border-radius:20px}}.sidebar{width:260px;background:var(--primary);border-right:1px solid var(--border-color);position:fixed;left:0;top:0;height:100vh;overflow-y:auto;z-index:100;transition:var(--transition-smooth)}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-header{padding:12px}.sidebar.collapsed .sidebar-logo{max-width:40px}.sidebar.collapsed .sidebar-menu a{justify-content:center;padding:12px 8px}.sidebar.collapsed .sidebar-menu a span{display:none}.sidebar.collapsed .sidebar-menu a i{width:auto}.sidebar-header{padding:24px 16px;border-bottom:2px solid var(--accent);display:flex;align-items:center;justify-content:space-between;background:var(--primary-dark);transition:var(--transition-smooth)}.sidebar-logo{max-width:150px;height:auto;transition:var(--transition-smooth)}.sidebar-toggle-btn{background:none;border:none;color:var(--white);cursor:pointer;font-size:1.2rem;display:none;transition:var(--transition-smooth);padding:4px 8px;z-index:101}.sidebar-toggle-btn:hover{color:var(--accent);transform:scale(1.1)}.sidebar-menu{list-style:none;padding:16px 0}.sidebar-menu li{margin:0}.sidebar-menu a{display:flex;align-items:center;gap:12px;padding:12px 24px;color:#ffffffe0;text-decoration:none;transition:var(--transition-smooth);border-left:4px solid transparent;position:relative;font-size:.9375rem}.sidebar-menu a:hover{background:#ffffff1f;color:var(--white);border-left-color:var(--accent);padding-left:22px}.sidebar-menu a.active{background:#db5a362e;color:var(--white);border-left-color:var(--accent);font-weight:600;box-shadow:inset -4px 0 0 var(--accent)}.sidebar-menu a i{width:20px;text-align:center;flex-shrink:0}.logout-btn{color:#ff6b6b!important;margin-top:auto}.logout-btn:hover{background:#ff6b6b1f!important}.d-flex{display:flex}.main-content{margin-left:260px;width:calc(100% - 260px);transition:var(--transition-smooth)}.main-content.sidebar-collapsed{margin-left:60px;width:calc(100% - 60px)}.top-bar{background:var(--white);border-bottom:1px solid var(--border-color);padding:16px 0;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.top-bar h5{font-weight:600;color:var(--primary)}.content-area{padding:32px 24px}.stats-card{border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-smooth);border-top:4px solid var(--primary);background:var(--white);box-shadow:var(--shadow-sm)}.stats-card:hover{box-shadow:0 0 20px 5px #b74c2dd9;transform:translateY(-4px);border-top:4px solid var(--accent)!important}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:var(--transition-smooth)}.stat-icon.info{background:#0033331a;color:var(--primary)}.stat-icon.success{background:#1987541a;color:var(--success-color)}.stat-icon.warning,.stat-icon.primary{background:#db5a361a;color:var(--accent)}.stat-icon.danger{background:#ef44441a;color:var(--danger)}.stats-card:hover .stat-icon{transform:scale(1.1) rotate(5deg)}.hero-section{background:var(--bg-gradient);color:var(--white);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg)}.action-card{border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-smooth);height:100%;overflow:hidden;background:var(--white);box-shadow:var(--shadow-sm);position:relative}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:0;transition:var(--transition-smooth)}.action-card:hover{box-shadow:0 0 22px 5px #b74b2d80!important;transform:translateY(-8px);border-color:var(--primary)}.action-card:hover:before{opacity:1}.action-card:hover .action-icon{transform:scale(1.15) rotate(-5deg)}.action-icon{width:56px;height:56px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin-bottom:16px;transition:var(--transition-smooth)}.action-icon.video,.action-icon.calendar,.action-icon.phone{background:#0033331a;color:var(--primary)}.action-icon.shield,.action-icon.user{background:#db5a361a;color:var(--accent)}.action-icon.file{background:#1987541a;color:var(--success-color)}.appointment-card{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;transition:var(--transition-smooth);border-left:4px solid transparent;background:var(--white);box-shadow:var(--shadow-sm)}.appointment-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);border-left-color:var(--accent);transform:translate(4px)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;transition:var(--transition-smooth)}.status-badge-upcoming{background:#0033331a;color:var(--primary)}.status-badge-completed{background:#1987541a;color:var(--success-color)}.status-badge-cancelled{background:#dc35451a;color:var(--danger-color)}.status-badge-requested{background:#ffb02026;color:#a06400}.list-group-item{border:none;border-bottom:1px solid var(--border-color);padding:16px;transition:var(--transition-smooth)}.list-group-item:last-child{border-bottom:none}.list-group-item:hover{background:#00333305;border-left:4px solid var(--accent);padding-left:12px}.patient-avatar{width:48px;height:48px;background:var(--primary-gradient);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);background:linear-gradient(135deg,#0033330d,#db5a3608);border-bottom:2px solid var(--primary)}.calendar-header div{padding:16px;text-align:center;font-weight:600;color:var(--primary);font-size:.875rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);overflow:auto}.calendar-day{min-height:120px;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:12px;background:var(--white);cursor:pointer;transition:var(--transition-smooth)}.calendar-day:hover{background:#00333305;box-shadow:inset 0 0 12px #0033330d}.calendar-day-number{font-weight:600;color:var(--primary);margin-bottom:8px}.calendar-day-number.today{width:32px;height:32px;background:var(--primary-gradient);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center}.calendar-day-appointment{font-size:.75rem;background:var(--primary-gradient);color:var(--white);padding:2px 6px;border-radius:4px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.intake-header{background:var(--primary-gradient);box-shadow:var(--shadow-lg)}.intake-full-overlay{position:fixed;inset:0;z-index:2000;background:#000000b3;display:flex;align-items:flex-start;justify-content:center;padding:20px 12px;overflow-y:auto}.intake-container{background:var(--white);width:100%;max-width:960px;border-radius:var(--radius-md);box-shadow:0 10px 40px #0006;overflow:hidden}@media(max-width:640px){.intake-full-overlay{padding:0}.intake-container{border-radius:0;height:100%;max-width:none;overflow:auto}}.back-link{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--primary);font-size:13px;font-weight:700;cursor:pointer;padding:0;margin-bottom:24px;transition:opacity .2s}.back-link:hover{opacity:.7}.back-link .icon{font-size:18px;line-height:1}.data-table tr:hover td{background:#00333305}table tr td,table tr th{white-space:nowrap}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.empty-state{padding:80px 40px;text-align:center;background:var(--g50);border-radius:20px;border:2px dashed var(--g200)}.empty-state .icon{font-size:48px;margin-bottom:16px;display:block}.empty-state h3{font-size:18px;font-weight:750;color:var(--navy);margin-bottom:8px}.empty-state p{font-size:14px;color:var(--g500)}.success-snackbar{background-color:var(--emerald)!important;color:#fff!important;--mdc-snackbar-container-color: var(--emerald);--mdc-snackbar-supporting-text-color: white}.success-snackbar .mdc-button__label{color:#fff!important}.error-snackbar{background-color:var(--coral)!important;color:#fff!important;--mdc-snackbar-container-color: var(--coral);--mdc-snackbar-supporting-text-color: white}.error-snackbar .mdc-button__label{color:#fff!important}.info-snackbar{background-color:var(--primary)!important;color:#fff!important;--mdc-snackbar-container-color: var(--primary);--mdc-snackbar-supporting-text-color: white}.info-snackbar .mdc-button__label{color:#fff!important}.mat-mdc-snack-bar-container .mdc-snackbar__label{font-family:var(--font-family)!important;font-weight:500!important}.swal-firstcall{border-radius:20px!important;font-family:var(--font-family)!important;box-shadow:0 25px 60px #0000002e!important;color:var(--primary)!important}.swal-firstcall-title{font-family:var(--font-family)!important;font-weight:800!important;font-size:20px!important;letter-spacing:-.3px!important}.swal-firstcall-btn{border-radius:10px!important;font-family:var(--font-family)!important;font-weight:700!important;font-size:13px!important;padding:10px 24px!important;transition:all .2s!important}.swal-firstcall-btn:hover{transform:translateY(-1px)!important;box-shadow:0 4px 14px #0003!important}.swal-firstcall-btn-cancel{border-radius:10px!important;font-family:var(--font-family)!important;font-weight:650!important;font-size:13px!important;padding:10px 24px!important}.swal-firstcall-input{border-radius:10px!important;border:1.5px solid var(--g200)!important;font-family:var(--font-family)!important;font-size:13.5px!important;padding:12px 14px!important;color:var(--navy)!important;transition:border-color .2s!important}.swal-firstcall-input:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px #00333314!important}.swal-firstcall-wide{width:480px!important;max-width:95vw!important}.swal2-timer-progress-bar{background:var(--primary)!important}.swal2-wide{width:380px!important}.swal2-btn{background:var(--g100)!important;color:var(--primary)!important;margin:8px 0!important;font-weight:600!important;border-radius:var(--radius-sm)!important;width:100%!important}.swal2-btn:hover{background:var(--accent)!important;color:var(--white)!important;box-shadow:0 8px 20px #db5a3666!important;transform:translateY(-2px)}.swal-employer-popup{width:360px!important;padding:.5rem!important;border-radius:var(--radius-lg);background:var(--g50);box-shadow:0 20px 30px #0000001a;color:var(--primary)}.swal-employer-popup .employer-roles{display:flex;flex-direction:column;gap:12px;margin-top:1rem}.swal-employer-popup .employer-roles .role-btn{display:flex;align-items:center;gap:12px;justify-content:center;padding:12px 16px;font-size:1rem;font-weight:600;border:2px solid transparent;border-radius:var(--radius-sm);background:var(--g200);color:var(--primary);cursor:pointer;transition:var(--transition-smooth)}.swal-employer-popup .employer-roles .role-btn i{font-size:1.25rem}.swal-employer-popup .employer-roles .role-btn:hover{background:var(--primary);color:var(--white)}.swal2-close{color:var(--primary)!important;font-size:1.2rem!important;top:12px!important;right:12px!important}.swal2-close:hover{color:var(--accent)!important}.mat-mdc-button-base{font-family:var(--font-family)!important}.role-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.role-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--white);cursor:pointer;transition:var(--transition-smooth);color:var(--text-muted)}.role-btn i{font-size:1.25rem}.role-btn span{font-size:.75rem;font-weight:500}.role-btn:hover{border-color:var(--primary);color:var(--primary);background:#0033330d}.role-btn.active{border-color:var(--primary);background:#0033331a;color:var(--primary)}.user-profile{display:flex;align-items:center;gap:8px;color:var(--text-muted)}.user-profile i{font-size:1.5rem;color:var(--primary)}.swiper-button-next svg,.swiper-button-prev svg{height:100%;object-fit:contain;width:100%;fill:currentColor;pointer-events:none;display:none}.text-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-primary{color:var(--primary)!important}.text-accent{color:var(--accent)!important}.text-muted{color:var(--text-muted)!important}.text-success{color:var(--success-color)!important}.text-danger{color:var(--danger-color)!important}.text-white{color:var(--white)!important}.bg-primary-gradient{background:var(--bg-gradient)!important}.bg-white{background:var(--white)!important}.bg-light{background:var(--g50)!important}.fw-normal{font-weight:var(--font-normal)}.fw-medium{font-weight:var(--font-medium)}.fw-semibold{font-weight:var(--font-semibold)}.fw-bold{font-weight:var(--font-bold)}.fw-extrabold{font-weight:var(--font-extrabold)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-auto{margin-top:auto}.mb-auto{margin-bottom:auto}.show-mobile{display:none!important}@media(max-width:768px){.hidden-mobile{display:none!important}.show-mobile{display:block!important}}@media(max-width:1024px){.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center}.sidebar-header{justify-content:space-between;padding:16px}.sidebar-logo{max-width:120px}.login-branding{display:none}.login-form-container{flex:1}}@media(max-width:768px){.sidebar{width:260px;position:fixed;left:0;top:0;height:100vh;z-index:999}.sidebar-header{padding:16px 12px;justify-content:space-between}.sidebar-logo{max-width:100px}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center}.sidebar.collapsed{width:60px}.main-content{margin-left:260px;width:calc(100% - 260px)}.main-content.sidebar-collapsed{margin-left:60px;width:calc(100% - 60px)}.content-area{padding:16px 12px}.role-selector{grid-template-columns:1fr}.calendar-day{min-height:80px}.stats-card{margin-bottom:12px}.hero-section{padding:20px}.action-card{margin-bottom:12px}.modal-body{padding:16px}.modal-header,.modal-footer{padding:12px 16px}}@media(max-width:576px){.sidebar{width:260px;position:fixed;transform:translate(0);z-index:999;box-shadow:2px 0 8px #00000026}.sidebar.mobile-hidden{transform:translate(-100%)}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center}.sidebar-header{padding:16px 12px;justify-content:space-between}.sidebar-logo{max-width:100px}.sidebar-menu a{padding:12px 16px;gap:12px}.sidebar-menu a span{display:inline}.main-content,.main-content.sidebar-collapsed{margin-left:0;width:100%}.top-bar{padding:12px 0}.content-area{padding:16px}.login-form-container{flex:1;padding:20px}.hero-logo{max-width:180px}.modal-dialog{margin:1rem}.modal-content{border-radius:var(--radius-sm)}.modal-header,.modal-footer{padding:12px 16px}}
