/* ═══════════════════════════════════════════════════════════════
   ATHENA — SECTIONS  (hero · trust · about · stats · services ·
   portfolio · process · testimonials · financing · faq · areas ·
   journal · contact · footer · lightbox · tweaks)
   ═══════════════════════════════════════════════════════════════ */

/* ─────────── HERO (pinned, scroll-scrubbed statue) ─────────── */
.hero { position: relative; z-index: 1; height: 240vh; }
.hero-pin {
  position: sticky; top: 0; height: 100vh; min-height: 600px; overflow: hidden;
  background:
    radial-gradient(120% 90% at 72% 30%, rgba(var(--accent-rgb),0.10), transparent 55%),
    var(--ink);
}
.hero-vid {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center 12%;
  filter: brightness(0.6) saturate(0.92) contrast(1.05);
  will-change: transform;
}
.hero-veil {
  position: absolute; inset: 0; will-change: opacity;
  background:
    linear-gradient(96deg, rgba(11,13,18,0.9) 0%, rgba(11,13,18,0.55) 34%, rgba(11,13,18,0.12) 56%, rgba(11,13,18,0.4) 100%),
    linear-gradient(to bottom, rgba(11,13,18,0.72) 0%, transparent 20%, transparent 52%, var(--ink) 100%);
}
.hero-inner { position: absolute; inset: 0; display: grid; place-items: center; padding: var(--nav-h) 2rem 0; will-change: opacity; }
.hero-grid { width: 100%; max-width: var(--maxw); display: grid; grid-template-columns: 1.08fr 0.92fr; align-items: center; gap: 2rem; will-change: transform; }
.hero-copy { max-width: 640px; }
.hero-eyebrow { font-family: var(--font-sans); font-size: 0.7rem; font-weight: 600; letter-spacing: 0.26em; text-transform: uppercase; color: var(--accent-bright); margin-bottom: 1.5rem; display: inline-flex; align-items: center; gap: 0.8rem; }
.hero-eyebrow::before { content: ''; width: 30px; height: 8px; background: var(--accent-bright); -webkit-mask: var(--meander-key) repeat-x center / auto 8px; mask: var(--meander-key) repeat-x center / auto 8px; }
.hero h1 { color: var(--paper); font-size: clamp(2.9rem, 6.3vw, 5.5rem); line-height: 0.98; letter-spacing: -0.014em; margin-bottom: 1.5rem; }
.hero h1 em { font-style: italic; color: var(--accent-pale); }
.hero-sub { font-family: var(--font-sans); font-size: 1.04rem; line-height: 1.7; color: var(--paper-muted); max-width: 32rem; margin: 1.6rem 0 2.3rem; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 1rem; }

.hero-logo { position: relative; display: flex; align-items: center; justify-content: center; will-change: transform; }
.hero-logo img { width: 100%; max-width: 440px; height: auto; filter: drop-shadow(0 24px 60px rgba(0,0,0,0.6)); }
[data-ornament="minimal"] .hero-logo .halo { display: none; }
.hero-logo .halo { position: absolute; width: 74%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, rgba(var(--accent-rgb),0.14), transparent 68%); z-index: -1; }

.scroll-cue { position: absolute; bottom: 1.9rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.6rem; z-index: 3; }
.scroll-cue span { font-family: var(--font-sans); font-size: 0.56rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent-bright); }
.scroll-cue .track { width: 1px; height: 42px; background: linear-gradient(var(--accent-bright), transparent); position: relative; overflow: hidden; }
.scroll-cue .track::after { content: ''; position: absolute; top: -50%; left: 0; width: 1px; height: 50%; background: var(--accent-pale); animation: cueDrop 2.4s var(--ease) infinite; }
@keyframes cueDrop { 0% { top: -50%; } 60%, 100% { top: 100%; } }
.hero-progress { position: absolute; left: 0; bottom: 0; width: 100%; height: 2px; background: rgba(var(--accent-rgb),0.14); z-index: 4; }
.hero-progress span { display: block; height: 100%; width: 0%; background: var(--accent-bright); }

