:root{--color-primary: #1a1a2e;--color-secondary: #16213e;--color-accent: #0f4c75;--color-highlight: #00b4d8;--color-light: #e6f7ff;--color-white: #ffffff;--color-gray: #6c757d;--color-orange: #f97316;--color-footer:#1a1a2e;--viewer-bg-dark: #1a1a2e;--viewer-bg-medium: #16213e;--viewer-bg-light: #0f4c75;--viewer-bg: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);--viewer-card-bg: rgba(255, 255, 255, .98);--viewer-border: rgba(226, 232, 240, .8);--viewer-shadow: 0 8px 32px rgba(15, 76, 117, .08);--viewer-gradient: linear-gradient(135deg, #0f4c75 0%, #00b4d8 100%);--viewer-accent: #0f4c75;--viewer-highlight: #00b4d8;--viewer-text: #1e293b;--viewer-text-light: #64748b;--viewer-canvas-height: 600px;--viewer-header-height: 400px;--color-background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);--color-surface: #f8f9fa;--color-text: #212529;--color-text-secondary: #6c757d;--color-border: #dee2e6;--color-success: #28a745;--color-warning: #ffc107;--color-error: #dc3545;--color-info: #17a2b8;--card-bg: var(--color-white);--input-bg: var(--color-white);--modal-overlay: rgba(0, 0, 0, .5);--font-primary: "Inter", sans-serif;--font-secondary: "Poppins", sans-serif;--font-family-base: var(--font-primary), system-ui, -apple-system, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--line-height-base: 1.6;--spacing-unit: 1rem;--space-xs: calc(var(--spacing-unit) * .25);--space-sm: calc(var(--spacing-unit) * .5);--space-md: var(--spacing-unit);--space-lg: calc(var(--spacing-unit) * 1.5);--space-xl: calc(var(--spacing-unit) * 2);--space-2xl: calc(var(--spacing-unit) * 3);--spacing-xs: var(--space-xs);--spacing-sm: var(--space-sm);--spacing-md: var(--space-md);--spacing-lg: var(--space-lg);--spacing-xl: var(--space-xl);--spacing-2xl: var(--space-2xl);--border-radius: 8px;--border-radius-base: var(--border-radius);--border-width: 1px;--border-color: var(--color-border);--container-width: 1200px;--header-height: 80px;--sidebar-width: 280px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-speed: var(--transition-normal);--transition-timing: ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}.dark-theme{--color-background: #1a202c;--color-surface: #2d3748;--color-text: #e2e8f0;--color-text-secondary: #a0aec0;--color-border: #4a5568;--color-success: #48bb78;--color-warning: #ed8936;--color-error: #f56565;--color-info: #4299e1;--color-footer:#00e6cc;--color-white: #1a202c;--color-primary: #4da6ff;--color-secondary: #2d3748;--color-accent: #00e6cc;--color-highlight: #00e6cc;--color-light: #2d3748;--color-orange: #fdba74;--viewer-bg-dark: #0a0a1a;--viewer-bg-medium: #1a202c;--viewer-bg-light: #2d3748;--card-bg: var(--color-surface);--input-bg: var(--color-surface);--modal-overlay: rgba(0, 0, 0, .7);--viewer-bg: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);--viewer-card-bg: rgba(30, 41, 59, .98);--viewer-border: rgba(71, 85, 105, .8);--viewer-shadow: 0 8px 32px rgba(0, 0, 0, .3);--viewer-text: #f1f5f9;--viewer-text-light: #94a3b8}.high-contrast{--color-background: #000000;--color-surface: #111111;--color-text: #ffffff;--color-text-secondary: #cccccc;--color-border: #ffffff;--color-success: #00ff00;--color-warning: #ffff00;--color-error: #ff0000;--color-info: #00ffff;--color-primary: #0066cc;--color-secondary: #004080;--color-accent: #00aaff;--color-highlight: #00ffff;--color-light: #111111;--color-orange: #ffa500;--viewer-bg-dark: #000000;--viewer-bg-medium: #111111;--viewer-bg-light: #222222;--contrast-boost: 20%;--color-primary: color-mix(in srgb, #0066cc, black var(--contrast-boost));--color-accent: color-mix(in srgb, #00aaff, white var(--contrast-boost));--card-bg: var(--color-surface);--input-bg: var(--color-surface);--modal-overlay: rgba(0, 0, 0, .9);--shadow-sm: 0 0 0 1px var(--color-border);--shadow-md: 0 0 0 2px var(--color-border);--shadow-lg: 0 0 0 3px var(--color-border)}*{margin:0;padding:0;box-sizing:border-box;transition:background-color var(--transition-speed) var(--transition-timing),color var(--transition-speed) var(--transition-timing),border-color var(--transition-speed) var(--transition-timing),box-shadow var(--transition-speed) var(--transition-timing)}html{scroll-behavior:smooth}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text);background-color:var(--color-background);transition:background-color var(--transition-speed) var(--transition-timing),color var(--transition-speed) var(--transition-timing);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{font-family:var(--font-secondary);font-weight:600;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-highlight)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-info{color:var(--color-info)}.d-block{display:block}.d-inline{display:inline}.d-inline-block{display:inline-block}.d-flex{display:flex}.d-grid{display:grid}.theme-transition{transition:all var(--transition-speed) var(--transition-timing)}.no-transition{transition:none!important}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.skip-to-content{position:absolute;top:-40px;left:0;background:var(--color-primary);color:var(--color-white);padding:var(--spacing-sm) var(--spacing-md);z-index:var(--z-popover)}.skip-to-content:focus{top:0}@media(prefers-reduced-motion:reduce){:root{--transition-fast: .01ms;--transition-normal: .01ms;--transition-slow: .01ms;--transition-speed: .01ms}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media print{:root{--color-background: white !important;--color-surface: white !important;--color-text: black !important;--color-text-secondary: #666 !important;--color-border: #ddd !important;--color-primary: black !important;--color-secondary: #333 !important}.dark-theme,.high-contrast{--color-background: white;--color-surface: white;--color-text: black;--color-text-secondary: #666;--color-border: #ddd;--color-primary: black;--color-secondary: #333}*{transition:none!important}.no-print{display:none!important}a{color:#000!important;text-decoration:underline}.page-break{page-break-before:always}}@media(min-width:768px){:root{--container-width: 720px}}@media(min-width:992px){:root{--container-width: 960px}}@media(min-width:1200px){:root{--container-width: 1140px}}@media(min-width:1920px){:root{--container-width: 1600px}}.card{background-color:var(--card-bg);border-radius:var(--border-radius);border:var(--border-width) solid var(--color-border);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--border-radius);cursor:pointer;font-family:inherit;font-size:var(--font-size-base);font-weight:500;line-height:1.5;text-align:center;text-decoration:none;transition:all var(--transition-fast)}.btn:hover{background-color:var(--color-accent);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--input-bg);color:var(--color-text);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius);font-family:inherit;font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-accent)}.common-header{background-color:var(--color-white);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:var(--z-sticky);width:100%;padding:0;transition:all var(--transition-fast);position:relative}.dark-theme .common-header{background-color:var(--color-surface);box-shadow:0 2px 8px #0000004d}.common-header-container{margin:0 auto;padding:0 var(--space-md);display:flex;align-items:center;justify-content:space-between;height:var(--header-height);position:relative}.scroll-progress-bar{position:absolute;bottom:0;left:0;width:100%;height:3px;background-color:#0000000d;z-index:var(--z-sticky);overflow:hidden}.dark-theme .scroll-progress-bar{background-color:#ffffff0d}.scroll-progress-indicator{height:100%;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-highlight) 50%,var(--color-accent) 100%);transition:width .1s ease-out;position:relative;border-radius:0 2px 2px 0}.scroll-progress-indicator:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 2s infinite;opacity:.5}.dark-theme .scroll-progress-indicator:after{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.8) 50%,transparent 100%);opacity:.3}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.high-contrast .scroll-progress-bar{background-color:#ffffff1a;height:4px}.high-contrast .scroll-progress-indicator{background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-highlight) 100%);box-shadow:0 0 8px var(--color-highlight)}.high-contrast .scroll-progress-indicator:after{animation:none;background:none;box-shadow:0 0 12px var(--color-highlight)}.common-header-logo{flex-shrink:0;z-index:1002;margin-left:20px}.common-header-logo-link{display:flex;align-items:center;text-decoration:none;gap:var(--space-sm);padding:var(--space-xs) 0;transition:opacity var(--transition-fast)}.common-header-logo-link:hover{opacity:.9}.common-header-logo-icon{display:flex;align-items:center;gap:2px;position:relative}.common-header-logo-icon-square,.common-header-logo-icon-circle,.common-header-logo-icon-triangle{font-size:12px;display:inline-block;transition:transform var(--transition-fast)}.common-header-logo-icon-square{color:var(--color-accent);transform:rotate(45deg)}.common-header-logo-icon-circle{color:var(--color-highlight);font-size:10px;position:relative;top:1px}.common-header-logo-icon-triangle{color:var(--color-secondary);font-size:10px;position:relative;top:-1px}.common-header-logo-link:hover .common-header-logo-icon-square{transform:rotate(90deg)}.common-header-logo-link:hover .common-header-logo-icon-circle{transform:scale(1.2)}.common-header-logo-link:hover .common-header-logo-icon-triangle{transform:rotate(180deg)}.common-header-logo-texts{display:flex;flex-direction:column;line-height:1}.common-header-logo-main{font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:800;color:var(--color-primary);letter-spacing:-.5px}.common-header-logo-sub{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-accent);font-weight:500;margin-top:1px}.dark-theme .common-header-logo-main{color:var(--color-text)}.common-header-nav{display:flex;align-items:center;margin:0 auto}.common-header-nav-list{display:flex;list-style:none;gap:var(--space-xl);margin:0;padding:0}.common-header-nav-item{position:relative}.common-header-nav-link{text-decoration:none;color:var(--color-text-secondary);font-weight:500;font-size:var(--font-size-md);padding:var(--space-sm) 0;position:relative;transition:color var(--transition-fast)}.common-header-nav-link:hover,.common-header-nav-link.active{color:var(--color-primary)}.dark-theme .common-header-nav-link:hover,.dark-theme .common-header-nav-link.active{color:var(--color-text)}.common-header-nav-link.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background-color:var(--color-accent);border-radius:2px}.common-header-actions{display:flex;align-items:center;gap:var(--space-sm);z-index:1002}.common-header-login-button,.common-header-signup-button{padding:var(--space-sm) var(--space-lg);border-radius:var(--border-radius);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;font-family:inherit}.common-header-login-button{background-color:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.common-header-login-button:hover{background-color:var(--color-accent);color:var(--color-white)}.common-header-signup-button{background-color:var(--color-accent);color:var(--color-white);border:1px solid var(--color-accent)}.common-header-signup-button:hover{background-color:var(--color-highlight);border-color:var(--color-highlight);transform:translateY(-2px);box-shadow:var(--shadow-md)}.common-header-user-section{display:flex;align-items:center;gap:var(--space-sm)}.common-header-user-button{display:flex;align-items:center;gap:var(--space-sm);background:none;border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius);cursor:pointer;transition:background-color var(--transition-fast)}.common-header-user-button:hover{background-color:var(--color-light)}.common-header-user-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--color-accent);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600}.common-header-user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}.common-header-logout-button{background:none;border:none;color:var(--color-text-secondary);padding:var(--space-xs);cursor:pointer;border-radius:var(--border-radius);transition:all var(--transition-fast)}.common-header-logout-button:hover{color:var(--color-error);background-color:var(--color-light)}.common-header-mobile-toggle{display:none;background:none;border:none;width:40px;height:40px;padding:8px;cursor:pointer;z-index:1003}.common-header-mobile-toggle-icon{display:block;width:24px;height:2px;background-color:var(--color-primary);position:relative;transition:all var(--transition-fast)}.dark-theme .common-header-mobile-toggle-icon{background-color:var(--color-text)}.common-header-mobile-toggle-icon:before,.common-header-mobile-toggle-icon:after{content:"";position:absolute;width:24px;height:2px;background-color:var(--color-primary);transition:all var(--transition-fast)}.dark-theme .common-header-mobile-toggle-icon:before,.dark-theme .common-header-mobile-toggle-icon:after{background-color:var(--color-text)}.common-header-mobile-toggle-icon:before{top:-6px}.common-header-mobile-toggle-icon:after{bottom:-6px}.common-header-mobile-toggle-icon.open{background-color:transparent}.common-header-mobile-toggle-icon.open:before{top:0;transform:rotate(45deg)}.common-header-mobile-toggle-icon.open:after{bottom:0;transform:rotate(-45deg)}.common-header-mobile-menu{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background-color:var(--color-white);transform:translate(100%);transition:transform var(--transition-normal);overflow-y:auto;z-index:1001}.dark-theme .common-header-mobile-menu{background-color:var(--color-surface)}.common-header-mobile-menu.open{transform:translate(0)}.common-header-mobile-menu-content{padding:var(--space-xl)}.common-header-mobile-menu-list{list-style:none;margin:0;padding:0}.common-header-mobile-menu-item{margin-bottom:var(--space-md)}.common-header-mobile-menu-link{display:block;padding:var(--space-sm) 0;text-decoration:none;color:var(--color-text);font-size:var(--font-size-lg);font-weight:500;transition:color var(--transition-fast)}.common-header-mobile-menu-link:hover,.common-header-mobile-menu-link.active{color:var(--color-accent)}.common-header-mobile-auth-section{margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.common-header-mobile-user-info{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.common-header-mobile-user-avatar{width:48px;height:48px;border-radius:50%;background-color:var(--color-accent);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:600;flex-shrink:0}.common-header-mobile-user-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:2px}.common-header-mobile-user-email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.common-header-mobile-auth-buttons{display:flex;flex-direction:column;gap:var(--space-md)}.common-header-mobile-login-button,.common-header-mobile-signup-button,.common-header-mobile-dashboard-button,.common-header-mobile-logout-button{width:100%;padding:var(--space-md);border-radius:var(--border-radius);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;font-family:inherit}.common-header-mobile-login-button{background-color:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.common-header-mobile-login-button:hover{background-color:var(--color-accent);color:var(--color-white)}.common-header-mobile-signup-button{background-color:var(--color-accent);color:var(--color-white);border:1px solid var(--color-accent)}.common-header-mobile-signup-button:hover{background-color:var(--color-highlight);border-color:var(--color-highlight)}.common-header-mobile-dashboard-button{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.common-header-mobile-dashboard-button:hover{background-color:var(--color-border)}.common-header-mobile-logout-button{background-color:transparent;color:var(--color-error);border:1px solid var(--color-error)}.common-header-mobile-logout-button:hover{background-color:var(--color-error);color:var(--color-white)}@media(max-width:1024px){.common-header-nav{display:none}.common-header-mobile-toggle{display:block}}@media(max-width:768px){.common-header-container{padding:0 var(--space-sm);height:64px}.common-header-logo-main{font-size:var(--font-size-lg)}.common-header-logo-sub{font-size:10px}.common-header-actions{display:none}.scroll-progress-bar{height:2px}}@media(max-width:480px){.common-header-logo-icon{display:none}.common-header-mobile-menu-content{padding:var(--space-lg)}.common-header-mobile-menu-link{font-size:var(--font-size-base)}}@media(prefers-reduced-motion:reduce){.scroll-progress-indicator:after{animation:none}.scroll-progress-indicator{transition:none}}.common-footer{background-color:var(--color-footer);color:var(--color-white);padding:var(--space-2xl) 0 var(--space-xl);margin-top:auto}.common-footer-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.common-footer-content{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);margin-bottom:var(--space-2xl)}@media(min-width:768px){.common-footer-content{grid-template-columns:2fr 3fr}}.common-footer-brand{display:flex;flex-direction:column;gap:var(--space-md)}.common-footer-logo{display:flex;align-items:center;gap:var(--space-xs)}.common-footer-logo-text{font-family:var(--font-secondary);font-size:var(--font-size-2xl);font-weight:700}.common-footer-logo-subtext{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-highlight);font-weight:500}.common-footer-description{color:var(--color-light);line-height:1.6;opacity:.9}.common-footer-social{display:flex;gap:var(--space-md);margin-top:var(--space-sm)}.common-footer-social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background-color:#ffffff1a;transition:background-color var(--transition-fast);text-decoration:none}.common-footer-social-link:hover{background-color:var(--color-highlight)}.common-footer-social-icon{font-size:var(--font-size-sm);font-weight:500}.common-footer-links{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-xl)}@media(min-width:640px){.common-footer-links{grid-template-columns:repeat(3,1fr)}}.common-footer-links-section{display:flex;flex-direction:column;gap:var(--space-md)}.common-footer-links-title{font-size:var(--font-size-lg);font-weight:600;margin:0;color:var(--color-white)}.common-footer-links-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.common-footer-links-item{margin:0}.common-footer-links-link{color:var(--color-light);text-decoration:none;transition:color var(--transition-fast);opacity:.9}.common-footer-links-link:hover{color:var(--color-highlight);opacity:1}.common-footer-copyright{padding-top:var(--space-xl);border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:var(--space-sm);align-items:center;text-align:center}@media(min-width:768px){.common-footer-copyright{flex-direction:row;justify-content:space-between;text-align:left}}.common-footer-copyright-text{margin:0;color:var(--color-light);opacity:.8;font-size:var(--font-size-sm)}.common-footer-copyright-stats{margin:0;color:var(--color-highlight);font-weight:600;font-size:var(--font-size-sm)}.common-theme-toggle{position:fixed;bottom:var(--space-lg);right:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;z-index:var(--z-fixed);box-shadow:var(--shadow-md);transition:all var(--transition-speed)}.common-theme-toggle:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.common-theme-toggle:active{transform:translateY(0)}.common-theme-toggle-icon{font-size:20px}.common-theme-toggle-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}@media(max-width:767px){.common-theme-toggle-text{display:none}.common-theme-toggle{padding:var(--space-sm);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center}}.main-layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-background);transition:background-color var(--transition-speed)}.main-layout-full-width{max-width:100%}.main-layout-skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:var(--space-sm) var(--space-md);text-decoration:none;z-index:var(--z-tooltip);border-radius:0 0 var(--border-radius-base) 0;transition:top .3s ease}.main-layout-skip-link:focus{top:0;outline:2px solid var(--color-accent);outline-offset:2px}.main-layout-header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--color-surface);box-shadow:var(--shadow-sm);transition:background-color var(--transition-speed)}.main-layout-main{flex:1;display:flex;flex-direction:column}.main-layout-page-header{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;padding:var(--space-xl) 0;position:relative;overflow:hidden}.main-layout-page-header:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.main-layout-page-header-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md);position:relative;z-index:1}.main-layout-page-title{font-size:var(--font-size-3xl);font-weight:800;margin:0 0 var(--space-sm);line-height:1.2}@media(max-width:767px){.main-layout-page-title{font-size:var(--font-size-2xl)}}.main-layout-breadcrumbs{margin-top:var(--space-md)}.main-layout-breadcrumbs-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.main-layout-breadcrumbs-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm)}.main-layout-breadcrumbs-link{color:#ffffffe6;text-decoration:none;transition:color var(--transition-speed);padding:var(--space-xs) 0}.main-layout-breadcrumbs-link:hover{color:#fff;text-decoration:underline}.main-layout-breadcrumbs-separator{color:#ffffff80}.main-layout-breadcrumbs-current{color:#fff;font-weight:600}.main-layout-footer{background-color:var(--color-surface);border-top:1px solid var(--color-border);transition:background-color var(--transition-speed)}.main-layout-debug-info{position:fixed;bottom:0;left:0;right:0;background-color:#000c;color:#fff;font-size:var(--font-size-xs);font-family:Courier New,monospace;padding:var(--space-xs) var(--space-md);z-index:var(--z-tooltip);display:none}@media(min-width:768px){.main-layout-debug-info{display:block}}.main-layout-debug-content{max-width:var(--container-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.main-layout-debug-text{opacity:.8}.main-layout-debug-path{color:var(--color-highlight);font-weight:600}@media(max-width:767px){.main-layout-page-header{padding:var(--space-lg) 0}}@media(max-width:480px){.main-layout-page-title{font-size:var(--font-size-xl)}.main-layout-breadcrumbs-item{font-size:var(--font-size-xs)}}.common-button{font-family:var(--font-primary);font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-normal);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);text-decoration:none}.common-button-small{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm);min-height:32px}.common-button-medium{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base);min-height:40px}.common-button-large{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg);min-height:48px}.common-button-primary{background-color:var(--color-accent);color:var(--color-white)}.common-button-primary:hover:not(.common-button-disabled){background-color:var(--color-highlight);transform:translateY(-2px);box-shadow:var(--shadow-md)}.common-button-secondary{background-color:transparent;color:var(--color-accent);border:2px solid var(--color-accent)}.common-button-secondary:hover:not(.common-button-disabled){background-color:var(--color-accent);color:var(--color-white)}.common-button-outline{background-color:transparent;color:var(--color-primary);border:1px solid var(--color-gray)}.common-button-outline:hover:not(.common-button-disabled){border-color:var(--color-accent);color:var(--color-accent)}.common-button-disabled{opacity:.6;cursor:not-allowed}.common-button-full-width{width:100%}.common-button-icon{display:inline-flex;align-items:center}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);padding:var(--space-md);position:relative;overflow:hidden}.auth-layout-background{position:absolute;inset:0;overflow:hidden;pointer-events:none}.auth-layout-background-shape{position:absolute;border-radius:50%;background:#ffffff1a;animation:auth-layout-float 20s infinite ease-in-out}.auth-layout-background-shape-1{width:300px;height:300px;top:-150px;right:-150px;animation-delay:0s}.auth-layout-background-shape-2{width:200px;height:200px;bottom:-100px;left:10%;animation-delay:5s}.auth-layout-background-shape-3{width:150px;height:150px;top:30%;left:-75px;animation-delay:10s}@keyframes auth-layout-float{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-20px) rotate(120deg)}66%{transform:translateY(20px) rotate(240deg)}}.auth-layout-container{display:flex;max-width:1200px;width:100%;min-height:700px;background-color:var(--color-surface);border-radius:var(--border-radius-base);overflow:hidden;box-shadow:var(--shadow-lg);position:relative;z-index:1}@media(max-width:1024px){.auth-layout-container{flex-direction:column;min-height:auto}}.auth-layout-left{flex:1;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;padding:var(--space-2xl);display:flex;align-items:center}.auth-layout-left-content{max-width:500px;width:100%}.auth-layout-logo{display:inline-flex;align-items:center;gap:var(--space-xs);text-decoration:none;margin-bottom:var(--space-2xl)}.auth-layout-logo-text{font-size:var(--font-size-2xl);font-weight:800;letter-spacing:-.5px}.auth-layout-logo-subtext{font-size:var(--font-size-sm);opacity:.9;font-weight:500}.auth-layout-illustration{margin:var(--space-2xl) 0;text-align:center}.auth-layout-illustration-icon{font-size:100px;animation:auth-layout-bounce 3s infinite ease-in-out}@keyframes auth-layout-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.auth-layout-info{margin-bottom:var(--space-2xl)}.auth-layout-title{font-size:var(--font-size-3xl);font-weight:800;margin:0 0 var(--space-md);line-height:1.2}.auth-layout-subtitle{font-size:var(--font-size-lg);opacity:.9;line-height:1.6;margin:0}.auth-layout-features{margin-bottom:var(--space-2xl)}.auth-layout-features-title{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--space-md)}.auth-layout-features-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-md)}.auth-layout-feature{display:flex;align-items:center;gap:var(--space-md)}.auth-layout-feature-icon{font-size:20px;width:40px;height:40px;background-color:#ffffff1a;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-layout-feature-text{font-size:var(--font-size-base);opacity:.9}.auth-layout-testimonial{background-color:#ffffff1a;border-radius:var(--border-radius-base);padding:var(--space-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-layout-testimonial-content{font-size:var(--font-size-lg);font-style:italic;line-height:1.6;margin-bottom:var(--space-lg);position:relative}.auth-layout-testimonial-content:before{content:'"';font-size:48px;position:absolute;top:-20px;left:-10px;opacity:.3;font-family:serif}.auth-layout-testimonial-author{display:flex;align-items:center;gap:var(--space-md)}.auth-layout-testimonial-avatar{width:50px;height:50px;background-color:#fff;color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-lg);flex-shrink:0}.auth-layout-testimonial-info{flex:1}.auth-layout-testimonial-name{font-weight:600;font-size:var(--font-size-base)}.auth-layout-testimonial-role{font-size:var(--font-size-sm);opacity:.8}.auth-layout-right{flex:1;padding:var(--space-2xl);display:flex;align-items:center;justify-content:center;background-color:var(--color-surface)}.auth-layout-right-content{max-width:400px;width:100%}.auth-layout-back{display:inline-block;color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);margin-bottom:var(--space-xl);transition:color var(--transition-speed)}.auth-layout-back:hover{color:var(--color-primary)}.auth-layout-form-container,.auth-layout-social{margin-bottom:var(--space-xl)}.auth-layout-social-divider{display:flex;align-items:center;text-align:center;margin:var(--space-lg) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.auth-layout-social-divider:before,.auth-layout-social-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.auth-layout-social-divider-text{padding:0 var(--space-md)}.auth-layout-social-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(max-width:480px){.auth-layout-social-buttons{grid-template-columns:1fr}}.auth-layout-social-button{display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.auth-layout-social-icon{font-weight:700;font-size:var(--font-size-lg)}.auth-layout-footer{text-align:center;padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.auth-layout-footer-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--space-md)}.auth-layout-footer-link{color:var(--color-accent);font-weight:600;text-decoration:none;transition:color var(--transition-speed)}.auth-layout-footer-link:hover{color:var(--color-primary);text-decoration:underline}.auth-layout-legal{display:flex;justify-content:center;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.auth-layout-legal-link{color:var(--color-text-secondary);font-size:var(--font-size-xs);text-decoration:none;transition:color var(--transition-speed)}.auth-layout-legal-link:hover{color:var(--color-primary)}.auth-layout-legal-separator{color:var(--color-text-secondary);font-size:var(--font-size-xs);opacity:.5}.auth-layout-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%)}.auth-layout-loading-content{text-align:center}.auth-layout-loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:auth-layout-spin 1s linear infinite;margin:0 auto var(--space-lg)}@keyframes auth-layout-spin{to{transform:rotate(360deg)}}.auth-layout-loading-text{color:#fff;font-size:var(--font-size-lg);margin:0}@media(max-width:1024px){.auth-layout-left,.auth-layout-right{padding:var(--space-xl)}.auth-layout-title{font-size:var(--font-size-2xl)}.auth-layout-illustration-icon{font-size:80px}}@media(max-width:767px){.auth-layout{padding:0}.auth-layout-container{min-height:100vh;border-radius:0}.auth-layout-left,.auth-layout-right{padding:var(--space-lg)}.auth-layout-left{padding-top:var(--space-2xl)}.auth-layout-title{font-size:var(--font-size-xl)}.auth-layout-illustration-icon{font-size:60px}.auth-layout-features-list{gap:var(--space-sm)}.auth-layout-feature-icon{width:32px;height:32px;font-size:16px}.auth-layout-feature-text{font-size:var(--font-size-sm)}}.features-hero-section{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);padding:var(--space-2xl) 0;position:relative;overflow:hidden}.features-hero-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md);display:grid;grid-template-columns:1fr;gap:var(--space-2xl);align-items:center}@media(min-width:1024px){.features-hero-container{grid-template-columns:1fr 1fr;gap:var(--space-3xl);padding:var(--space-xl) var(--space-md)}}.features-hero-content{display:flex;flex-direction:column;gap:var(--space-lg);z-index:2}.features-hero-badge{display:inline-flex;align-items:center;background-color:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:50px;padding:var(--space-xs) var(--space-lg);width:fit-content}.features-hero-badge-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-highlight);letter-spacing:1px}.features-hero-title{font-size:var(--font-size-3xl);font-weight:800;line-height:1.2;margin:0}@media(min-width:768px){.features-hero-title{font-size:var(--font-size-4xl)}}.features-hero-title-highlight{display:block;color:var(--color-highlight);margin-top:var(--space-xs)}.features-hero-description{font-size:var(--font-size-lg);line-height:1.6;opacity:.9;margin:0}@media(max-width:767px){.features-hero-description{font-size:var(--font-size-base)}}.features-hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-md)}.features-hero-button{min-width:160px}@media(max-width:767px){.features-hero-button{width:100%}}.features-hero-button-primary{background-color:var(--color-highlight);border-color:var(--color-highlight)}.features-hero-button-primary:hover{background-color:#00a0c4;border-color:#00a0c4}.features-hero-button-secondary{color:var(--color-white);border-color:#ffffff4d}.features-hero-button-secondary:hover{background-color:#ffffff1a;border-color:var(--color-white)}.features-hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid rgba(255,255,255,.1)}.features-hero-stat{display:flex;flex-direction:column;align-items:center;text-align:center}@media(min-width:768px){.features-hero-stat{align-items:flex-start;text-align:left}}.features-hero-stat-number{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-highlight);line-height:1}.features-hero-stat-label{font-size:var(--font-size-sm);opacity:.8;margin-top:var(--space-xs)}.features-hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:300px}@media(min-width:1024px){.features-hero-visual{min-height:400px}}.features-hero-visual-container{position:relative;width:100%;max-width:400px;aspect-ratio:1}.features-hero-visual-animation{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;height:80%}.features-hero-visual-circle{position:absolute;border-radius:50%;border:2px solid rgba(0,180,216,.3);animation:features-hero-pulse 3s infinite ease-in-out}.features-hero-visual-circle-1{inset:0;animation-delay:0s}.features-hero-visual-circle-2{inset:15%;border-color:#00b4d880;animation-delay:.5s}.features-hero-visual-circle-3{inset:30%;border-color:#00b4d8b3;animation-delay:1s}.features-hero-visual-cube{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);width:60px;height:60px;background:linear-gradient(45deg,var(--color-highlight),#00a0c4);animation:features-hero-rotate 10s infinite linear}@keyframes features-hero-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes features-hero-rotate{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.features-hero-visual-text{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:var(--font-size-lg);font-weight:600;color:var(--color-highlight);padding:var(--space-md);background:#0000004d;border-radius:var(--border-radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.features-hero-scroll-indicator{position:absolute;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);opacity:.7;transition:opacity var(--transition-normal);cursor:pointer;z-index:2}.features-hero-scroll-indicator:hover{opacity:1}.features-hero-scroll-text{font-size:var(--font-size-sm);letter-spacing:2px;text-transform:uppercase}.features-hero-scroll-arrow{width:20px;height:20px;border-bottom:2px solid var(--color-white);border-right:2px solid var(--color-white);transform:rotate(45deg);animation:features-hero-scroll 2s infinite}@keyframes features-hero-scroll{0%,20%,50%,80%,to{transform:rotate(45deg) translateY(0)}40%{transform:rotate(45deg) translateY(-10px)}60%{transform:rotate(45deg) translateY(-5px)}}@media(max-width:767px){.features-hero-section{padding:var(--space-xl) 0}.features-hero-stats{grid-template-columns:1fr;gap:var(--space-md);text-align:center}.features-hero-stat{align-items:center}.features-hero-visual{min-height:250px;order:-1}.features-hero-visual-text{font-size:var(--font-size-base);padding:var(--space-sm)}}.features-service-card{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-xl);display:flex;flex-direction:column;height:100%;transition:all var(--transition-normal);position:relative;overflow:hidden}.features-service-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background-color:var(--service-color-primary, var(--color-accent));transform:scaleX(0);transition:transform var(--transition-normal)}.features-service-card:hover:before{transform:scaleX(1)}.features-service-card-clickable{cursor:pointer}.features-service-card-clickable:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.features-service-card-header{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg)}.features-service-card-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background-color:var(--service-color-light, rgba(15, 76, 117, .1));border-radius:12px;color:var(--service-color-primary, var(--color-accent))}.features-service-card-icon svg{width:32px;height:32px}.features-service-card-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0;line-height:1.3}.features-service-card-body{flex:1;display:flex;flex-direction:column;gap:var(--space-lg)}.features-service-card-description{color:var(--color-gray);line-height:1.6;margin:0;font-size:var(--font-size-base)}.features-service-card-features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.features-service-card-feature{display:flex;align-items:flex-start;gap:var(--space-sm)}.features-service-card-feature-icon{color:var(--service-color-primary, var(--color-accent));font-weight:700;font-size:var(--font-size-sm);flex-shrink:0;margin-top:2px}.features-service-card-feature-text{font-size:var(--font-size-sm);color:var(--color-primary);line-height:1.5}.features-service-card-footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-light)}.features-service-card-button{color:var(--service-color-primary, var(--color-accent));border-color:var(--service-color-primary, var(--color-accent))}.features-service-card-button:hover{background-color:var(--service-color-primary, var(--color-accent));color:var(--color-white)}.features-service-card-featured{background:linear-gradient(135deg,var(--service-color-primary, var(--color-accent)) 0%,color-mix(in srgb,var(--service-color-primary, var(--color-accent)) 70%,black) 100%);color:var(--color-white)}.features-service-card-featured .features-service-card-title,.features-service-card-featured .features-service-card-description,.features-service-card-featured .features-service-card-feature-text{color:var(--color-white)}.features-service-card-featured .features-service-card-icon{background-color:#fff3;color:var(--color-white)}.features-service-card-featured .features-service-card-feature-icon{color:var(--color-white)}.features-service-card-featured .features-service-card-footer{border-top-color:#fff3}.features-service-card-featured .features-service-card-button{color:var(--color-white);border-color:var(--color-white);background-color:transparent}.features-service-card-featured .features-service-card-button:hover{background-color:var(--color-white);color:var(--service-color-primary, var(--color-accent))}.features-service-card-compact{padding:var(--space-lg)}.features-service-card-compact .features-service-card-header{flex-direction:row;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.features-service-card-compact .features-service-card-icon{width:48px;height:48px}.features-service-card-compact .features-service-card-icon svg{width:24px;height:24px}.features-service-card-compact .features-service-card-title{font-size:var(--font-size-lg)}.features-service-card-compact .features-service-card-footer{margin-top:var(--space-lg);padding-top:var(--space-md)}@media(max-width:767px){.features-service-card{padding:var(--space-lg)}.features-service-card-header{gap:var(--space-sm);margin-bottom:var(--space-md)}.features-service-card-icon{width:48px;height:48px}.features-service-card-icon svg{width:24px;height:24px}.features-service-card-title{font-size:var(--font-size-lg)}.features-service-card-featured{padding:var(--space-lg)}}@media(max-width:480px){.features-service-card{padding:var(--space-md)}.features-service-card-compact .features-service-card-header{flex-direction:column;align-items:flex-start}}.features-services-grid{padding:var(--space-2xl) 0;background-color:var(--color-light)}.features-services-grid-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.features-services-grid-header{text-align:center;max-width:800px;margin:0 auto var(--space-2xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.features-services-grid-badge{display:inline-flex;align-items:center;background-color:#0f4c751a;border-radius:50px;padding:var(--space-xs) var(--space-lg)}.features-services-grid-badge-text{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent);letter-spacing:1px}.features-services-grid-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);margin:0;line-height:1.2}@media(max-width:767px){.features-services-grid-title{font-size:var(--font-size-2xl)}}.features-services-grid-subtitle{font-size:var(--font-size-lg);color:var(--color-gray);line-height:1.6;margin:0;max-width:600px}@media(max-width:767px){.features-services-grid-subtitle{font-size:var(--font-size-base)}}.features-services-grid-content{display:grid;grid-template-columns:1fr;gap:var(--space-xl);margin-bottom:var(--space-2xl)}@media(min-width:768px){.features-services-grid-content{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.features-services-grid-content{grid-template-columns:repeat(2,1fr)}.features-services-grid-content .features-service-card-featured{grid-column:span 2}}.features-services-grid-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl);padding:var(--space-xl);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md)}@media(min-width:768px){.features-services-grid-stats{grid-template-columns:repeat(4,1fr);gap:var(--space-2xl);padding:var(--space-2xl)}}.features-services-grid-stat{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.features-services-grid-stat-number{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-accent);line-height:1}@media(max-width:767px){.features-services-grid-stat-number{font-size:var(--font-size-2xl)}}.features-services-grid-stat-label{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500}@media(max-width:767px){.features-services-grid{padding:var(--space-xl) 0}.features-services-grid-header{margin-bottom:var(--space-xl);gap:var(--space-md)}.features-services-grid-content{gap:var(--space-lg);margin-bottom:var(--space-xl)}.features-services-grid-stats{padding:var(--space-lg);gap:var(--space-lg)}}@media(max-width:480px){.features-services-grid-stats{grid-template-columns:1fr;gap:var(--space-md)}.features-services-grid-stat{padding:var(--space-md) 0;border-bottom:1px solid var(--color-light)}.features-services-grid-stat:last-child{border-bottom:none}}.features-viewer-preview{padding:var(--space-2xl) 0;background:linear-gradient(180deg,var(--color-white) 0%,var(--color-light) 100%)}.features-viewer-preview-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.features-viewer-preview-header{text-align:center;max-width:800px;margin:0 auto var(--space-2xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.features-viewer-preview-badge{display:inline-flex;align-items:center;background-color:#00b4d81a;border-radius:50px;padding:var(--space-xs) var(--space-lg)}.features-viewer-preview-badge-text{font-size:var(--font-size-sm);font-weight:600;color:var(--color-highlight);letter-spacing:1px}.features-viewer-preview-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);margin:0;line-height:1.2}@media(max-width:767px){.features-viewer-preview-title{font-size:var(--font-size-2xl)}}.features-viewer-preview-subtitle{font-size:var(--font-size-lg);color:var(--color-gray);line-height:1.6;margin:0;max-width:600px}.features-viewer-preview-content{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);margin-bottom:var(--space-2xl)}@media(min-width:1024px){.features-viewer-preview-content{grid-template-columns:1fr 1fr;gap:var(--space-3xl)}}.features-viewer-preview-demo{display:flex;flex-direction:column;gap:var(--space-xl)}.features-viewer-preview-canvas{position:relative;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--border-radius);overflow:hidden;min-height:400px;display:flex;align-items:center;justify-content:center}@media(min-width:768px){.features-viewer-preview-canvas{min-height:500px}}.features-viewer-preview-scene{position:relative;width:300px;height:300px;perspective:1200px}@media(min-width:768px){.features-viewer-preview-scene{width:400px;height:400px}}.features-viewer-preview-cube{position:absolute;width:200px;height:200px;transform-style:preserve-3d;animation:features-viewer-preview-rotate 20s infinite linear;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes features-viewer-preview-rotate{0%{transform:translate(-50%,-50%) rotateX(0) rotateY(0) rotate(0)}to{transform:translate(-50%,-50%) rotateX(360deg) rotateY(360deg) rotate(360deg)}}.features-viewer-preview-face{position:absolute;width:200px;height:200px;background:linear-gradient(45deg,var(--color-highlight),rgba(0,180,216,.7));border:2px solid rgba(255,255,255,.3);opacity:.8}.features-viewer-preview-face-front{transform:translateZ(100px)}.features-viewer-preview-face-back{transform:rotateY(180deg) translateZ(100px)}.features-viewer-preview-face-right{transform:rotateY(90deg) translateZ(100px)}.features-viewer-preview-face-left{transform:rotateY(-90deg) translateZ(100px)}.features-viewer-preview-face-top{transform:rotateX(90deg) translateZ(100px)}.features-viewer-preview-face-bottom{transform:rotateX(-90deg) translateZ(100px)}.features-viewer-preview-grid{position:absolute;bottom:0;left:0;right:0;height:100px;background-image:linear-gradient(rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;transform:perspective(500px) rotateX(60deg);transform-origin:bottom}.features-viewer-preview-light{position:absolute;width:20px;height:20px;border-radius:50%;background-color:#ffffff80;filter:blur(10px)}.features-viewer-preview-light-1{top:20%;left:20%}.features-viewer-preview-light-2{bottom:20%;right:20%}.features-viewer-preview-controls{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);display:flex;gap:var(--space-sm);opacity:0;transition:opacity var(--transition-normal)}.features-viewer-preview-controls-visible{opacity:1}.features-viewer-preview-control{background-color:#00000080;border:1px solid rgba(255,255,255,.3);color:var(--color-white);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.features-viewer-preview-control:hover{background-color:#00b4d8b3;transform:scale(1.1)}.features-viewer-preview-upload{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#ffffffe6;border-radius:var(--border-radius);padding:var(--space-xl);text-align:center;width:80%;max-width:300px;box-shadow:var(--shadow-lg);border:2px dashed var(--color-accent);cursor:pointer;transition:all var(--transition-normal)}.features-viewer-preview-upload:hover{background-color:var(--color-white);transform:translate(-50%,-50%) scale(1.05)}.features-viewer-preview-upload-icon{font-size:48px;margin-bottom:var(--space-md)}.features-viewer-preview-upload-text{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin-bottom:var(--space-xs)}.features-viewer-preview-upload-formats{font-size:var(--font-size-sm);color:var(--color-gray)}.features-viewer-preview-stats{display:grid;align-self:center;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);background-color:var(--color-white);padding:var(--space-lg);border-radius:var(--border-radius);box-shadow:var(--shadow-md)}.features-viewer-preview-stat{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.features-viewer-preview-stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-accent)}.features-viewer-preview-stat-label{font-size:var(--font-size-sm);color:var(--color-gray);text-transform:uppercase;letter-spacing:1px}.features-viewer-preview-features{display:flex;flex-direction:column;gap:var(--space-xl);padding:20px}.features-viewer-preview-features-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);margin:0}.features-viewer-preview-features-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-lg)}.features-viewer-preview-feature{display:flex;gap:var(--space-md);align-items:flex-start}.features-viewer-preview-feature-icon{font-size:24px;flex-shrink:0;width:48px;height:48px;background-color:#0f4c751a;border-radius:12px;display:flex;align-items:center;justify-content:center}.features-viewer-preview-feature-content{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.features-viewer-preview-feature-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.features-viewer-preview-feature-description{font-size:var(--font-size-sm);color:var(--color-gray);line-height:1.5}.features-viewer-preview-actions{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-lg)}.features-viewer-preview-button{min-width:160px}.features-viewer-preview-recent{margin-top:var(--space-2xl);padding-top:var(--space-2xl);border-top:1px solid var(--color-light)}.features-viewer-preview-recent-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-lg)}.features-viewer-preview-recent-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-md)}@media(min-width:640px){.features-viewer-preview-recent-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.features-viewer-preview-recent-grid{grid-template-columns:repeat(4,1fr)}}.features-viewer-preview-recent-item{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-md);display:flex;align-items:center;gap:var(--space-md);border:1px solid var(--color-light);transition:all var(--transition-fast)}.features-viewer-preview-recent-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.features-viewer-preview-recent-icon{font-size:24px;width:48px;height:48px;background-color:#0f4c751a;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.features-viewer-preview-recent-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.features-viewer-preview-recent-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.features-viewer-preview-recent-details{font-size:var(--font-size-xs);color:var(--color-gray)}.features-viewer-preview-recent-view{background:none;border:none;color:var(--color-accent);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius);transition:all var(--transition-fast);white-space:nowrap}.features-viewer-preview-recent-view:hover{background-color:#0f4c751a}@media(max-width:767px){.features-viewer-preview{padding:var(--space-xl) 0}.features-viewer-preview-header{margin-bottom:var(--space-xl);gap:var(--space-md)}.features-viewer-preview-content{gap:var(--space-xl);margin-bottom:var(--space-xl)}.features-viewer-preview-canvas{min-height:350px}.features-viewer-preview-scene{width:250px;height:250px}.features-viewer-preview-cube,.features-viewer-preview-face{width:150px;height:150px}.features-viewer-preview-face-front{transform:translateZ(75px)}.features-viewer-preview-face-back{transform:rotateY(180deg) translateZ(75px)}.features-viewer-preview-face-right{transform:rotateY(90deg) translateZ(75px)}.features-viewer-preview-face-left{transform:rotateY(-90deg) translateZ(75px)}.features-viewer-preview-face-top{transform:rotateX(90deg) translateZ(75px)}.features-viewer-preview-face-bottom{transform:rotateX(-90deg) translateZ(75px)}.features-viewer-preview-upload{padding:var(--space-lg);width:90%}.features-viewer-preview-actions{flex-direction:column}.features-viewer-preview-button{width:100%}}.features-testimonials{padding:var(--space-2xl) 0;background:linear-gradient(180deg,var(--color-light) 0%,var(--color-white) 100%);position:relative;overflow:hidden}.features-testimonials:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-highlight),transparent)}.features-testimonials-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md);gap:10px}.features-testimonials-header{text-align:center;max-width:800px;margin:0 auto var(--space-2xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.features-testimonials-badge{display:inline-flex;align-items:center;background-color:#0f4c751a;border-radius:50px;padding:var(--space-xs) var(--space-lg)}.features-testimonials-badge-text{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent);letter-spacing:1px}.features-testimonials-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);margin:0;line-height:1.2}@media(max-width:767px){.features-testimonials-title{font-size:var(--font-size-2xl)}}.features-testimonials-subtitle{font-size:var(--font-size-lg);color:var(--color-gray);line-height:1.6;margin:0;max-width:600px}.features-testimonials-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg);margin-bottom:var(--space-2xl);padding:var(--space-lg);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}@media(min-width:768px){.features-testimonials-stats{grid-template-columns:repeat(4,1fr);gap:var(--space-xl);padding:var(--space-xl)}}.features-testimonials-stat{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md)}.features-testimonials-stat-value{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-accent);line-height:1;font-family:var(--font-secondary)}.features-testimonials-stat-label{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500}.features-testimonials-content{display:grid;grid-template-columns:1fr;gap:var(--space-2xl)}@media(min-width:1024px){.features-testimonials-content{grid-template-columns:1fr 1fr;gap:var(--space-3xl)}}.features-testimonials-active{display:flex;flex-direction:column;gap:var(--space-xl)}.features-testimonials-card{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-2xl);box-shadow:var(--shadow-lg);position:relative;border-top:4px solid var(--testimonial-color, var(--color-accent));transition:transform var(--transition-normal)}.features-testimonials-card:hover{transform:translateY(-4px)}.features-testimonials-card-quote{position:absolute;top:var(--space-lg);right:var(--space-lg);font-size:80px;color:var(--testimonial-color, var(--color-accent));opacity:.1;font-family:serif;line-height:1}.features-testimonials-card-content{margin-bottom:var(--space-xl);position:relative;z-index:1}.features-testimonials-card-text{font-size:var(--font-size-lg);line-height:1.6;color:var(--color-primary);margin:0 0 var(--space-lg);font-style:italic}.features-testimonials-card-rating{display:flex;gap:var(--space-xs)}.features-testimonials-card-star{font-size:20px;color:#e5e7eb}.features-testimonials-card-star-filled{color:#fbbf24}.features-testimonials-card-author{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background-color:#0f4c750d;border-radius:var(--border-radius);margin-bottom:var(--space-lg)}.features-testimonials-card-avatar{width:60px;height:60px;border-radius:50%;background-color:var(--testimonial-color, var(--color-accent));color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:700;flex-shrink:0}.features-testimonials-card-author-info{flex:1}.features-testimonials-card-name{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin-bottom:2px}.features-testimonials-card-role{font-size:var(--font-size-sm);color:var(--color-gray);margin-bottom:2px}.features-testimonials-card-company{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:600}.features-testimonials-card-project{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background-color:var(--color-light);border-radius:var(--border-radius);font-size:var(--font-size-sm)}.features-testimonials-card-project-label{color:var(--color-gray);font-weight:500}.features-testimonials-card-project-name{color:var(--color-primary);font-weight:600}.features-testimonials-controls{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.features-testimonials-control{width:48px;height:48px;border-radius:50%;background-color:var(--color-light);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-size-lg);color:var(--color-primary);transition:all var(--transition-fast);flex-shrink:0}.features-testimonials-control:hover{background-color:var(--color-accent);color:var(--color-white);transform:scale(1.1)}.features-testimonials-dots{display:flex;gap:var(--space-sm);flex:1;justify-content:center}.features-testimonials-dot{width:10px;height:10px;border-radius:50%;background-color:var(--color-light);border:none;cursor:pointer;padding:0;transition:all var(--transition-fast)}.features-testimonials-dot:hover{background-color:var(--color-gray)}.features-testimonials-dot-active{background-color:var(--color-accent);transform:scale(1.2)}.features-testimonials-list{display:flex;flex-direction:column;gap:var(--space-xl)}.features-testimonials-filters{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding:var(--space-md);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.features-testimonials-filter{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background-color:var(--color-light);border:none;border-radius:50px;font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray);cursor:pointer;transition:all var(--transition-fast)}.features-testimonials-filter:hover,.features-testimonials-filter-active{background-color:var(--color-accent);color:var(--color-white)}.features-testimonials-filter-count{font-size:var(--font-size-xs);background-color:#fff3;border-radius:50px;padding:2px 6px;min-width:20px;text-align:center}.features-testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md);max-height:400px;overflow-y:auto;padding-right:var(--space-sm)}.features-testimonials-grid::-webkit-scrollbar{width:6px}.features-testimonials-grid::-webkit-scrollbar-track{background:var(--color-light);border-radius:3px}.features-testimonials-grid::-webkit-scrollbar-thumb{background:var(--color-gray);border-radius:3px}.features-testimonials-item{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-normal);border-left:3px solid var(--testimonial-color, var(--color-accent));position:relative}.features-testimonials-item:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.features-testimonials-item-active{background-color:#0f4c750d;box-shadow:var(--shadow-sm)}.features-testimonials-item-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.features-testimonials-item-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--testimonial-color, var(--color-accent));color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:700;flex-shrink:0}.features-testimonials-item-info{flex:1;min-width:0}.features-testimonials-item-name{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.features-testimonials-item-company{font-size:var(--font-size-xs);color:var(--color-gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.features-testimonials-item-content{margin-bottom:var(--space-md)}.features-testimonials-item-text{font-size:var(--font-size-sm);line-height:1.5;color:var(--color-gray);margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.features-testimonials-item-footer{display:flex;align-items:center;justify-content:space-between}.features-testimonials-item-category{font-size:var(--font-size-xs);font-weight:600;color:var(--color-white);background-color:var(--testimonial-color, var(--color-accent));padding:2px 8px;border-radius:50px}.features-testimonials-item-rating{display:flex;gap:2px}.features-testimonials-item-star{font-size:12px;color:#e5e7eb}.features-testimonials-item-star-filled{color:#fbbf24}.features-testimonials-cta{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-secondary) 100%);border-radius:var(--border-radius);padding:var(--space-xl);color:var(--color-white);display:flex;flex-direction:column;gap:var(--space-lg)}@media(min-width:768px){.features-testimonials-cta{flex-direction:row;align-items:center;justify-content:space-between}}.features-testimonials-cta-content{flex:1}.features-testimonials-cta-title{font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--space-sm)}.features-testimonials-cta-text{font-size:var(--font-size-sm);opacity:.9;margin:0;line-height:1.5}.features-testimonials-cta-actions{display:flex;flex-wrap:wrap;gap:var(--space-md)}.features-testimonials-cta-button{white-space:nowrap}.features-testimonials-cta-button:first-child{background-color:var(--color-white);color:var(--color-accent);border-color:var(--color-white)}.features-testimonials-cta-button:first-child:hover{background-color:transparent;color:var(--color-white)}.features-testimonials-cta-button:last-child{color:var(--color-white);border-color:var(--color-white);background-color:transparent}.features-testimonials-cta-button:last-child:hover{background-color:var(--color-white);color:var(--color-accent)}@media(max-width:767px){.features-testimonials{padding:var(--space-xl) 0}.features-testimonials-header{margin-bottom:var(--space-xl);gap:var(--space-md)}.features-testimonials-stats{grid-template-columns:1fr;gap:var(--space-md);padding:var(--space-md);margin-bottom:var(--space-xl)}.features-testimonials-stat{padding:var(--space-sm);flex-direction:row;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-light)}.features-testimonials-stat:last-child{border-bottom:none}.features-testimonials-stat-value{font-size:var(--font-size-xl)}.features-testimonials-content{gap:var(--space-xl)}.features-testimonials-card{padding:var(--space-xl)}.features-testimonials-card-quote{font-size:60px;top:var(--space-md);right:var(--space-md)}.features-testimonials-card-text{font-size:var(--font-size-base)}.features-testimonials-grid{max-height:none}.features-testimonials-cta{padding:var(--space-lg)}.features-testimonials-cta-actions{flex-direction:column}.features-testimonials-cta-button{width:100%}}@media(max-width:480px){.features-testimonials-card{padding:var(--space-lg)}.features-testimonials-card-author{flex-direction:column;text-align:center;padding:var(--space-md)}.features-testimonials-card-avatar{width:50px;height:50px;font-size:var(--font-size-base)}.features-testimonials-controls{flex-direction:column;gap:var(--space-md)}.features-testimonials-dots{order:-1}.features-testimonials-filters{justify-content:center}.features-testimonials-filter{flex:1;justify-content:center;min-width:70px}}@keyframes testimonial-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.features-testimonials-card-active{animation:testimonial-fade-in .5s ease-out}.features-stats-counter{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg);text-align:center;position:relative}.features-stats-counter:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-accent),var(--color-highlight));border-radius:var(--border-radius);opacity:0;transform:scaleX(0);transition:all var(--transition-normal)}.features-stats-counter:hover:before{opacity:1;transform:scaleX(1)}.features-stats-counter-number{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-accent);line-height:1;margin-bottom:var(--space-sm);font-family:var(--font-secondary)}.features-stats-counter-suffix{font-size:var(--font-size-xl);font-weight:600;margin-left:2px;color:var(--color-highlight)}.features-stats-counter-label{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500;text-transform:uppercase;letter-spacing:1px}@media(max-width:767px){.features-stats-counter{padding:var(--space-md)}.features-stats-counter-number{font-size:var(--font-size-2xl)}.features-stats-counter-label{font-size:var(--font-size-xs)}}@media(max-width:480px){.features-stats-counter{padding:var(--space-sm)}.features-stats-counter-number{font-size:var(--font-size-xl)}}.page-home{display:flex;flex-direction:column;gap:var(--space-2xl)}.page-home-section{padding:var(--space-2xl) 0}@media(max-width:767px){.page-home-section{padding:var(--space-xl) 0}}.page-home-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.page-home-section-header{text-align:center;max-width:800px;margin:0 auto var(--space-2xl)}.page-home-section-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);margin:0 0 var(--space-md);line-height:1.2}@media(max-width:767px){.page-home-section-title{font-size:var(--font-size-2xl)}}.page-home-section-subtitle{font-size:var(--font-size-lg);color:var(--color-gray);line-height:1.6;max-width:600px;margin:0 auto}@media(max-width:767px){.page-home-section-subtitle{font-size:var(--font-size-base)}}.page-home-section-stats{background-color:var(--color-light)}.page-home-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl)}@media(min-width:768px){.page-home-stats-grid{grid-template-columns:repeat(4,1fr)}}.page-home-projects-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl);margin-bottom:var(--space-2xl)}@media(min-width:768px){.page-home-projects-grid{grid-template-columns:repeat(3,1fr)}}.page-home-project-card{background-color:var(--color-white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.page-home-project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.page-home-project-image{height:200px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:80px;padding:var(--space-xl)}.page-home-project-content{padding:var(--space-xl)}.page-home-project-category{display:inline-block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent);background-color:#00b4d81a;padding:var(--space-xs) var(--space-md);border-radius:50px;margin-bottom:var(--space-md)}.page-home-project-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-sm);line-height:1.3}.page-home-project-description{color:var(--color-gray);line-height:1.6;margin:0 0 var(--space-md)}.page-home-project-client{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm)}.page-home-project-client-label{color:var(--color-gray);font-weight:500}.page-home-project-client-name{color:var(--color-primary);font-weight:600}.page-home-section-actions{text-align:center}.page-home-section-cta{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);text-align:center}.page-home-cta-content{max-width:800px;margin:0 auto}.page-home-cta-title{font-size:var(--font-size-3xl);font-weight:800;margin:0 0 var(--space-lg);line-height:1.2}@media(max-width:767px){.page-home-cta-title{font-size:var(--font-size-2xl)}}.page-home-cta-text{font-size:var(--font-size-lg);opacity:.9;line-height:1.6;margin:0 auto var(--space-xl);max-width:600px}.page-home-cta-actions{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}@media(max-width:767px){.page-home-cta-actions{flex-direction:column;align-items:center}.page-home-cta-actions .common-button{min-width:250px}}.page-home-section-services{background-color:var(--color-white)}.page-home-section-viewer{background-color:var(--color-light)}.page-home-section-testimonials{background-color:var(--color-white)}.page-home-section-projects{background-color:var(--color-light)}.page-services{display:flex;flex-direction:column;gap:var(--space-2xl)}.page-services-section{padding:var(--space-2xl) 0}@media(max-width:767px){.page-services-section{padding:var(--space-xl) 0}}.page-services-container{max-width:var(--container-width, 1200px);margin:0 auto;padding:0 var(--space-md)}.page-services-section-header{text-align:center;max-width:800px;margin:0 auto var(--space-2xl)}.page-services-section-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);margin:0 0 var(--space-md);line-height:1.2}@media(max-width:767px){.page-services-section-title{font-size:var(--font-size-2xl)}}.page-services-section-subtitle{font-size:var(--font-size-lg);color:var(--color-gray, #6b7280);line-height:1.6;max-width:600px;margin:0 auto}@media(max-width:767px){.page-services-section-subtitle{font-size:var(--font-size-base)}}.page-services-hero{background:linear-gradient(135deg,var(--color-primary, #2563eb) 0%,var(--color-secondary, #7c3aed) 100%);color:var(--color-white, #ffffff);padding:var(--space-2xl) 0;position:relative;overflow:hidden}.page-services-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.page-services-hero-content{max-width:800px;position:relative;z-index:1}.page-services-hero-title{font-size:var(--font-size-4xl);font-weight:800;margin:0 0 var(--space-md);line-height:1.2;color:var(--color-white, #ffffff)}@media(max-width:767px){.page-services-hero-title{font-size:var(--font-size-3xl)}}.page-services-hero-subtitle{font-size:var(--font-size-xl);opacity:.9;margin:0 0 var(--space-lg);line-height:1.4;color:var(--color-white, #ffffff)}.page-services-hero-description{font-size:var(--font-size-lg);opacity:.8;line-height:1.6;margin:0;color:var(--color-white, #ffffff)}.page-services-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl);margin-bottom:var(--space-2xl)}@media(min-width:768px){.page-services-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.page-services-grid{grid-template-columns:repeat(3,1fr)}}.page-services-section-process{background-color:var(--color-light, #f8fafc)}.page-services-process-flow{display:flex;flex-direction:column;gap:var(--space-xl);position:relative}@media(min-width:768px){.page-services-process-flow{flex-direction:row;flex-wrap:wrap;justify-content:space-between}}.page-services-process-step{display:flex;align-items:flex-start;gap:var(--space-lg);position:relative;z-index:1;flex:1;min-width:250px}@media(min-width:768px){.page-services-process-step{flex-direction:column;text-align:center;gap:var(--space-md);min-height:200px}}.page-services-process-step-number{width:60px;height:60px;background-color:var(--color-accent, #3b82f6);color:var(--color-white, #ffffff);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;flex-shrink:0;align-self:center;z-index:2}@media(min-width:768px){.page-services-process-step-number{width:80px;height:80px;font-size:var(--font-size-2xl)}}.page-services-process-step-content{flex:1;align-self:center}.page-services-process-step-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary, #2563eb);margin:0 0 var(--space-sm)}.page-services-process-step-description{color:var(--color-gray, #6b7280);line-height:1.6;margin:0;font-size:var(--font-size-base)}.page-services-process-step-connector{display:none}@media(min-width:768px){.page-services-process-step-connector{display:block;position:absolute;top:40px;left:50%;width:100%;height:2px;background-color:var(--color-border, #e5e7eb);z-index:0}.page-services-process-step:last-child .page-services-process-step-connector{display:none}}.page-services-pricing-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl);max-width:1200px;margin:0 auto}@media(min-width:768px){.page-services-pricing-grid{grid-template-columns:repeat(3,1fr);align-items:flex-start}}.page-services-pricing-card{background-color:var(--color-white, #ffffff);border-radius:var(--border-radius, 12px);padding:var(--space-xl);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));display:flex;flex-direction:column;transition:transform var(--transition-normal, .3s ease),box-shadow var(--transition-normal, .3s ease);position:relative;border:1px solid var(--color-border, #e5e7eb)}.page-services-pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1))}.page-services-pricing-card-featured{border:2px solid var(--color-accent, #3b82f6);transform:scale(1.05);z-index:2}@media(max-width:767px){.page-services-pricing-card-featured{transform:none;margin-top:var(--space-xl);margin-bottom:var(--space-xl)}}.page-services-pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background-color:var(--color-accent, #3b82f6);color:var(--color-white, #ffffff);padding:var(--space-xs) var(--space-lg);border-radius:50px;font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:1px;white-space:nowrap}.page-services-pricing-header{text-align:center;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border, #e5e7eb)}.page-services-pricing-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary, #2563eb);margin:0 0 var(--space-sm)}.page-services-pricing-price{display:flex;align-items:baseline;justify-content:center;gap:var(--space-xs)}.page-services-pricing-amount{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary, #2563eb)}.page-services-pricing-period{font-size:var(--font-size-lg);color:var(--color-gray, #6b7280)}.page-services-pricing-features{list-style:none;margin:0 0 var(--space-xl);padding:0;flex:1}.page-services-pricing-features li{padding:var(--space-sm) 0;color:var(--color-text, #1f2937);border-bottom:1px solid var(--color-light, #f8fafc);position:relative;padding-left:var(--space-lg);font-size:var(--font-size-base)}.page-services-pricing-features li:before{content:"✓";position:absolute;left:0;color:var(--color-success, #10b981);font-weight:700}.page-services-pricing-features li:last-child{border-bottom:none}.page-services-section-cta{background:linear-gradient(135deg,var(--color-primary, #2563eb) 0%,var(--color-secondary, #7c3aed) 100%);color:var(--color-white, #ffffff);text-align:center}.page-services-cta-content{max-width:800px;margin:0 auto}.page-services-cta-title{font-size:var(--font-size-3xl);font-weight:800;margin:0 0 var(--space-lg);line-height:1.2;color:var(--color-white, #ffffff)}@media(max-width:767px){.page-services-cta-title{font-size:var(--font-size-2xl)}}.page-services-cta-text{font-size:var(--font-size-lg);opacity:.9;line-height:1.6;margin:0 auto var(--space-xl);max-width:600px;color:var(--color-white, #ffffff)}.page-services-cta-actions{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}@media(max-width:767px){.page-services-cta-actions{flex-direction:column;align-items:center}.page-services-cta-actions .common-button{min-width:250px}}.page-services-section-stats{background-color:var(--color-light, #f8fafc)}.page-services-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl)}@media(min-width:768px){.page-services-stats-grid{grid-template-columns:repeat(4,1fr)}}.page-services-process-step-container{position:relative;width:100%}.page-services-process-step-arrow{display:none}@media(min-width:768px){.page-services-process-step-arrow{display:block;position:absolute;top:40px;left:calc(100% - 30px);width:60px;height:2px;background-color:var(--color-border, #e5e7eb)}.page-services-process-step-arrow:after{content:"";position:absolute;right:-6px;top:-5px;width:12px;height:12px;border-top:2px solid var(--color-border, #e5e7eb);border-right:2px solid var(--color-border, #e5e7eb);transform:rotate(45deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page-services-process-step{animation:fadeInUp .6s ease forwards}.page-services-process-step:nth-child(1){animation-delay:.1s}.page-services-process-step:nth-child(2){animation-delay:.2s}.page-services-process-step:nth-child(3){animation-delay:.3s}.page-services-process-step:nth-child(4){animation-delay:.4s}.page-services-process-step:nth-child(5){animation-delay:.5s}.page-services-process-step:nth-child(6){animation-delay:.6s}.page-services-pricing-card{position:relative;overflow:hidden}.page-services-pricing-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(59,130,246,.1),transparent);transition:left .6s ease}.page-services-pricing-card:hover:before{left:100%}.page-services-grid+.page-services-section{margin-top:var(--space-2xl)}@media(max-width:767px){.page-services{gap:var(--space-xl)}.page-services-stats-grid{grid-template-columns:1fr}.page-services-process-step{min-width:100%}.page-services-pricing-grid{gap:var(--space-lg)}}@media print{.page-services-hero,.page-services-section-cta{background:#fff!important;color:#000!important}.page-services-pricing-card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}}.common-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;padding:var(--space-md);animation:common-modal-fade-in .2s ease-out}.modal-center{margin-top:50px;background-color:var(--color-white);border-radius:2%}@keyframes common-modal-fade-in{0%{opacity:0}to{opacity:1}}.common-modal{border-radius:var(--border-radius);max-width:100%;max-height:90vh;display:flex;flex-direction:column;animation:common-modal-slide-up .3s ease-out}@keyframes common-modal-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.common-modal-small{width:400px}.common-modal-medium{width:600px}.common-modal-large{width:800px}.common-modal-full{width:95vw;height:95vh}.common-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-light);flex-shrink:0}.common-modal-title{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--color-primary)}.common-modal-close-button{background:none;border:none;font-size:var(--font-size-2xl);line-height:1;cursor:pointer;color:var(--color-gray);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color var(--transition-fast)}.common-modal-close-button:hover{background-color:var(--color-light);color:var(--color-primary)}.common-modal-body{padding:var(--space-lg);overflow-y:auto;flex:1;max-height:70vh}.common-modal-footer{padding:var(--space-lg);border-top:1px solid var(--color-light);display:flex;gap:var(--space-md);justify-content:flex-end;flex-shrink:0}.page-portfolio{display:flex;flex-direction:column;gap:var(--space-2xl)}.page-portfolio-section{padding:var(--space-2xl) 0}@media(max-width:767px){.page-portfolio-section{padding:var(--space-xl) 0}}.page-portfolio-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.page-portfolio-hero{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);padding:var(--space-2xl) 0;position:relative;overflow:hidden}.page-portfolio-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.page-portfolio-hero-content{max-width:800px;position:relative;z-index:1}.page-portfolio-hero-title{font-size:var(--font-size-4xl);font-weight:800;margin:0 0 var(--space-md);line-height:1.2}@media(max-width:767px){.page-portfolio-hero-title{font-size:var(--font-size-3xl)}}.page-portfolio-hero-subtitle{font-size:var(--font-size-xl);opacity:.9;margin:0 0 var(--space-lg);line-height:1.4}.page-portfolio-hero-description{font-size:var(--font-size-lg);opacity:.8;line-height:1.6;margin:0}.page-portfolio-section-filters{background-color:var(--color-light)}.page-portfolio-filters{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center}.page-portfolio-filter{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);background-color:var(--color-white);border:2px solid transparent;border-radius:50px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray);cursor:pointer;transition:all var(--transition-fast)}.page-portfolio-filter:hover{border-color:var(--color-accent);color:var(--color-accent)}.page-portfolio-filter-active{background-color:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}.page-portfolio-filter-label{white-space:nowrap}.page-portfolio-filter-count{background-color:#0000001a;padding:2px 8px;border-radius:10px;font-size:var(--font-size-xs)}.page-portfolio-filter-active .page-portfolio-filter-count{background-color:#fff3}.page-portfolio-projects-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media(min-width:768px){.page-portfolio-projects-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.page-portfolio-projects-grid{grid-template-columns:repeat(3,1fr)}}.page-portfolio-project-card{background-color:var(--color-white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.page-portfolio-project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.page-portfolio-project-image{height:200px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:80px;padding:var(--space-xl)}.page-portfolio-project-content{padding:var(--space-xl)}.page-portfolio-project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.page-portfolio-project-category{font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent);background-color:#00b4d81a;padding:var(--space-xs) var(--space-md);border-radius:50px}.page-portfolio-project-year{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500}.page-portfolio-project-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-sm);line-height:1.3}.page-portfolio-project-description{color:var(--color-gray);line-height:1.6;margin:0 0 var(--space-md)}.page-portfolio-project-client{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);margin-bottom:var(--space-md)}.page-portfolio-project-client-label{color:var(--color-gray);font-weight:500}.page-portfolio-project-client-name{color:var(--color-primary);font-weight:600}.page-portfolio-project-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.page-portfolio-project-tag{font-size:var(--font-size-xs);color:var(--color-gray);background-color:var(--color-light);padding:2px 8px;border-radius:4px}.page-portfolio-section-stats{background-color:var(--color-light)}.page-portfolio-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl)}@media(min-width:768px){.page-portfolio-stats-grid{grid-template-columns:repeat(4,1fr)}}.page-portfolio-stat{text-align:center;padding:var(--space-xl);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.page-portfolio-stat-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-accent);margin-bottom:var(--space-xs);line-height:1}.page-portfolio-stat-label{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500}.page-portfolio-section-cta{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);text-align:center}.page-portfolio-cta-content{max-width:800px;margin:0 auto}.page-portfolio-cta-title{font-size:var(--font-size-3xl);font-weight:800;margin:0 0 var(--space-lg);line-height:1.2}@media(max-width:767px){.page-portfolio-cta-title{font-size:var(--font-size-2xl)}}.page-portfolio-cta-text{font-size:var(--font-size-lg);opacity:.9;line-height:1.6;margin:0 auto var(--space-xl);max-width:600px}.page-portfolio-cta-actions{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}@media(max-width:767px){.page-portfolio-cta-actions{flex-direction:column;align-items:center}.page-portfolio-cta-actions .common-button{min-width:250px}}.page-portfolio-project-modal{display:flex;flex-direction:column;gap:var(--space-xl)}.page-portfolio-project-modal-header{display:flex;align-items:flex-start;gap:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--color-border)}@media(max-width:767px){.page-portfolio-project-modal-header{flex-direction:column;gap:var(--space-lg)}}.page-portfolio-project-modal-image{width:120px;height:120px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;font-size:60px;flex-shrink:0}.page-portfolio-project-modal-info{flex:1}.page-portfolio-project-modal-meta{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.page-portfolio-project-modal-category{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent);background-color:#00b4d81a;padding:var(--space-xs) var(--space-md);border-radius:50px}.page-portfolio-project-modal-year{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500}.page-portfolio-project-modal-client{font-size:var(--font-size-base);color:var(--color-text);margin-bottom:var(--space-md)}.page-portfolio-project-modal-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.page-portfolio-project-modal-tag{font-size:var(--font-size-xs);color:var(--color-gray);background-color:var(--color-light);padding:2px 8px;border-radius:4px}.page-portfolio-project-modal-content{display:flex;flex-direction:column;gap:var(--space-lg)}.page-portfolio-project-modal-subtitle{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin:0}.page-portfolio-project-modal-description{color:var(--color-text);line-height:1.6;margin:0}.page-portfolio-project-modal-features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.page-portfolio-project-modal-feature{display:flex;align-items:center;gap:var(--space-sm);color:var(--color-text)}.page-portfolio-project-modal-feature-icon{color:var(--color-success);font-weight:700}.page-portfolio-project-modal-actions{display:flex;gap:var(--space-md);padding-top:var(--space-xl);border-top:1px solid var(--color-border);justify-content:flex-end}@media(max-width:767px){.page-portfolio-project-modal-actions{flex-direction:column}}.page-about{display:flex;flex-direction:column;gap:var(--space-2xl)}.page-about-hero{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);padding:var(--space-2xl) 0;position:relative;overflow:hidden}.page-about-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.page-about-hero-content{max-width:800px;position:relative;z-index:1}.page-about-hero-title{font-size:var(--font-size-4xl);font-weight:800;margin:0 0 var(--space-md);line-height:1.2}@media(max-width:767px){.page-about-hero-title{font-size:var(--font-size-3xl)}}.page-about-hero-subtitle{font-size:var(--font-size-xl);opacity:.9;margin:0 0 var(--space-lg);line-height:1.4}.page-about-hero-description{font-size:var(--font-size-lg);opacity:.8;line-height:1.6;margin:0}.page-about-mission-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl);margin-bottom:var(--space-2xl)}@media(min-width:768px){.page-about-mission-grid{grid-template-columns:repeat(2,1fr)}}.page-about-mission-card{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-xl);box-shadow:var(--shadow-md);text-align:center}.page-about-mission-icon{font-size:48px;margin-bottom:var(--space-lg)}.page-about-mission-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-md)}.page-about-mission-text{color:var(--color-gray);line-height:1.6;margin:0}.page-about-section-values{background-color:var(--color-light)}.page-about-values-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media(min-width:768px){.page-about-values-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.page-about-values-grid{grid-template-columns:repeat(4,1fr)}}.page-about-value-card{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-xl);text-align:center;box-shadow:var(--shadow-sm);transition:transform var(--transition-normal)}.page-about-value-card:hover{transform:translateY(-4px)}.page-about-value-icon{font-size:40px;margin-bottom:var(--space-md)}.page-about-value-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-sm)}.page-about-value-description{color:var(--color-gray);line-height:1.6;margin:0}.page-about-team-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media(min-width:768px){.page-about-team-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.page-about-team-grid{grid-template-columns:repeat(4,1fr)}}.page-about-team-card{background-color:var(--color-white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--transition-normal)}.page-about-team-card:hover{transform:translateY(-4px)}.page-about-team-image{height:200px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:80px;padding:var(--space-xl)}.page-about-team-content{padding:var(--space-xl)}.page-about-team-name{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-xs)}.page-about-team-role{font-size:var(--font-size-lg);font-weight:600;color:var(--color-accent);margin:0 0 var(--space-xs)}.page-about-team-department{font-size:var(--font-size-sm);color:var(--color-gray);margin:0 0 var(--space-sm)}.page-about-team-experience{font-size:var(--font-size-sm);color:var(--color-text);margin:0 0 var(--space-md)}.page-about-team-bio{color:var(--color-gray);line-height:1.6;margin:0 0 var(--space-md)}.page-about-team-skills{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.page-about-team-skill{font-size:var(--font-size-xs);color:var(--color-gray);background-color:var(--color-light);padding:2px 8px;border-radius:4px}.page-about-section-timeline{background-color:var(--color-light)}.page-about-timeline{position:relative;max-width:800px;margin:0 auto}.page-about-timeline:before{content:"";position:absolute;left:30px;top:0;bottom:0;width:2px;background-color:var(--color-border)}@media(min-width:768px){.page-about-timeline:before{left:50%;transform:translate(-50%)}}.page-about-timeline-item{display:flex;margin-bottom:var(--space-xl);position:relative}@media(min-width:768px){.page-about-timeline-item{width:50%}.page-about-timeline-item:nth-child(odd){padding-right:var(--space-2xl);text-align:right}.page-about-timeline-item:nth-child(2n){margin-left:auto;padding-left:var(--space-2xl)}}.page-about-timeline-year{width:60px;height:60px;background-color:var(--color-accent);color:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:700;flex-shrink:0;position:relative;z-index:1}@media(min-width:768px){.page-about-timeline-year{position:absolute;top:0}.page-about-timeline-item:nth-child(odd) .page-about-timeline-year{right:-30px}.page-about-timeline-item:nth-child(2n) .page-about-timeline-year{left:-30px}}.page-about-timeline-content{flex:1;padding-left:var(--space-xl)}@media(min-width:768px){.page-about-timeline-content{padding-left:0}.page-about-timeline-item:nth-child(2n) .page-about-timeline-content{padding-left:var(--space-xl)}}.page-about-timeline-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-sm)}.page-about-timeline-description{color:var(--color-gray);line-height:1.6;margin:0}.page-about-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl)}@media(min-width:768px){.page-about-stats-grid{grid-template-columns:repeat(4,1fr)}}.page-about-stat{text-align:center;padding:var(--space-xl);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.page-about-stat-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-accent);margin-bottom:var(--space-xs);line-height:1}.page-about-stat-label{font-size:var(--font-size-sm);color:var(--color-gray);font-weight:500}.page-about-section-cta{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);text-align:center}.page-about-cta-content{max-width:800px;margin:0 auto}.page-about-cta-title{font-size:var(--font-size-3xl);font-weight:800;margin:0 0 var(--space-lg);line-height:1.2}@media(max-width:767px){.page-about-cta-title{font-size:var(--font-size-2xl)}}.page-about-cta-text{font-size:var(--font-size-lg);opacity:.9;line-height:1.6;margin:0 auto var(--space-xl);max-width:600px}.page-about-cta-actions{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}@media(max-width:767px){.page-about-cta-actions{flex-direction:column;align-items:center}.page-about-cta-actions .common-button{min-width:250px}}.page-about-section{padding:var(--space-2xl) 0}@media(max-width:767px){.page-about-section{padding:var(--space-xl) 0}}.page-about-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.page-about-section-header{text-align:center;max-width:800px;margin:0 auto var(--space-2xl)}.page-about-section-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);margin:0 0 var(--space-md);line-height:1.2}@media(max-width:767px){.page-about-section-title{font-size:var(--font-size-2xl)}}.page-about-section-subtitle{font-size:var(--font-size-lg);color:var(--color-gray);line-height:1.6;max-width:600px;margin:0 auto}@media(max-width:767px){.page-about-section-subtitle{font-size:var(--font-size-base)}}.common-input-wrapper{display:flex;flex-direction:column;gap:var(--space-sm)}.common-input-wrapper-full-width{width:100%}.common-input-label{font-weight:500;color:var(--color-primary);font-size:var(--font-size-sm)}.common-input-required{color:#dc2626;margin-left:2px}.common-input-container{display:flex;align-items:center;border:1px solid var(--color-gray);border-radius:var(--border-radius);padding:0 var(--space-md);transition:all var(--transition-fast);background-color:var(--color-white)}.common-input-container:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px #0f4c751a}.common-input-container-error{border-color:#dc2626}.common-input-container-error:focus-within{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.common-input-container-disabled{background-color:var(--color-light);opacity:.6;cursor:not-allowed}.common-input{flex:1;border:none;outline:none;padding:var(--space-sm) 0;font-family:var(--font-primary);font-size:var(--font-size-base);color:var(--color-primary);background:transparent;min-height:40px}.common-input::placeholder{color:var(--color-gray);opacity:.7}.common-input:disabled{cursor:not-allowed}.common-input-prefix,.common-input-suffix{color:var(--color-gray);font-size:var(--font-size-sm);flex-shrink:0}.common-input-prefix{margin-right:var(--space-sm)}.common-input-suffix{margin-left:var(--space-sm)}.common-input-message{font-size:var(--font-size-sm);min-height:20px}.common-input-message-helper{color:var(--color-gray)}.common-input-message-error{color:#dc2626}.page-contact{display:flex;flex-direction:column;gap:var(--space-2xl)}.page-contact-section{padding:var(--space-2xl) 0}.page-contact-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md)}.page-contact-hero{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);padding:var(--space-2xl) 0;position:relative;overflow:hidden}.page-contact-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.page-contact-hero-content{max-width:800px;position:relative;z-index:1}.page-contact-hero-title{font-size:var(--font-size-4xl);font-weight:800;margin:0 0 var(--space-md);line-height:1.2}@media(max-width:767px){.page-contact-hero-title{font-size:var(--font-size-3xl)}}.page-contact-hero-subtitle{font-size:var(--font-size-xl);opacity:.9;margin:0 0 var(--space-lg);line-height:1.4}.page-contact-hero-description{font-size:var(--font-size-lg);opacity:.8;line-height:1.6;margin:0}.page-contact-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);margin:var(--space-2xl) 0}@media(min-width:1024px){.page-contact-grid{grid-template-columns:2fr 1fr;gap:var(--space-3xl)}}.page-contact-form-section{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-2xl);box-shadow:var(--shadow-md)}.page-contact-section-header{margin-bottom:var(--space-xl)}.page-contact-section-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-sm)}.page-contact-section-subtitle{color:var(--color-gray);line-height:1.6;margin:0}.page-contact-form{display:flex;flex-direction:column;gap:var(--space-lg)}.page-contact-form-row{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}@media(min-width:768px){.page-contact-form-row{grid-template-columns:1fr 1fr}}.page-contact-form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.page-contact-form-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary)}.page-contact-form-select{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:var(--font-size-base);color:var(--color-primary);background-color:var(--color-white);cursor:pointer;transition:border-color var(--transition-fast);width:100%}.page-contact-form-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #00b4d81a}.page-contact-form-select:disabled{opacity:.6;cursor:not-allowed}.page-contact-form-textarea{padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:var(--font-size-base);color:var(--color-primary);background-color:var(--color-white);font-family:inherit;resize:vertical;transition:border-color var(--transition-fast);width:100%}.page-contact-form-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #00b4d81a}.page-contact-form-textarea:disabled{opacity:.6;cursor:not-allowed}.page-contact-form-error{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--space-xs)}.page-contact-form-actions{display:flex;justify-content:flex-end}.page-contact-info-section{display:flex;flex-direction:column;gap:var(--space-2xl)}.page-contact-info-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}.page-contact-info-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.page-contact-info-card:hover{transform:translateY(-2px)}.page-contact-info-icon{font-size:24px;width:48px;height:48px;background-color:var(--color-light);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-contact-info-content{flex:1}.page-contact-info-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-xs)}.page-contact-info-details{color:var(--color-gray);text-decoration:none;line-height:1.6;margin:0;transition:color var(--transition-fast)}.page-contact-info-details:hover{color:var(--color-accent)}.page-contact-faq-section{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.page-contact-faq-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-lg)}.page-contact-faq-list{display:flex;flex-direction:column;gap:var(--space-lg)}.page-contact-faq-item{padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border)}.page-contact-faq-item:last-child{border-bottom:none;padding-bottom:0}.page-contact-faq-question{font-size:var(--font-size-base);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-sm)}.page-contact-faq-answer{color:var(--color-gray);line-height:1.6;margin:0}.page-contact-social-section{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-xl);box-shadow:var(--shadow-sm);text-align:center}.page-contact-social-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-lg)}.page-contact-social-links{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}.page-contact-social-link{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:var(--color-light);border-radius:50%;text-decoration:none;transition:all var(--transition-fast)}.page-contact-social-link:hover{background-color:var(--color-accent);transform:translateY(-2px)}.page-contact-social-icon{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.page-contact-social-link:hover .page-contact-social-icon{color:var(--color-white)}.page-contact-section-map{background-color:var(--color-light);padding:40px}.page-contact-map-container{background-color:var(--color-white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md)}.page-contact-map-placeholder{padding:var(--space-2xl);text-align:center;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white)}.page-contact-map-icon{font-size:64px}.page-contact-map-title{font-size:var(--font-size-2xl);font-weight:700;margin:0}.page-contact-map-text{font-size:var(--font-size-lg);opacity:.9;margin:0;max-width:400px}.page-contact-success-modal{text-align:center;padding:var(--space-xl) 0}.page-contact-success-icon{width:80px;height:80px;background-color:var(--color-success);color:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;margin:0 auto var(--space-lg)}.page-contact-success-text{color:var(--color-text);line-height:1.6;margin:0 0 var(--space-xl);font-size:var(--font-size-lg)}.page-contact-success-actions{display:flex;justify-content:center;gap:var(--space-md)}@media(max-width:767px){.page-contact-form-section,.page-contact-faq-section,.page-contact-social-section{padding:var(--space-lg)}.page-contact-map-placeholder{padding:var(--space-xl)}.page-contact-success-modal{padding:var(--space-lg) 0}}@media(max-width:767px){.page-contact-section{padding:var(--space-xl) 0}}.location-map{width:100%;border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}.location-map-container{position:relative;width:100%;height:100%}.location-map-iframe{width:100%;border:none;display:block}.location-map-info{position:absolute;bottom:30px;left:30px;max-width:350px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius);padding:var(--space-lg);box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.2);animation:slideInUp .5s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.location-map-info-content{display:flex;flex-direction:column;gap:var(--space-md)}.location-map-info-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin:0;line-height:1.3}.location-map-info-address{color:var(--color-text);line-height:1.5;margin:0;font-size:var(--font-size-base);background:var(--color-light);padding:var(--space-sm);border-radius:var(--border-radius-sm);border-left:4px solid var(--color-accent)}.location-map-info-address strong{color:var(--color-primary);font-weight:600}.location-map-info-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:var(--space-sm)}.location-map-directions-button,.location-map-call-button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);text-decoration:none;border-radius:var(--border-radius);font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-fast);min-width:140px;text-align:center}.location-map-directions-button{background-color:var(--color-accent);color:var(--color-white);flex:1}.location-map-directions-button:hover{background-color:var(--color-accent-dark);transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--color-white)}.location-map-call-button{background-color:var(--color-success);color:var(--color-white);flex:1}.location-map-call-button:hover{background-color:var(--color-success-dark);transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--color-white)}.location-map-controls{position:absolute;top:20px;right:20px;display:flex;gap:var(--space-sm)}.location-map-zoom-controls{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius);padding:var(--space-xs);display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.location-map-zoom-in,.location-map-zoom-out{background:none;border:none;width:40px;height:40px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:background-color var(--transition-fast);border-radius:var(--border-radius-sm)}.location-map-zoom-in:hover,.location-map-zoom-out:hover{background-color:var(--color-light)}@media(max-width:768px){.location-map-info{position:relative;bottom:auto;left:auto;right:auto;max-width:100%;margin:0;background:var(--color-white);border-radius:0;border-top:1px solid var(--color-border);box-shadow:none;padding:var(--space-md)}.location-map-info-actions{flex-direction:column}.location-map-directions-button,.location-map-call-button{width:100%}.location-map-controls{top:10px;right:10px}}@media(min-width:769px)and (max-width:1024px){.location-map-info{max-width:300px;bottom:20px;left:20px}}@media(prefers-color-scheme:dark){.location-map-info{background:#1e1e28f2;border:1px solid rgba(255,255,255,.1)}.location-map-info-title{color:var(--color-white)}.location-map-info-address{color:var(--color-gray-light);background:#ffffff1a}.location-map-info-address strong{color:var(--color-white)}}.viewer-viewer-controls{background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md);height:100%;display:flex;flex-direction:column}.viewer-viewer-controls-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-light);flex-shrink:0}.viewer-viewer-controls-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin:0}.viewer-viewer-controls-reset{font-size:var(--font-size-sm);color:var(--color-accent);background:none;border:none;cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius);transition:all var(--transition-fast);font-weight:500}.viewer-viewer-controls-reset:hover{background-color:#0f4c751a}.viewer-viewer-controls-content{flex:1;overflow-y:auto;padding:var(--space-lg);max-height:500px}.viewer-viewer-controls-content::-webkit-scrollbar{width:6px}.viewer-viewer-controls-content::-webkit-scrollbar-track{background:var(--color-light);border-radius:3px}.viewer-viewer-controls-content::-webkit-scrollbar-thumb{background:var(--color-gray);border-radius:3px}.viewer-viewer-controls-group{margin-bottom:var(--space-xl)}.viewer-viewer-controls-group:last-child{margin-bottom:0}.viewer-viewer-controls-group-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-light)}.viewer-viewer-controls-row{margin-bottom:var(--space-lg)}.viewer-viewer-controls-row:last-child{margin-bottom:0}.viewer-viewer-controls-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm)}.viewer-viewer-controls-color-picker{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.viewer-viewer-controls-color-option{width:32px;height:32px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);position:relative}.viewer-viewer-controls-color-option:hover{transform:scale(1.1);box-shadow:var(--shadow-sm)}.viewer-viewer-controls-color-option-active{border-color:var(--color-primary);transform:scale(1.1);box-shadow:var(--shadow-sm)}.viewer-viewer-controls-color-option-active:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.5)}.viewer-viewer-controls-quality{display:flex;gap:var(--space-xs)}.viewer-viewer-controls-quality-option{flex:1;padding:var(--space-xs) var(--space-sm);background-color:var(--color-light);border:1px solid var(--color-light);border-radius:var(--border-radius);font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray);cursor:pointer;transition:all var(--transition-fast);text-align:center}.viewer-viewer-controls-quality-option:hover{background-color:#0f4c751a;color:var(--color-primary)}.viewer-viewer-controls-quality-option-active{background-color:var(--color-accent);border-color:var(--color-accent);color:var(--color-white)}.viewer-viewer-controls-toggle{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.viewer-viewer-controls-toggle:last-child{margin-bottom:0}.viewer-viewer-controls-toggle-label{flex:1;font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary)}.viewer-viewer-controls-toggle-description{display:block;font-size:var(--font-size-xs);color:var(--color-gray);font-weight:400;margin-top:2px}.viewer-viewer-controls-toggle-button{width:50px;height:24px;background-color:var(--color-gray);border:none;border-radius:12px;cursor:pointer;position:relative;transition:all var(--transition-fast);flex-shrink:0}.viewer-viewer-controls-toggle-button-active{background-color:var(--color-accent)}.viewer-viewer-controls-toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:var(--color-white);border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.viewer-viewer-controls-toggle-button-active .viewer-viewer-controls-toggle-knob{transform:translate(26px)}.viewer-viewer-controls-slider{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:var(--color-light);border-radius:3px;outline:none}.viewer-viewer-controls-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background-color:var(--color-accent);border-radius:50%;cursor:pointer;border:2px solid var(--color-white);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.viewer-viewer-controls-slider::-webkit-slider-thumb:hover{transform:scale(1.1);background-color:var(--color-highlight)}.viewer-viewer-controls-slider::-moz-range-thumb{width:20px;height:20px;background-color:var(--color-accent);border-radius:50%;cursor:pointer;border:2px solid var(--color-white);box-shadow:var(--shadow-sm)}.viewer-viewer-controls-shortcuts{display:flex;flex-direction:column;gap:var(--space-sm)}.viewer-viewer-controls-shortcut{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);background-color:var(--color-light);border-radius:var(--border-radius)}.viewer-viewer-controls-key{font-family:Courier New,monospace;font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);background-color:var(--color-white);padding:2px 8px;border-radius:4px;border:1px solid var(--color-light);min-width:120px;text-align:center}.viewer-viewer-controls-action{font-size:var(--font-size-sm);color:var(--color-gray);flex:1}@media(max-width:767px){.viewer-viewer-controls-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.viewer-viewer-controls-reset{align-self:flex-end}.viewer-viewer-controls-quality{flex-direction:column}.viewer-viewer-controls-shortcut{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.viewer-viewer-controls-key{min-width:auto;width:100%}}.viewer-model-viewer{display:flex;flex-direction:column;height:100%;background-color:var(--color-white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md)}.viewer-model-viewer-empty{display:flex;align-items:center;justify-content:center;min-height:500px;background-color:var(--color-light)}.viewer-model-viewer-placeholder{text-align:center;padding:var(--space-2xl);max-width:400px}.viewer-model-viewer-placeholder-icon{font-size:64px;margin-bottom:var(--space-lg);opacity:.5}.viewer-model-viewer-placeholder-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-md)}.viewer-model-viewer-placeholder-text{color:var(--color-gray);line-height:1.6;margin:0}.viewer-model-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);background-color:var(--color-white);border-bottom:1px solid var(--color-light);flex-shrink:0}.viewer-model-viewer-info{flex:1;min-width:0}.viewer-model-viewer-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-model-viewer-meta{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.viewer-model-viewer-format,.viewer-model-viewer-size,.viewer-model-viewer-date{font-size:var(--font-size-xs);color:var(--color-gray);background-color:var(--color-light);padding:2px 8px;border-radius:4px}.viewer-model-viewer-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.viewer-model-viewer-action{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background-color:var(--color-light);border:1px solid var(--color-light);border-radius:var(--border-radius);font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.viewer-model-viewer-action:hover,.viewer-model-viewer-action-fullscreen{background-color:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}.viewer-model-viewer-action-fullscreen:hover{background-color:var(--color-highlight);border-color:var(--color-highlight)}.viewer-model-viewer-canvas{flex:1;min-height:400px;position:relative;overflow:hidden}.viewer-model-viewer-canvas canvas{width:100%!important;height:100%!important;outline:none}.viewer-model-viewer-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#000000b3;z-index:10}.viewer-model-viewer-loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.3);border-top-color:var(--color-highlight);border-radius:50%;animation:viewer-spin 1s linear infinite;margin-bottom:var(--space-md)}@keyframes viewer-spin{to{transform:rotate(360deg)}}.viewer-model-viewer-loading-text{color:var(--color-white);font-size:var(--font-size-lg);margin:0}.viewer-model-viewer-error{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#dc26261a;z-index:10;padding:var(--space-xl);text-align:center}.viewer-model-viewer-error-icon{font-size:48px;margin-bottom:var(--space-lg)}.viewer-model-viewer-error-title{font-size:var(--font-size-lg);font-weight:600;color:#dc2626;margin:0 0 var(--space-sm)}.viewer-model-viewer-error-text{color:var(--color-gray);line-height:1.6;margin:0;max-width:400px}.viewer-model-viewer-details{padding:var(--space-lg);background-color:var(--color-white);border-top:1px solid var(--color-light);flex-shrink:0}.viewer-model-viewer-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-md)}.viewer-model-viewer-tag{font-size:var(--font-size-xs);color:var(--color-accent);background-color:#0f4c751a;padding:2px 8px;border-radius:50px;font-weight:500}.viewer-model-viewer-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.viewer-model-viewer-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-sm);background-color:var(--color-light);border-radius:var(--border-radius)}.viewer-model-viewer-stat-label{font-size:var(--font-size-xs);color:var(--color-gray);margin-bottom:2px}.viewer-model-viewer-stat-value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary)}@media(max-width:767px){.viewer-model-viewer-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.viewer-model-viewer-actions{width:100%;justify-content:flex-end}.viewer-model-viewer-canvas{min-height:300px}.viewer-model-viewer-stats{grid-template-columns:1fr;gap:var(--space-sm)}.viewer-model-viewer-stat{flex-direction:row;justify-content:space-between;align-items:center}.viewer-model-viewer-stat-label{margin-bottom:0}}@media(max-width:480px){.viewer-model-viewer-actions{flex-wrap:wrap}.viewer-model-viewer-action{flex:1;justify-content:center}}.viewer-model-uploader{background-color:var(--color-white);border-radius:var(--border-radius);padding:var(--space-xl);box-shadow:var(--shadow-md);height:100%}.viewer-model-uploader-header{margin-bottom:var(--space-xl);text-align:center}.viewer-model-uploader-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-sm)}.viewer-model-uploader-subtitle{color:var(--color-gray);line-height:1.6;max-width:600px;margin:0 auto}.viewer-model-uploader-dropzone{border:2px dashed var(--color-accent);border-radius:var(--border-radius);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:all var(--transition-normal);margin-bottom:var(--space-xl);background-color:#0f4c750d}.viewer-model-uploader-dropzone:hover{background-color:#0f4c751a;border-color:var(--color-highlight)}.viewer-model-uploader-dropzone-active{background-color:#0f4c7526;border-color:var(--color-highlight);border-style:solid}.viewer-model-uploader-input{display:none}.viewer-model-uploader-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.viewer-model-uploader-icon{font-size:48px;margin-bottom:var(--space-sm)}.viewer-model-uploader-dropzone-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin:0}.viewer-model-uploader-dropzone-text{color:var(--color-gray);margin:0}.viewer-model-uploader-dropzone-formats{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:500;margin:var(--space-xs) 0}.viewer-model-uploader-dropzone-limit{font-size:var(--font-size-xs);color:var(--color-gray);margin:0}.viewer-model-uploader-files{margin-bottom:var(--space-xl)}.viewer-model-uploader-files-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-md)}.viewer-model-uploader-files-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg);max-height:200px;overflow-y:auto;padding-right:var(--space-sm)}.viewer-model-uploader-files-list::-webkit-scrollbar{width:6px}.viewer-model-uploader-files-list::-webkit-scrollbar-track{background:var(--color-light);border-radius:3px}.viewer-model-uploader-files-list::-webkit-scrollbar-thumb{background:var(--color-gray);border-radius:3px}.viewer-model-uploader-file{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--color-light);border-radius:var(--border-radius);transition:all var(--transition-fast)}.viewer-model-uploader-file:hover{background-color:#0f4c751a}.viewer-model-uploader-file-icon{font-size:20px;width:40px;height:40px;background-color:var(--color-white);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.viewer-model-uploader-file-info{flex:1;min-width:0}.viewer-model-uploader-file-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-model-uploader-file-size{font-size:var(--font-size-xs);color:var(--color-gray)}.viewer-model-uploader-file-remove{background:none;border:none;color:#dc2626;font-size:18px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-fast);flex-shrink:0}.viewer-model-uploader-file-remove:hover{background-color:#dc2626;color:var(--color-white)}.viewer-model-uploader-actions{display:flex;justify-content:flex-end;gap:var(--space-md)}.viewer-model-uploader-progress{background-color:var(--color-light);border-radius:var(--border-radius);padding:var(--space-lg);margin-bottom:var(--space-xl)}.viewer-model-uploader-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.viewer-model-uploader-progress-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-primary);margin:0}.viewer-model-uploader-progress-status{font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:1px}.viewer-model-uploader-progress-bar{height:8px;background-color:var(--color-white);border-radius:4px;overflow:hidden;margin-bottom:var(--space-sm)}.viewer-model-uploader-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-highlight));border-radius:4px;transition:width .3s ease}.viewer-model-uploader-progress-percent{font-size:var(--font-size-lg);font-weight:700;color:var(--color-accent);text-align:center}.viewer-model-uploader-tips-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-md)}.viewer-model-uploader-tips-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-md)}.viewer-model-uploader-tip{display:flex;align-items:flex-start;gap:var(--space-md)}.viewer-model-uploader-tip-icon{font-size:20px;flex-shrink:0;margin-top:2px}.viewer-model-uploader-tip-text{font-size:var(--font-size-sm);color:var(--color-gray);line-height:1.5;margin:0}@media(max-width:767px){.viewer-model-uploader{padding:var(--space-lg)}.viewer-model-uploader-dropzone{padding:var(--space-xl)}.viewer-model-uploader-actions{flex-direction:column}.viewer-model-uploader-actions button{width:100%}}@media(max-width:480px){.viewer-model-uploader-dropzone{padding:var(--space-lg)}.viewer-model-uploader-icon{font-size:36px}.viewer-model-uploader-file{padding:var(--space-sm);gap:var(--space-sm)}.viewer-model-uploader-file-icon{width:32px;height:32px;font-size:16px}}.viewer-model-gallery{background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md);height:100%;display:flex;flex-direction:column}.viewer-model-gallery-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-light);flex-shrink:0}.viewer-model-gallery-header-content{flex:1}.viewer-model-gallery-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-xs)}.viewer-model-gallery-subtitle{font-size:var(--font-size-sm);color:var(--color-gray);margin:0}.viewer-model-gallery-header-actions{display:flex;align-items:center;gap:var(--space-lg)}.viewer-model-gallery-count{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent);background-color:#0f4c751a;padding:var(--space-xs) var(--space-sm);border-radius:50px}.viewer-model-gallery-view-toggle{display:flex;gap:2px;background-color:var(--color-light);border-radius:var(--border-radius);padding:2px}.viewer-model-gallery-view-button{background:none;border:none;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--color-gray);border-radius:6px;transition:all var(--transition-fast)}.viewer-model-gallery-view-button:hover{background-color:#ffffff80;color:var(--color-primary)}.viewer-model-gallery-view-button-active{background-color:var(--color-white);color:var(--color-accent);box-shadow:var(--shadow-sm)}.viewer-model-gallery-recent{padding:var(--space-lg);border-bottom:1px solid var(--color-light)}.viewer-model-gallery-recent-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-md)}.viewer-model-gallery-recent-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(min-width:768px){.viewer-model-gallery-recent-grid{grid-template-columns:repeat(4,1fr)}}.viewer-model-gallery-recent-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background-color:var(--color-light);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent}.viewer-model-gallery-recent-item:hover{background-color:#0f4c751a;transform:translateY(-2px)}.viewer-model-gallery-recent-item-active{border-color:var(--color-accent);background-color:#0f4c751a}.viewer-model-gallery-recent-icon{font-size:20px;width:40px;height:40px;background-color:var(--color-white);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.viewer-model-gallery-recent-info{flex:1;min-width:0}.viewer-model-gallery-recent-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-model-gallery-recent-meta{font-size:var(--font-size-xs);color:var(--color-gray)}.viewer-model-gallery-recent-badge{font-size:10px;font-weight:800;color:var(--color-highlight);background-color:#00b4d81a;padding:2px 6px;border-radius:50px;text-transform:uppercase;letter-spacing:1px}.viewer-model-gallery-filters{padding:var(--space-lg);border-bottom:1px solid var(--color-light);display:flex;flex-direction:column;gap:var(--space-md)}.viewer-model-gallery-search{position:relative}.viewer-model-gallery-search-input{width:100%;padding:var(--space-sm) var(--space-lg) var(--space-sm) 40px;border:1px solid var(--color-light);border-radius:var(--border-radius);font-size:var(--font-size-sm);color:var(--color-primary);background-color:var(--color-white);transition:all var(--transition-fast)}.viewer-model-gallery-search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #0f4c751a}.viewer-model-gallery-search-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--color-gray);pointer-events:none}.viewer-model-gallery-filter-group{display:flex;gap:var(--space-md);flex-wrap:wrap}.viewer-model-gallery-filter-select{flex:1;min-width:120px;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-light);border-radius:var(--border-radius);font-size:var(--font-size-sm);color:var(--color-primary);background-color:var(--color-white);cursor:pointer;transition:all var(--transition-fast)}.viewer-model-gallery-filter-select:focus{outline:none;border-color:var(--color-accent)}.viewer-model-gallery-clear-button{white-space:nowrap}.viewer-model-gallery-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.viewer-model-gallery-content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-lg)}.viewer-model-gallery-content-list{display:flex;flex-direction:column;gap:var(--space-sm)}.viewer-model-gallery-item{background-color:var(--color-light);border-radius:var(--border-radius);padding:var(--space-md);cursor:pointer;transition:all var(--transition-normal);border:2px solid transparent}.viewer-model-gallery-content-grid .viewer-model-gallery-item{display:flex;flex-direction:column;height:100%}.viewer-model-gallery-content-list .viewer-model-gallery-item{display:flex;align-items:center;gap:var(--space-md)}.viewer-model-gallery-item:hover{background-color:#0f4c751a;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.viewer-model-gallery-item-active{border-color:var(--color-accent);background-color:#0f4c751a}.viewer-model-gallery-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.viewer-model-gallery-content-list .viewer-model-gallery-item-header{margin-bottom:0;flex-shrink:0}.viewer-model-gallery-item-icon{font-size:24px;width:48px;height:48px;background-color:var(--color-white);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.viewer-model-gallery-content-list .viewer-model-gallery-item-icon{width:40px;height:40px;font-size:20px}.viewer-model-gallery-item-actions{opacity:0;transition:opacity var(--transition-fast)}.viewer-model-gallery-item:hover .viewer-model-gallery-item-actions{opacity:1}.viewer-model-gallery-item-action{background:none;border:none;font-size:16px;color:var(--color-gray);cursor:pointer;padding:var(--space-xs);border-radius:4px;transition:all var(--transition-fast)}.viewer-model-gallery-item-action:hover{color:#dc2626;background-color:#dc26261a}.viewer-model-gallery-item-content{flex:1;margin-bottom:var(--space-md)}.viewer-model-gallery-content-list .viewer-model-gallery-item-content{margin-bottom:0;min-width:0}.viewer-model-gallery-item-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-model-gallery-content-list .viewer-model-gallery-item-title{white-space:normal}.viewer-model-gallery-item-description{font-size:var(--font-size-sm);color:var(--color-gray);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.viewer-model-gallery-content-list .viewer-model-gallery-item-description{-webkit-line-clamp:1}.viewer-model-gallery-item-footer{display:flex;flex-direction:column;gap:var(--space-sm)}.viewer-model-gallery-content-list .viewer-model-gallery-item-footer{flex-direction:row;align-items:center;justify-content:space-between;margin-left:auto;min-width:200px}.viewer-model-gallery-item-meta{display:flex;align-items:center;gap:var(--space-md)}.viewer-model-gallery-item-format,.viewer-model-gallery-item-size{font-size:var(--font-size-xs);color:var(--color-gray);background-color:var(--color-white);padding:2px 6px;border-radius:4px}.viewer-model-gallery-item-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.viewer-model-gallery-item-tag{font-size:10px;color:var(--color-accent);background-color:#0f4c751a;padding:2px 6px;border-radius:50px;font-weight:500}.viewer-model-gallery-item-tag-more{font-size:10px;color:var(--color-gray);font-weight:500}.viewer-model-gallery-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center}.viewer-model-gallery-empty-icon{font-size:64px;margin-bottom:var(--space-lg);opacity:.5}.viewer-model-gallery-empty-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin:0 0 var(--space-sm)}.viewer-model-gallery-empty-text{color:var(--color-gray);line-height:1.6;margin:0;max-width:300px}.viewer-model-gallery-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--color-light);background-color:#0f4c750d}.viewer-model-gallery-stat{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.viewer-model-gallery-stat-value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-accent);line-height:1}.viewer-model-gallery-stat-label{font-size:var(--font-size-xs);color:var(--color-gray);font-weight:500}@media(max-width:767px){.viewer-model-gallery-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.viewer-model-gallery-header-actions{width:100%;justify-content:space-between}.viewer-model-gallery-content-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-md)}.viewer-model-gallery-content-list .viewer-model-gallery-item{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.viewer-model-gallery-content-list .viewer-model-gallery-item-footer{width:100%;margin-left:0;min-width:auto}.viewer-model-gallery-stats{grid-template-columns:1fr;gap:var(--space-md)}.viewer-model-gallery-stat{flex-direction:row;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-light)}.viewer-model-gallery-stat:last-child{border-bottom:none}}@media(max-width:480px){.viewer-model-gallery-filter-group{flex-direction:column}.viewer-model-gallery-filter-select,.viewer-model-gallery-clear-button{width:100%}.viewer-model-gallery-recent-grid{grid-template-columns:1fr}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg)}.loading-spinner-fullscreen{position:fixed;inset:0;background-color:#fffffff2;z-index:var(--z-modal)}.dark-theme .loading-spinner-fullscreen{background-color:#000000f2}.loading-spinner-overlay{position:absolute;inset:0;background-color:#ffffffd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-fixed)}.dark-theme .loading-spinner-overlay{background-color:#000000d9}.loading-spinner{display:inline-block;position:relative}.spinner-small{width:24px;height:24px}.spinner-medium{width:40px;height:40px}.spinner-large{width:60px;height:60px}.spinner-xlarge{width:80px;height:80px}.spinner-primary{border-color:var(--color-primary) transparent var(--color-primary) transparent}.spinner-secondary{border-color:var(--color-secondary) transparent var(--color-secondary) transparent}.spinner-accent{border-color:var(--color-accent) transparent var(--color-accent) transparent}.spinner-highlight{border-color:var(--color-highlight) transparent var(--color-highlight) transparent}.spinner-success{border-color:var(--color-success) transparent var(--color-success) transparent}.spinner-warning{border-color:var(--color-warning) transparent var(--color-warning) transparent}.spinner-error{border-color:var(--color-error) transparent var(--color-error) transparent}.spinner-white{border-color:white transparent white transparent}.spinner-dark{border-color:#333 transparent #333 transparent}.spinner-slow{animation-duration:1.5s}.spinner-normal{animation-duration:1s}.spinner-fast{animation-duration:.5s}.loading-spinner-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;max-width:200px;line-height:1.4}.spinner-circle{border:3px solid;border-radius:50%;animation:spinner-rotate linear infinite}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-dots{display:flex;align-items:center;justify-content:center;gap:4px}.spinner-dots .spinner-dot{width:8px;height:8px;border-radius:50%;background-color:currentColor;animation:spinner-dots-bounce 1.4s ease-in-out infinite both}.spinner-dots .spinner-dot:nth-child(1){animation-delay:-.32s}.spinner-dots .spinner-dot:nth-child(2){animation-delay:-.16s}@keyframes spinner-dots-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.spinner-pulse{border-radius:50%;background-color:currentColor;animation:spinner-pulse 1.2s ease-in-out infinite both}@keyframes spinner-pulse{0%,to{transform:scale(.8);opacity:.5}50%{transform:scale(1);opacity:1}}.spinner-ring{display:inline-block}.spinner-ring div{box-sizing:border-box;display:block;position:absolute;border:3px solid;border-radius:50%;animation:spinner-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;border-color:currentColor transparent transparent transparent}.spinner-ring div:nth-child(1){animation-delay:-.45s}.spinner-ring div:nth-child(2){animation-delay:-.3s}.spinner-ring div:nth-child(3){animation-delay:-.15s}@keyframes spinner-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-gear{animation:spinner-rotate 2s linear infinite}.spinner-gear-inner{width:100%;height:100%;background:radial-gradient(circle at 50% 50%,transparent 30%,currentColor 31%,currentColor 40%,transparent 41%),linear-gradient(0deg,transparent 45%,currentColor 45%,currentColor 55%,transparent 55%),linear-gradient(90deg,transparent 45%,currentColor 45%,currentColor 55%,transparent 55%),linear-gradient(45deg,transparent 45%,currentColor 45%,currentColor 55%,transparent 55%),linear-gradient(135deg,transparent 45%,currentColor 45%,currentColor 55%,transparent 55%)}.spinner-cube{width:100%;height:100%;position:relative;transform-style:preserve-3d;animation:spinner-cube-rotate 3s infinite linear}.cube-face{position:absolute;width:100%;height:100%;background-color:currentColor;opacity:.7}.cube-face-front{transform:translateZ(20px)}.cube-face-back{transform:translateZ(-20px) rotateY(180deg)}.cube-face-right{transform:translate(20px) rotateY(90deg)}.cube-face-left{transform:translate(-20px) rotateY(-90deg)}.cube-face-top{transform:translateY(-20px) rotateX(90deg)}.cube-face-bottom{transform:translateY(20px) rotateX(-90deg)}@keyframes spinner-cube-rotate{0%{transform:rotateX(0) rotateY(0)}to{transform:rotateX(360deg) rotateY(360deg)}}.spinner-grid{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:2px}.spinner-grid div{background-color:currentColor;animation:spinner-grid-scale 1.2s ease-in-out infinite}.spinner-grid div:nth-child(1){animation-delay:0s}.spinner-grid div:nth-child(2){animation-delay:.1s}.spinner-grid div:nth-child(3){animation-delay:.2s}.spinner-grid div:nth-child(4){animation-delay:.1s}.spinner-grid div:nth-child(5){animation-delay:.2s}.spinner-grid div:nth-child(6){animation-delay:.3s}.spinner-grid div:nth-child(7){animation-delay:.2s}.spinner-grid div:nth-child(8){animation-delay:.3s}.spinner-grid div:nth-child(9){animation-delay:.4s}@keyframes spinner-grid-scale{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.5);opacity:.5}}.spinner-clock{border:3px solid;border-radius:50%;position:relative}.spinner-clock .clock-hand{position:absolute;top:50%;left:50%;width:2px;height:45%;background-color:currentColor;transform-origin:0 0;animation:spinner-clock-rotate 2s linear infinite}@keyframes spinner-clock-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-hourglass{width:100%;height:100%;position:relative}.hourglass-top,.hourglass-bottom{position:absolute;width:100%;height:50%;background-color:currentColor;clip-path:polygon(50% 0%,0% 100%,100% 100%)}.hourglass-top{top:0;animation:hourglass-top 2s ease-in-out infinite}.hourglass-bottom{bottom:0;transform:rotate(180deg);animation:hourglass-bottom 2s ease-in-out infinite}@keyframes hourglass-top{0%,50%{transform:rotate(0)}25%,75%{transform:rotate(180deg)}to{transform:rotate(360deg)}}@keyframes hourglass-bottom{0%,50%{transform:rotate(180deg)}25%,75%{transform:rotate(360deg)}to{transform:rotate(540deg)}}.spinner-orbit{position:relative}.orbit-circle{position:absolute;border-radius:50%;background-color:currentColor;animation:orbit-spin linear infinite}.orbit-circle-1{width:30%;height:30%;top:0;left:35%;animation-duration:1s}.orbit-circle-2{width:20%;height:20%;top:40%;right:0;animation-duration:1.5s}.orbit-circle-3{width:15%;height:15%;bottom:20%;left:20%;animation-duration:2s}@keyframes orbit-spin{0%{transform:rotate(0) translate(150%) rotate(0)}to{transform:rotate(360deg) translate(150%) rotate(-360deg)}}.spinner-infinity{width:100%;height:100%}.spinner-infinity div{width:100%;height:100%;border:3px solid transparent;border-top-color:currentColor;border-bottom-color:currentColor;border-radius:50%;animation:spinner-infinity-rotate 1.5s ease-in-out infinite}@keyframes spinner-infinity-rotate{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(.7)}to{transform:rotate(360deg) scale(1)}}.spinner-moon{width:100%;height:100%;position:relative}.moon-shape{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 70% 50%,transparent 40%,currentColor 41%);animation:moon-orbit 3s ease-in-out infinite}@keyframes moon-orbit{0%,to{transform:rotate(0)}50%{transform:rotate(180deg)}}.spinner-wave{display:flex;align-items:center;justify-content:center;gap:3px;height:40px}.wave-bar{width:4px;height:100%;background-color:currentColor;animation:wave-stretch 1.2s ease-in-out infinite}.wave-bar:nth-child(1){animation-delay:-1.2s}.wave-bar:nth-child(2){animation-delay:-1.1s}.wave-bar:nth-child(3){animation-delay:-1s}.wave-bar:nth-child(4){animation-delay:-.9s}.wave-bar:nth-child(5){animation-delay:-.8s}@keyframes wave-stretch{0%,40%,to{transform:scaleY(.4)}20%{transform:scaleY(1)}}.spinner-bars{display:flex;align-items:center;justify-content:center;gap:2px;width:100%;height:100%}.spinner-bars .bar{width:20%;height:100%;background-color:currentColor;animation:bars-bounce 1.4s ease-in-out infinite}.spinner-bars .bar:nth-child(1){animation-delay:-.32s}.spinner-bars .bar:nth-child(2){animation-delay:-.16s}.spinner-bars .bar:nth-child(3){animation-delay:0s}.spinner-bars .bar:nth-child(4){animation-delay:.16s}@keyframes bars-bounce{0%,80%,to{transform:scaleY(.4)}40%{transform:scaleY(1)}}@media(prefers-reduced-motion:reduce){.loading-spinner,.loading-spinner *{animation-duration:2s!important;animation-timing-function:step-end!important}}@media(max-width:768px){.spinner-large,.spinner-xlarge{width:50px;height:50px}.loading-spinner-message{font-size:var(--font-size-xs)}}.page-viewer-container{min-height:100vh;background:var(--viewer-bg);padding-bottom:60px}.page-viewer-hero{background:var(--viewer-gradient);color:#fff;padding:clamp(2rem,4vw,3rem) 1.5rem;height:var(--viewer-header-height);max-height:400px;display:flex;align-items:center;position:relative;overflow:hidden}.page-viewer-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.page-viewer-hero-content{max-width:1200px;width:100%;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center}@media(max-width:768px){.page-viewer-hero{height:auto;min-height:300px;padding:1.5rem}.page-viewer-hero-content{grid-template-columns:1fr;gap:1.5rem;text-align:center}}.page-viewer-hero-text{max-width:600px}.page-viewer-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1;margin-bottom:.75rem}.page-viewer-title-gradient{background:linear-gradient(135deg,#fff,#a5f3fc);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-viewer-subtitle{font-size:clamp(.9rem,1.5vw,1.1rem);opacity:.9;line-height:1.5}.page-viewer-hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.page-viewer-stat-item{display:flex;flex-direction:column;align-items:center;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem .75rem;border-radius:10px;border:1px solid rgba(255,255,255,.2);min-width:100px}.page-viewer-stat-number{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.page-viewer-stat-label{font-size:.75rem;opacity:.8}.page-viewer-main{max-width:1200px;margin:-2.5rem auto 1.5rem;padding:0 1.5rem;position:relative;z-index:10}.page-viewer-tabs-container{background:var(--viewer-card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:.75rem 1rem;margin-bottom:1.5rem;box-shadow:var(--viewer-shadow);border:1px solid var(--viewer-border);display:flex;justify-content:space-between;align-items:center;gap:.75rem}.page-viewer-tabs{display:flex;gap:.25rem}.page-viewer-tab{position:relative;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;color:var(--viewer-text-light);transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden}.page-viewer-tab:hover{background:#0f4c750d;color:var(--viewer-accent)}.page-viewer-tab-active{background:var(--viewer-gradient);color:#fff;box-shadow:0 2px 12px #0f4c754d}.page-viewer-tab-icon{font-size:1rem}.page-viewer-tab-indicator{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:3px;height:3px;background:#fff;border-radius:50%}.page-viewer-quick-actions{display:flex;gap:.5rem}.page-viewer-action-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#0f4c751a;border:1px solid var(--viewer-border);border-radius:6px;color:var(--viewer-accent);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease}.page-viewer-action-btn:hover{background:#0f4c7533}.page-viewer-content{background:var(--viewer-card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:var(--viewer-shadow);border:1px solid var(--viewer-border);overflow:hidden}.page-viewer-layout{display:grid;grid-template-columns:1fr;gap:1rem;padding:1.5rem}@media(min-width:1024px){.page-viewer-layout{grid-template-columns:2fr 1fr;gap:1.5rem}}.page-viewer-canvas-section{height:var(--viewer-canvas-height);max-height:600px;border-radius:8px;overflow:hidden;border:1px solid var(--viewer-border);position:relative}.page-viewer-canvas-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#0f4c750d;border-bottom:1px solid var(--viewer-border);position:absolute;top:0;left:0;right:0;z-index:10;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.page-viewer-canvas-header h3{margin:0;font-size:.875rem;font-weight:600;color:var(--viewer-text)}.page-viewer-canvas-info{display:flex;gap:.5rem}.page-viewer-info-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#0f4c751a;border-radius:12px;font-size:.6875rem;color:var(--viewer-accent);border:1px solid var(--viewer-border)}.page-viewer-dot{width:5px;height:5px;border-radius:50%}.page-viewer-dot-online{background:#10b981;box-shadow:0 0 0 1px #10b9814d}.page-viewer-canvas-container{width:100%;height:100%;background:var(--viewer-bg)}.page-viewer-controls-section{height:var(--viewer-canvas-height);max-height:600px;border-radius:8px;overflow:hidden;border:1px solid var(--viewer-border);display:flex;flex-direction:column}.page-viewer-controls-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#0f4c750d;border-bottom:1px solid var(--viewer-border);flex-shrink:0}.page-viewer-controls-header h3{margin:0;font-size:.875rem;font-weight:600;color:var(--viewer-text)}.page-viewer-help-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--viewer-border);background:#0f4c751a;color:var(--viewer-accent);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;transition:all .2s ease}.page-viewer-help-btn:hover{background:#0f4c7533}.page-viewer-gallery-container{padding:1.5rem;min-height:500px}.page-viewer-gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-viewer-gallery-header h3{margin:0;font-size:1.25rem;color:var(--viewer-text)}.page-viewer-gallery-filters{display:flex;gap:.75rem}.page-viewer-filter-select,.page-viewer-search-input{padding:.375rem .75rem;border:1px solid var(--viewer-border);border-radius:6px;background:var(--viewer-card-bg);color:var(--viewer-text);font-size:.875rem;height:32px}.page-viewer-filter-select:focus,.page-viewer-search-input:focus{outline:none;border-color:var(--viewer-accent);box-shadow:0 0 0 2px #0f4c751a}.page-viewer-upload-container{padding:1.5rem;min-height:500px}.page-viewer-upload-header{margin-bottom:1.5rem}.page-viewer-upload-header h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--viewer-text)}.page-viewer-upload-subtitle{font-size:.875rem;color:var(--viewer-text-light);margin:0;line-height:1.4}.page-viewer-canvas-loading,.page-viewer-gallery-loading,.page-viewer-upload-loading{display:flex;align-items:center;justify-content:center;height:100%;min-height:300px}.page-viewer-mobile-nav{position:fixed;bottom:0;left:0;right:0;display:none;background:var(--viewer-card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--viewer-border);padding:.5rem;z-index:1000}@media(max-width:768px){.page-viewer-canvas-section,.page-viewer-controls-section{height:400px;max-height:400px}.page-viewer-mobile-nav{display:flex;justify-content:space-around}.page-viewer-tabs,.page-viewer-quick-actions{display:none}.page-viewer-layout{padding:1rem;grid-template-columns:1fr}.page-viewer-hero-stats{grid-template-columns:repeat(3,1fr);gap:.5rem}.page-viewer-stat-item{padding:.75rem .5rem}.page-viewer-stat-number{font-size:1rem}.page-viewer-gallery-header{flex-direction:column;align-items:flex-start;gap:.75rem}.page-viewer-gallery-filters{width:100%;flex-direction:column}.page-viewer-container{padding-bottom:70px}}.page-viewer-mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:none;border:none;border-radius:6px;color:var(--viewer-text-light);cursor:pointer;transition:all .15s ease;font-size:.75rem}.page-viewer-mobile-nav-btn-active{color:var(--viewer-accent);background:#0f4c751a}.page-viewer-mobile-nav-icon{font-size:1rem}.page-viewer-mobile-nav-label{font-size:.6875rem;font-weight:500}[data-tooltip]{position:relative}[data-tooltip]:hover:before{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--viewer-text);color:#fff;padding:.375rem .5rem;border-radius:4px;font-size:.6875rem;white-space:nowrap;z-index:1000;margin-bottom:.25rem;pointer-events:none}.dark-theme .page-viewer-info-badge,.dark-theme .page-viewer-action-btn{background:#ffffff1a;border-color:#fff3}.dark-theme .page-viewer-filter-select,.dark-theme .page-viewer-search-input{background:#1e293bcc;border-color:#ffffff1a}@keyframes page-viewer-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-viewer-content>*{animation:page-viewer-fadeIn .2s ease-out}.page-viewer-container ::-webkit-scrollbar{width:6px;height:6px}.page-viewer-container ::-webkit-scrollbar-track{background:#0f4c751a;border-radius:3px}.page-viewer-container ::-webkit-scrollbar-thumb{background:var(--viewer-accent);border-radius:3px}.page-viewer-container ::-webkit-scrollbar-thumb:hover{background:var(--viewer-highlight)}@media(prefers-reduced-motion:reduce){.page-viewer-tab,.page-viewer-action-btn,.page-viewer-help-btn,.page-viewer-mobile-nav-btn,.page-viewer-content>*{animation:none;transition:none}}@media(max-width:480px){.page-viewer-canvas-section,.page-viewer-controls-section{height:350px;max-height:350px}.page-viewer-hero{padding:1rem;min-height:250px}.page-viewer-main{margin:-1.5rem auto 1rem;padding:0 1rem}.page-viewer-content{border-radius:8px}}.page-viewer-height-control{max-height:100vh;overflow-y:auto}.common-card{background-color:var(--color-white);border-radius:var(--border-radius);overflow:hidden;transition:all var(--transition-normal)}.common-card-default{border:1px solid var(--color-light)}.common-card-outline{border:1px solid var(--color-accent)}.common-card-elevated{border:none;box-shadow:var(--shadow-md)}.common-card-padding-none{padding:0}.common-card-padding-small{padding:var(--space-md)}.common-card-padding-medium{padding:var(--space-lg)}.common-card-padding-large{padding:var(--space-xl)}.common-card-hoverable{cursor:pointer}.common-card-hoverable:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.common-card-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-light);margin-bottom:var(--space-md)}.common-card-body{flex:1}.common-card-footer{padding-top:var(--space-md);border-top:1px solid var(--color-light);margin-top:var(--space-md)}.page-dashboard{min-height:100vh;background:var(--color-background);color:var(--color-text)}.dashboard-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-xl) 0;margin-bottom:var(--space-lg)}.dashboard-header-content{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-lg)}.dashboard-header-info{flex:1;min-width:300px}.dashboard-header-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text);margin-bottom:var(--space-xs);font-family:var(--font-secondary)}.dashboard-header-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);opacity:.9}.dashboard-header-actions{display:flex;gap:var(--space-md);flex-wrap:wrap}.dashboard-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.dashboard-nav-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--space-md);display:flex;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.dashboard-nav-container::-webkit-scrollbar{display:none}.dashboard-nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:500;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--transition-fast);position:relative}.dashboard-nav-item:hover{color:var(--color-primary);background:var(--color-light)}.dashboard-nav-item-active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:linear-gradient(to bottom,transparent 0%,rgba(15,76,117,.05) 100%)}.dashboard-nav-item-active .dashboard-nav-icon{transform:scale(1.1)}.dashboard-nav-icon{font-size:var(--font-size-lg);transition:transform var(--transition-fast)}.dashboard-nav-label{transition:all var(--transition-fast)}.dashboard-content{max-width:var(--container-width);margin:0 auto;padding:var(--space-xl) var(--space-md)}.dashboard-container{width:100%}.dashboard-overview{display:flex;flex-direction:column;gap:var(--space-2xl)}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-lg)}.dashboard-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg);transition:all var(--transition-normal);cursor:pointer}.dashboard-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.dashboard-stat-content{display:flex;align-items:center;gap:var(--space-lg)}.dashboard-stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--color-light);border-radius:var(--border-radius);color:var(--color-primary)}.dashboard-stat-info{flex:1}.dashboard-stat-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text);line-height:1;margin-bottom:var(--space-xs)}.dashboard-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.dashboard-section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-xl);margin-bottom:var(--space-lg)}.dashboard-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.dashboard-section-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);font-family:var(--font-secondary)}.dashboard-projects-list{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-project-item{display:grid;grid-template-columns:2fr 1fr 2fr 1fr auto;gap:var(--space-lg);align-items:center;padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.dashboard-project-item:last-child{border-bottom:none}.dashboard-project-info{min-width:200px}.dashboard-project-name{font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs);font-size:var(--font-size-base)}.dashboard-project-client{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.dashboard-project-type{font-size:var(--font-size-xs);color:var(--color-accent);background:#00b4d81a;padding:var(--space-xs) var(--space-sm);border-radius:12px;display:inline-block}.dashboard-project-status-badge{padding:var(--space-xs) var(--space-sm);border-radius:12px;font-size:var(--font-size-xs);font-weight:500;color:#fff;text-transform:capitalize;text-align:center;min-width:80px}.dashboard-project-progress{min-width:150px}.dashboard-project-progress-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden;margin-bottom:var(--space-xs)}.dashboard-project-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-highlight));border-radius:3px;transition:width .5s ease}.dashboard-project-progress-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:right}.dashboard-project-due{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:100px}.dashboard-project-actions{display:flex;gap:var(--space-xs)}.dashboard-columns{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl)}@media(max-width:1024px){.dashboard-columns{grid-template-columns:1fr}}.dashboard-models-list{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-model-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--border-radius);background:var(--color-background);transition:all var(--transition-fast)}.dashboard-model-item:hover{border-color:var(--color-primary);transform:translate(4px)}.dashboard-model-icon{width:48px;height:48px;background:var(--color-light);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);color:var(--color-primary)}.dashboard-model-info{flex:1}.dashboard-model-name{font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs);font-size:var(--font-size-base)}.dashboard-model-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dashboard-model-action{background:none;border:none;color:var(--color-gray);cursor:pointer;padding:var(--space-xs);border-radius:4px;transition:all var(--transition-fast)}.dashboard-model-action:hover{color:var(--color-error);background:#dc35451a}.dashboard-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-xl);text-align:center;gap:var(--space-md)}.dashboard-empty-icon{font-size:3rem;opacity:.5}.dashboard-empty-text{color:var(--color-text-secondary);font-size:var(--font-size-lg)}.dashboard-activity-list{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-activity-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);border-radius:var(--border-radius);background:var(--color-background);border:1px solid transparent;transition:all var(--transition-fast)}.dashboard-activity-item:hover{border-color:var(--color-border);background:var(--color-surface)}.dashboard-activity-icon{width:32px;height:32px;background:var(--color-light);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-base);color:var(--color-primary);flex-shrink:0}.dashboard-activity-content{flex:1}.dashboard-activity-action{font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs);font-size:var(--font-size-sm)}.dashboard-activity-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.dashboard-projects-tab,.dashboard-models-tab,.dashboard-analytics-tab,.dashboard-team-tab,.dashboard-billing-tab{display:flex;flex-direction:column;gap:var(--space-xl)}.dashboard-tab-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);font-family:var(--font-secondary)}.dashboard-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.dashboard-project-card{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);transition:all var(--transition-normal);height:100%}.dashboard-project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.dashboard-project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.dashboard-project-card-type{font-size:var(--font-size-xs);color:var(--color-primary);background:#0f4c751a;padding:var(--space-xs) var(--space-sm);border-radius:12px;font-weight:500}.dashboard-project-card-status{font-size:var(--font-size-xs);font-weight:500;text-transform:capitalize}.dashboard-project-card-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);line-height:1.3}.dashboard-project-card-client{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4;flex:1}.dashboard-project-card-progress{margin-top:auto}.dashboard-project-card-progress-info{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.dashboard-project-card-progress-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.dashboard-project-card-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-highlight));border-radius:3px;transition:width .5s ease}.dashboard-project-card-due{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-xs)}.dashboard-project-card-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.dashboard-models-actions{display:flex;gap:var(--space-md);flex-wrap:wrap}.dashboard-models-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.dashboard-models-list-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-xl)}.dashboard-models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-lg)}.dashboard-model-card{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);transition:all var(--transition-normal)}.dashboard-model-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.dashboard-model-card-image{width:100%;height:120px;background:var(--color-light);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--color-primary)}.dashboard-model-card-content{flex:1}.dashboard-model-card-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.dashboard-model-card-meta{display:flex;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.dashboard-model-card-format,.dashboard-model-card-size{padding:2px 6px;background:var(--color-surface);border-radius:4px}.dashboard-model-card-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.dashboard-model-card-tag{font-size:var(--font-size-xs);color:var(--color-accent);background:#00b4d81a;padding:var(--space-xs) var(--space-sm);border-radius:12px;display:inline-block}.dashboard-model-card-actions{display:flex;gap:var(--space-sm);margin-top:auto}.dashboard-analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg)}.dashboard-analytics-card{padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);height:100%}.dashboard-analytics-card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-lg);font-family:var(--font-secondary)}.dashboard-analytics-chart-placeholder{height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);background:var(--color-background);border-radius:var(--border-radius);color:var(--color-text-secondary)}.dashboard-analytics-chart{font-size:3rem;opacity:.5}.dashboard-analytics-storage{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-analytics-storage-info{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dashboard-analytics-storage-bar{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.dashboard-analytics-storage-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-highlight));border-radius:4px;transition:width .5s ease}.dashboard-analytics-activity{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-analytics-activity-item{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.dashboard-analytics-activity-item:last-child{padding-bottom:0;border-bottom:none}.dashboard-analytics-activity-time{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.dashboard-analytics-activity-action{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.dashboard-analytics-team{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-analytics-team-member{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);border-radius:var(--border-radius);transition:all var(--transition-fast)}.dashboard-analytics-team-member:hover{background:var(--color-background)}.dashboard-analytics-team-avatar{width:40px;height:40px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.dashboard-analytics-team-info{flex:1;min-width:0}.dashboard-analytics-team-name{font-weight:600;color:var(--color-text);margin-bottom:2px;font-size:var(--font-size-sm)}.dashboard-analytics-team-role{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.dashboard-analytics-team-progress{width:100px}.dashboard-analytics-team-progress-bar{height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.dashboard-analytics-team-progress-fill{height:100%;background:var(--color-accent);border-radius:2px}.dashboard-team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-lg)}.dashboard-team-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-md);padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);transition:all var(--transition-normal)}.dashboard-team-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.dashboard-team-card-avatar{width:80px;height:80px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-xl)}.dashboard-team-card-content{flex:1}.dashboard-team-card-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.dashboard-team-card-role{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.dashboard-team-card-status{font-size:var(--font-size-xs);color:var(--color-success);background:#28a7451a;padding:var(--space-xs) var(--space-sm);border-radius:12px;display:inline-block}.dashboard-team-card-actions{display:flex;gap:var(--space-sm);width:100%;justify-content:center}.dashboard-team-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-lg);margin-top:var(--space-lg)}.dashboard-team-stat{text-align:center}.dashboard-team-stat-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:var(--space-xs)}.dashboard-team-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.dashboard-billing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg)}.dashboard-billing-card{padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);height:100%}.dashboard-billing-card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-lg);font-family:var(--font-secondary)}.dashboard-billing-plan{text-align:center;padding:var(--space-lg);background:var(--color-background);border-radius:var(--border-radius);margin-bottom:var(--space-lg)}.dashboard-billing-plan-name{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--space-sm)}.dashboard-billing-plan-price{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text);margin-bottom:var(--space-lg)}.dashboard-billing-plan-period{font-size:var(--font-size-lg);color:var(--color-text-secondary)}.dashboard-billing-plan-features{list-style:none;text-align:left;margin:var(--space-lg) 0}.dashboard-billing-plan-features li{padding:var(--space-sm) 0;color:var(--color-text);font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border)}.dashboard-billing-plan-features li:last-child{border-bottom:none}.dashboard-billing-plan-actions{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-billing-history{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-billing-history-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--color-background);border-radius:var(--border-radius);transition:all var(--transition-fast)}.dashboard-billing-history-item:hover{background:var(--color-surface)}.dashboard-billing-history-month{font-weight:600;color:var(--color-text);font-size:var(--font-size-sm)}.dashboard-billing-history-amount{font-weight:600;color:var(--color-primary);font-size:var(--font-size-sm)}.dashboard-billing-history-status{font-size:var(--font-size-xs);color:var(--color-success);background:#28a7451a;padding:var(--space-xs) var(--space-sm);border-radius:12px}.dashboard-billing-history-action{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline;transition:all var(--transition-fast)}.dashboard-billing-history-action:hover{color:var(--color-accent)}.dashboard-billing-payment{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-billing-payment-method{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-background);border-radius:var(--border-radius)}.dashboard-billing-payment-icon{font-size:2rem}.dashboard-billing-payment-info{flex:1}.dashboard-billing-payment-type{font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.dashboard-billing-payment-expiry{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dashboard-billing-payment-actions{display:flex;gap:var(--space-sm)}.dashboard-billing-next{text-align:center;padding:var(--space-xl);background:var(--color-background);border-radius:var(--border-radius)}.dashboard-billing-next-date{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--space-sm)}.dashboard-billing-next-amount{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);margin-bottom:var(--space-md)}.dashboard-billing-next-note{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.dashboard-upload-modal{display:flex;flex-direction:column;gap:var(--space-xl)}.dashboard-upload-dropzone{border:2px dashed var(--color-border);border-radius:var(--border-radius);padding:var(--space-2xl);text-align:center;transition:all var(--transition-normal);cursor:pointer;position:relative}.dashboard-upload-dropzone:hover{border-color:var(--color-primary);background:var(--color-light)}.dashboard-upload-input{position:absolute;width:100%;height:100%;top:0;left:0;opacity:0;cursor:pointer}.dashboard-upload-label{cursor:pointer}.dashboard-upload-icon{font-size:3rem;margin-bottom:var(--space-lg);opacity:.7}.dashboard-upload-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.dashboard-upload-text{color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.dashboard-upload-note{font-size:var(--font-size-sm);color:var(--color-gray);font-style:italic}.dashboard-upload-file{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg)}.dashboard-upload-file-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.dashboard-upload-file-name{font-weight:600;color:var(--color-text);word-break:break-all}.dashboard-upload-file-size{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;margin-left:var(--space-md)}.dashboard-upload-progress-bar{height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.dashboard-upload-progress-fill{height:100%;width:0%;background:var(--color-accent);border-radius:2px;animation:uploadProgress 2s ease-in-out infinite}@keyframes uploadProgress{0%{width:0%}50%{width:70%}to{width:100%}}.dashboard-upload-actions{display:flex;justify-content:flex-end;gap:var(--space-md)}.dashboard-settings-modal,.dashboard-settings-form{display:flex;flex-direction:column;gap:var(--space-xl)}.dashboard-settings-section{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-settings-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);font-family:var(--font-secondary);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.dashboard-settings-storage{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg)}.dashboard-settings-storage-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dashboard-settings-storage-bar{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:var(--space-lg)}.dashboard-settings-storage-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-highlight));border-radius:4px;transition:width .5s ease}.dashboard-settings-actions{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.dashboard-settings-logout{color:var(--color-error)!important;border-color:var(--color-error)!important}.dashboard-settings-logout:hover{background:var(--color-error)!important;color:#fff!important}@media(max-width:1024px){.dashboard-header-content{flex-direction:column;align-items:flex-start;text-align:left}.dashboard-header-actions{width:100%;justify-content:flex-start}.dashboard-project-item{grid-template-columns:1fr;gap:var(--space-md)}.dashboard-project-info{min-width:auto}}@media(max-width:768px){.dashboard-stats-grid,.dashboard-models-stats{grid-template-columns:repeat(2,1fr)}.dashboard-analytics-grid,.dashboard-billing-grid{grid-template-columns:1fr}.dashboard-project-item{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.dashboard-project-actions{width:100%;justify-content:flex-start}.dashboard-settings-actions{flex-direction:column;gap:var(--space-md);align-items:stretch}}@media(max-width:480px){.dashboard-stats-grid,.dashboard-models-stats,.dashboard-projects-grid,.dashboard-models-grid,.dashboard-team-grid{grid-template-columns:1fr}.dashboard-section-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.dashboard-models-actions{flex-direction:column;width:100%}.dashboard-header-actions{flex-direction:column;align-items:stretch}.dashboard-upload-actions{flex-direction:column}}.dark-theme .dashboard-stat-card,.dark-theme .dashboard-section-card,.dark-theme .dashboard-project-card,.dark-theme .dashboard-model-card,.dark-theme .dashboard-analytics-card,.dark-theme .dashboard-team-card,.dark-theme .dashboard-billing-card,.dark-theme .dashboard-settings-storage{background:var(--color-surface);border-color:var(--color-border)}.dark-theme .dashboard-model-item,.dark-theme .dashboard-activity-item,.dark-theme .dashboard-billing-history-item,.dark-theme .dashboard-billing-payment-method,.dark-theme .dashboard-upload-file{background:var(--color-background);border-color:var(--color-border)}.dark-theme .dashboard-billing-plan,.dark-theme .dashboard-billing-next{background:var(--color-surface)}.dark-theme .dashboard-stat-card:hover,.dark-theme .dashboard-project-card:hover,.dark-theme .dashboard-model-card:hover,.dark-theme .dashboard-team-card:hover{box-shadow:0 8px 32px #0000004d}.high-contrast .dashboard-nav-item-active{border-bottom-width:3px}.high-contrast .dashboard-stat-card:hover,.high-contrast .dashboard-project-card:hover,.high-contrast .dashboard-model-card:hover,.high-contrast .dashboard-team-card:hover{outline:2px solid var(--color-border);outline-offset:2px}.high-contrast .dashboard-upload-dropzone:hover{border-width:3px}.dashboard-stat-card,.dashboard-project-card,.dashboard-model-card,.dashboard-team-card{will-change:transform,box-shadow;backface-visibility:hidden}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.dashboard-loading{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.dashboard-models-list,.dashboard-activity-list,.dashboard-analytics-activity,.dashboard-billing-history{max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.dashboard-models-list::-webkit-scrollbar,.dashboard-activity-list::-webkit-scrollbar,.dashboard-analytics-activity::-webkit-scrollbar,.dashboard-billing-history::-webkit-scrollbar{width:6px}.dashboard-models-list::-webkit-scrollbar-track,.dashboard-activity-list::-webkit-scrollbar-track,.dashboard-analytics-activity::-webkit-scrollbar-track,.dashboard-billing-history::-webkit-scrollbar-track{background:transparent}.dashboard-models-list::-webkit-scrollbar-thumb,.dashboard-activity-list::-webkit-scrollbar-thumb,.dashboard-analytics-activity::-webkit-scrollbar-thumb,.dashboard-billing-history::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.dashboard-models-list::-webkit-scrollbar-thumb:hover,.dashboard-activity-list::-webkit-scrollbar-thumb:hover,.dashboard-analytics-activity::-webkit-scrollbar-thumb:hover,.dashboard-billing-history::-webkit-scrollbar-thumb:hover{background:var(--color-gray)}.auth-page-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.auth-card{width:100%;max-width:420px;background:var(--color-bg);border-radius:12px;box-shadow:0 10px 40px #00000026;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.auth-card:hover{transform:translateY(-2px);box-shadow:0 15px 50px #0003}.auth-card-header{padding:32px 32px 16px;text-align:center;border-bottom:1px solid var(--color-border)}.auth-card-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px}.auth-card-logo-icon{font-size:28px;color:var(--color-primary)}.auth-card-logo-text{font-size:24px;font-weight:700;color:var(--color-primary)}.auth-card-title{font-size:24px;font-weight:700;color:var(--color-text);margin:0 0 8px;line-height:1.3}.auth-card-subtitle{font-size:14px;color:var(--color-text-secondary);margin:0;line-height:1.5}.auth-card-body{padding:24px 32px 32px}.auth-card-error{background-color:#dc35451a;border:1px solid rgba(220,53,69,.2);color:var(--color-error);padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:8px;animation:slideIn .3s ease}.auth-card-error:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--color-error);color:#fff;border-radius:50%;font-size:12px;font-weight:700}.auth-card-form{display:flex;flex-direction:column;gap:20px}.auth-form-group{display:flex;flex-direction:column;gap:8px}.auth-form-label{font-size:14px;font-weight:600;color:var(--color-text);display:flex;align-items:center;justify-content:space-between}.auth-form-label-required:after{content:"*";color:var(--color-error);margin-left:4px}.auth-form-input{width:100%;padding:12px 16px;font-size:14px;color:var(--color-text);background-color:var(--color-bg-light);border:1px solid var(--color-border);border-radius:6px;transition:all .2s ease;outline:none}.auth-form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1);background-color:#fff}.auth-form-input:disabled{background-color:var(--color-disabled);cursor:not-allowed;opacity:.7}.auth-form-input-error{border-color:var(--color-error)!important}.auth-form-input-error:focus{box-shadow:0 0 0 3px #dc35451a!important}.auth-form-error{font-size:12px;color:var(--color-error);margin-top:4px;display:flex;align-items:center;gap:4px}.auth-card-options{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.auth-card-remember{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text-secondary);cursor:pointer;transition:color .2s ease}.auth-card-remember:hover{color:var(--color-text)}.auth-card-remember input[type=checkbox]{width:16px;height:16px;border:2px solid var(--color-border);border-radius:4px;cursor:pointer;transition:all .2s ease;appearance:none;position:relative}.auth-card-remember input[type=checkbox]:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.auth-card-remember input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.auth-card-remember input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.auth-card-forgot{background:none;border:none;color:var(--color-primary);font-size:14px;cursor:pointer;padding:0;transition:color var(--transition-speed);text-decoration:none}.auth-card-forgot:hover{color:var(--color-primary-dark);text-decoration:underline}.auth-card-forgot:disabled{opacity:.5;cursor:not-allowed;text-decoration:none}.auth-card-divider{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--color-text-secondary);font-size:14px}.auth-card-divider:before,.auth-card-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.auth-card-divider span{padding:0 16px;background-color:var(--color-bg)}.auth-card-social{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-card-social-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;color:var(--color-text);background-color:#fff;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .2s ease}.auth-card-social-button:hover{background-color:var(--color-bg-light);border-color:var(--color-border-dark)}.auth-card-social-button:disabled{opacity:.5;cursor:not-allowed}.auth-card-social-icon{font-weight:700;font-size:16px}.auth-card-social-google{color:#db4437}.auth-card-social-github{color:#333}.auth-card-footer{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid var(--color-border)}.auth-card-footer-text{color:var(--color-text-secondary);font-size:14px;margin:0;line-height:1.5}.auth-card-footer-link{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:0;transition:color var(--transition-speed);font-size:14px}.auth-card-footer-link:hover{color:var(--color-primary-dark);text-decoration:underline}.auth-card-input{width:80%}.auth-card-password-strength{margin-top:-12px}.auth-card-password-strength-bar{height:4px;background-color:var(--color-light);border-radius:2px;overflow:hidden;margin-bottom:4px}.auth-card-password-strength-fill{height:100%;border-radius:2px;transition:width .3s ease,background-color .3s ease}.auth-card-password-strength-info{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--color-text-secondary)}.auth-card-checkboxes{display:flex;flex-direction:column;gap:12px;margin-top:8px}.auth-card-checkbox{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--color-text-secondary);cursor:pointer;line-height:1.4;transition:color .2s ease}.auth-card-checkbox:hover{color:var(--color-text)}.auth-card-checkbox input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;border:2px solid var(--color-border);border-radius:4px;cursor:pointer;transition:all .2s ease;appearance:none;position:relative}.auth-card-checkbox input[type=checkbox]:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.auth-card-checkbox input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.auth-card-checkbox input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.auth-card-checkbox.error{color:var(--color-error)}.auth-card-checkbox.error input[type=checkbox]{border-color:var(--color-error)}.auth-card-checkbox-error{display:block;font-size:12px;color:var(--color-error);margin-top:2px}.auth-card-checkbox a{color:var(--color-primary);text-decoration:none;font-weight:500}.auth-card-checkbox a:hover{text-decoration:underline}.auth-card-submit-button{margin-top:8px}.auth-card-submit-button button{width:100%;padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background-color:var(--color-primary);border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.auth-card-submit-button button:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.auth-card-submit-button button:active:not(:disabled){transform:translateY(0)}.auth-card-submit-button button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.auth-card-submit-button-loading{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.auth-card-submit-button-loading:after{content:"";width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.auth-card-success{background-color:#1987541a;border:1px solid rgba(25,135,84,.2);color:var(--color-success);padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:8px;animation:slideIn .3s ease}.auth-card-success:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--color-success);color:#fff;border-radius:50%;font-size:12px;font-weight:700}.auth-page-toggle{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px}.auth-page-toggle button{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:4px 8px;font-size:14px;transition:color .2s ease}.auth-page-toggle button:hover{color:var(--color-primary-dark);text-decoration:underline}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:480px){.auth-page-container{padding:16px}.auth-card{max-width:100%;border-radius:8px}.auth-card-header{padding:24px 24px 16px}.auth-card-body{padding:20px 24px 24px}.auth-card-name-fields,.auth-card-social{grid-template-columns:1fr}.auth-card-options{flex-direction:column;align-items:flex-start;gap:12px}.auth-card-remember{width:100%}}@media(prefers-color-scheme:dark){.auth-card{background-color:var(--color-bg-dark);border:1px solid var(--color-border-dark)}.auth-form-input{background-color:var(--color-bg-dark-light);border-color:var(--color-border-dark);color:var(--color-text-dark)}.auth-form-input:focus{background-color:var(--color-bg-dark-light);border-color:var(--color-primary)}.auth-card-social-button{background-color:var(--color-bg-dark);border-color:var(--color-border-dark);color:var(--color-text-dark)}.auth-card-social-button:hover{background-color:var(--color-bg-dark-light)}}
