:root {
    
    --color-bg: #050505;
    --color-text: #e0e0e0;
    --color-text-muted: #b5b5b5;
    --color-white: #ffffff;
    --color-border: #222222;
    --color-border-muted: rgba(255, 255, 255, 0.1);
    --color-overlay: rgba(5, 5, 5, 0.95);
    
    --spacing-xs: 0.125rem; 
    --spacing-1: 0.25rem;   
    --spacing-2: 0.5rem;    
    --spacing-3: 0.75rem;   
    --spacing-4: 1rem;      
    --spacing-6: 1.5rem;    
    --spacing-8: 2rem;      
    --spacing-12: 3rem;     
    --spacing-16: 4rem;     
    --spacing-24: 6rem;     
    --spacing-32: 8rem;     
    --spacing-40: 10rem;    

    --font-serif: "Times New Roman", Times, serif;
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

    --size-xs: clamp(0.7rem, 0.5vw + 0.6rem, 0.75rem);
    --size-sm: clamp(0.8rem, 0.5vw + 0.7rem, 0.875rem);
    --size-base: clamp(0.875rem, 0.5vw + 0.8rem, 1rem); 
    --size-md: clamp(1rem, 0.5vw + 0.9rem, 1.1rem);  
    --size-lg: clamp(1.1rem, 1vw + 1rem, 1.25rem);   
    --size-xl: clamp(1.8rem, 2vw + 1rem, 2.8rem);     

    --tracking-tight: 0.02em;
    --tracking-normal: 0.05em;
    --tracking-wide: 0.1em;
    --tracking-wider: 0.15em;
    --tracking-widest: 0.25em;

    --layout-max-width: 900px;
    --layout-logo-size: 60px;
    
    --transition-fast: 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --transition-base: 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --transition-slow: 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --duration-breath: 6s ease-in-out infinite;

    --z-base: 1;
    --z-header: 100;
    --z-overlay: 999;
    --z-modal: 1000;
}

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

html {
    font-size: 100%;
    scroll-behavior: smooth;
}

body {
    background-color: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: var(--size-base);
    line-height: 1.8;
    letter-spacing: var(--tracking-tight);
    min-height: 100vh;
    
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 400;
    text-transform: uppercase;
    color: var(--color-text);
}

a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.layout-boundary {
    width: 100%;
    max-width: var(--layout-max-width);
    padding: var(--spacing-24) var(--spacing-6);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-32); 
}

.header {
    width: 100%;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: var(--spacing-12);
}

.header-grid {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-2);
}

.main {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-16);
    width: 100%;
}

.section {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-12);
}

.border-top {
    border-top: 1px solid var(--color-border);
    padding-top: var(--spacing-16);
}

.footer {
    width: 100%;
    border-top: 1px solid var(--color-border);
    padding-top: var(--spacing-16);
    padding-bottom: var(--spacing-8);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8);
    text-align: center;
    font-size: var(--size-sm);
    color: var(--color-text-muted);
}

.section-history {
    display: none; 
}

.registration {
    position: relative;
    margin-top: var(--spacing-8); 
    padding-top: var(--spacing-8);
}

.logo-wrapper {
    width: var(--layout-logo-size);
    height: var(--layout-logo-size);
    display: flex;
    justify-content: center;
    align-items: center;
}

.logo {
    width: 100%;
    height: auto;
    display: block;
    will-change: transform, opacity;
}

.monitor {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-family: var(--font-sans);
}

.monitor-label {
    font-size: var(--size-xs);
    letter-spacing: var(--tracking-widest);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-1);
}

.monitor-digits {
    font-family: var(--font-sans);
    font-size: var(--size-md);
    letter-spacing: var(--tracking-wide);
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
    display: flex;
    justify-content: center;
}

.monitor-digit {
    display: inline-block;
    position: relative;
}

.monitor-digit.cycling {
    animation: animation-digit var(--transition-fast) ease-out;
    color: var(--color-white);
}

.hero {
    text-align: center;
    padding: var(--spacing-4) 0;
}

.hero h1 {
    font-family: var(--font-serif);
    font-size: var(--size-xl);
    letter-spacing: var(--tracking-wider);
    margin-bottom: var(--spacing-8);
    line-height: 1.1;
}

.hero h2 {
    font-family: var(--font-serif);
    font-size: var(--size-md);
    letter-spacing: var(--tracking-wide);
    color: var(--color-text-muted);
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.prose {
    max-width: 65ch;
    margin: 0 auto;
    font-size: var(--size-md);
    color: var(--color-text-muted);
}

.prose-sm {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
    max-width: 60ch;
}

.card-director {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--spacing-12);
    align-items: center;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    padding: var(--spacing-12);
}

.portrait-wrapper {
    width: 100%;
    line-height: 0;
    border: 1px solid var(--color-border);
}

.portrait {
    width: 100%;
    height: auto;
    display: block;
    mix-blend-mode: luminosity;
    filter: contrast(1.1);
}

.director-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    text-align: left;
}

.director-info h3 {
    font-family: var(--font-serif);
    font-size: var(--size-lg);
    letter-spacing: var(--tracking-wide);
}

.role {
    font-size: var(--size-xs);
    text-transform: uppercase;
    letter-spacing: var(--tracking-widest);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-4);
}

.qa-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-12);
    align-items: center;
}