/* ─────────── TRUST STRIP ─────────── */
.trust { position: relative; z-index: 2; border-top: 1px solid var(--ink-line); border-bottom: 1px solid var(--ink-line); }
.trust-row { display: flex; align-items: stretch; justify-content: space-between; flex-wrap: wrap; }
.trust-item { flex: 1 1 0; min-width: 180px; padding: 1.7rem 1.6rem; display: flex; flex-direction: column; gap: 0.35rem; border-left: 1px solid var(--ink-line); }
.trust-item:first-child { border-left: none; }
.trust-item .k { font-family: var(--font-sans); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent-bright); }
.trust-item .v { font-family: var(--font-display); font-size: 1.28rem; color: var(--paper); line-height: 1.15; }
.trust-item .v small { font-family: var(--font-sans); font-size: 0.78rem; color: var(--paper-muted); letter-spacing: 0.02em; }

/* ─────────── ABOUT / STORY ─────────── */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
.about-copy .lead { margin: 1.4rem 0; }
.about-copy .body + .body { margin-top: 1.1rem; }
.about-sig { display: flex; align-items: center; gap: 1.1rem; margin-top: 2.2rem; }
.about-sig .name { font-family: var(--font-display); font-size: 1.35rem; color: var(--ink-text); line-height: 1.1; }
.about-sig .role { font-family: var(--font-sans); font-size: 0.66rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-deep); margin-top: 0.25rem; }

.about-figure { position: relative; }
.about-figure .frame { position: relative; overflow: hidden; }
.about-figure img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/5; }
.about-figure image-slot { display: block; width: 100%; height: auto; aspect-ratio: 4/5; }
.about-figure .seal {
  position: absolute; right: -18px; bottom: -18px; width: 118px; height: 118px; border-radius: 50%;
  background: var(--ink); color: var(--accent-pale); display: grid; place-items: center; text-align: center;
  border: 1px solid rgba(var(--accent-rgb),0.4); box-shadow: 0 18px 40px rgba(11,13,18,0.28); z-index: 4;
}
.about-figure .seal b { font-family: var(--font-display); font-size: 1.9rem; line-height: 0.9; display: block; }
.about-figure .seal span { font-family: var(--font-sans); font-size: 0.5rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--paper-muted); margin-top: 0.2rem; }

.principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; margin-top: 2.6rem; }
.principle { }
.principle .n { font-family: var(--font-display); font-size: 0.9rem; color: var(--accent-deep); letter-spacing: 0.1em; }
.principle h4 { font-family: var(--font-display); font-size: 1.15rem; color: var(--ink-text); margin: 0.3rem 0 0.35rem; }
.principle p { font-family: var(--font-sans); font-size: 0.84rem; line-height: 1.55; color: var(--ink-muted); }

/* ─────────── STATS BAND ─────────── */
.stat-band { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--marble-line); }
.stat { padding: clamp(2rem, 3.4vw, 3rem) 1.5rem; text-align: center; border-left: 1px solid var(--marble-line); }
.stat:first-child { border-left: none; }
.stat .num { font-family: var(--font-display); font-size: clamp(2.4rem, 4.4vw, 3.6rem); line-height: 1; color: var(--ink-text); }
.stat .num .u { color: var(--accent-deep); }
.stat .lbl { font-family: var(--font-sans); font-size: 0.64rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-muted); margin-top: 0.7rem; }
.s-ink .stat .num, .s-ink-2 .stat .num { color: var(--paper); }
.s-ink .stat .num .u, .s-ink-2 .stat .num .u { color: var(--accent-bright); }
.s-ink .stat .lbl, .s-ink-2 .stat .lbl { color: var(--paper-muted); }

