﻿:root {
  --bg: #f6f8fc;
  --surface: #ffffff;
  --text: #102033;
  --text-soft: #55657b;
  --text-faint: #7b8aa0;
  --line: rgba(79, 70, 229, 0.18);
  --line-soft: #d9e2ef;
  --brand: #4f46e5;
  --brand-strong: #3f38c9;
  --brand-soft: rgba(79, 70, 229, 0.12);
  --hero: #0d1b2a;
  --hero-soft: #c9d4ef;
  --success: #198754;
  --shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
  --radius: 24px;
  --radius-sm: 16px;
  --container: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "Figtree", sans-serif; color: var(--text); background: var(--bg); line-height: 1.6; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
button { cursor: pointer; border: 0; background: none; }
.container { width: min(calc(100% - 2rem), var(--container)); margin: 0 auto; }
.section { padding: 5.5rem 0; }
.section-light { background: var(--surface); }
.section-muted { background: var(--bg); }
.section-sep { height: 1px; background: linear-gradient(90deg, transparent, var(--line), transparent); }
.site-header { position: fixed; inset: 0 0 auto; z-index: 50; transition: background-color .25s ease, border-color .25s ease, box-shadow .25s ease; }
.site-header.is-scrolled { background: rgba(255,255,255,.92); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(15,23,42,.08); box-shadow: 0 8px 24px rgba(15,23,42,.05); }
.header-inner { min-height: 4.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brand { font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 1rem; color: #fff; }
.site-header.is-scrolled .brand, .site-header.menu-open .brand { color: var(--text); }
.brand-mark { color: var(--brand); }
.desktop-nav { display: flex; align-items: center; gap: .3rem; }
.desktop-nav a { padding: .6rem .9rem; border-radius: 999px; color: rgba(255,255,255,.72); font-size: .82rem; font-weight: 600; transition: color .2s ease, background-color .2s ease; }
.desktop-nav a:hover, .desktop-nav a.is-active { color: #fff; }
.site-header.is-scrolled .desktop-nav a, .site-header.menu-open .desktop-nav a { color: var(--text-soft); }
.site-header.is-scrolled .desktop-nav a:hover, .site-header.is-scrolled .desktop-nav a.is-active, .site-header.menu-open .desktop-nav a:hover, .site-header.menu-open .desktop-nav a.is-active { color: var(--brand); }
.header-actions { display: flex; align-items: center; gap: .75rem; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-height: 3rem; padding: .8rem 1.35rem; border-radius: 999px; font-weight: 700; transition: transform .2s ease, background-color .2s ease, border-color .2s ease, color .2s ease; }
.button:hover { transform: translateY(-1px); }
.button-sm { min-height: 2.25rem; padding: .45rem .95rem; font-size: .82rem; }
.button-primary { background: var(--brand); color: #fff; }
.button-primary:hover { background: var(--brand-strong); }
.button-secondary { border: 1px solid rgba(255,255,255,.2); color: #fff; background: rgba(255,255,255,.04); }
.button-secondary:hover { border-color: rgba(255,255,255,.38); background: rgba(255,255,255,.1); }
.button-full { width: 100%; }
.menu-toggle { display: none; width: 2.75rem; height: 2.75rem; border-radius: 14px; border: 1px solid rgba(255,255,255,.12); }
.menu-toggle span { display: block; width: 18px; height: 2px; background: #fff; margin: 4px auto; border-radius: 999px; }
.site-header.is-scrolled .menu-toggle, .site-header.menu-open .menu-toggle { border-color: rgba(15,23,42,.08); background: rgba(15,23,42,.03); }
.site-header.is-scrolled .menu-toggle span, .site-header.menu-open .menu-toggle span { background: var(--text); }
.mobile-menu { display: none; }
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; background: radial-gradient(circle at 20% 10%, rgba(99,102,241,.22), transparent 35%), radial-gradient(circle at 82% 28%, rgba(79,70,229,.18), transparent 32%), var(--hero); }
.hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 60px 60px; mask-image: linear-gradient(180deg, rgba(0,0,0,.9), transparent 85%); }
.hero-content { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0,1.1fr) minmax(320px,420px); gap: 4rem; align-items: center; padding: 7rem 0 5rem; }
.eyebrow-pill { display: inline-flex; align-items: center; padding: .45rem .8rem; border-radius: 999px; background: rgba(79,70,229,.14); border: 1px solid rgba(99,102,241,.28); color: #c9cbff; font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.hero h1, .section-heading h2, .quote-block p, .contact-copy h2, .project-modal h2, .profile-card h2, .card-item h3, .tool-card h3, .project-card h3, .timeline-card h3, .contact-panel h3 { font-family: "Space Grotesk", sans-serif; }
.hero h1 { margin: 1rem 0 0; color: #fff; font-size: clamp(3rem, 7vw, 5.7rem); line-height: .98; letter-spacing: -.05em; }
.hero h1 span { color: #7c8dff; }
.hero-text { max-width: 40rem; margin: 1.5rem 0 0; color: var(--hero-soft); font-size: 1.12rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.2rem; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 2rem; margin-top: 3rem; padding-top: 1.8rem; border-top: 1px solid rgba(255,255,255,.1); }
.hero-stats strong { display: block; color: #fff; font-family: "Space Grotesk", sans-serif; font-size: 1.7rem; }
.hero-stats span { color: var(--hero-soft); font-size: .82rem; }
.hero-card { position: relative; }
.hero-card-glow { position: absolute; inset: 8% -5% -5% 5%; background: rgba(79,70,229,.2); filter: blur(38px); }
.profile-card { position: relative; padding: 2rem; border-radius: var(--radius); border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.05); backdrop-filter: blur(12px); box-shadow: var(--shadow); }
.avatar-box { width: 5rem; height: 5rem; border-radius: 1.2rem; display: grid; place-items: center; font-family: "Space Grotesk", sans-serif; font-size: 1.6rem; font-weight: 700; color: #c9cbff; background: rgba(79,70,229,.16); border: 1px solid rgba(99,102,241,.35); }
.profile-card h2 { margin: 1.2rem 0 .25rem; color: #fff; font-size: 1.35rem; }
.profile-card p { margin: 0; color: #a9b6ff; }
.skill-meter-list { margin-top: 1.5rem; display: grid; gap: 1rem; }
.skill-meter-head { display: flex; justify-content: space-between; gap: 1rem; color: #dee5f7; font-size: .88rem; margin-bottom: .45rem; }
.skill-meter-track { height: .38rem; border-radius: 999px; background: rgba(255,255,255,.1); overflow: hidden; }
.skill-meter-track div { height: 100%; border-radius: inherit; background: linear-gradient(90deg,#4f46e5,#7c8dff); }
.tool-tags, .tag-list, .tool-list, .skill-list, .chip-cloud { display: flex; flex-wrap: wrap; gap: .55rem; }
.tool-tags { margin-top: 1.5rem; padding-top: 1.3rem; border-top: 1px solid rgba(255,255,255,.1); }
.tool-tags span, .tag-list span, .tool-list span, .skill-list span, .chip-cloud span { padding: .45rem .7rem; border-radius: 999px; font-size: .78rem; }
.tool-tags span { color: #dee5f7; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); }
.scroll-cue { position: absolute; left: 50%; bottom: 2rem; transform: translateX(-50%); color: #c6d1e5; text-transform: uppercase; letter-spacing: .18em; font-size: .72rem; }
.two-col { display: grid; grid-template-columns: .9fr 1.2fr; gap: 4rem; align-items: start; }
.portrait-column { position: relative; }
.portrait-card { position: relative; overflow: hidden; border-radius: var(--radius); border: 1px solid var(--line-soft); box-shadow: var(--shadow); }
.portrait-card img { width: 100%; height: 100%; min-height: 34rem; object-fit: cover; }
.portrait-label { position: absolute; inset: auto 0 0; padding: 1.4rem; background: linear-gradient(180deg, transparent, rgba(13,27,42,.88)); color: #fff; }
.portrait-label span { display: block; color: #b5c4ff; font-size: .9rem; margin-top: .2rem; }
.floating-badge { position: absolute; right: -1rem; bottom: -1.5rem; padding: 1rem 1.1rem; border-radius: 1.15rem; background: var(--brand); color: #fff; box-shadow: var(--shadow); }
.floating-badge strong { display: block; font-family: "Space Grotesk", sans-serif; font-size: 1.5rem; }
.floating-badge span { font-size: .84rem; color: rgba(255,255,255,.85); }
.section-heading { max-width: 46rem; margin-bottom: 2.2rem; }
.section-center { margin-inline: auto; text-align: center; }
.section-eyebrow { margin: 0 0 .6rem; color: var(--brand); text-transform: uppercase; letter-spacing: .16em; font-size: .72rem; font-weight: 800; }
.section-heading h2 { margin: 0; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.08; letter-spacing: -.04em; }
.section-heading p, .paragraph-stack, .card-item p, .project-body p, .timeline-card > p, .modal-gallery figcaption { color: var(--text-soft); }
.section-heading p { margin: .9rem 0 0; font-size: 1rem; }
.paragraph-stack { display: grid; gap: 1rem; }
.micro-heading { margin: 0 0 1rem; text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; color: var(--text-faint); font-weight: 800; }
.highlights-box { margin-top: 2rem; }
.check-grid, .experience-points, .deliverables-list { padding: 0; margin: 0; list-style: none; display: grid; gap: .85rem 1rem; }
.check-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.check-grid li::before, .deliverables-list li::before, .experience-points li::before { content: ""; width: .55rem; height: .55rem; border-radius: 999px; background: var(--brand); flex: 0 0 auto; margin-top: .42rem; }
.check-grid li, .deliverables-list li, .experience-points li { display: flex; gap: .75rem; color: var(--text-soft); }
.card-grid, .tool-grid, .project-grid { display: grid; gap: 1.25rem; }
.four-up { grid-template-columns: repeat(4, minmax(0,1fr)); }
.three-up { grid-template-columns: repeat(3, minmax(0,1fr)); }
.card-item, .tool-card, .project-card, .timeline-card { background: var(--surface); border: 1px solid var(--line-soft); border-radius: var(--radius); box-shadow: var(--shadow); }
.card-item, .tool-card, .timeline-card { padding: 1.4rem; }
.card-icon { width: 2.9rem; height: 2.9rem; border-radius: .95rem; display: grid; place-items: center; background: var(--brand-soft); color: var(--brand); font-weight: 800; margin-bottom: 1rem; }
.card-item h3 { font-size: 1rem; line-height: 1.35; margin: 0; }
.card-item p { margin: .65rem 0 0; font-size: .92rem; }
.filter-bar { display: flex; flex-wrap: wrap; gap: .7rem; margin-bottom: 1.6rem; }
.filter-chip { padding: .7rem 1rem; border-radius: 999px; border: 1px solid var(--line-soft); background: var(--surface); color: var(--text-soft); font-size: .82rem; font-weight: 700; }
.filter-chip.is-active { background: var(--brand); border-color: var(--brand); color: #fff; }
.project-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.project-card { overflow: hidden; }
.project-image { position: relative; aspect-ratio: 16 / 9; }
.project-image img { width: 100%; height: 100%; object-fit: cover; }
.project-category, .project-highlight { position: absolute; top: 1rem; z-index: 1; padding: .45rem .7rem; border-radius: 999px; font-size: .72rem; font-weight: 800; }
.project-category { left: 1rem; }
.project-highlight { right: 1rem; background: rgba(255,255,255,.92); color: var(--text); }
.project-body { padding: 1.4rem; }
.project-body h3, .timeline-card h3, .tool-card h3, .contact-panel h3 { margin: 0; }
.project-body p { margin: .7rem 0 0; }
.tag-list { margin: 1rem 0 0; }
.tag-list span, .tool-list span, .skill-list span, .chip-cloud span { border: 1px solid var(--line-soft); background: #f7f9fd; color: var(--text-soft); }
.project-footer { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1rem 1.4rem 1.4rem; }
.deliverables-preview { display: grid; gap: .35rem; color: var(--text-faint); font-size: .8rem; }
.project-open { color: var(--brand); font-weight: 800; }
.timeline { position: relative; max-width: 52rem; padding-left: 2.8rem; }
.timeline::before { content: ""; position: absolute; left: .9rem; top: .5rem; bottom: .5rem; width: 1px; background: linear-gradient(180deg, transparent, var(--brand), transparent); }
.timeline-entry { position: relative; margin-bottom: 1.25rem; }
.timeline-entry::before { content: ""; position: absolute; left: -2.35rem; top: 1.6rem; width: .8rem; height: .8rem; border-radius: 999px; background: var(--brand); box-shadow: 0 0 0 5px rgba(79,70,229,.12); }
.timeline-head { display: flex; justify-content: space-between; gap: 1rem; align-items: start; margin-bottom: .8rem; }
.timeline-role { color: var(--brand); font-weight: 700; margin: .3rem 0 0; }
.timeline-period { color: var(--text-faint); font-size: .84rem; margin: .3rem 0 0; }
.status-badge { display: inline-flex; padding: .3rem .65rem; border-radius: 999px; background: rgba(25,135,84,.12); color: var(--success); font-size: .74rem; font-weight: 800; margin-top: .55rem; }
.tool-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.tool-head { display: flex; align-items: center; gap: .85rem; margin-bottom: 1.3rem; }
.progress-list { display: grid; gap: 1rem; }
.progress-head { display: flex; justify-content: space-between; gap: 1rem; margin-bottom: .4rem; color: var(--text-soft); font-size: .9rem; }
.progress-track { height: .45rem; border-radius: 999px; background: #e4eaf3; overflow: hidden; }
.progress-track div { height: 100%; border-radius: inherit; background: linear-gradient(90deg,#4f46e5,#7c8dff); }
.also-tools { margin-top: 2rem; }
.center-text { text-align: center; }
.quote-section { padding-top: 4rem; }
.quote-block { margin: 0; padding-left: 2rem; border-left: 4px solid var(--brand); }
.quote-mark { display: block; color: #cfd4ff; font-size: 4rem; line-height: 1; }
.quote-block p { margin: .4rem 0 0; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.18; letter-spacing: -.04em; }
.quote-block footer { margin-top: 1rem; color: var(--text-soft); font-weight: 700; }
.contact-section { background: radial-gradient(circle at 15% 10%, rgba(99,102,241,.18), transparent 22%), var(--hero); color: #fff; padding-bottom: 2.5rem; }
.contact-grid { display: grid; grid-template-columns: .95fr 1.15fr; gap: 3rem; align-items: start; }
.contact-eyebrow, .contact-text, .contact-links span, .form-note { color: #a8b6ca; }
.contact-copy h2 { margin: 0; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.08; letter-spacing: -.04em; }
.contact-text { max-width: 34rem; margin-top: 1rem; }
.contact-links { display: grid; gap: 1rem; margin-top: 2rem; }
.contact-links a, .contact-links div { display: block; padding: 1rem 1.1rem; border-radius: var(--radius-sm); background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); }
.contact-links strong, .footer-bar p:first-child { color: #fff; }
.contact-links span { display: block; margin-top: .2rem; }
.contact-panel { padding: 1.5rem; border-radius: var(--radius); border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.05); backdrop-filter: blur(12px); }
.contact-panel h3 { font-size: 1.15rem; margin-bottom: 1rem; }
.contact-panel form { display: grid; gap: 1rem; }
.form-row { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.contact-panel label { display: grid; gap: .45rem; }
.contact-panel label span { font-size: .84rem; color: #d8e1ef; }
.contact-panel input, .contact-panel textarea { width: 100%; border-radius: 14px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.05); color: #fff; padding: .9rem 1rem; outline: none; }
.contact-panel input::placeholder, .contact-panel textarea::placeholder { color: #8294ad; }
.contact-panel input:focus, .contact-panel textarea:focus { border-color: rgba(124,141,255,.85); box-shadow: 0 0 0 4px rgba(79,70,229,.16); }
.form-note.is-success { color: #82ddb2; }
.footer-bar { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-top: 3rem; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.08); }
.footer-bar p { margin: 0; color: #7f91a9; font-size: .84rem; }
.footer-bar p span { color: #7c8dff; }
.project-modal { width: min(920px, calc(100% - 2rem)); border: 0; padding: 0; background: transparent; }
.project-modal::backdrop { background: rgba(2,6,23,.72); backdrop-filter: blur(8px); }
.project-modal-card { position: relative; background: var(--surface); border-radius: 28px; padding: 1.5rem; box-shadow: 0 30px 80px rgba(15,23,42,.22); max-height: 90vh; overflow: auto; }
.modal-close { position: sticky; top: 0; margin-left: auto; display: grid; place-items: center; width: 2.6rem; height: 2.6rem; border-radius: 999px; border: 1px solid var(--line-soft); background: rgba(255,255,255,.95); color: var(--text); font-size: 1.7rem; }
.modal-hero { display: grid; gap: 1.25rem; }
.modal-hero img { width: 100%; border-radius: 20px; aspect-ratio: 16 / 9; object-fit: cover; }
.modal-header { display: grid; gap: .75rem; }
.modal-header h2 { margin: 0; font-size: clamp(1.8rem, 3vw, 2.5rem); line-height: 1.1; letter-spacing: -.04em; }
.modal-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; margin-top: 1.5rem; }
.modal-panel { padding: 1rem; border-radius: 20px; }
.modal-panel strong { display: block; margin-bottom: .55rem; text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; }
.modal-section { margin-top: 1.5rem; }
.modal-section h3 { margin-bottom: .8rem; font-family: "Space Grotesk", sans-serif; }
.modal-gallery { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; margin-top: 1.2rem; }
.modal-gallery figure { margin: 0; }
.modal-gallery img { width: 100%; border-radius: 18px; aspect-ratio: 4 / 3; object-fit: cover; }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .55s ease, transform .55s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width: 1080px) { .four-up { grid-template-columns: repeat(2, minmax(0,1fr)); } .three-up, .tool-grid, .project-grid, .contact-grid, .hero-content, .two-col, .modal-grid { grid-template-columns: 1fr; } .hero-card { max-width: 30rem; } }
@media (max-width: 860px) { .desktop-nav, .desktop-cta { display: none; } .menu-toggle, .mobile-menu { display: block; } .mobile-menu { max-height: 0; overflow: hidden; background: rgba(255,255,255,.97); backdrop-filter: blur(14px); transition: max-height .25s ease; } .site-header.menu-open { background: rgba(255,255,255,.97); border-bottom: 1px solid rgba(15,23,42,.08); } .mobile-menu-inner { display: grid; gap: .55rem; padding: 0 0 1rem; } .mobile-menu a { padding: .9rem 0; color: var(--text-soft); border-bottom: 1px solid rgba(15,23,42,.05); font-weight: 700; } .site-header.menu-open .mobile-menu { max-height: 28rem; } }
@media (max-width: 720px) { .section { padding: 4.2rem 0; } .hero-content { padding-top: 6.4rem; } .hero-stats, .check-grid, .form-row, .modal-gallery { grid-template-columns: 1fr; } .check-grid, .hero-stats { display: grid; } .timeline { padding-left: 2rem; } .timeline-entry::before { left: -1.55rem; } .timeline::before { left: .35rem; } .footer-bar { flex-direction: column; } }

.project-card-featured { background: linear-gradient(180deg, #ffffff, #fbfcff); }
.project-mosaic { position: relative; padding: 1rem; background: linear-gradient(135deg, color-mix(in srgb, var(--case-surface) 78%, #ffffff 22%), #ffffff); border-bottom: 1px solid var(--line-soft); }
.project-mosaic-grid { display: grid; grid-template-columns: 1.5fr .9fr; grid-template-rows: repeat(2, minmax(0, 140px)); gap: .85rem; margin-top: 3rem; }
.project-shot { margin: 0; overflow: hidden; border-radius: 20px; border: 1px solid rgba(255,255,255,.8); box-shadow: 0 16px 30px rgba(15,23,42,.12); background: #fff; }
.project-shot img { width: 100%; height: 100%; object-fit: cover; display: block; }
.project-shot.shot-1 { grid-row: 1 / span 2; min-height: 288px; }
.project-shot.shot-2, .project-shot.shot-3 { min-height: 140px; }
.project-mosaic-caption { margin-top: .85rem; color: var(--text-faint); font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 700; }
.project-body-featured { display: grid; gap: 1.2rem; }
.project-kicker { margin: 0 0 .45rem; text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; font-weight: 800; color: var(--brand); }
.project-meta-strip { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; padding-top: .4rem; }
.project-meta-label { display: block; margin-bottom: .6rem; color: var(--text-faint); text-transform: uppercase; letter-spacing: .12em; font-size: .7rem; font-weight: 800; }
.deliverables-preview-featured { gap: .45rem; }
.project-footer-featured { align-items: center; border-top: 1px solid var(--line-soft); }
.project-note { margin: 0; color: var(--text-faint); font-size: .88rem; max-width: 28rem; }
@media (max-width: 720px) { .project-mosaic-grid { grid-template-columns: 1fr; grid-template-rows: none; } .project-shot.shot-1 { grid-row: auto; min-height: 220px; } .project-shot.shot-2, .project-shot.shot-3 { min-height: 180px; } .project-meta-strip { grid-template-columns: 1fr; } .project-footer-featured { align-items: start; } }

.video-frame { position: relative; width: 100%; padding-top: 56.25%; border-radius: 20px; overflow: hidden; background: #0f172a; }
.video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-link { display: inline-flex; align-items: center; justify-content: center; min-height: 2.75rem; padding: .7rem 1rem; border-radius: 999px; background: #dc2626; color: #fff; font-weight: 700; }
.video-link:hover { background: #b91c1c; }

.video-links-list { display: flex; flex-wrap: wrap; gap: .75rem; }

.project-shot img,
.modal-gallery img,
.modal-hero img {
  cursor: zoom-in;
}
.image-lightbox {
  width: min(1100px, calc(100% - 2rem));
  border: 0;
  padding: 0;
  background: transparent;
}
.image-lightbox::backdrop {
  background: rgba(2, 6, 23, 0.84);
  backdrop-filter: blur(10px);
}
.image-lightbox-card {
  position: relative;
  background: rgba(15, 23, 42, 0.96);
  border-radius: 28px;
  padding: 1rem 1rem 1.25rem;
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.35);
}
.image-lightbox-close {
  position: absolute;
  top: .85rem;
  right: .85rem;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 1.7rem;
}
.image-lightbox-close:hover {
  background: rgba(255,255,255,.2);
}
#image-lightbox-img {
  display: block;
  width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 20px;
  background: #0f172a;
}
#image-lightbox-caption {
  margin: .9rem .5rem 0;
  color: #cbd5e1;
  text-align: center;
  font-size: .92rem;
}
