:root { --bg: #0d0f11; --surface: rgba(20, 24, 28, 0.82); --surface-strong: rgba(28, 33, 38, 0.95); --surface-soft: rgba(16, 19, 22, 0.92); --border: rgba(255, 255, 255, 0.1); --text: #f4f3ef; --muted: #a9aeb6; --accent: #c7a66f; --accent-soft: rgba(199, 166, 111, 0.14); --accent-strong: #f0d8ad; --shadow: 0 28px 70px rgba(0, 0, 0, 0.38); --shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.22); --radius-sm: 8px; --radius-md: 12px; --radius-lg: 18px; } html { scroll-behavior: smooth; } body { font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: radial-gradient(circle at top left, rgba(199, 166, 111, 0.15), transparent 30%), radial-gradient(circle at 85% 12%, rgba(111, 137, 199, 0.12), transparent 26%), linear-gradient(180deg, #111418 0%, #0d0f11 44%, #0a0b0d 100%); color: var(--text); line-height: 1.6; letter-spacing: -0.01em; overflow-x: hidden; } body.page-cinematic::before, body.page-cinematic::after { content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -1; } body.page-cinematic::before { background: radial-gradient(circle at 20% 10%, rgba(255, 214, 150, 0.14), transparent 20%), radial-gradient(circle at 80% 18%, rgba(120, 160, 255, 0.08), transparent 24%), radial-gradient(circle at 50% 120%, rgba(255, 255, 255, 0.05), transparent 34%); filter: blur(8px); } body.page-cinematic::after { opacity: 0.08; background-image: linear-gradient(rgba(255, 255, 255, 0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px); background-size: 160px 160px; mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.55), transparent 90%); } a { color: inherit; } img { display: block; } .section-shell { padding: 4.8rem 0; position: relative; } .section-shell::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.018)); pointer-events: none; } .section-border-top { border-top: 1px solid rgba(255, 255, 255, 0.06); } .site-header { background: rgba(10, 12, 14, 0.72); backdrop-filter: blur(18px); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.22); } .navbar { padding: 0.9rem 0; } .brand-mark { display: inline-flex; width: 2.35rem; height: 2.35rem; align-items: center; justify-content: center; border: 1px solid rgba(255, 255, 255, 0.14); border-radius: 10px; background: var(--surface); color: var(--accent); font-size: 0.88rem; font-weight: 700; letter-spacing: 0.08em; } .brand-title { font-size: 0.95rem; font-weight: 600; color: var(--text); } .brand-subtitle { font-size: 0.74rem; color: var(--muted); } .nav-link { color: var(--muted); font-size: 0.95rem; padding: 0.55rem 0.75rem !important; border-radius: 8px; } .nav-link:hover, .nav-link.active { color: var(--text); background: rgba(255, 255, 255, 0.06); } .scene-label { display: inline-flex; align-items: center; gap: 0.55rem; margin-bottom: 1rem; padding: 0.38rem 0.78rem; border-radius: 999px; border: 1px solid rgba(255, 255, 255, 0.12); background: rgba(255, 255, 255, 0.04); color: var(--text); font-size: 0.76rem; letter-spacing: 0.12em; text-transform: uppercase; } .scene-label::before { content: ""; width: 0.45rem; height: 0.45rem; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-strong)); box-shadow: 0 0 18px rgba(199, 166, 111, 0.75); } .hero-section { padding-top: 5.6rem; padding-bottom: 4.5rem; } .hero-stage { min-height: calc(100vh - 76px); display: flex; align-items: center; } .hero-stage::before { content: ""; position: absolute; inset: 2rem 0 auto; height: 32rem; background: radial-gradient(circle at 16% 25%, rgba(240, 216, 173, 0.22), transparent 22%), radial-gradient(circle at 82% 16%, rgba(92, 113, 168, 0.18), transparent 20%), linear-gradient(90deg, rgba(255, 255, 255, 0.03), transparent 28%, transparent 72%, rgba(255, 255, 255, 0.03)); filter: blur(10px); pointer-events: none; } .eyebrow, .list-label, .modal-eyebrow, .moment-kicker, .timeline-year { text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.73rem; color: var(--accent); } .display-hero { font-size: clamp(3rem, 6.4vw, 5.8rem); line-height: 0.92; letter-spacing: -0.06em; margin: 0.8rem 0 1.25rem; max-width: 10.5ch; text-wrap: balance; } .hero-lead, .section-heading p, .content-panel p, .timeline-card p, .moment-card p, .gallery-body p, .quote-card footer, .footer-copy, .modal-copy, .filter-status { color: var(--muted); } .hero-lead { max-width: 42rem; font-size: 1.06rem; } .hero-actions { margin-top: 1.75rem; margin-bottom: 1.9rem; } .btn { border-radius: 999px; padding: 0.88rem 1.2rem; font-weight: 600; box-shadow: none !important; transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease, border-color 0.22s ease; } .btn:hover, .btn:focus-visible { transform: translateY(-1px); } .btn-accent { background: linear-gradient(135deg, var(--accent-strong), var(--accent)); border: 1px solid rgba(240, 216, 173, 0.85); color: #101113; box-shadow: 0 16px 34px rgba(199, 166, 111, 0.22) !important; } .btn-accent:hover, .btn-accent:focus { background: #c4ad88; border-color: #c4ad88; color: #101113; } .btn-outline-light { border-color: rgba(255, 255, 255, 0.18); background: rgba(255, 255, 255, 0.03); } .btn-outline-light:hover, .btn-outline-light:focus { background: rgba(255, 255, 255, 0.08); border-color: rgba(255, 255, 255, 0.2); } .hero-meta { max-width: 44rem; } .stat-card, .content-panel, .timeline-card, .moment-card, .quote-card, .gallery-card, .gallery-modal-content, .modal-image-frame { background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.01)), var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); backdrop-filter: blur(14px); } .stat-card { padding: 1rem 1rem 0.95rem; min-height: 100%; position: relative; overflow: hidden; } .stat-card::after { content: ""; position: absolute; inset: auto -12% -46% auto; width: 7rem; height: 7rem; border-radius: 50%; background: radial-gradient(circle, rgba(199, 166, 111, 0.24), transparent 70%); } .stat-value { display: block; font-size: 1.05rem; font-weight: 700; color: var(--text); } .stat-label { display: block; margin-top: 0.25rem; font-size: 0.82rem; color: var(--muted); } .hero-media { max-width: 30rem; margin-inline: auto; position: relative; } .media-frame { position: relative; overflow: hidden; border-radius: 24px; border: 1px solid rgba(255, 255, 255, 0.12); background: #0c0d0e; box-shadow: var(--shadow); } .media-frame::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 28%, rgba(0, 0, 0, 0.28) 100%); pointer-events: none; } .media-frame-badge { position: absolute; top: 1rem; left: 1rem; z-index: 2; padding: 0.45rem 0.8rem; border-radius: 999px; background: rgba(7, 8, 10, 0.62); border: 1px solid rgba(255, 255, 255, 0.14); color: var(--text); font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; backdrop-filter: blur(10px); } .media-frame img { width: 100%; height: auto; aspect-ratio: 4 / 5; object-fit: cover; filter: saturate(0.88) contrast(1.06) brightness(0.92); transform: scale(1.02); } .image-caption { margin-top: 0.85rem; color: var(--muted); font-size: 0.86rem; } .section-heading { max-width: 46rem; margin-bottom: 2.2rem; } .section-heading h2 { font-size: clamp(2rem, 4vw, 3.25rem); line-height: 1.02; margin: 0.65rem 0 0.9rem; letter-spacing: -0.05em; } .content-panel, .moment-card, .quote-card { padding: 1.35rem; } .content-panel h3, .timeline-card h3, .moment-card h3, .gallery-body h3 { font-size: 1.15rem; margin-bottom: 0.7rem; } .detail-list li { display: flex; flex-direction: column; gap: 0.2rem; padding: 0.9rem 0; border-top: 1px solid rgba(255, 255, 255, 0.07); } .detail-list li:first-child { border-top: 0; padding-top: 0.2rem; } .detail-list span { color: var(--muted); font-size: 0.83rem; text-transform: uppercase; letter-spacing: 0.12em; } .detail-list strong { font-size: 0.98rem; font-weight: 600; } .timeline-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; } .timeline-card { padding: 1.4rem; } .timeline-card ul { margin: 1rem 0 0; padding-left: 1.1rem; color: var(--muted); } .timeline-card li + li { margin-top: 0.5rem; } .moment-card { min-height: 100%; } .gallery-toolbar { display: flex; gap: 1rem; justify-content: space-between; align-items: center; flex-wrap: wrap; margin-bottom: 1.5rem; } .btn-filter { background: transparent; border: 1px solid var(--border); color: var(--muted); padding: 0.68rem 0.95rem; } .btn-filter:hover, .btn-filter:focus, .btn-filter.active { background: var(--accent-soft); border-color: rgba(184, 160, 122, 0.45); color: var(--text); } .gallery-card { width: 100%; padding: 0; color: inherit; overflow: hidden; transition: transform 0.24s ease, border-color 0.24s ease, background 0.24s ease; } .gallery-card:hover, .gallery-card:focus-visible { transform: translateY(-4px); border-color: rgba(184, 160, 122, 0.45); background: var(--surface-strong); } .gallery-image-wrap { background: #0d0f11; overflow: hidden; border-bottom: 1px solid rgba(255, 255, 255, 0.06); } .gallery-image { width: 100%; height: 21rem; object-fit: cover; filter: grayscale(0.08); } .gallery-body { padding: 1rem 1rem 1.1rem; } .gallery-meta { display: flex; justify-content: space-between; gap: 1rem; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--accent); margin-bottom: 0.7rem; } .gallery-item.is-hidden { display: none; } .quote-card p { font-size: 1.28rem; line-height: 1.3; letter-spacing: -0.03em; margin-bottom: 1rem; } .site-footer { padding: 2rem 0 2.6rem; background: #0f1113; } .footer-title { font-weight: 600; margin-bottom: 0.25rem; } .gallery-modal-content { background: var(--surface-soft); } .modal-image-frame { padding: 0.6rem; background: #0c0d0e; } .modal-image-frame img { width: 100%; height: auto; border-radius: 10px; object-fit: cover; } .modal-copy { padding: 1rem 0; } .toast { border-radius: 12px; } .reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.8s ease, transform 0.8s ease; will-change: transform, opacity; } .reveal.is-visible { opacity: 1; transform: translateY(0); } .reveal-delay-1 { transition-delay: 0.08s; } .reveal-delay-2 { transition-delay: 0.16s; } .reveal-delay-3 { transition-delay: 0.24s; } :focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; } @media (max-width: 991.98px) { .timeline-grid { grid-template-columns: 1fr; } .timeline-grid::before { display: none; } .hero-section { padding-top: 3.8rem; } .hero-floating-note { right: 1rem; bottom: 1rem; } } @media (max-width: 767.98px) { .section-shell { padding: 3.4rem 0; } .display-hero { max-width: 12ch; } .gallery-image { height: 18rem; } .section-heading { margin-bottom: 1.4rem; } .hero-marquee { gap: 0.55rem; letter-spacing: 0.12em; } .hero-floating-note { position: static; width: 100%; margin-top: 1rem; } } .hero-copy { position: relative; z-index: 1; } .hero-roles { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 1.25rem; } .hero-roles span { padding: 0.42rem 0.78rem; border-radius: 999px; border: 1px solid rgba(255, 255, 255, 0.09); background: rgba(255, 255, 255, 0.03); color: var(--muted); font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase; } .hero-marquee { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 1.4rem; color: rgba(244, 243, 239, 0.72); font-size: 0.85rem; letter-spacing: 0.18em; text-transform: uppercase; } .hero-marquee span { position: relative; padding-right: 1rem; } .hero-marquee span::after { content: "•"; position: absolute; right: 0; color: rgba(199, 166, 111, 0.7); } .hero-marquee span:last-child::after { display: none; } .hero-floating-note { position: absolute; right: -1.2rem; bottom: 2.4rem; width: min(15rem, 72%); padding: 1rem 1.05rem; border-radius: 18px; border: 1px solid rgba(255, 255, 255, 0.12); background: rgba(12, 14, 16, 0.78); box-shadow: var(--shadow-soft); backdrop-filter: blur(12px); } .floating-kicker { display: block; margin-bottom: 0.35rem; color: var(--accent); font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.14em; } .hero-floating-note strong { display: block; font-size: 0.96rem; line-height: 1.45; } .content-panel, .timeline-card, .moment-card, .quote-card, .gallery-card { transition: transform 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease, background 0.28s ease; } .content-panel:hover, .timeline-card:hover, .moment-card:hover, .quote-card:hover, .gallery-card:hover { transform: translateY(-4px); border-color: rgba(199, 166, 111, 0.28); box-shadow: var(--shadow); } .timeline-grid { position: relative; } .timeline-grid::before { content: ""; position: absolute; left: 0; right: 0; top: 0.9rem; height: 1px; background: linear-gradient(90deg, transparent, rgba(199, 166, 111, 0.4), transparent); } .timeline-card { position: relative; padding: 1.45rem; } .timeline-card::before { content: ""; position: absolute; top: -0.5rem; left: 1.45rem; width: 0.7rem; height: 0.7rem; border-radius: 50%; background: linear-gradient(135deg, var(--accent-strong), var(--accent)); box-shadow: 0 0 0 6px rgba(199, 166, 111, 0.12); } .quote-card { position: relative; overflow: hidden; } .quote-card::before { content: ""; position: absolute; top: -1.6rem; right: 0.9rem; font-size: 8rem; line-height: 1; color: rgba(255, 255, 255, 0.04); font-family: Georgia, serif; } .gallery-image-wrap { position: relative; } .gallery-image-wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 30%, rgba(0, 0, 0, 0.38)); pointer-events: none; } .gallery-card:hover .gallery-image, .gallery-card:focus-visible .gallery-image { transform: scale(1.05); } .gallery-image { transition: transform 0.5s ease; } .site-footer { background: linear-gradient(180deg, rgba(11, 13, 15, 0.92), #090a0b); }