/* ─────────── SERVICES ─────────── */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: 3.4rem; }
.svc { position: relative; display: flex; flex-direction: column; text-decoration: none; background: #fff; border: 1px solid var(--marble-line); overflow: hidden; transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), border-color 0.5s var(--ease); }
[data-surface="obsidian"] .svc { background: var(--ink-2); border-color: var(--ink-line); }
.svc:hover { transform: translateY(-8px); box-shadow: 0 26px 54px rgba(11,13,18,0.14); border-color: rgba(var(--accent-rgb),0.4); }
.svc-media { position: relative; aspect-ratio: 16/11; overflow: hidden; }
.svc-media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02) contrast(1.02); transition: transform 0.9s var(--ease); }
.svc:hover .svc-media img { transform: scale(1.06); }
.svc-media .tag { position: absolute; top: 0.9rem; left: 0.9rem; z-index: 2; font-family: var(--font-sans); font-size: 0.56rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent-pale); background: rgba(11,13,18,0.72); padding: 0.4rem 0.7rem; }
.svc-body { padding: 1.5rem 1.6rem 1.8rem; display: flex; flex-direction: column; flex: 1; }
.svc-body .n { font-family: var(--font-display); font-size: 0.95rem; color: var(--accent-deep); }
[data-surface="obsidian"] .svc-body .n { color: var(--accent-bright); }
.svc-body h3 { font-size: 1.55rem; color: var(--ink-text); margin: 0.2rem 0 0.7rem; }
[data-surface="obsidian"] .svc-body h3 { color: var(--paper); }
.svc-body p { font-family: var(--font-sans); font-size: 0.9rem; line-height: 1.65; color: var(--ink-muted); }
[data-surface="obsidian"] .svc-body p { color: var(--paper-muted); }
.svc-body .go { margin-top: auto; padding-top: 1.2rem; display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-sans); font-size: 0.66rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-deep); }
[data-surface="obsidian"] .svc-body .go { color: var(--accent-bright); }
.svc-body .go .arrow { transition: transform 0.4s var(--ease); }
.svc:hover .svc-body .go .arrow { transform: translateX(4px); }
.svc.wide { grid-column: span 2; background: var(--marble-2); }
[data-surface="obsidian"] .svc.wide { background: var(--ink-2); }
.svc.wide .svc-media { aspect-ratio: 16/6.5; }

/* ─────────── PORTFOLIO / GALLERY ─────────── */
.filter-bar { display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; margin: 3rem 0; }
.filter-btn { padding: 0.55rem 1.25rem; font-family: var(--font-sans); font-size: 0.64rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--ink-muted); background: transparent; border: 1px solid var(--marble-line); cursor: pointer; transition: all 0.35s var(--ease); }
.filter-btn:hover { color: var(--accent-deep); border-color: rgba(var(--accent-rgb),0.5); }
.filter-btn.active { color: var(--paper); background: var(--ink); border-color: var(--ink); }
.s-ink .filter-btn { color: var(--paper-muted); border-color: var(--ink-line); }
.s-ink .filter-btn.active { color: #1c150a; background: var(--accent); border-color: var(--accent); }

.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.gitem { position: relative; cursor: pointer; overflow: hidden; background: var(--marble-3); }
.gitem-media { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.gitem-media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02) contrast(1.02); transition: transform 0.9s var(--ease); }
.gitem:hover .gitem-media img { transform: scale(1.06); }
.gitem-media::after { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(11,13,18,0.78), rgba(11,13,18,0.06) 46%, transparent 66%); opacity: 0.9; transition: opacity 0.5s var(--ease); }
.gitem-frame { position: absolute; inset: 12px; z-index: 3; pointer-events: none; border: 1px solid rgba(var(--accent-rgb),0.55); opacity: 0; transform: scale(1.03); transition: opacity 0.5s var(--ease), transform 0.5s var(--ease); }
.gitem:hover .gitem-frame { opacity: 1; transform: scale(1); }
.gitem-cap { position: absolute; left: 0; right: 0; bottom: 0; z-index: 4; padding: 1.4rem; transform: translateY(6px); transition: transform 0.5s var(--ease); }
.gitem:hover .gitem-cap { transform: none; }
.gitem-cap .t { font-family: var(--font-display); font-size: 1.12rem; color: var(--paper); line-height: 1.2; }
.gitem-cap .l { display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-sans); font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-bright); margin-top: 0.5rem; }
.gitem-cap .l::before { content: ''; width: 14px; height: 1px; background: var(--accent-bright); }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 95; background: rgba(8,9,12,0.95); backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.4s var(--ease); padding: 2rem; }
.lightbox.open { opacity: 1; pointer-events: auto; }
.lb-stage { position: relative; max-width: 1000px; width: 100%; }
.lb-frame { position: relative; }
.lb-frame img { width: 100%; max-height: 78vh; object-fit: contain; display: block; }
.lb-cap { text-align: center; margin-top: 1.3rem; }
.lb-cap .t { font-family: var(--font-display); font-size: 1.5rem; color: var(--paper); }
.lb-cap .l { font-family: var(--font-sans); font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-bright); margin-top: 0.5rem; }
.lb-btn { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(var(--accent-rgb),0.1); border: 1px solid rgba(var(--accent-rgb),0.42); color: var(--accent-bright); width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s; z-index: 5; }
.lb-btn:hover { background: rgba(var(--accent-rgb),0.24); }
.lb-prev { left: -70px; } .lb-next { right: -70px; }
.lb-close { position: absolute; top: 1.4rem; right: 1.4rem; background: none; border: none; color: var(--accent-bright); cursor: pointer; z-index: 6; }