.qa-item {
    max-width: 60ch;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.question {
    font-size: var(--size-md);
    letter-spacing: var(--tracking-wide);
    color: var(--color-text);
    font-family: var(--font-serif);
}

.answer {
    font-size: var(--size-md);
    color: var(--color-text-muted);
}

.qa-expanded {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-12);
    align-items: center;
}

.qa-expanded[hidden] {
    display: none;
}

.toggle-wrapper {
    margin-top: var(--spacing-12);
    text-align: center;
}

.disclaimer {
    font-size: var(--size-xs);
    color: var(--color-text-muted);
    margin-top: var(--spacing-4);
}

.narrative {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
    max-width: 60ch;
    margin: 0 auto;
}

.history-frame {
    width: 100%;
    padding: var(--spacing-4);
}

.index-wrapper {
    width: 100%;
    margin-top: var(--spacing-8);
}

.index-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--spacing-8);
    border-top: 1px solid var(--color-border-muted);
    padding-top: var(--spacing-8);
}

.index-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-4);
}

.label {
    font-size: var(--size-xs);
    letter-spacing: var(--tracking-widest);
    color: var(--color-text-muted);
    text-transform: uppercase;
}

.list-links, .list-legal {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.list-links a {
    transition: color var(--transition-fast), text-shadow var(--transition-fast);
}
.list-links a:hover {
    color: var(--color-white);
    text-shadow: 0 0 5px rgba(255, 255, 255, 0.3);
}

.links-public {
    margin-top: var(--spacing-2);
    font-size: var(--size-xs);
    letter-spacing: var(--tracking-wide);
}

.links-public a {
    transition: color var(--transition-fast), text-shadow var(--transition-fast);
}
.links-public a:hover {
    color: var(--color-white);
    text-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

.link-legal {
    margin-top: var(--spacing-4);
}

.copyright {
    font-size: var(--size-xs);
    color: var(--color-text-muted);
}

.overlay {
    position: fixed;
    inset: 0;
    background-color: var(--color-bg);
    z-index: var(--z-overlay);
    display: flex;
    justify-content: center;
    align-items: center;
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--transition-slow);
    will-change: opacity;
}

.overlay.active {
    opacity: 1;
    pointer-events: all;
}

.overlay-content {
    text-align: center;
}

.overlay-text {
    font-size: var(--size-xs);
    letter-spacing: var(--tracking-widest);
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-4);
}

.overlay-date {
    font-family: var(--font-sans);
    font-size: var(--size-lg);
    color: var(--color-white);
    letter-spacing: var(--tracking-wide);
}

.lightbox {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    background: rgba(0, 0, 0, 0.9);
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-base);
}
.lightbox.active {
    opacity: 1;
    pointer-events: all;
}
.lightbox-content {
    max-width: 90vw;
    max-height: 90vh;
    border: 1px solid var(--color-border);
}
.lightbox-close {
    position: absolute;
    top: var(--spacing-6);
    right: var(--spacing-6);
    color: var(--color-white);
    font-size: var(--size-xl);
    cursor: pointer;
}

.link-logo:hover .logo {
    opacity: 0.8;
}

.link-subtle {
    border-bottom: 1px solid transparent;
    transition: border-color var(--transition-fast);
}

.link-subtle:hover {
    color: var(--color-white);
    border-color: var(--color-white);
}

.toggle-btn {
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-family: var(--font-sans);
    font-size: var(--size-xs);
    letter-spacing: var(--tracking-widest);
    cursor: pointer;
    padding: var(--spacing-4);
    transition: color var(--transition-fast);
}

.toggle-btn:hover {
    color: var(--color-white);
    text-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

a {
    transition: color var(--transition-fast), text-shadow var(--transition-fast);
}

a:hover {
    color: var(--color-white);

.link-history {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
}
.link-history:hover {
    color: var(--color-white);
}

@keyframes animation-breath {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.02); opacity: 0.8; }
    100% { transform: scale(1); opacity: 1; }
}

.animate-breath {
    animation: animation-breath var(--duration-breath);
    will-change: transform, opacity;
}

@keyframes animation-glitch-hover {
    0% { transform: translate(0); }
    20% { transform: translate(-2px, 2px); }
    40% { transform: translate(-2px, -2px); }
    60% { transform: translate(2px, 2px); }
    80% { transform: translate(2px, -2px); }
    100% { transform: translate(0); }
}

.animate-glitch:hover {
    animation: animation-glitch-hover 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94) both infinite;
}

@media (max-width: 768px) {
    .layout-boundary {
        padding: var(--spacing-12) var(--spacing-4);
        overflow-x: hidden; 
    }

    .card-director {
        grid-template-columns: 1fr;
        text-align: center;
        gap: var(--spacing-8);
    }
    
    .director-info {
        text-align: center;
        align-items: center;
    }
    
    .portrait-wrapper {
        max-width: 200px;
        margin: 0 auto;
    }

    .index-content {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .index-content {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .animate-breath, 
    .animate-glitch, 
    .card-director, 
    .link-subtle:hover {
        animation: none !important;
        transition: none !important;
    }
}

.reduced-motion .animate-breath,
.reduced-motion .animate-glitch,
.reduced-motion .card-director,
.reduced-motion .link-subtle:hover {
    animation: none !important;
    transition: none !important;
}
