*{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%;-webkit-tap-highlight-color:transparent}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}:root{--color-primary: #000000;--color-secondary: #333333;--color-accent: #bfd7ea;--color-accent-hover: #a8c7dc;--color-error: #c81d25;--color-danger: #a01620;--color-success: #10b981;--color-warning: #f59e0b;--color-info: #bfd7ea;--color-background: #000000;--color-background-secondary: rgba(255, 255, 255, .05);--color-background-tertiary: rgba(255, 255, 255, .1);--color-text-primary: #ffffff;--color-text-secondary: #e2e8f0;--color-text-muted: #94a3b8;--color-text-inverse: #000000;--color-border: #333333;--color-border-light: #404040;--color-border-focus: #bfd7ea;--font-headline: "Source Serif 4", Georgia, serif;--font-sans: "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-accent: "Yellowtail", cursive;--font-mono: "Courier New", monospace;--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: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.6;--line-height-relaxed: 1.8;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--letter-spacing-wider: .1em;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--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);--border-radius: 3px;--border-radius-sm: 3px;--border-radius-md: 3px;--border-radius-lg: 3px;--border-radius-xl: 3px;--border-radius-full: 9999px;--radius-sm: var(--border-radius-sm);--radius-md: var(--border-radius-md);--radius-lg: var(--border-radius-lg);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6);--max-width-sm: 640px;--max-width-md: 768px;--max-width-lg: 1024px;--max-width-xl: 1280px;--max-width-2xl: 1536px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--thumbnail-sm: 30px;--thumbnail-md: 40px;--thumbnail-lg: 60px}body.light-mode{--color-primary: #1a1a1a;--color-secondary: #666666;--color-accent: #c81d25;--color-accent-hover: #a01620;--color-background: #f5f1e8;--color-background-secondary: rgba(0, 0, 0, .05);--color-background-tertiary: rgba(0, 0, 0, .1);--color-text-primary: #1a1a1a;--color-text-secondary: #333333;--color-text-muted: #666666;--color-text-inverse: #ffffff;--color-border: #d4cfc4;--color-border-light: #e5e1d8;--color-border-focus: #c81d25;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .2)}body{margin:0;font-family:var(--font-sans);font-size:16px;line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-family:var(--font-headline);line-height:var(--line-height-tight);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}h1{font-size:var(--font-size-5xl);font-weight:var(--font-weight-semibold)}h2{font-size:var(--font-size-4xl);font-weight:var(--font-weight-semibold)}h3{font-size:var(--font-size-3xl);font-weight:var(--font-weight-normal)}h4{font-size:var(--font-size-2xl);font-weight:var(--font-weight-normal)}h5{font-size:var(--font-size-xl);font-weight:var(--font-weight-normal)}h6{font-size:var(--font-size-lg);font-weight:var(--font-weight-normal)}p{margin:0;font-family:var(--font-sans);line-height:var(--line-height-normal)}small{font-size:var(--font-size-sm)}code{font-family:var(--font-mono);font-size:var(--font-size-sm);background-color:var(--color-background-secondary);padding:.125rem .25rem;border-radius:var(--border-radius-sm)}pre{font-family:var(--font-mono);font-size:var(--font-size-sm);background-color:var(--color-background-secondary);padding:var(--space-md);border-radius:var(--border-radius);overflow-x:auto}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none;margin:0;padding:0}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-accent-hover);text-decoration:underline}a:focus{outline:2px solid var(--color-border-focus);outline-offset:2px}button,input[type=button],input[type=submit],input[type=reset]{display:inline-flex;align-items:center;justify-content:center;min-height:44px;min-width:44px;padding:.75rem 2rem;font-family:var(--font-sans);font-size:16px;font-weight:var(--font-weight-semibold);line-height:1;color:#fff;background-color:var(--color-error);border:none;border-radius:var(--border-radius);cursor:pointer;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}button:hover:not(:disabled),input[type=button]:hover:not(:disabled),input[type=submit]:hover:not(:disabled),input[type=reset]:hover:not(:disabled){background-color:var(--color-danger);transform:translateY(-1px)}button:active:not(:disabled),input[type=button]:active:not(:disabled),input[type=submit]:active:not(:disabled),input[type=reset]:active:not(:disabled){transform:translateY(0)}button:disabled,input[type=button]:disabled,input[type=submit]:disabled,input[type=reset]:disabled{opacity:.5;cursor:not-allowed}button.secondary,input[type=button].secondary,input[type=submit].secondary,input[type=reset].secondary{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text-primary)}button.secondary:hover:not(:disabled),input[type=button].secondary:hover:not(:disabled),input[type=submit].secondary:hover:not(:disabled),input[type=reset].secondary:hover:not(:disabled){background-color:var(--color-background-secondary);border-color:var(--color-border-light);transform:translateY(-1px)}input,select,textarea{width:100%;min-height:44px;padding:.75rem;font-family:var(--font-sans);font-size:16px;line-height:1.5;color:var(--color-text-primary);background-color:#0000004d;border:1px solid var(--color-border);border-radius:var(--border-radius);transition:border-color var(--transition-base),box-shadow var(--transition-base);-webkit-appearance:none;appearance:none}body.light-mode input,body.light-mode select,body.light-mode textarea{background-color:#fffc}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode input:focus,body.light-mode select:focus,body.light-mode textarea:focus{box-shadow:0 0 0 3px #c81d251a}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem}body.light-mode select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}textarea{min-height:100px;resize:vertical}label{display:block;margin-bottom:var(--space-sm);font-size:16px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.container{width:100%;max-width:var(--max-width-xl);margin:0 auto;padding:0 var(--space-md)}.error-message{background-color:#c81d2533;color:var(--color-error);padding:var(--space-md);border-radius:var(--border-radius);border:1px solid var(--color-error);border-left:4px solid var(--color-error);font-size:var(--font-size-base);margin:var(--space-md) 0;line-height:var(--line-height-normal)}.success-message{background-color:#bfd7ea33;color:var(--color-text-primary);padding:var(--space-md);border-radius:var(--border-radius);border:1px solid var(--color-accent);border-left:4px solid var(--color-accent);font-size:var(--font-size-base);margin:var(--space-md) 0;line-height:var(--line-height-normal)}.info-message{background-color:#bfd7ea33;color:var(--color-text-primary);padding:var(--space-md);border-radius:var(--border-radius);border:1px solid var(--color-info);border-left:4px solid var(--color-info);font-size:var(--font-size-base);margin:var(--space-md) 0;line-height:var(--line-height-normal)}.warning-message{background-color:#f59e0b33;color:var(--color-warning);padding:var(--space-md);border-radius:var(--border-radius);border:1px solid var(--color-warning);border-left:4px solid var(--color-warning);font-size:var(--font-size-base);margin:var(--space-md) 0;line-height:var(--line-height-normal)}body.light-mode .warning-message{color:#92400e}.field-error{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--space-xs);display:block}.loading{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-accent);animation:spin .6s linear infinite}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--color-border);border-radius:50%;border-top-color:var(--color-accent);animation:spin .8s linear infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);gap:var(--space-md);min-height:200px}.loading-text{color:var(--color-text-muted);font-size:var(--font-size-base)}.empty-state{text-align:center;padding:var(--space-xl);color:var(--color-text-muted);background-color:var(--color-background-secondary);border-radius:var(--border-radius);font-size:var(--font-size-base);line-height:var(--line-height-normal)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-sm)}.empty-state-description{font-size:var(--font-size-base);color:var(--color-text-muted)}.card{background-color:transparent;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-lg);border:1px solid var(--color-border);transition:box-shadow var(--transition-base),transform var(--transition-slow)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{margin-bottom:var(--space-md)}.card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card-body{color:var(--color-text-primary)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.form-group:last-child{margin-bottom:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@media(min-width:768px){:root{--font-size-base: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.25rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3.5rem}.container{padding:0 var(--space-lg)}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}}@media(min-width:1024px){.container{padding:0 var(--space-xl)}}.error-boundary{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:var(--space-lg);background-color:var(--color-background)}.error-boundary-content{text-align:center;max-width:500px;padding:var(--space-2xl);background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.error-boundary-content h1{color:var(--color-error);margin-bottom:var(--space-md);font-size:var(--font-size-2xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.error-boundary-content p{color:var(--color-text-secondary);margin-bottom:var(--space-xl);font-size:var(--font-size-base);line-height:var(--line-height-normal)}.error-reset-button{background-color:var(--color-error);color:#fff;border:none;padding:.75rem 2rem;font-size:16px;font-family:var(--font-sans);font-weight:var(--font-weight-semibold);border-radius:var(--border-radius);cursor:pointer;min-height:44px;min-width:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast)}.error-reset-button:hover{background-color:var(--color-danger);transform:translateY(-1px)}.error-reset-button:active{background-color:var(--color-danger);transform:translateY(0)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;background-color:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius-full);color:var(--color-text-primary);cursor:pointer;width:44px;height:44px;transition:border-color var(--transition-base)}.theme-toggle:hover{border-color:var(--color-text-muted)}.theme-toggle:focus{outline:none;border-color:var(--color-text-secondary)}.theme-icon{width:20px;height:20px;display:block}body:not(.light-mode) .theme-toggle{color:#fff}body.light-mode .theme-toggle{color:#1a1a1a}body.light-mode .theme-toggle:hover{color:#fff;background-color:var(--color-error);border-color:var(--color-error)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-secondary);padding:var(--spacing-md);position:relative}.login-container{width:100%;max-width:400px}.login-card{background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.login-logo{display:flex;justify-content:center;margin-bottom:var(--spacing-sm)}.login-logo img{max-width:200px;height:auto;width:100%}.login-title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-sm);color:var(--color-text)}.login-subtitle{font-size:var(--font-size-base);text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-size:var(--font-size-base);font-weight:500;color:var(--color-text)}.form-group input{width:100%;min-height:44px;padding:.75rem;font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-group input:disabled{background-color:var(--color-bg-secondary);cursor:not-allowed;opacity:.6}.login-button{width:100%;min-height:44px;padding:.75rem 1.5rem;font-size:var(--font-size-base);font-weight:600;color:#fff;background-color:var(--color-error);border:none;border-radius:var(--border-radius);cursor:pointer;transition:background-color .2s,transform .1s;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.login-button:hover:not(:disabled){background-color:var(--color-danger)}.login-button:active:not(:disabled){transform:scale(.98)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:var(--spacing-lg);text-align:center}.reset-link{font-size:var(--font-size-base);color:var(--color-accent);text-decoration:none;display:inline-block;min-height:44px;display:flex;align-items:center;justify-content:center;padding:var(--space-sm);-webkit-tap-highlight-color:transparent}.reset-link:hover{color:var(--color-accent-hover);text-decoration:underline}body.light-mode .reset-link{color:var(--color-error)}body.light-mode .reset-link:hover{color:var(--color-danger)}@media(min-width:768px){.login-card{padding:2.5rem}.login-title{font-size:2rem}}.reset-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-secondary);padding:var(--spacing-md);position:relative}.theme-toggle-wrapper{position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:10}.reset-container{width:100%;max-width:400px}.reset-card{background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.reset-title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-sm);color:var(--color-text)}.reset-subtitle{font-size:var(--font-size-base);text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.reset-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.reset-button{width:100%;min-height:44px;padding:.75rem 1.5rem;font-size:var(--font-size-base);font-weight:600;color:#fff;background-color:var(--color-error);border:none;border-radius:var(--border-radius);cursor:pointer;transition:background-color .2s,transform .1s;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.reset-button:hover:not(:disabled){background-color:var(--color-danger)}.reset-button:active:not(:disabled){transform:scale(.98)}.reset-button:disabled{opacity:.6;cursor:not-allowed}.success-message p{margin-bottom:var(--space-md);line-height:1.6}.success-note{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.reset-footer{margin-top:var(--spacing-lg);text-align:center}@media(min-width:768px){.reset-card{padding:2.5rem}.reset-title{font-size:2rem}}.input-error{border-color:var(--color-error, #dc2626)!important}.input-error:focus{box-shadow:0 0 0 3px #dc26261a!important}.field-error{font-size:var(--font-size-sm);color:var(--color-error, #dc2626);margin-top:-.25rem}.reset-confirm-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-background-secondary);padding:var(--space-md);position:relative}.theme-toggle-wrapper{position:absolute;top:var(--space-md);right:var(--space-md);z-index:10}.reset-confirm-container{width:100%;max-width:400px}.reset-confirm-card{background-color:var(--color-background);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:var(--space-xl);border:1px solid var(--color-border)}.reset-confirm-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);text-align:center;margin-bottom:var(--space-sm);color:var(--color-text-primary);font-family:var(--font-headline)}.reset-confirm-subtitle{font-size:var(--font-size-base);text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-xl);line-height:var(--line-height-normal)}.reset-confirm-form{display:flex;flex-direction:column;gap:var(--space-lg)}.reset-confirm-button{width:100%;min-height:44px;padding:.75rem 1.5rem;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:#fff;background-color:var(--color-error);border:none;border-radius:var(--border-radius);cursor:pointer;transition:background-color var(--transition-base),transform var(--transition-fast);display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.reset-confirm-button:hover:not(:disabled){background-color:var(--color-danger);transform:translateY(-1px)}.reset-confirm-button:active:not(:disabled){transform:translateY(0)}.reset-confirm-button:disabled{opacity:.5;cursor:not-allowed}.success-message{background-color:#bfd7ea33;border:1px solid var(--color-accent);border-left:4px solid var(--color-accent);border-radius:var(--border-radius);padding:var(--space-lg);color:var(--color-text-primary);text-align:center}body.light-mode .success-message{background-color:#10b9811a;color:#065f46;border-color:var(--color-success)}.success-message p{margin-bottom:var(--space-md);line-height:var(--line-height-normal);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.success-message p:last-child{margin-bottom:0}.success-note{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-normal)}body.light-mode .success-note{color:#15803d}.reset-confirm-footer{margin-top:var(--space-lg);text-align:center}.back-link{font-size:var(--font-size-base);color:var(--color-accent);text-decoration:none;display:inline-block;min-height:44px;display:flex;align-items:center;justify-content:center;padding:var(--space-sm);-webkit-tap-highlight-color:transparent}.back-link:hover{color:var(--color-accent-hover);text-decoration:underline}body.light-mode .back-link{color:var(--color-error)}body.light-mode .back-link:hover{color:var(--color-danger)}@media(min-width:768px){.reset-confirm-card{padding:2.5rem}.reset-confirm-title{font-size:2rem}}.input-error{border-color:var(--color-error)!important}.input-error:focus{box-shadow:0 0 0 3px #c81d2533!important}.field-error{font-size:var(--font-size-sm);color:var(--color-error);margin-top:var(--space-xs)}.location-list{margin-top:var(--space-sm)}.location-list.empty{padding:var(--space-md) 0}.locations{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-md)}.location-item{display:flex;align-items:center;padding:var(--space-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius);border-left:4px solid var(--color-accent);min-height:44px;transition:background-color var(--transition-base),transform var(--transition-fast)}.location-item:hover{background-color:var(--color-background-tertiary);transform:translate(2px)}.location-number{font-weight:var(--font-weight-bold);color:var(--color-text-secondary);margin-right:var(--space-md);font-size:var(--font-size-lg)}.location-name{font-size:var(--font-size-base);color:var(--color-text-primary);flex:1}@media(min-width:768px){.locations{gap:var(--space-md)}.location-item{padding:var(--space-md) var(--space-lg)}.location-name{font-size:var(--font-size-lg)}}@media(min-width:1024px){.locations{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md)}}.activity-table-container{width:100%;border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:transparent}.activity-table{width:100%;border-collapse:collapse;font-family:var(--font-sans);font-size:var(--font-size-sm);table-layout:auto}.activity-table thead{background-color:var(--color-background-secondary);border-bottom:2px solid var(--color-border)}.activity-table th{padding:var(--space-md) var(--space-sm);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.activity-table th:nth-child(1){padding-left:var(--space-md);padding-right:var(--space-sm)}.activity-table th:nth-child(2){padding-left:var(--space-lg)}.activity-table th:nth-child(3),.activity-table th:nth-child(4){text-align:center}.activity-table th:nth-child(4){padding-right:var(--space-md)}.activity-table tbody .activity-row{border-bottom:1px solid var(--color-border);transition:background-color var(--transition-base)}.activity-table tbody .activity-row:hover{background-color:var(--color-background-secondary)}.activity-table td{padding:var(--space-md) var(--space-sm);color:var(--color-text-primary);vertical-align:middle;height:60px}.activity-type-cell{width:1%;white-space:nowrap;text-align:left;padding-left:var(--space-md)!important;padding-right:var(--space-sm)!important}.activity-type-icon{display:inline-flex;align-items:center;justify-content:flex-start;color:var(--color-accent)}.activity-title-cell{width:auto;max-width:0;padding-left:var(--space-lg)!important}.title-content{display:flex;flex-direction:column;gap:var(--space-xs);justify-content:center;min-width:0;max-width:100%}.title-row{display:flex;align-items:baseline;gap:var(--space-sm);overflow:hidden;min-width:0;max-width:100%}.title-row-with-thumbnail{display:flex;align-items:center;gap:var(--space-sm);overflow:hidden;min-width:0;max-width:100%}.table-thumbnail{width:var(--thumbnail-md);height:var(--thumbnail-md);min-width:var(--thumbnail-md);border-radius:var(--border-radius);overflow:hidden;background-color:var(--color-background-tertiary)}.table-thumbnail img{width:100%;height:100%;object-fit:cover}.title-text{font-weight:var(--font-weight-semibold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;max-width:100%}.description-text{color:var(--color-text-secondary);font-size:var(--font-size-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0}.activity-link{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--color-accent);font-size:var(--font-size-xs);text-decoration:none;transition:color var(--transition-base)}.activity-link:hover{color:var(--color-accent-hover)}.link-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-date-cell{width:120px;white-space:nowrap;color:var(--color-text-secondary);font-size:var(--font-size-xs);text-align:center}.activity-readers-cell{width:100px;text-align:center;padding-right:var(--space-md)!important}.reader-count{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);color:var(--color-text-secondary);font-size:var(--font-size-xs)}.reader-number{white-space:nowrap}.reader-count-display{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);cursor:default;padding:4px;border-radius:var(--border-radius);transition:background-color var(--transition-fast)}.reader-count-display.editable{cursor:pointer}.reader-count-display.editable:hover{background-color:var(--color-background-tertiary)}.edit-icon{opacity:0;color:var(--color-text-muted);transition:opacity var(--transition-fast)}.reader-count-display.editable:hover .edit-icon{opacity:1}.reader-count-input{width:80px;padding:4px 8px;border:1px solid var(--color-accent);border-radius:var(--border-radius);font-size:var(--font-size-xs);font-family:var(--font-sans);text-align:center;background-color:var(--color-background-primary);color:var(--color-text-primary)}.reader-count-input:focus{outline:none;box-shadow:0 0 0 2px #3b82f633}.reader-count-placeholder{color:var(--color-text-muted);font-size:var(--font-size-xs)}@media(max-width:768px){.activity-table th,.activity-table td{padding:var(--space-sm) var(--space-xs)}.activity-table td{height:70px}.activity-table th{font-size:.6rem}.activity-table th:nth-child(1){padding-left:var(--space-sm)!important;padding-right:var(--space-xs)!important}.activity-table th:nth-child(2){padding-left:var(--space-sm)!important}.activity-type-cell{width:40px;padding-left:var(--space-sm)!important;padding-right:var(--space-xs)!important}.activity-title-cell{padding-left:var(--space-sm)!important}.activity-date-cell{width:80px;font-size:.65rem}.activity-readers-cell{width:70px;padding-right:var(--space-sm)!important}.reader-count{flex-direction:column;gap:2px;align-items:center}.reader-number{font-size:.65rem}.title-text{font-size:var(--font-size-xs)}.description-text{display:none}.link-text{font-size:.6rem}.table-thumbnail{width:var(--thumbnail-sm);height:var(--thumbnail-sm);min-width:var(--thumbnail-sm)}.reader-count-input{width:60px;font-size:.7rem}}.activity-filters{background-color:var(--color-background-secondary);padding:var(--space-md);border-radius:var(--border-radius-lg);margin-bottom:var(--space-md);border:1px solid var(--color-border)}.filter-group{display:flex;flex-direction:column;margin-bottom:var(--space-md)}.filter-group:last-child{margin-bottom:0}.filter-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-sm)}.filter-select,.filter-input{width:100%;padding:.75rem;font-size:16px;font-family:var(--font-sans);border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:#0000004d;color:var(--color-text-primary);min-height:44px;cursor:pointer;transition:border-color var(--transition-base),box-shadow var(--transition-base)}body.light-mode .filter-select,body.light-mode .filter-input{background-color:#fffc}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .filter-select:focus,body.light-mode .filter-input:focus{box-shadow:0 0 0 3px #c81d251a}.filter-select:hover,.filter-input:hover{border-color:var(--color-border-light)}.custom-date-range{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.clear-filters-button{width:100%;background-color:var(--color-error);color:#fff;border:none;padding:.75rem 1rem;border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;min-width:44px;margin-top:var(--space-md);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast);-webkit-tap-highlight-color:transparent}.clear-filters-button:hover{background-color:var(--color-danger);transform:translateY(-1px)}.clear-filters-button:active{background-color:var(--color-danger);transform:translateY(0)}@media(min-width:768px){.activity-filters{padding:var(--space-lg);display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:flex-end}.filter-group{flex:1;min-width:200px;margin-bottom:0}.custom-date-range{flex-basis:100%;display:flex;flex-direction:row;gap:var(--space-md);margin-top:0;padding-top:0;border-top:none}.custom-date-range .filter-group{flex:1}.clear-filters-button{width:auto;min-width:150px;margin-top:0}}@media(min-width:1024px){.activity-filters{padding:var(--space-lg) var(--space-xl)}.filter-group{min-width:220px}}.angler-reach-chart{background-color:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-slow)}.angler-reach-chart:hover{box-shadow:var(--shadow-md)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.header-left{display:flex;flex-direction:column;gap:var(--space-xs)}.chart-header h3{font-size:var(--font-size-xl);margin:0;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-family:var(--font-headline)}.activity-count{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.total-anglers{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-error);font-family:var(--font-headline)}.chart-container{width:100%;padding:var(--space-md) 0;position:relative;overflow:visible}.chart-bars{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-sm);height:200px;padding:0 var(--space-sm);position:relative;overflow:visible}.bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);height:100%;position:relative;z-index:1}.bar-wrapper:hover{z-index:2}.bar-label-container{position:relative;display:flex;flex-direction:column;align-items:center;min-height:30px}.bar-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center}.website-indicator{position:absolute;top:16px;left:50%;transform:translate(-50%);color:var(--color-accent);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-in}body.light-mode .website-indicator{color:#3b82f6}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-3px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.bar-container{width:100%;flex:1;display:flex;align-items:flex-end;justify-content:center}.bar-stacked{width:100%;max-width:60px;border-radius:var(--border-radius) var(--border-radius) 0 0;transition:opacity var(--transition-base);position:relative;display:flex;flex-direction:column;overflow:visible;cursor:pointer;z-index:10}.bar-total{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);white-space:nowrap}.bar-segment{width:100%;transition:opacity var(--transition-base)}.bar-segment.newsletter{background:#1e3a5f}.bar-segment.facebook{background:#2c5f77}.bar-segment.instagram{background:#6b9ab8}.chart-legend{display:flex;justify-content:center;gap:var(--space-lg);margin-top:var(--space-md);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.chart-note{text-align:center;margin-top:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic}.legend-color{width:16px;height:16px;border-radius:var(--border-radius-sm)}.legend-color.newsletter{background:#1e3a5f}.legend-color.facebook{background:#2c5f77}.legend-color.instagram,.legend-color.website{background:#6b9ab8}.bar-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:999999;padding:var(--space-md)}body.light-mode .modal-overlay{background-color:#00000080}.modal-content{background-color:#000;border:2px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--space-xl);max-width:600px;width:100%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #000000e6}body.light-mode .modal-content{background-color:#f5f1e8}.modal-close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;color:var(--color-text-primary);font-size:2rem;line-height:1;cursor:pointer;padding:0;min-width:auto;min-height:auto;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-base)}.modal-close:hover{color:var(--color-error);transform:none}.modal-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-lg) 0;padding-right:var(--space-xl)}.modal-body{display:flex;flex-direction:column;gap:var(--space-lg)}.modal-section{border-bottom:1px solid var(--color-border);padding-bottom:var(--space-md)}.modal-section:last-of-type{border-bottom:none}.modal-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin:0 0 var(--space-md) 0}.modal-activity-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid rgba(255,255,255,.05)}body.light-mode .modal-activity-item{border-bottom:1px solid rgba(0,0,0,.05)}.modal-activity-item:last-child{border-bottom:none}.modal-activity-content{flex:1;display:flex;flex-direction:column;gap:var(--space-xs);min-width:0}.modal-thumbnail{width:var(--thumbnail-lg);height:var(--thumbnail-lg);min-width:var(--thumbnail-lg);border-radius:var(--border-radius);overflow:hidden;background-color:var(--color-background-tertiary)}.modal-thumbnail img{width:100%;height:100%;object-fit:cover}.modal-activity-title{color:var(--color-text-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:var(--font-weight-semibold)}.modal-activity-url{color:var(--color-accent);font-size:var(--font-size-sm);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color var(--transition-base)}.modal-activity-url:hover{color:var(--color-accent-hover);text-decoration:underline}body.light-mode .modal-activity-url{color:var(--color-error)}body.light-mode .modal-activity-url:hover{color:var(--color-danger)}.modal-activity-count{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap}.modal-total{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-total-value{color:var(--color-error);font-size:var(--font-size-xl)}@media(max-width:767px){.angler-reach-chart{border:none;border-radius:0;box-shadow:none;position:relative}.angler-reach-chart:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.angler-reach-chart:hover{box-shadow:none;transform:none}.chart-bars{gap:var(--space-xs);padding:0}.bar-stacked{max-width:50px}.bar-label{font-size:var(--font-size-xs)}.bar-total{font-size:10px}}@media(min-width:768px){.angler-reach-chart{padding:var(--space-xl)}.chart-header h3{font-size:var(--font-size-2xl)}.total-anglers{font-size:2rem}.chart-bars{height:250px;gap:var(--space-md)}.bar{max-width:80px}.bar-value{font-size:var(--font-size-sm)}}@media(min-width:1024px){.chart-bars{height:300px}}.website-features-section{background-color:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-slow),transform var(--transition-slow)}.website-features-section:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.website-features-section h2{margin:0;color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.total-features{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-error);font-family:var(--font-headline)}.website-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-lg)}.website-card{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);overflow:hidden;cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base)}.website-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000004d}.website-card:focus{outline:2px solid var(--color-border-focus);outline-offset:2px}body.light-mode .website-card:hover{box-shadow:0 8px 16px #00000026}.website-card-image{width:100%;height:200px;overflow:hidden;background-color:var(--color-background-tertiary);display:flex;align-items:center;justify-content:center}.website-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.website-card:hover .website-card-image img{transform:scale(1.05)}.website-card-placeholder{color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center}.website-card-content{padding:var(--space-md)}.website-card-title{margin:0 0 var(--space-sm) 0;color:var(--color-text-primary);font-size:var(--font-size-lg);font-family:var(--font-headline);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.website-card-date{margin:0 0 var(--space-sm) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.website-card-link{display:flex;align-items:center;gap:var(--space-xs);color:var(--color-border-focus);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}body.light-mode .website-card-link{color:var(--color-error)}.load-more-button{display:block;margin:0 auto;background-color:var(--color-background-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.75rem 2rem;border-radius:var(--border-radius);font-size:var(--font-size-base);font-family:var(--font-sans);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base)}.load-more-button:hover{background-color:var(--color-background-tertiary);border-color:var(--color-border-focus)}body.light-mode .load-more-button:hover{border-color:var(--color-error)}@media(max-width:1024px)and (min-width:768px){.website-cards-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.website-features-section h2{font-size:var(--font-size-2xl)}.total-features{font-size:2rem}}@media(max-width:767px){.website-features-section{border:none;border-radius:0;box-shadow:none;position:relative}.website-features-section:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.website-features-section:hover{box-shadow:none;transform:none}.website-cards-grid{grid-template-columns:1fr;gap:var(--space-md)}.website-card{display:flex;flex-direction:row}.website-card-image{width:120px;min-width:120px;height:120px;flex-shrink:0}.website-card-content{flex:1;display:flex;flex-direction:column;justify-content:center}.website-card-title{font-size:var(--font-size-base);-webkit-line-clamp:3;line-clamp:3}.website-features-section h2{font-size:var(--font-size-xl)}.load-more-button{width:100%}}.metrics-dashboard{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}@media(max-width:1200px){.metrics-dashboard{grid-template-columns:repeat(2,1fr)}}.metric-card{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md);transition:transform var(--transition-base),box-shadow var(--transition-base);box-shadow:var(--shadow-sm)}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-icon{width:48px;height:48px;min-width:48px;background-color:var(--color-background-tertiary);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;color:var(--color-accent)}body.light-mode .metric-icon{background-color:#bfd7ea33;color:#3b82f6}.metric-content{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.metric-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-family:var(--font-headline);line-height:1}.metric-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}@media(max-width:1024px)and (min-width:768px){.metric-value{font-size:var(--font-size-2xl)}.metric-icon{width:40px;height:40px;min-width:40px}.metric-icon svg{width:20px;height:20px}}@media(max-width:767px){.metrics-dashboard{gap:var(--space-xs);margin-bottom:var(--space-lg)}.metric-card{padding:var(--space-sm);flex-direction:column;text-align:center;gap:var(--space-xs)}.metric-icon{width:32px;height:32px;min-width:32px}.metric-icon svg{width:18px;height:18px}.metric-value{font-size:var(--font-size-lg)}.metric-label{font-size:10px;line-height:1.2}}.guide-dashboard{min-height:100vh;background-color:var(--color-background)}.dashboard-header{background-color:var(--color-background-secondary);color:var(--color-text-primary);padding:var(--space-md);display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}@media(min-width:768px){.dashboard-header{border-radius:var(--border-radius)}}.user-profile{display:flex;align-items:center;gap:var(--space-md)}.user-info{display:flex;flex-direction:column;gap:var(--space-xs)}.nav-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.nav-locations{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}@media(max-width:767px){.user-info h1{font-size:var(--font-size-lg)}}.location-icon{font-size:var(--font-size-base);color:var(--color-text-muted)}.header-location{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);background-color:var(--color-background-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);color:var(--color-text-primary);white-space:nowrap}.user-avatar{width:48px;height:48px;border-radius:50%;border:2px solid #ffffff;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-background-secondary);flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);font-family:var(--font-headline)}.dashboard-header h1{font-size:var(--font-size-xl);margin:0;font-weight:var(--font-weight-semibold);font-family:var(--font-headline)}.logout-button{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border);padding:.625rem 1rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;min-width:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:border-color var(--transition-base),color var(--transition-base)}.logout-button:hover{border-color:var(--color-error);background-color:var(--color-error);color:#fff}.logout-button:active{border-color:var(--color-text-secondary)}.dashboard-content{max-width:1200px;margin:0 auto;padding:var(--space-md) 0}@media(min-width:768px){.dashboard-content{padding:var(--space-lg) 0}}.locations-section,.activities-section{background-color:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-slow),transform var(--transition-slow)}.locations-section:hover,.activities-section:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.locations-section h2,.activities-section h2{font-size:var(--font-size-xl);margin:0 0 var(--space-md) 0;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-family:var(--font-headline)}@media(max-width:767px){.dashboard-header{border-radius:0;border-left:none;border-right:none}.locations-section,.activities-section{border:none;border-radius:0;box-shadow:none;position:relative}.locations-section:after,.activities-section:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.locations-section:hover,.activities-section:hover{box-shadow:none;transform:none}}@media(min-width:768px){.dashboard-header h1{font-size:1.5rem}.locations-section,.activities-section{padding:var(--space-xl)}.locations-section h2,.activities-section h2{font-size:var(--font-size-2xl)}}@media(min-width:1024px){.dashboard-header{padding:1.5rem 2rem}.dashboard-header h1{font-size:1.75rem}}.guide-management{display:flex;flex-direction:column;gap:var(--space-xl)}.create-guide-section{background-color:var(--color-background-secondary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.create-guide-section h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.guide-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group input{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);color:var(--color-text-primary);background-color:#0000004d;min-height:44px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}body.light-mode .form-group input{background-color:#fffc}.form-group input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .form-group input:focus{box-shadow:0 0 0 3px #c81d251a}.form-group input.error{border-color:var(--color-error)}.form-group input:disabled{background-color:var(--color-background-tertiary);cursor:not-allowed;opacity:.6}.guides-list-header{margin-bottom:var(--space-lg)}.guides-list-header h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.guides-controls{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md)}.sort-controls{display:flex;flex-direction:column;gap:var(--space-sm)}.sort-controls label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.sort-buttons{display:flex;gap:var(--space-sm);flex-wrap:wrap}.guides-list{display:grid;gap:var(--space-md);grid-template-columns:1fr}.guide-card{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--space-md);display:flex;gap:var(--space-md);align-items:center}.guide-card:hover{border-color:var(--color-border-light)}.guide-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;border:2px solid var(--color-border);overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-background-tertiary)}.guide-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);font-family:var(--font-headline)}.avatar-preview-container{display:flex;align-items:center;gap:var(--space-md)}.avatar-preview{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border)}.remove-avatar-button{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text-primary);padding:.5rem 1rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:36px;min-width:auto;text-transform:none;letter-spacing:normal;transition:background-color var(--transition-base),border-color var(--transition-base)}.remove-avatar-button:hover:not(:disabled){background-color:var(--color-background-secondary);border-color:var(--color-error);color:var(--color-error)}.field-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-xs)}.guide-info{flex:1;min-width:0}.guide-info h4{margin:0 0 var(--space-xs) 0;color:var(--color-text-primary);font-size:var(--font-size-base);font-family:var(--font-headline);font-weight:var(--font-weight-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guide-email{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guide-meta{display:none}.edit-button{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:.375rem .75rem;border-radius:var(--border-radius);font-size:var(--font-size-xs);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:32px;min-width:auto;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base);flex-shrink:0}.edit-button:hover{background-color:var(--color-background-tertiary);border-color:var(--color-accent);color:var(--color-accent)}.modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--space-lg);animation:fadeInOverlay .15s ease-out}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes slideInModal{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-content.edit-modal{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--space-xl);max-width:500px;width:100%;max-height:calc(100vh - var(--space-xl) * 2);overflow-y:auto;position:relative;animation:slideInModal .15s ease-out}body.light-mode .modal-content.edit-modal{background-color:var(--color-background)}.modal-content.edit-modal h3{margin:0 0 var(--space-lg) 0;color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.modal-close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-2xl);cursor:pointer;padding:var(--space-xs);min-width:auto;min-height:auto;line-height:1;transition:color var(--transition-base)}.modal-close:hover{color:var(--color-text-primary);background:none;transform:none}.modal-close:active{transform:none}.edit-form{display:flex;flex-direction:column;gap:var(--space-md)}.current-avatar{margin-bottom:var(--space-sm)}.avatar-placeholder-large{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);background-color:var(--color-background-secondary);border:2px solid var(--color-border)}.location-dates-list{display:flex;flex-direction:column;gap:var(--space-sm)}.location-date-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius)}.location-date-item .location-name{flex:1;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.location-date-item input[type=datetime-local]{width:auto;min-width:180px}.empty-text{color:var(--color-text-muted);font-size:var(--font-size-sm);font-style:italic}.modal-actions{display:flex;gap:var(--space-md);margin-top:var(--space-md)}.cancel-button{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text-primary);padding:.75rem 2rem;border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),border-color var(--transition-base);flex:1}.cancel-button:hover:not(:disabled){background-color:var(--color-background-secondary);border-color:var(--color-border-light);transform:none}.cancel-button:active:not(:disabled){transform:none}.modal-actions .submit-button{flex:1;margin-top:0}.modal-actions .submit-button:hover:not(:disabled){transform:none}.modal-actions .submit-button:active:not(:disabled){transform:none}@media(min-width:768px){.guides-list{grid-template-columns:repeat(2,1fr)}.guide-form{max-width:600px}}@media(min-width:1200px){.guides-list{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px){.guides-controls{flex-direction:row;align-items:flex-end}.search-box{max-width:400px}.sort-controls{flex-shrink:0}}@media(max-width:767px){.create-guide-section{padding:var(--space-md);border:none;border-radius:0}.create-guide-section h3,.guides-list-header h3{font-size:var(--font-size-lg)}.guide-card{padding:var(--space-sm)}.submit-button,.sort-buttons{width:100%}.sort-button{flex:1;min-width:0}.modal-overlay{padding:var(--space-sm);align-items:flex-start;padding-top:var(--space-lg)}.modal-content.edit-modal{padding:var(--space-lg);max-height:calc(100vh - var(--space-xl))}.location-date-item{flex-direction:column;align-items:stretch}.location-date-item input[type=datetime-local]{width:100%}.modal-actions{flex-direction:column}}.activity-management{display:flex;flex-direction:column;gap:var(--space-xl)}.create-activity-section{background-color:var(--color-background-secondary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.create-activity-section h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.activity-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);color:var(--color-text-primary);background-color:#0000004d;min-height:44px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}body.light-mode .form-group input,body.light-mode .form-group select,body.light-mode .form-group textarea{background-color:#fffc}.form-group textarea{min-height:100px;resize:vertical;line-height:var(--line-height-normal)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .form-group input:focus,body.light-mode .form-group select:focus,body.light-mode .form-group textarea:focus{box-shadow:0 0 0 3px #c81d251a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--color-error)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--color-background-tertiary);cursor:not-allowed;opacity:.6}.submit-button{background-color:var(--color-error);color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast);margin-top:var(--space-sm)}@media(min-width:768px){.activity-form{max-width:600px}}@media(max-width:767px){.create-activity-section{padding:var(--space-md);border:none;border-radius:0}.create-activity-section h3{font-size:var(--font-size-lg)}.submit-button{width:100%}}.image-preview-container{display:flex;flex-direction:column;gap:var(--space-sm);align-items:flex-start}.image-preview{max-width:100%;max-height:300px;border-radius:var(--border-radius);border:1px solid var(--color-border);object-fit:cover}.remove-image-button{background-color:var(--color-background-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);cursor:pointer;transition:background-color var(--transition-base)}.remove-image-button:hover:not(:disabled){background-color:var(--color-background-secondary)}.remove-image-button:disabled{opacity:.5;cursor:not-allowed}.field-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}input[type=file]{padding:.5rem!important;cursor:pointer}input[type=file]::-webkit-file-upload-button{background-color:var(--color-background-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;font-family:var(--font-sans);font-size:var(--font-size-sm);margin-right:var(--space-sm);transition:background-color var(--transition-base)}input[type=file]::-webkit-file-upload-button:hover{background-color:var(--color-background-secondary)}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.8}body.light-mode input[type=date]::-webkit-calendar-picker-indicator{filter:invert(0);opacity:.6}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.csv-import-section{background-color:var(--color-background-secondary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);margin-top:var(--space-xl)}.csv-import-section h3{margin-top:0;margin-bottom:var(--space-sm);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.csv-import-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-md);line-height:var(--line-height-normal)}.csv-import-form{display:flex;flex-direction:column;gap:var(--space-md);max-width:600px}.import-button{background-color:var(--color-primary);color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast);margin-top:var(--space-sm);align-self:flex-start}.import-button:hover:not(:disabled){background-color:var(--color-primary-dark, #1565c0);transform:translateY(-1px)}.import-button:active:not(:disabled){transform:translateY(0)}.import-button:disabled{opacity:.5;cursor:not-allowed}.csv-results{margin-top:var(--space-lg);padding:var(--space-md);background-color:var(--color-background-tertiary);border-radius:var(--border-radius);border:1px solid var(--color-border)}.csv-result-success{color:var(--color-success, #4caf50);font-weight:var(--font-weight-semibold);padding:var(--space-sm) 0}.csv-result-warning{color:var(--color-warning, #ff9800);font-weight:var(--font-weight-medium);padding:var(--space-sm) 0}.csv-result-error{color:var(--color-error);font-weight:var(--font-weight-semibold);padding:var(--space-sm) 0}.csv-result-info{color:var(--color-text-secondary);font-style:italic;padding:var(--space-sm) 0}.csv-result-warnings,.csv-result-errors{margin-top:var(--space-sm);padding:var(--space-sm);border-radius:var(--border-radius)}.csv-result-warnings{background-color:#ff98001a;border:1px solid rgba(255,152,0,.3)}.csv-result-errors{background-color:#f443361a;border:1px solid rgba(244,67,54,.3)}.csv-result-warnings strong,.csv-result-errors strong{display:block;margin-bottom:var(--space-xs)}.csv-result-warnings ul,.csv-result-errors ul{margin:0;padding-left:var(--space-lg);font-size:var(--font-size-sm)}.csv-result-warnings li{color:var(--color-warning, #ff9800)}.csv-result-errors li{color:var(--color-error)}.csv-format-mismatch{margin-top:var(--space-lg);padding:var(--space-lg);background-color:#ff98001a;border:2px solid var(--color-warning, #ff9800);border-radius:var(--border-radius-lg);text-align:center}.csv-format-mismatch-icon{font-size:2.5rem;margin-bottom:var(--space-sm)}.csv-format-mismatch-message{color:var(--color-text-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);margin-bottom:var(--space-lg);font-weight:var(--font-weight-medium)}.csv-format-mismatch-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.csv-format-mismatch-actions .proceed-button{background-color:var(--color-warning, #ff9800);color:#000;border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:var(--font-size-base);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;transition:background-color var(--transition-base),transform var(--transition-fast)}.csv-format-mismatch-actions .proceed-button:hover:not(:disabled){background-color:#e68900;transform:translateY(-1px)}.csv-format-mismatch-actions .proceed-button:disabled{opacity:.5;cursor:not-allowed}.csv-format-mismatch-actions .cancel-button{background-color:var(--color-background-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:var(--font-size-base);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;transition:background-color var(--transition-base),transform var(--transition-fast)}.csv-format-mismatch-actions .cancel-button:hover:not(:disabled){background-color:var(--color-background-secondary);transform:translateY(-1px)}.csv-format-mismatch-actions .cancel-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:767px){.csv-import-section{padding:var(--space-md);border:none;border-radius:0;margin-top:var(--space-lg)}.csv-import-section h3{font-size:var(--font-size-lg)}.import-button{width:100%}.csv-format-mismatch-actions{flex-direction:column}.csv-format-mismatch-actions .proceed-button,.csv-format-mismatch-actions .cancel-button{width:100%}}.location-management{display:flex;flex-direction:column;gap:var(--space-xl)}.create-location-section{background-color:var(--color-background-secondary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.create-location-section h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.location-form{display:flex;flex-direction:column;gap:var(--space-md);max-width:600px}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-group label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-base)}.form-group input,.form-group select{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);color:var(--color-text-primary);background-color:#0000004d;min-height:44px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}body.light-mode .form-group input,body.light-mode .form-group select{background-color:#fffc}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .form-group input:focus,body.light-mode .form-group select:focus{box-shadow:0 0 0 3px #c81d251a}.form-group input.error,.form-group select.error{border-color:var(--color-error)}.form-group input:disabled,.form-group select:disabled{background-color:var(--color-background-tertiary);cursor:not-allowed;opacity:.6}.submit-button{background-color:var(--color-error);color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast)}.submit-button:hover:not(:disabled){background-color:var(--color-danger);transform:translateY(-1px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.locations-list-header{margin-bottom:var(--space-lg)}.locations-list-header h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.locations-controls{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md)}.search-box{position:relative;flex:1}.search-input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);color:var(--color-text-primary);background-color:#0000004d;min-height:44px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}body.light-mode .search-input{background-color:#fffc}.search-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .search-input:focus{box-shadow:0 0 0 3px #c81d251a}.search-input::placeholder{color:var(--color-text-muted)}.clear-search{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-lg);cursor:pointer;padding:.5rem;min-width:auto;min-height:auto;display:flex;align-items:center;justify-content:center;transition:color var(--transition-base)}.clear-search:hover{color:var(--color-text-primary);transform:translateY(-50%)}.sort-controls{display:flex;gap:var(--space-sm)}.sort-button{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text-primary);padding:.5rem 1rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:36px;text-transform:none;letter-spacing:normal;transition:background-color var(--transition-base),border-color var(--transition-base),transform var(--transition-fast)}.sort-button:hover{background-color:var(--color-background-secondary);border-color:var(--color-border-light);transform:translateY(-1px)}.sort-button.active,body.light-mode .sort-button.active{background-color:var(--color-accent);border-color:var(--color-accent);color:var(--color-text-inverse)}.locations-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-sm)}.location-item{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--space-md) var(--space-md);font-size:var(--font-size-base);color:var(--color-text-primary);transition:box-shadow var(--transition-base),transform var(--transition-fast),border-color var(--transition-base);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.location-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px);border-color:var(--color-border-light)}.location-item.selected{border-color:var(--color-accent);background-color:#bfd7ea1a;box-shadow:0 0 0 2px #bfd7ea33}body.light-mode .location-item.selected{border-color:var(--color-accent);background-color:#c81d250d;box-shadow:0 0 0 2px #c81d251a}.location-item:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .location-item:focus{box-shadow:0 0 0 3px #c81d251a}.location-name-text{flex:1}.guide-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-xs);background-color:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);flex-shrink:0}body.light-mode .guide-count-badge{background-color:var(--color-accent)}.location-details-panel{background-color:var(--color-background-secondary);border:2px solid var(--color-accent);border-radius:var(--border-radius-lg);padding:var(--space-lg);margin-top:var(--space-lg);animation:fadeIn .3s ease-out}.location-details-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.location-details-header h4{margin:0;color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.close-details{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-xl);cursor:pointer;padding:var(--space-xs);min-width:auto;min-height:auto;display:flex;align-items:center;justify-content:center;transition:color var(--transition-base);line-height:1}.close-details:hover{color:var(--color-text-primary);transform:none}.location-details-empty{text-align:center;padding:var(--space-xl);color:var(--color-text-muted)}.location-details-subtitle{margin:0 0 var(--space-md) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.guides-with-location-list{display:flex;flex-direction:column;gap:var(--space-sm)}.guide-with-location-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--color-background-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius);transition:box-shadow var(--transition-base)}.guide-with-location-item:hover{box-shadow:var(--shadow-sm)}.guide-avatar-small{width:40px;height:40px;border-radius:50%;flex-shrink:0;border:2px solid var(--color-border);overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-background-secondary)}.guide-avatar-small img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-small{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);font-family:var(--font-headline)}.guide-with-location-info{flex:1;display:flex;flex-direction:column;gap:var(--space-xs);min-width:0}.guide-with-location-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guide-with-location-email{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guide-with-location-date{flex-shrink:0;font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap}.empty-state-small{text-align:center;color:var(--color-text-muted);padding:var(--space-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius);font-size:var(--font-size-sm)}.guide-assignment-section{background-color:var(--color-background-secondary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.guide-assignment-section h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.guide-assignment-section h4{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-secondary);font-size:var(--font-size-lg);font-family:var(--font-headline);font-weight:var(--font-weight-normal)}.guide-locations-container{margin-top:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.assigned-locations{background-color:var(--color-background-tertiary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.assigned-list{display:flex;flex-direction:column;gap:var(--space-sm)}.assigned-location-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius);border:1px solid var(--color-border)}.location-order{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--color-accent);color:var(--color-text-inverse);border-radius:50%;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0}body.light-mode .location-order{background-color:var(--color-error)}.location-name{flex:1;color:var(--color-text-primary);font-weight:var(--font-weight-normal)}.remove-button{background-color:var(--color-error);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:36px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base);flex-shrink:0}.remove-button:hover:not(:disabled){background-color:var(--color-danger)}.remove-button:disabled{opacity:.5;cursor:not-allowed}.add-location-section{background-color:var(--color-background-tertiary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.add-location-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.available-location-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius);border:1px solid var(--color-border)}.available-location-item .location-name{flex:1;color:var(--color-text-primary)}.add-button{background-color:var(--color-success);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-width:44px;min-height:36px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base);flex-shrink:0}.add-button:hover:not(:disabled){background-color:#0d9668}.add-button:disabled{opacity:.5;cursor:not-allowed}@media(min-width:768px){.locations-controls{flex-direction:row;align-items:flex-end}.search-box{max-width:400px}.sort-controls{flex-shrink:0}.locations-list{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-md)}.guide-locations-container{flex-direction:row;gap:var(--space-lg)}.assigned-locations,.add-location-section{flex:1}}@media(min-width:1024px){.locations-list{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:767px){.create-location-section,.guide-assignment-section{padding:var(--space-md);border:none;border-radius:0;position:relative}.create-location-section:after,.guide-assignment-section:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.create-location-section h3,.locations-list-header h3,.guide-assignment-section h3{font-size:var(--font-size-lg)}.guide-assignment-section h4{font-size:var(--font-size-base)}.locations-list{grid-template-columns:1fr}.location-details-panel{padding:var(--space-md);border:none;border-radius:0;position:relative}.location-details-panel:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.location-details-header h4{font-size:var(--font-size-lg)}.assigned-locations,.add-location-section{border:none;border-radius:0;position:relative}.assigned-locations:after,.add-location-section:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.guide-with-location-item{flex-wrap:wrap}.guide-with-location-date{width:100%;text-align:center}.assigned-location-item{flex-wrap:wrap}.remove-button{width:100%;margin-top:var(--space-sm)}.available-location-item{flex-direction:column;align-items:stretch}.add-button,.submit-button{width:100%}}.guide-preview-view{width:100%}.guide-preview-selector{background-color:var(--color-background-secondary);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);margin-bottom:var(--space-xl)}.guide-preview-selector h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.guide-preview-selector .form-group{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:0;max-width:600px}.guide-preview-selector label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-base)}.guide-select{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:16px;font-family:var(--font-sans);color:var(--color-text-primary);background-color:#0000004d;min-height:44px;cursor:pointer;transition:border-color var(--transition-base),box-shadow var(--transition-base)}body.light-mode .guide-select{background-color:#fffc}.guide-select:hover{border-color:var(--color-border-light)}.guide-select:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #bfd7ea1a}body.light-mode .guide-select:focus{box-shadow:0 0 0 3px #c81d251a}.guide-preview-container-breakout{width:100%;max-width:1200px;margin:0 auto;padding:0}.guide-preview-container{width:100%}.guide-dashboard-preview{background-color:transparent;border:none;border-radius:0;padding:0;animation:fadeIn .3s ease-out;max-width:1200px;margin:0 auto}.preview-header{background-color:var(--color-background-secondary);color:var(--color-text-primary);padding:var(--space-md);display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}@media(min-width:768px){.preview-header{border-radius:var(--border-radius)}}.preview-header .user-profile{display:flex;align-items:center;gap:var(--space-md)}.preview-header .user-info{display:flex;flex-direction:column;gap:var(--space-xs)}.preview-header .user-avatar{width:48px;height:48px;border-radius:50%;border:2px solid #ffffff;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-background-secondary);flex-shrink:0}.preview-header .user-avatar img{width:100%;height:100%;object-fit:cover}.preview-header .avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);font-family:var(--font-headline)}.preview-header .user-info h1{font-size:var(--font-size-xl);margin:0;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-family:var(--font-headline)}.preview-header .header-actions{display:flex;align-items:center;gap:var(--space-sm);min-width:44px}.preview-header .header-locations{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.preview-header .location-icon,.secondary-nav .location-icon{font-size:var(--font-size-base);color:var(--color-text-muted)}.preview-header .header-location,.secondary-nav .header-location{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);background-color:var(--color-background-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);color:var(--color-text-primary);white-space:nowrap}.secondary-nav{background-color:var(--color-background-secondary);padding:var(--space-sm) 1rem;display:flex;flex-direction:column;gap:var(--space-xs);max-width:1200px;margin:0 auto;position:relative}.secondary-nav:before{content:"";position:absolute;top:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.secondary-nav .nav-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.secondary-nav .nav-locations{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.guide-dashboard-preview .metrics-dashboard{margin-top:var(--space-md)}@media(min-width:768px){.guide-dashboard-preview .metrics-dashboard{margin-top:var(--space-lg)}}.guide-dashboard-preview .activities-section{background-color:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg);margin-top:var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-slow),transform var(--transition-slow)}.guide-dashboard-preview .activities-section:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}@media(max-width:767px){.guide-dashboard-preview .activities-section{border:none;border-radius:0;box-shadow:none;position:relative}.guide-dashboard-preview .activities-section:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.guide-dashboard-preview .activities-section:hover{box-shadow:none;transform:none}}.guide-dashboard-preview .activities-section h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-md) 0;font-family:var(--font-headline)}.activities-note{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:calc(var(--space-sm) * -1);margin-bottom:var(--space-md);font-style:italic;display:block}.guide-dashboard-preview .activities-list{display:grid;gap:var(--space-lg);margin-top:var(--space-lg)}@media(max-width:767px){.guide-preview-selector{padding:var(--space-md);border:none;border-radius:0}.guide-preview-selector h3{font-size:var(--font-size-lg)}.guide-dashboard-preview{padding:0}.preview-header{border-radius:0;border-left:none;border-right:none}.preview-header .user-info h1{font-size:var(--font-size-lg)}}@media(min-width:768px){.preview-header .user-info h1{font-size:1.5rem}}@media(min-width:1024px){.preview-header{padding:1.5rem 2rem}.preview-header .user-info h1{font-size:1.75rem}.guide-dashboard-preview .activities-list{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}.admin-dashboard{min-height:100vh;background-color:var(--color-background)}.admin-header{background-color:var(--color-background-secondary);color:var(--color-text-primary);padding:var(--space-md);display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}@media(min-width:768px){.admin-header{border-radius:var(--border-radius)}}.admin-header h1{margin:0;font-size:var(--font-size-2xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold)}.header-actions{display:flex;align-items:center;gap:var(--space-sm)}.logout-button{background-color:var(--color-error);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);cursor:pointer;min-height:44px;min-width:44px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);transition:background-color var(--transition-base),transform var(--transition-fast)}.logout-button:hover{background-color:var(--color-danger);transform:translateY(-1px)}.logout-button:active{background-color:var(--color-danger);transform:translateY(0)}.admin-tabs{display:flex;background-color:var(--color-background-secondary);border:1px solid var(--color-border);overflow-x:auto;max-width:1200px;margin:0 auto}@media(min-width:768px){.admin-tabs{border-radius:var(--border-radius)}}.tab-button{flex:1;padding:var(--space-md);background-color:transparent;border:none;border-bottom:3px solid transparent;font-size:var(--font-size-base);font-family:var(--font-sans);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);cursor:pointer;min-height:44px;text-transform:none;letter-spacing:normal;transition:all var(--transition-base);white-space:nowrap}.tab-button:hover{background-color:var(--color-background-tertiary)}body.light-mode .tab-button:hover{background-color:var(--color-accent);color:#fff!important}.tab-button.active{border-bottom-color:var(--color-accent);color:var(--color-accent);font-weight:600}.admin-content{max-width:1200px;margin:0 auto;padding:var(--space-lg) 0}.admin-content.no-padding{padding:0}.admin-section{background-color:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-slow),transform var(--transition-slow)}.admin-section:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-section h2{margin-top:0;margin-bottom:var(--space-lg);color:var(--color-text-primary);font-size:var(--font-size-2xl);font-family:var(--font-headline)}.admin-section.preview-section{padding:0;border:none;box-shadow:none;background-color:transparent}.admin-section.preview-section:hover{box-shadow:none;transform:none}.admin-section.preview-section h2{padding:var(--space-lg);margin-bottom:0}@media(max-width:768px){.admin-section.preview-section h2{padding:var(--space-md)}.admin-section.preview-section:after{display:none}}.admin-section-description{color:var(--color-text-secondary);margin-bottom:var(--space-lg);font-size:var(--font-size-base)}@media(max-width:768px){.admin-header{border-radius:0;border-left:none;border-right:none}.admin-header h1{font-size:1.25rem}.logout-button{padding:.5rem 1rem;font-size:.9rem}.admin-tabs{border-radius:0;border-left:none;border-right:none}.tab-button{font-size:.9rem;padding:.75rem}.admin-section{padding:var(--space-md);border:none;border-radius:0;box-shadow:none;position:relative}.admin-section:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background-color:var(--color-border)}.admin-section:hover{box-shadow:none;transform:none}.admin-section h2{font-size:var(--font-size-xl)}}#root{min-height:100vh}@media(min-width:768px){#root{padding:var(--space-md)}}@media(min-width:1024px){#root{padding:var(--space-xl)}}.app-container{max-width:var(--max-width-xl);margin:0 auto;padding:0 var(--space-md)}@media(min-width:768px){.app-container{padding:0 var(--space-lg)}}@media(min-width:1024px){.app-container{padding:0 var(--space-xl)}}.main-content{padding:var(--space-lg) 0}.page-header{margin-bottom:var(--space-xl)}.page-title{font-size:var(--font-size-3xl);font-family:var(--font-headline);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-md)}.page-description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-normal)}@media(min-width:768px){.main-content{padding:var(--space-xl) 0}.page-title{font-size:var(--font-size-4xl)}}