/* ─────────── PROCESS (dark band) ─────────── */
.proc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 3.6rem; }
.proc-step { position: relative; padding: 0 1.8rem; }
.proc-step:not(:first-child) { border-left: 1px solid var(--ink-line); }
.proc-step .rn { font-family: var(--font-display); font-size: 3.2rem; line-height: 1; color: var(--accent-bright); opacity: 0.9; }
.proc-step h3 { font-size: 1.5rem; color: var(--paper); margin: 0.9rem 0 0.7rem; }
.proc-step p { font-family: var(--font-sans); font-size: 0.88rem; line-height: 1.65; color: var(--paper-muted); }

/* ─────────── TESTIMONIALS ─────────── */
.sample-note { font-family: var(--font-sans); font-size: 0.68rem; letter-spacing: 0.08em; color: var(--ink-faint); font-style: italic; margin-top: 0.9rem; }
.s-ink .sample-note { color: var(--paper-faint); }
.tst-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: 3.2rem; }
.tst { position: relative; background: #fff; border: 1px solid var(--marble-line); padding: 2.2rem 2rem; display: flex; flex-direction: column; }
[data-surface="obsidian"] .tst { background: var(--ink-2); border-color: var(--ink-line); }
.tst .stars { display: flex; gap: 3px; color: var(--accent); margin-bottom: 1.1rem; }
.tst blockquote { font-family: var(--font-display); font-size: 1.28rem; line-height: 1.45; color: var(--ink-text); margin: 0 0 1.6rem; font-weight: 400; }
[data-surface="obsidian"] .tst blockquote { color: var(--paper); }
.tst .who { margin-top: auto; display: flex; align-items: center; gap: 0.85rem; }
.tst .who .nm { font-family: var(--font-sans); font-size: 0.82rem; font-weight: 700; color: var(--ink-text); letter-spacing: 0.02em; }
[data-surface="obsidian"] .tst .who .nm { color: var(--paper); }
.tst .who .loc { font-family: var(--font-sans); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-deep); margin-top: 0.2rem; }
[data-surface="obsidian"] .tst .who .loc { color: var(--accent-bright); }
.tst .who .tick { width: 34px; height: 34px; flex: none; border-radius: 50%; background: var(--marble-2); display: grid; place-items: center; color: var(--accent-deep); font-family: var(--font-display); font-size: 1rem; }

/* ─────────── FINANCING (slim band) ─────────── */
.fin-row { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.fin-row .txt { max-width: 42rem; }
.fin-row h3 { color: var(--paper); font-size: clamp(1.6rem, 2.6vw, 2.3rem); }
.fin-row p { font-family: var(--font-sans); font-size: 0.95rem; line-height: 1.6; color: var(--paper-muted); margin-top: 0.7rem; }

/* ─────────── FAQ ─────────── */
.faq-grid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: start; }
.faq-list { border-top: 1px solid var(--marble-line); }
.s-ink .faq-list { border-color: var(--ink-line); }
.faq-item { border-bottom: 1px solid var(--marble-line); }
.s-ink .faq-item { border-color: var(--ink-line); }
.faq-q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 1.4rem 0; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; font-family: var(--font-display); font-size: 1.2rem; color: var(--ink-text); transition: color 0.3s; }
.s-ink .faq-q { color: var(--paper); }
.faq-q:hover { color: var(--accent-deep); }
.s-ink .faq-q:hover { color: var(--accent-bright); }
.faq-q .ic { position: relative; width: 15px; height: 15px; flex: none; }
.faq-q .ic::before, .faq-q .ic::after { content: ''; position: absolute; background: var(--accent); transition: transform 0.35s var(--ease); }
.faq-q .ic::before { top: 7px; left: 0; width: 100%; height: 1.5px; }
.faq-q .ic::after { left: 7px; top: 0; width: 1.5px; height: 100%; }
.faq-item.open .faq-q .ic::after { transform: scaleY(0); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease); }
.faq-a p { font-family: var(--font-sans); font-size: 0.95rem; line-height: 1.7; color: var(--ink-muted); padding-bottom: 1.5rem; max-width: 42rem; }
.s-ink .faq-a p { color: var(--paper-muted); }

