:root{--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Playfair Display", Georgia, "Times New Roman", serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", monospace;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--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;--line-height-tight: 1.2;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 2;--letter-spacing-tighter: -.05em;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--letter-spacing-wider: .05em;--letter-spacing-widest: .1em;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e5e5e5;--gray-300: #d4d4d4;--gray-400: #a3a3a3;--gray-500: #737373;--gray-600: #525252;--gray-700: #404040;--gray-800: #262626;--gray-900: #171717;--gray-950: #0a0a0a;--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-300: #93c5fd;--blue-400: #60a5fa;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--blue-800: #1e40af;--blue-900: #1e3a8a;--space-0: 0;--space-px: 1px;--space-0-5: .125rem;--space-1: .25rem;--space-1-5: .375rem;--space-2: .5rem;--space-2-5: .625rem;--space-3: .75rem;--space-3-5: .875rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-9: 2.25rem;--space-10: 2.5rem;--space-11: 2.75rem;--space-12: 3rem;--space-14: 3.5rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-28: 7rem;--space-32: 8rem;--radius-none: 0;--radius-sm: .125rem;--radius-base: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-base: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px}:root{--color-bg-primary: var(--gray-50);--color-bg-secondary: var(--gray-100);--color-bg-elevated: #ffffff;--color-bg-overlay: rgba(255, 255, 255, .95);--color-text-primary: var(--gray-900);--color-text-secondary: var(--gray-600);--color-text-tertiary: var(--gray-500);--color-text-inverse: #ffffff;--color-border-primary: var(--gray-200);--color-border-secondary: var(--gray-300);--color-border-focus: var(--blue-500);--color-accent-primary: var(--blue-600);--color-accent-hover: var(--blue-700);--color-accent-light: var(--blue-50);--shadow-color: rgba(0, 0, 0, .1)}[data-theme=dark]{--color-bg-primary: var(--gray-950);--color-bg-secondary: var(--gray-900);--color-bg-elevated: var(--gray-800);--color-bg-overlay: rgba(0, 0, 0, .95);--color-text-primary: var(--gray-50);--color-text-secondary: var(--gray-400);--color-text-tertiary: var(--gray-500);--color-text-inverse: var(--gray-900);--color-border-primary: var(--gray-700);--color-border-secondary: var(--gray-600);--color-border-focus: var(--blue-400);--color-accent-primary: var(--blue-400);--color-accent-hover: var(--blue-300);--color-accent-light: var(--blue-950);--shadow-color: rgba(0, 0, 0, .4);--shadow-xs: 0 1px 2px 0 var(--shadow-color);--shadow-sm: 0 1px 3px 0 var(--shadow-color), 0 1px 2px -1px var(--shadow-color);--shadow-base: 0 4px 6px -1px var(--shadow-color), 0 2px 4px -2px var(--shadow-color);--shadow-md: 0 10px 15px -3px var(--shadow-color), 0 4px 6px -4px var(--shadow-color);--shadow-lg: 0 20px 25px -5px var(--shadow-color), 0 8px 10px -6px var(--shadow-color);--shadow-xl: 0 25px 50px -12px var(--shadow-color)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;-webkit-text-size-adjust:100%;text-size-adjust:100%;overflow:hidden;background:#faf9f6}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}#introduction-modal{position:fixed;inset:0;z-index:1000;background:#faf9f6;overflow:hidden}#introduction-modal.hidden{display:none}.intro-stage{position:absolute;inset:0;display:none;flex-direction:column;justify-content:space-between;padding:0 2rem;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.intro-stage.active{display:flex;animation:stageEnter .4s ease-out}@keyframes stageEnter{0%{opacity:0}to{opacity:1}}.intro-stage-inner{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:340px;margin:0 auto;width:100%}.intro-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;margin-bottom:2rem;filter:grayscale(100%);opacity:.85}.intro-title{font-family:Cormorant Garamond,Georgia,serif;font-size:2.2rem;font-weight:500;line-height:1.12;color:#1a1a1a;letter-spacing:-.015em;margin-bottom:1rem}.intro-subtitle{font-family:Crimson Pro,Georgia,serif;font-size:1rem;font-weight:300;color:#777;margin-bottom:.5rem}.intro-date{font-family:Crimson Pro,Georgia,serif;font-size:.85rem;font-weight:300;color:#aaa;letter-spacing:.06em}.intro-tap-hint{font-family:Crimson Pro,Georgia,serif;font-size:.75rem;font-weight:300;color:#bbb;margin-top:3rem;letter-spacing:.04em}.intro-heading{font-family:Cormorant Garamond,Georgia,serif;font-size:1.75rem;font-weight:500;color:#1a1a1a;line-height:1.15;margin-bottom:1.5rem;letter-spacing:-.01em}.intro-body{font-family:Crimson Pro,Georgia,serif;font-size:1rem;font-weight:300;color:#444;line-height:1.6;margin-bottom:1rem}.intro-body-secondary{color:#888;font-style:italic}.intro-instructions{margin-bottom:1.5rem}.intro-instruction{display:flex;align-items:baseline;gap:.75rem;padding:.6rem 0;border-bottom:1px solid #e8e6e1;font-family:Crimson Pro,Georgia,serif;font-size:.95rem;font-weight:300;color:#444;line-height:1.5}.intro-instruction:first-child{border-top:1px solid #e8e6e1}.intro-instruction-icon{font-family:Crimson Pro,Georgia,serif;font-size:.8rem;font-weight:400;color:#999;flex-shrink:0;min-width:2.5rem;text-align:center;letter-spacing:.02em}.intro-counter{font-family:Crimson Pro,Georgia,serif;font-size:.7rem;font-weight:300;color:#bbb;text-align:center;padding:1.5rem 0;letter-spacing:.08em;font-variant-numeric:tabular-nums}.hidden{display:none!important}@media(prefers-reduced-motion:reduce){.intro-stage.active{animation:none}}body:has(.browse-view:not(.hidden)){overflow:auto!important;background:#faf9f6}body:has(.browse-view:not(.hidden)):before{display:none}.browse-view{background:#faf9f6;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;position:relative}.browse-header{padding:1rem 1.5rem 0;flex-shrink:0}.browse-header-rule{height:1px;background:#1a1a1a}.browse-header-inner{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0}.browse-header-label{font-family:Crimson Pro,Georgia,serif;font-size:.7rem;font-weight:400;text-transform:uppercase;letter-spacing:.12em;color:#888}.browse-header-right{display:flex;align-items:baseline;gap:.75rem}.browse-header-position{font-family:Crimson Pro,Georgia,serif;font-size:.7rem;font-weight:300;color:#aaa;letter-spacing:.06em;font-variant-numeric:tabular-nums}.intro-reopen-btn{background:none;border:1px solid #ccc;border-radius:50%;width:22px;height:22px;font-family:Crimson Pro,Georgia,serif;font-size:.7rem;font-weight:400;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:color .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent;flex-shrink:0;position:relative;top:-1px}.intro-reopen-btn:hover{color:#1a1a1a;border-color:#1a1a1a}.intro-reopen-btn:active{opacity:.5}.director-view-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.director-view-container.exiting-left{opacity:0;transform:translate(-20px);transition:opacity .18s ease-in,transform .18s ease-in}.director-view-container.exiting-right{opacity:0;transform:translate(20px);transition:opacity .18s ease-in,transform .18s ease-in}.director-view-container.entering-right{opacity:0;transform:translate(20px)}.director-view-container.entering-left{opacity:0;transform:translate(-20px)}.director-nav{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-top:1px solid #e0ddd8;background:#faf9f6;flex-shrink:0;gap:.5rem}.director-nav-btn{display:flex;align-items:center;gap:.4rem;background:none;border:none;cursor:pointer;padding:.5rem 0;font-family:Crimson Pro,Georgia,serif;font-size:.8rem;font-weight:400;color:#1a1a1a;-webkit-tap-highlight-color:transparent;min-height:44px;transition:opacity .15s ease}.director-nav-btn:active{opacity:.5}.director-nav-btn:disabled{opacity:.2;cursor:default}.director-nav-arrow{font-size:1rem;line-height:1}.director-nav-label{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#888;font-weight:300}.director-nav-counter{font-family:Crimson Pro,Georgia,serif;font-size:.7rem;font-weight:300;color:#aaa;text-align:center;letter-spacing:.04em;flex-shrink:0}.browse-progress{height:2px;background:#e8e6e1;flex-shrink:0}.browse-progress-fill{height:100%;background:#1a1a1a;transition:width .3s ease;width:0%}.swipe-hint{display:none;align-items:center;justify-content:center;gap:.6rem;padding:.6rem 1rem;font-family:Crimson Pro,Georgia,serif;font-size:.75rem;font-weight:300;color:#aaa;letter-spacing:.04em;animation:swipeHintFade 4s ease-in-out forwards;pointer-events:none}.swipe-hint-arrow{font-size:.85rem;color:#ccc}@media(pointer:coarse){.swipe-hint{display:flex}}.swipe-hint.dismissed{display:none!important}@keyframes swipeHintFade{0%{opacity:0}15%{opacity:1}70%{opacity:1}to{opacity:0}}@media(prefers-reduced-motion:reduce){.director-view-container,.browse-progress-fill{transition:none}.swipe-hint{animation:none;opacity:1}}#about-overlay{position:fixed;inset:0;z-index:900;background:#faf9f6;overflow-y:auto;-webkit-overflow-scrolling:touch;display:none;opacity:0;transition:opacity .3s ease}#about-overlay.visible{display:block;opacity:1}.about-inner{max-width:380px;margin:0 auto;padding:3rem 2rem 4rem}.about-close{display:flex;justify-content:flex-end;margin-bottom:2.5rem}.about-close-btn{background:none;border:1px solid #ccc;border-radius:50%;width:28px;height:28px;font-family:Crimson Pro,Georgia,serif;font-size:.85rem;font-weight:300;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:color .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent}.about-close-btn:hover{color:#1a1a1a;border-color:#1a1a1a}.about-header{margin-bottom:2.5rem}.about-title{font-family:Cormorant Garamond,Georgia,serif;font-size:1.75rem;font-weight:500;color:#1a1a1a;line-height:1.15;letter-spacing:-.01em;margin-bottom:.5rem}.about-subtitle{font-family:Crimson Pro,Georgia,serif;font-size:.9rem;font-weight:300;color:#999;letter-spacing:.04em}.about-section{margin-bottom:2rem}.about-section-heading{font-family:Cormorant Garamond,Georgia,serif;font-size:1.1rem;font-weight:600;color:#1a1a1a;margin-bottom:.75rem;letter-spacing:-.01em}.about-text{font-family:Crimson Pro,Georgia,serif;font-size:.95rem;font-weight:300;color:#444;line-height:1.65;margin-bottom:.75rem}.about-text:last-child{margin-bottom:0}.about-quote{font-style:italic;color:#666;border-left:2px solid #ddd;padding-left:1rem;margin:1rem 0}.about-divider{height:1px;background:#e8e6e1;margin:2rem 0}.about-credit{font-family:Crimson Pro,Georgia,serif;font-size:.85rem;font-weight:300;color:#888;line-height:1.6;margin-bottom:.35rem}.about-credit-label{color:#666;font-weight:400}.about-actions{margin-top:2.5rem;display:flex;flex-direction:column;gap:1rem}.about-action-link{font-family:Crimson Pro,Georgia,serif;font-size:.85rem;font-weight:300;color:#999;background:none;border:none;cursor:pointer;padding:0;text-align:left;letter-spacing:.04em;transition:color .15s ease;-webkit-tap-highlight-color:transparent}.about-action-link:hover{color:#1a1a1a}.about-attribution{margin-top:3rem;padding-top:1.5rem;border-top:1px solid #e8e6e1;font-family:Crimson Pro,Georgia,serif;font-size:.75rem;font-weight:300;color:#bbb;letter-spacing:.04em}.about-attribution a{color:#999;text-decoration:none;transition:color .15s ease}.about-attribution a:hover{color:#1a1a1a}@media(prefers-reduced-motion:reduce){#about-overlay{transition:none}}.skip-links{position:absolute;top:-100px;left:0;z-index:10000}.skip-link{position:absolute;top:0;left:0;background:var(--color-bg-primary);color:var(--color-text-primary);padding:8px 16px;text-decoration:none;font-weight:600;border:2px solid #1a1a1a;border-radius:4px;transform:translateY(-100%);transition:transform .2s ease-in-out}.skip-link:focus{transform:translateY(0);outline:3px solid #1a1a1a;outline-offset:2px}.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.keyboard-navigation-active *:focus{outline:3px solid #1a1a1a!important;outline-offset:2px!important;border-radius:4px}.keyboard-navigation-active button:focus{outline:3px solid #1a1a1a!important;outline-offset:2px!important}button:disabled,button[aria-disabled=true]{opacity:.6;cursor:not-allowed;pointer-events:none}[aria-busy=true]{position:relative;pointer-events:none}@media(pointer:coarse){button,[role=button]{min-height:44px;min-width:44px}}@media print{.skip-links{display:none!important}}@media(max-width:768px){.skip-link{font-size:.875rem;padding:6px 12px}}