/* ─────────── SERVICE AREAS ─────────── */
.areas-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
.areas-list { column-count: 2; column-gap: 2rem; }
.areas-list li { list-style: none; font-family: var(--font-display); font-size: 1.35rem; color: var(--ink-text); padding: 0.6rem 0; border-bottom: 1px solid var(--marble-line); display: flex; align-items: center; gap: 0.7rem; break-inside: avoid; }
.s-ink .areas-list li { color: var(--paper); border-color: var(--ink-line); }
.areas-list li::before { content: ''; width: 7px; height: 7px; flex: none; background: var(--accent); transform: rotate(45deg); }
.areas-fig { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.areas-fig img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02); }
.areas-fig .cap { position: absolute; left: 0; right: 0; bottom: 0; padding: 1.4rem; background: linear-gradient(to top, rgba(11,13,18,0.8), transparent); color: var(--paper); font-family: var(--font-sans); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; }

/* ─────────── JOURNAL ─────────── */
.jrnl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: 3.2rem; }
.jrnl { text-decoration: none; display: flex; flex-direction: column; }
.jrnl-media { position: relative; aspect-ratio: 3/2; overflow: hidden; background: var(--marble-3); }
.jrnl-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.9s var(--ease); filter: saturate(1.02); }
.jrnl:hover .jrnl-media img { transform: scale(1.05); }
.jrnl .meta { display: flex; align-items: center; gap: 0.8rem; margin: 1.1rem 0 0.6rem; font-family: var(--font-sans); font-size: 0.62rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-deep); }
[data-surface="obsidian"] .jrnl .meta { color: var(--accent-bright); }
.jrnl .meta .dot { width: 3px; height: 3px; border-radius: 50%; background: currentColor; }
.jrnl .meta .date { color: var(--ink-faint); }
.jrnl h3 { font-size: 1.4rem; line-height: 1.2; color: var(--ink-text); transition: color 0.3s; }
[data-surface="obsidian"] .jrnl h3 { color: var(--paper); }
.jrnl:hover h3 { color: var(--accent-deep); }
[data-surface="obsidian"] .jrnl:hover h3 { color: var(--accent-bright); }

/* ─────────── CONTACT / INQUIRE ─────────── */
.inquire-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2.5rem, 5vw, 4.5rem); align-items: start; }
.contact-item { padding: 1.3rem 0; border-bottom: 1px solid var(--ink-line); }
.contact-item .k { font-family: var(--font-sans); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-bright); margin-bottom: 0.5rem; }
.contact-item .v { font-family: var(--font-display); font-size: 1.3rem; color: var(--paper); }
.contact-item .v a { text-decoration: none; transition: color 0.3s; }
.contact-item .v a:hover { color: var(--accent-bright); }
.contact-cred { margin-top: 2rem; font-family: var(--font-sans); font-size: 0.72rem; line-height: 1.9; color: var(--paper-muted); letter-spacing: 0.03em; }
.contact-cred .gold { color: var(--accent-bright); }

.form { position: relative; background: var(--ink-2); padding: clamp(1.8rem, 3vw, 2.8rem); border: 1px solid var(--ink-line); }
.form-sub { display: flex; align-items: center; gap: 0.8rem; margin: 2rem 0 1.2rem; }
.form-sub:first-of-type { margin-top: 0; }
.form-sub-line { width: 26px; height: 8px; flex: none; background: var(--accent-bright); -webkit-mask: var(--meander-key) repeat-x center / auto 8px; mask: var(--meander-key) repeat-x center / auto 8px; }
.form-sub-label { font-family: var(--font-sans); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-bright); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { margin-bottom: 1.2rem; }
.field label { display: block; font-family: var(--font-sans); font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--paper-muted); margin-bottom: 0.55rem; }
.field label em { color: var(--accent-bright); font-style: normal; }
.field input, .field textarea { width: 100%; padding: 0.9rem 1rem; background: rgba(8,9,12,0.6); border: 1px solid var(--ink-line); color: var(--paper); font-family: var(--font-sans); font-size: 0.92rem; transition: border-color 0.3s, box-shadow 0.3s; }
.field input:focus, .field textarea:focus { outline: none; border-color: rgba(var(--accent-rgb),0.6); box-shadow: 0 0 0 1px rgba(var(--accent-rgb),0.3); }
.field textarea { resize: vertical; min-height: 110px; }
.form-note { font-family: var(--font-sans); font-size: 0.76rem; color: var(--paper-faint); margin-top: 1rem; }
.form-success { display: none; padding: 1.1rem 1.3rem; margin-top: 1.3rem; border: 1px solid rgba(var(--accent-rgb),0.4); background: rgba(var(--accent-rgb),0.08); color: var(--accent-pale); font-family: var(--font-sans); font-size: 0.9rem; line-height: 1.55; }
.form-success.show { display: block; }

/* custom dropdown */
.cdrop { position: relative; }
.cdrop-btn { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 0.7rem; padding: 0.9rem 1rem; background: rgba(8,9,12,0.6); border: 1px solid var(--ink-line); color: var(--paper-faint); font-family: var(--font-sans); font-size: 0.92rem; text-align: left; cursor: pointer; transition: border-color 0.3s; }
.cdrop-btn:hover { border-color: rgba(var(--accent-rgb),0.45); }
.cdrop.open .cdrop-btn { border-color: rgba(var(--accent-rgb),0.6); }
.cdrop-btn.filled { color: var(--paper); }
.cdrop-chev { width: 13px; height: 13px; color: var(--accent-bright); flex: none; transition: transform 0.35s var(--ease); }
.cdrop.open .cdrop-chev { transform: rotate(180deg); }
.cdrop-menu { position: absolute; top: calc(100% + 5px); left: 0; right: 0; z-index: 30; list-style: none; margin: 0; padding: 5px; background: #12151b; border: 1px solid rgba(var(--accent-rgb),0.3); box-shadow: 0 22px 50px rgba(0,0,0,0.5); max-height: 0; overflow: hidden; opacity: 0; pointer-events: none; transition: opacity 0.3s var(--ease), max-height 0.35s var(--ease); }
.cdrop.open .cdrop-menu { max-height: 300px; overflow: auto; opacity: 1; pointer-events: auto; }
.cdrop-opt { padding: 0.65rem 0.85rem; font-family: var(--font-sans); font-size: 0.88rem; color: var(--paper-muted); cursor: pointer; border-left: 2px solid transparent; transition: background 0.25s, color 0.25s, border-color 0.25s; }
.cdrop-opt:hover, .cdrop-opt.sel { color: var(--accent-pale); background: rgba(var(--accent-rgb),0.09); border-left-color: var(--accent); }

/* ─────────── FOOTER ─────────── */
.footer { background: var(--ink); color: var(--paper); padding: 4.5rem 0 2.2rem; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 2.5rem; align-items: start; }
.footer-logo img { height: 66px; width: auto; margin-bottom: 1.2rem; }
.footer-logo p { font-family: var(--font-sans); font-size: 0.86rem; line-height: 1.7; color: var(--paper-muted); max-width: 22rem; }
.footer-logo .cred { margin-top: 1.2rem; font-size: 0.74rem; color: var(--paper-faint); letter-spacing: 0.04em; }
.footer-logo .cred b { color: var(--accent-bright); font-weight: 600; }
.footer-col h4 { font-family: var(--font-sans); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-bright); margin: 0 0 1.2rem; }
.footer-col a, .footer-col span { display: block; font-family: var(--font-sans); color: var(--paper-muted); text-decoration: none; font-size: 0.88rem; padding: 0.35rem 0; transition: color 0.3s; }
.footer-col a:hover { color: var(--accent-bright); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; margin-top: 3.4rem; padding-top: 1.8rem; border-top: 1px solid var(--ink-line); }
.footer-bottom p { font-family: var(--font-sans); font-size: 0.72rem; color: var(--paper-faint); letter-spacing: 0.03em; }

/* ═══════════════ OBSIDIAN SURFACE — full legibility ═══════════════ */
/* Components inside marble sections that flip dark under the Obsidian tweak */
[data-surface="obsidian"] .s-marble .body,
[data-surface="obsidian"] .s-marble-2 .body { color: var(--paper-muted); }
[data-surface="obsidian"] .s-marble .gold,
[data-surface="obsidian"] .s-marble-2 .gold { color: var(--accent-bright); }
[data-surface="obsidian"] .s-marble .sample-note,
[data-surface="obsidian"] .s-marble-2 .sample-note { color: var(--paper-faint); }

/* About — signature + principles */
[data-surface="obsidian"] .about-sig .name { color: var(--paper); }
[data-surface="obsidian"] .about-sig .role { color: var(--accent-bright); }
[data-surface="obsidian"] .principle .n { color: var(--accent-bright); }
[data-surface="obsidian"] .principle h4 { color: var(--paper); }
[data-surface="obsidian"] .principle p { color: var(--paper-muted); }

/* Stats band */
[data-surface="obsidian"] .stat { border-color: var(--ink-line); }
[data-surface="obsidian"] .stat .num { color: var(--paper); }
[data-surface="obsidian"] .stat .num .u { color: var(--accent-bright); }
[data-surface="obsidian"] .stat .lbl { color: var(--paper-muted); }

/* Portfolio filters */
[data-surface="obsidian"] .filter-btn { color: var(--paper-muted); border-color: var(--ink-line); }
[data-surface="obsidian"] .filter-btn:hover { color: var(--accent-bright); border-color: rgba(var(--accent-rgb),0.5); }
[data-surface="obsidian"] .filter-btn.active { color: #1c150a; background: var(--accent); border-color: var(--accent); }

/* FAQ */
[data-surface="obsidian"] .faq-list,
[data-surface="obsidian"] .faq-item { border-color: var(--ink-line); }
[data-surface="obsidian"] .faq-q { color: var(--paper); }
[data-surface="obsidian"] .faq-q:hover { color: var(--accent-bright); }
[data-surface="obsidian"] .faq-a p { color: var(--paper-muted); }

/* Service areas */
[data-surface="obsidian"] .areas-list li { color: var(--paper); border-color: var(--ink-line); }

/* Primary button needs to lift off the ink background */
[data-surface="obsidian"] .btn-primary { background: var(--ink-3); border: 1px solid var(--ink-line); box-shadow: 0 10px 30px rgba(0,0,0,0.35); }
[data-surface="obsidian"] .btn-primary:hover { background: var(--ink-2); }

/* ═══════════════ RESPONSIVE ═══════════════ */
@media (max-width: 1024px) {
  .svc-grid, .gallery-grid, .tst-grid, .jrnl-grid { grid-template-columns: repeat(2, 1fr); }
  .proc-grid { grid-template-columns: repeat(2, 1fr); gap: 2.5rem 0; }
  .stat-band { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(3) { border-left: none; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-logo { display: none; }
}
@media (max-width: 820px) {
  .about-grid, .faq-grid, .areas-grid, .inquire-grid { grid-template-columns: 1fr; }
  .about-figure { max-width: 460px; }
  .principles { grid-template-columns: 1fr; gap: 1.2rem; }
  .trust-item { border-left: none; border-top: 1px solid var(--ink-line); flex-basis: 50%; }
  .footer-grid { grid-template-columns: 1fr 1fr; }

  /* Form — mobile ergonomics */
  .form { padding: 1.5rem 1.25rem 1.75rem; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .field { margin-bottom: 1.1rem; }
  .field label { font-size: 0.66rem; }
  .field input, .field textarea, .cdrop-btn { font-size: 1rem; padding: 1rem; }
  .cdrop-opt { padding: 0.85rem 1rem; font-size: 0.95rem; }
  .form-sub { margin: 1.6rem 0 1rem; }
}
@media (max-width: 560px) {
  .svc-grid, .gallery-grid, .tst-grid, .jrnl-grid, .stat-band, .proc-grid { grid-template-columns: 1fr; }
  .svc.wide { grid-column: auto; }
  .svc.wide .svc-media { aspect-ratio: 16/11; }
  .stat { border-left: none; border-top: 1px solid var(--marble-line); }
  .stat:first-child { border-top: none; }
  .areas-list { column-count: 1; }
  .footer-grid { grid-template-columns: 1fr; }
  .proc-step { padding: 0; }
  .proc-step:not(:first-child) { border-left: none; }
}
