/*
Theme Name: DFC Media — Vibrant
Theme URI: https://droneflyingcompany.ca
Author: Drone Flying Company
Description: Premium dark luxury WordPress theme. v2.13.0 — Stage 2 of audit work. Security: fixed canonical URL XSS vector, hardened HTTPS-redirect against CRLF injection, sanitized REQUEST_URI in checklist 404 rescue. Performance: removed wp_cache_delete that defeated persistent object cache, self-hosted Leaflet (~175KB) to remove unpkg.com SPOF — homepage no longer breaks if unpkg has an outage. Content: image-replaceable backgrounds for CTA band, Contact, Testimonials, and Why Us sections — set photos in admin and they auto-overlay with a dark or cream gradient depending on section.
Version: 2.13.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: dfc-media
*/

/* ─── VARIABLES ─────────────────────────────────────── */
:root {
  /* ── Vibrant DFC palette ── */
  --gold:      #f0a500;       /* electric amber — main brand accent */
  --gold-lt:   #ffc53d;       /* bright amber highlight */
  --gold-dk:   #c47f00;       /* deep amber */
  --cyan:      #00d4ff;       /* electric cyan — secondary accent */
  --cyan-dk:   #0099bb;       /* deep cyan */
  --black:     #060a14;       /* deep navy-black */
  --blk-mid:   #0c1220;       /* navy card background */
  --blk-deep:  #04080f;       /* deepest background */
  --white:     #f0f4ff;       /* cool white with blue tint */
  --muted:     #6b7a9a;       /* blue-grey muted text */
  --border:    rgba(240,165,0,.25);
  --serif:     'Cormorant Garamond', Georgia, serif;
  --sans:      'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --mono:      'DM Mono', 'Courier New', monospace;
}

/* ─── RESET ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* scroll-behavior ONLY via JS (prefers-reduced-motion safe)
   Never set it on html/body globally — it causes a visible
   animated scroll-to-top on every page reload in Safari/iOS */
html{font-size:16px}

/* overflow-x:hidden on body breaks iOS native scroll bounce
   and is the #1 cause of elastic shake on reload.
   We move it to a wrapper instead (see below). */
body{
  background:var(--black);
  color:var(--white);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  /* No overflow-x here — it would disable iOS momentum scroll */
  overscroll-behavior-y: none; /* stops the pull-to-refresh bounce at top of page */
  position: relative; /* needed for burst dot absolute positioning */
}

/* Clip horizontal overflow at the viewport level without
   affecting the body scroll container */
#page-wrapper{
  overflow-x: hidden;
  width: 100%;
}

/* Locks scroll while loader is visible — prevents page jumping
   underneath the preloader during first load */
body.loading {
  overflow: hidden;
  height: 100vh;
}
body.has-cursor{cursor:none}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none;transition:color .3s}
a:hover{color:var(--gold-lt)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:300;line-height:1.18;color:var(--white)}
p{line-height:1.8;color:var(--muted)}
em{font-style:italic;color:var(--gold-lt)}
.screen-reader-text{position:absolute;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* ─── CURSOR ────────────────────────────────────────── */
#dfc-dot{position:fixed;z-index:9999;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--gold);pointer-events:none;transform:translate(-50%,-50%);transition:transform .1s,background .2s}
#dfc-ring{position:fixed;z-index:9998;top:0;left:0;width:36px;height:36px;border-radius:50%;border:1px solid rgba(201,168,76,.5);pointer-events:none;transform:translate(-50%,-50%);transition:width .3s cubic-bezier(.16,1,.3,1),height .3s cubic-bezier(.16,1,.3,1),border-color .3s}

/* ─── PRELOADER ─────────────────────────────────────── */
#dfc-loader{position:fixed;inset:0;z-index:9990;background:var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .9s,visibility .9s}
#dfc-loader.out{opacity:0;visibility:hidden;pointer-events:none}
.loader-name{font-family:var(--serif);font-size:clamp(1.8rem,4vw,3.2rem);font-weight:300;letter-spacing:.32em;text-transform:uppercase;color:var(--white);margin-bottom:2.5rem;animation:fadeUp .8s .3s both}
.loader-track{width:180px;height:1px;background:rgba(255,255,255,.1);overflow:hidden}
.loader-bar{height:100%;width:0;background:var(--gold);animation:loadBar 2.2s .6s cubic-bezier(.76,0,.24,1) forwards}
.loader-sub{font-family:var(--mono);font-size:.58rem;letter-spacing:.28em;color:var(--muted);text-transform:uppercase;margin-top:1.2rem;animation:fadeUp .6s .8s both}

/* ─── NAV ───────────────────────────────────────────── */
#site-header{position:fixed;top:0;left:0;right:0;z-index:200;height:78px;padding:0 5vw;display:flex;align-items:center;justify-content:space-between;transition:background .4s,border-color .4s;border-bottom:1px solid transparent}
#site-header.scrolled{background:rgba(10,10,10,.94);backdrop-filter:blur(18px);border-bottom-color:var(--border)}
.site-branding{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.site-branding svg{width:34px;height:34px;flex-shrink:0}
.brand-name{font-family:var(--serif);font-size:1rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--white)}
#primary-nav{display:flex;align-items:center;gap:2.5rem}
#primary-nav a{font-family:var(--sans);font-size:.65rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,242,238,.6);position:relative;transition:color .3s}
#primary-nav a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .3s}
#primary-nav a:hover{color:var(--white)}
#primary-nav a:hover::after{transform:scaleX(1);transform-origin:left}
#primary-nav a.is-active{color:var(--gold)}
.nav-book{font-family:var(--sans)!important;font-size:.62rem!important;font-weight:500!important;letter-spacing:.22em!important;text-transform:uppercase!important;color:var(--black)!important;background:var(--gold);padding:.6rem 1.4rem;transition:background .3s!important}
.nav-book::after{display:none!important}
.nav-book:hover{background:var(--gold-lt)!important;color:var(--black)!important}
.menu-toggle{display:none;background:none;border:1px solid var(--border);color:var(--white);padding:.4rem .7rem;cursor:pointer;font-size:1.1rem}
#mobile-nav{display:none;position:fixed;top:78px;left:0;right:0;z-index:190;background:rgba(10,10,10,.97);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);padding:1.5rem 5vw 2rem;flex-direction:column;gap:1.2rem}
#mobile-nav.open{display:flex}
#mobile-nav a{font-family:var(--sans);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,242,238,.7);padding:.5rem 0;border-bottom:1px solid rgba(201,168,76,.1);transition:color .2s}
#mobile-nav a:hover{color:var(--gold)}

/* ─── HERO ──────────────────────────────────────────── */
#hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-color:#111008;will-change:transform}
.hero-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 50% at 68% 28%,rgba(201,168,76,.1) 0%,transparent 60%)}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,10,10,.88) 0%,rgba(10,10,10,.4) 50%,rgba(10,10,10,.15) 100%)}
.hero-gridlines{position:absolute;inset:0;z-index:1;pointer-events:none;background-image:linear-gradient(rgba(201,168,76,.038) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.038) 1px,transparent 1px);background-size:78px 78px}
.hero-content{position:relative;z-index:5;padding:0 5vw 9vh;max-width:1400px}
.hero-eyebrow{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem;animation:fadeUp .8s .2s both}
.eyebrow-line{width:36px;height:1px;background:var(--gold)}
.eyebrow-text{font-family:var(--mono);font-size:.56rem;letter-spacing:.3em;color:var(--gold);text-transform:uppercase}
.hero-headline{font-family:var(--serif);font-size:clamp(3.2rem,7.5vw,7rem);font-weight:300;line-height:1.08;max-width:14ch;animation:fadeUp 1s .35s cubic-bezier(.16,1,.3,1) both}

/* ──────────────────────────────────────────────────────
   STACKED-WORD HERO (v2.7.0 — Mont-fort-inspired)
   Three lines stacked vertically. The middle line is a
   "rotor" — a fixed-height window that crops to one word,
   and the inner stack of words slides up every few seconds.
   ────────────────────────────────────────────────────── */
.hero-headline-stacked{
  max-width: none;
  line-height: 1.02;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.hero-stack-line{
  display: block;
  white-space: nowrap;
}
.hero-stack-static{
  /* Static lines — just the literal text from the template */
}
.hero-stack-rotor{
  /* The cropping window. Height is 1.25em (not 1em) so descenders on
     letters like g, p, y, j and italic overhang aren't clipped. The
     inner stack still translates by 1.25em per word — see JS. */
  display: inline-block;
  height: 1.25em;
  line-height: 1.25;
  overflow: hidden;
  vertical-align: top;
  position: relative;
}
.hero-stack-rotor-inner{
  display: flex;
  flex-direction: column;
  /* Translate animated via JS — each word is 1.25em tall, rotor crops to 1.25em */
  transition: transform .65s cubic-bezier(.65,.05,.36,1);
  will-change: transform;
}
.hero-stack-word{
  display: block;
  height: 1.25em;
  line-height: 1.25;
  /* Words start at 0.4 opacity; only the active word sits at 1 */
  opacity: .35;
  transition: opacity .5s ease;
}
.hero-stack-word.is-active{
  opacity: 1;
}
.hero-stack-word em{
  /* Inherit the gold styling that .hero-headline em already provides,
     but we explicitly set it here in case the global rule changes. */
  font-style: italic;
  color: var(--gold-lt);
  text-shadow: 0 0 40px rgba(240,165,0,.4);
}

/* Subtle entrance: the whole stacked block fades up just like the
   regular headline does */
.hero-headline-stacked{
  animation: fadeUp 1s .35s cubic-bezier(.16,1,.3,1) both;
}

/* Reduce motion: respect users with prefers-reduced-motion. The rotor
   becomes a static stack showing only the first word. */
@media (prefers-reduced-motion: reduce){
  .hero-stack-rotor-inner{ transition: none; }
  .hero-stack-word{ opacity: 1; }
  .hero-stack-rotor{ height: auto; }
}
.hero-sub{margin-top:1.8rem;font-size:.72rem;font-weight:300;letter-spacing:.14em;color:rgba(245,242,238,.5);text-transform:uppercase;line-height:2;max-width:48ch;animation:fadeUp .8s .55s both}
.hero-actions{margin-top:2.4rem;display:flex;align-items:center;gap:2rem;animation:fadeUp .8s .7s both}
.btn-primary{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:.95rem 2.2rem;transition:background .3s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--gold-lt);color:var(--black)}
.btn-ghost{font-family:var(--sans);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(245,242,238,.65);border-bottom:1px solid rgba(245,242,238,.3);padding-bottom:2px;transition:color .3s,border-color .3s;background:none;border-top:none;border-left:none;border-right:none;cursor:pointer}
.btn-ghost:hover{color:var(--gold-lt);border-color:var(--gold)}
.hero-scroll{position:absolute;bottom:2.8rem;right:5vw;z-index:5;display:flex;flex-direction:column;align-items:center;gap:.6rem;animation:fadeUp .8s 1s both}
.scroll-line{width:1px;height:55px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2.2s ease-in-out infinite}
.scroll-label{font-family:var(--mono);font-size:.5rem;letter-spacing:.2em;color:var(--muted);writing-mode:vertical-rl;text-transform:uppercase}
.hero-stats{position:absolute;bottom:0;right:0;z-index:5;display:flex;animation:fadeUp .8s .9s both}
.stat-item{padding:1.3rem 1.8rem;border-top:1px solid var(--border);border-left:1px solid var(--border);background:rgba(10,10,10,.72);backdrop-filter:blur(10px);text-align:center}
.stat-num{font-family:var(--serif);font-size:1.9rem;font-weight:300;color:var(--gold-lt);display:block;line-height:1}
.stat-lbl{font-family:var(--mono);font-size:.5rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;display:block;margin-top:3px}

/* ─── MARQUEE ───────────────────────────────────────── */
.dfc-marquee{background:var(--gold);padding:.85rem 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;animation:marqueeRun 32s linear infinite}
.marquee-item{font-family:var(--sans);font-size:.58rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--black);padding:0 2.5rem}

/* ─── SECTION COMMONS ───────────────────────────────── */
.dfc-section{padding:7rem 5vw}
.section-dark{background:var(--blk-mid)}
.section-black{background:var(--black)}
.section-gold{background:var(--gold)}
.section-tag{display:flex;align-items:center;gap:.9rem;margin-bottom:.9rem}
.tag-line{width:28px;height:1px;background:var(--gold)}
.tag-text{font-family:var(--mono);font-size:.58rem;letter-spacing:.26em;color:var(--gold);text-transform:uppercase}
.section-title{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,4rem);font-weight:300;line-height:1.15;color:var(--white);max-width:22ch}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ─── SERVICES ──────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:3.5rem;border:1px solid var(--border)}
.service-card{background:var(--blk-mid);padding:2.4rem 2rem;position:relative;overflow:hidden;transition:background .4s}
.service-card:hover{background:#121009}
.svc-num{font-family:var(--mono);font-size:.56rem;letter-spacing:.2em;color:var(--gold);margin-bottom:1.6rem}
.svc-icon{margin-bottom:1.3rem}
.svc-icon svg{width:44px;height:44px}
.service-card h3{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--white);margin-bottom:.9rem;line-height:1.2}
.service-card p{font-size:.7rem;line-height:1.85;color:var(--muted);margin-bottom:1.4rem}
.svc-link{font-family:var(--mono);font-size:.56rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;display:inline-flex;align-items:center;gap:.4rem;transition:gap .3s}
.svc-link:hover{gap:.7rem;color:var(--gold-lt)}
.svc-border{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.76,0,.24,1)}
.service-card:hover .svc-border{transform:scaleX(1)}

/* ─── PORTFOLIO ─────────────────────────────────────── */
.portfolio-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem;flex-wrap:wrap;gap:1.5rem}
.portfolio-filters{display:flex;gap:.7rem;flex-wrap:wrap}
.filter-btn{font-family:var(--mono);font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);background:none;border:1px solid rgba(122,115,106,.3);padding:.45rem 1.1rem;cursor:pointer;transition:all .3s}
.filter-btn.active,.filter-btn:hover{color:var(--black);background:var(--gold);border-color:var(--gold)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.port-item{position:relative;overflow:hidden;aspect-ratio:4/3;cursor:pointer;background:#1a1510}
.port-item.wide{grid-column:span 2;aspect-ratio:16/9}
.port-item img,.port-placeholder{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .65s cubic-bezier(.25,.46,.45,.94)}
.port-item:hover img,.port-item:hover .port-placeholder{transform:scale(1.05)}
.port-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,10,10,.88) 0%,rgba(10,10,10,.15) 50%,transparent 100%);opacity:0;transition:opacity .38s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.4rem}
.port-item:hover .port-overlay{opacity:1}
.port-cat{font-family:var(--mono);font-size:.5rem;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:3px}
.port-name{font-family:var(--serif);font-size:1.1rem;font-weight:300;color:var(--white)}
.port-empty{display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.6rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;height:100%;background:var(--blk-mid);border:1px dashed rgba(201,168,76,.2);text-align:center;padding:1rem}

/* ─── PROCESS ───────────────────────────────────────── */
.process-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:3.5rem;align-items:start}
.steps-list{display:flex;flex-direction:column}
.step-item{display:flex;gap:1.8rem;padding:1.8rem 0;border-bottom:1px solid rgba(201,168,76,.1);cursor:pointer;transition:padding-left .3s}
.step-item:first-child{border-top:1px solid rgba(201,168,76,.1)}
.step-item:hover{padding-left:.5rem}
.step-n{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;color:var(--gold);min-width:2.2rem;padding-top:.15rem;flex-shrink:0}
.step-item h4{font-family:var(--serif);font-size:1.25rem;font-weight:400;color:var(--white);margin-bottom:.5rem}
.step-item p{font-size:.7rem;line-height:1.8;color:var(--muted)}
.process-visual{position:relative}
.process-img-wrap{aspect-ratio:3/4;overflow:hidden;position:relative;background:linear-gradient(135deg,#1a1510,#0d0c0b)}
.process-img-wrap img{width:100%;height:100%;object-fit:cover}
.process-img-wrap::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 40%,rgba(201,168,76,.14) 0%,transparent 60%)}
.process-badge{position:absolute;bottom:1.8rem;left:1.8rem;right:1.8rem;background:rgba(10,10,10,.88);backdrop-filter:blur(12px);border:1px solid var(--border);padding:1.4rem}
.badge-tag{font-family:var(--mono);font-size:.52rem;letter-spacing:.24em;color:var(--gold);text-transform:uppercase;margin-bottom:.4rem}
.badge-title{font-family:var(--serif);font-size:1rem;font-weight:300;color:var(--white)}

/* ─── TESTIMONIALS ──────────────────────────────────── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:3.5rem}
.testi-card{background:var(--blk-mid);padding:2.4rem;border-top:2px solid var(--gold);position:relative}
.quote-glyph{font-family:var(--serif);font-size:4.5rem;line-height:.5;color:rgba(201,168,76,.18);display:block;margin-bottom:1.4rem}
.testi-card blockquote{font-family:var(--serif);font-size:1rem;font-weight:300;font-style:italic;line-height:1.72;color:rgba(245,242,238,.78);margin-bottom:1.8rem}
.testi-author{display:flex;align-items:center;gap:1rem}
.author-ava{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--gold-dk),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.9rem;color:var(--black)}
.author-name{font-family:var(--sans);font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--white);display:block}
.author-role{font-family:var(--mono);font-size:.56rem;color:var(--muted);display:block;margin-top:3px}
.testi-stars{position:absolute;top:2.2rem;right:2.2rem;color:var(--gold);font-size:.6rem;letter-spacing:.1em}

/* ─── WHY US ────────────────────────────────────────── */
.why-layout{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:center}
.why-headline{font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;color:var(--black);line-height:1.18}
.why-items{display:grid;grid-template-columns:1fr 1fr;gap:2.2rem}
.why-item h4{font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--black);margin-bottom:.65rem;display:flex;align-items:center;gap:.5rem}
.why-item h4::before{content:'';width:18px;height:1px;background:rgba(10,10,10,.4);flex-shrink:0}
.why-item p{font-size:.7rem;line-height:1.8;color:rgba(10,10,10,.62)}

/* ─── PRICING ───────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:3.5rem}
.price-card{background:var(--blk-mid);border:1px solid rgba(201,168,76,.15);padding:2.8rem 2.2rem;position:relative;transition:border-color .3s,transform .3s}
.price-card:hover{border-color:var(--gold);transform:translateY(-4px)}
.price-card.featured{background:linear-gradient(135deg,rgba(201,168,76,.1),rgba(201,168,76,.02));border-color:var(--gold)}
.price-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--gold);font-family:var(--mono);font-size:.5rem;letter-spacing:.18em;color:var(--black);padding:3px 14px;text-transform:uppercase;white-space:nowrap}
.price-tier{font-family:var(--mono);font-size:.56rem;letter-spacing:.24em;color:var(--gold);text-transform:uppercase;margin-bottom:1.3rem}
.price-amount{font-family:var(--serif);font-size:3.2rem;font-weight:300;color:var(--white);line-height:1}
.price-amount sup{font-size:1.2rem;font-family:var(--sans);font-weight:300;vertical-align:super}
.price-desc{font-size:.62rem;color:var(--muted);margin-top:.4rem;margin-bottom:1.8rem}
.price-divider{height:1px;background:var(--border);margin-bottom:1.8rem}
.price-features{margin-bottom:2.2rem}
.price-features li{font-size:.7rem;color:rgba(245,242,238,.7);padding:.55rem 0;border-bottom:1px solid rgba(201,168,76,.06);display:flex;align-items:center;gap:.7rem}
.price-features li::before{content:'';width:14px;height:1px;background:var(--gold);flex-shrink:0}
.price-cta{display:block;text-align:center;font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:.9rem;border:1px solid var(--gold);color:var(--gold);transition:background .3s,color .3s}
.price-cta:hover,.price-card.featured .price-cta{background:var(--gold);color:var(--black)}

/* ─── CONTACT ───────────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:3.5rem;align-items:start}
.contact-info h3{font-family:var(--serif);font-size:1.8rem;font-weight:300;color:var(--white);margin-bottom:1rem}
.contact-info p{font-size:.72rem;line-height:1.85;color:var(--muted);margin-bottom:2rem}
.contact-details{display:flex;flex-direction:column;gap:.7rem;margin-bottom:2rem}
.contact-row{display:flex;align-items:center;gap:1rem;font-size:.72rem;color:rgba(245,242,238,.7)}
.contact-row strong{font-family:var(--mono);font-size:.56rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;min-width:60px}
.contact-row a{color:rgba(245,242,238,.7);transition:color .2s}
.contact-row a:hover{color:var(--gold-lt)}
.contact-areas{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.area-tag{font-family:var(--mono);font-size:.52rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(201,168,76,.6);border:1px solid rgba(201,168,76,.2);padding:.28rem .7rem}
.contact-form{display:flex;flex-direction:column;gap:1.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-family:var(--mono);font-size:.54rem;letter-spacing:.2em;color:var(--gold);text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.2);color:var(--white);font-family:var(--sans);font-size:.72rem;font-weight:300;padding:.85rem 1rem;outline:none;transition:border-color .3s;width:100%;appearance:none;-webkit-appearance:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c9a84c' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-group textarea{resize:vertical;min-height:120px}
.form-success{display:none;padding:1rem 1.2rem;background:rgba(201,168,76,.1);border:1px solid var(--gold);font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;color:var(--gold-lt)}

/* ─── CTA BAND ──────────────────────────────────────── */
.cta-band{text-align:center;position:relative;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-band::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:350px;background:radial-gradient(ellipse,rgba(201,168,76,.08) 0%,transparent 70%);pointer-events:none}
.cta-band h2{font-family:var(--serif);font-size:clamp(2rem,4.5vw,4.5rem);font-weight:300;color:var(--white);margin-bottom:1.2rem;position:relative;z-index:1}
.cta-band p{font-size:.72rem;letter-spacing:.1em;color:var(--muted);margin-bottom:2.2rem;position:relative;z-index:1}

/* ─── FOOTER ────────────────────────────────────────── */
#site-footer{background:var(--blk-deep);padding:4.5rem 5vw 1.8rem;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3.5rem;margin-bottom:3.5rem}
.footer-brand-name{font-family:var(--serif);font-size:1.2rem;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--white);display:block;margin-bottom:.9rem}
.footer-brand p{font-size:.7rem;line-height:1.8;color:var(--muted);max-width:30ch;margin-bottom:1.6rem}
.footer-contact a{display:block;font-family:var(--mono);font-size:.65rem;color:var(--gold);margin-bottom:.4rem;transition:color .2s}
.footer-contact a:hover{color:var(--gold-lt)}
.footer-col h5{font-family:var(--mono);font-size:.56rem;letter-spacing:.24em;color:rgba(245,242,238,.3);text-transform:uppercase;margin-bottom:1.3rem}
.footer-col li{margin-bottom:.65rem}
.footer-col a{font-size:.7rem;color:var(--muted);transition:color .2s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(201,168,76,.1);padding-top:1.6rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem}
.footer-copy{font-family:var(--mono);font-size:.54rem;letter-spacing:.12em;color:rgba(122,115,106,.45);text-transform:uppercase}
.footer-certs{display:flex;gap:.8rem}
.cert-pill{font-family:var(--mono);font-size:.5rem;letter-spacing:.14em;color:rgba(201,168,76,.45);text-transform:uppercase;border:1px solid rgba(201,168,76,.18);padding:3px 9px}

/* ─── KEYFRAMES ─────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes loadBar{to{width:100%}}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}
@keyframes marqueeRun{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── RESPONSIVE ────────────────────────────────────── */
@media(max-width:1080px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .port-item.wide{grid-column:span 2}
  .process-layout{grid-template-columns:1fr;gap:3rem}
  .testi-grid{grid-template-columns:1fr 1fr}
  .why-layout{grid-template-columns:1fr;gap:2.5rem}
  .pricing-grid{grid-template-columns:1fr 1fr}
  .contact-layout{grid-template-columns:1fr;gap:3rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .hero-stats{display:none}
}
@media(max-width:700px){
  .dfc-section{padding:4rem 5vw}
  #primary-nav{display:none}
  .menu-toggle{display:block}
  .services-grid,.testi-grid,.pricing-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .port-item.wide{grid-column:span 1;aspect-ratio:4/3}
  .why-items,.footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  #dfc-dot,#dfc-ring{display:none}
}

/* ═══ DYNAMIC VARS (overridden by PHP) ═══ */
:root { --radius: 0px; }
button, .btn-primary, .price-cta, .filter-btn, .service-card, .dfc-rep, .testi-card, .price-card {
  border-radius: var(--radius);
}

/* ═══ CURSOR STYLES ═══ */
body.has-cursor { cursor: none; }
body.has-cursor a, body.has-cursor button, body.has-cursor input, body.has-cursor textarea, body.has-cursor select { cursor: none; }

#dfc-dot {
  position: fixed; z-index: 9999; top: 0; left: 0;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold); pointer-events: none;
  transform: translate(-50%,-50%);
  transition: transform .1s, background .2s;
  will-change: left, top;
}
#dfc-ring {
  position: fixed; z-index: 9998; top: 0; left: 0;
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid rgba(201,168,76,.55); pointer-events: none;
  transform: translate(-50%,-50%);
  transition: width .3s cubic-bezier(.16,1,.3,1), height .3s, border-color .3s;
  will-change: left, top;
}
#dfc-cam, #dfc-drone, #dfc-lens, #dfc-arrow, #dfc-cross {
  position: fixed; z-index: 9999; top: 0; left: 0;
  pointer-events: none;
  transform: translate(-50%,-50%);
  color: var(--gold);
  will-change: left, top;
}
#dfc-cam svg { width: 32px; height: 32px; filter: drop-shadow(0 0 6px rgba(201,168,76,.6)); }
#dfc-drone svg { width: 40px; height: 40px; filter: drop-shadow(0 0 8px rgba(201,168,76,.5)); animation: droneFloat .8s ease-in-out infinite alternate; }
@keyframes droneFloat { from { filter: drop-shadow(0 0 4px rgba(201,168,76,.3)); } to { filter: drop-shadow(0 2px 12px rgba(201,168,76,.8)); } }
#dfc-lens svg { width: 36px; height: 36px; animation: lensRotate 4s linear infinite; }
@keyframes lensRotate { to { transform: translate(-50%,-50%) rotate(360deg); } }
#dfc-arrow svg { width: 20px; height: 24px; }
#dfc-cross { width: 36px; height: 36px; }
#dfc-cross .ch-h { position: absolute; top: 50%; left: 0; right: 0; height: 1px; background: var(--gold); transform: translateY(-50%); }
#dfc-cross .ch-v { position: absolute; left: 50%; top: 0; bottom: 0; width: 1px; background: var(--gold); transform: translateX(-50%); }
#dfc-cross .ch-dot { position: absolute; top: 50%; left: 50%; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); transform: translate(-50%,-50%); }
#dfc-spotlight {
  position: fixed; z-index: 9995; top: 0; left: 0;
  width: 200px; height: 200px; pointer-events: none;
  transform: translate(-50%,-50%);
  background: radial-gradient(circle, rgba(201,168,76,.15) 0%, transparent 70%);
  border-radius: 50%;
}

/* ═══ LOADERS ═══ */
#dfc-loader {
  position: fixed; inset: 0; z-index: 9990;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  transition: opacity .9s ease, visibility .9s;
}
#dfc-loader.out { opacity: 0; visibility: hidden; pointer-events: none; }
.loader-brand { font-family: var(--serif); font-size: clamp(1.6rem,3.5vw,3rem); font-weight: 300; letter-spacing: .32em; text-transform: uppercase; margin-bottom: 2.5rem; animation: fadeUp .8s .3s both; }
.loader-sub   { font-family: var(--mono); font-size: .58rem; letter-spacing: .28em; text-transform: uppercase; margin-top: 1.2rem; animation: fadeUp .6s .8s both; }

/* Bar loader */
body.loader-bar #dfc-loader { background: var(--black); }
body.loader-bar .loader-brand { color: var(--white); }
body.loader-bar .loader-sub   { color: var(--muted); }
.loader-track { width: 180px; height: 1px; background: rgba(255,255,255,.1); overflow: hidden; }
.loader-bar-fill { height: 100%; width: 0; background: var(--gold); animation: loadBar 2.2s .6s cubic-bezier(.76,0,.24,1) forwards; }

/* Circle loader */
body.loader-circle #dfc-loader { background: var(--black); }
body.loader-circle .loader-brand { color: var(--white); }
body.loader-circle .loader-sub   { color: var(--muted); }
.loader-ring-wrap { width: 60px; height: 60px; position: relative; }
.loader-ring-svg { animation: spinRing 1.2s linear infinite; width: 60px; height: 60px; }
@keyframes spinRing { to { transform: rotate(360deg); } }

/* Shutter loader */
body.loader-shutter #dfc-loader { background: #000; }
body.loader-shutter .loader-brand { color: #fff; }
body.loader-shutter .loader-sub   { color: #888; }
.loader-shutter-iris { width: 80px; height: 80px; position: relative; margin-bottom: 1.5rem; }
.loader-shutter-iris::before, .loader-shutter-iris::after { content: ''; position: absolute; inset: 0; border-radius: 50%; border: 3px solid var(--gold); animation: shutterOpen 2s ease forwards; }
.loader-shutter-iris::after { animation-delay: .3s; border-color: rgba(201,168,76,.4); }
@keyframes shutterOpen { from { transform: scale(0) rotate(-180deg); opacity: 0; } to { transform: scale(1) rotate(0); opacity: 1; } }

/* Split loader */
body.loader-split #dfc-loader { overflow: hidden; background: transparent; }
.loader-split-top, .loader-split-bottom { position: absolute; left: 0; right: 0; height: 50%; background: var(--black); display: flex; align-items: flex-end; justify-content: center; }
.loader-split-top { top: 0; padding-bottom: 1rem; animation: splitTop 2.8s cubic-bezier(.76,0,.24,1) forwards; }
.loader-split-bottom { bottom: 0; padding-top: 1rem; animation: splitBottom 2.8s cubic-bezier(.76,0,.24,1) forwards; }
@keyframes splitTop    { to { transform: translateY(-100%); } }
@keyframes splitBottom { to { transform: translateY(100%); } }
.loader-split-text { position: relative; z-index: 1; text-align: center; }

/* Drone loader */
body.loader-drone #dfc-loader { background: var(--black); overflow: hidden; }
body.loader-drone .loader-brand { color: var(--white); }
body.loader-drone .loader-sub   { color: var(--muted); }
.loader-drone-anim { position: absolute; top: 30%; animation: droneFly 2.5s ease-in-out infinite; }
.loader-drone-anim svg { width: 48px; height: 48px; color: var(--gold); filter: drop-shadow(0 0 12px rgba(201,168,76,.6)); }
@keyframes droneFly { 0%{left:-80px;transform:rotate(-5deg)} 50%{transform:rotate(3deg)} 100%{left:calc(100% + 80px);transform:rotate(-5deg)} }

/* Counter loader */
body.loader-counter #dfc-loader { background: var(--black); }
.loader-counter-num { font-family: var(--serif); font-size: 20vw; font-weight: 300; color: var(--gold); line-height: 1; animation: countDown 2.8s steps(1) forwards; }
@keyframes countDown {
  0%  { content: '3'; } 0.1%  { /* 3 */ }
  33% { opacity: .6; }
  34% { opacity: 1; }
  66% { opacity: .6; }
  67% { opacity: 1; }
  100%{ opacity: 0; }
}

/* Film loader */
body.loader-film #dfc-loader { background: #0a0a0a; }
.loader-film-strip { display: flex; gap: 4px; margin-bottom: 2rem; animation: filmScroll 2s linear forwards; }
.loader-film-frame { width: 40px; height: 55px; background: rgba(201,168,76,.15); border: 1px solid rgba(201,168,76,.3); border-radius: 2px; }
@keyframes filmScroll { from { opacity:0; transform: translateX(40px); } to { opacity:1; transform: translateX(0); } }

/* ═══ PARTICLES CANVAS ═══ */
#dfc-particles { position: absolute; inset: 0; z-index: 2; pointer-events: none; }

/* ═══ ANNOUNCEMENT BAR ═══ */
#dfc-topbar {
  background: var(--gold); color: var(--black);
  text-align: center; padding: .55rem 3rem;
  font-family: var(--sans); font-size: .65rem;
  font-weight: 500; letter-spacing: .15em; text-transform: uppercase;
  position: relative;
}
#dfc-topbar a { color: var(--black); text-decoration: underline; margin-left: .75rem; }
.topbar-close { position: absolute; right: 1rem; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; font-size: 1rem; color: var(--black); opacity: .6; }
.topbar-close:hover { opacity: 1; }

/* ═══ BACK TO TOP ═══ */
#dfc-btt {
  position: fixed; bottom: 2rem; right: 2rem; z-index: 500;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--gold); color: var(--black);
  border: none; cursor: pointer; font-size: 1.2rem;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: translateY(12px);
  transition: opacity .3s, transform .3s, background .2s;
  box-shadow: 0 4px 20px rgba(201,168,76,.3);
}
#dfc-btt.visible { opacity: 1; transform: translateY(0); }
#dfc-btt:hover { background: var(--gold-lt); }
#dfc-btt.style-drone { border-radius: 8px; }

/* ═══ FAQ SECTION ═══ */
#faq { background: var(--black); }
.faq-grid { max-width: 900px; margin-top: 3rem; }
.faq-item {
  border-bottom: 1px solid rgba(201,168,76,.12);
  overflow: hidden;
}
.faq-item:first-child { border-top: 1px solid rgba(201,168,76,.12); }
.faq-q {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 1.4rem 0; cursor: pointer;
  font-family: var(--serif); font-size: 1.1rem;
  font-weight: 400; color: var(--white); line-height: 1.3;
  transition: color .2s; user-select: none;
}
.faq-q:hover { color: var(--gold-lt); }
.faq-q .faq-icon {
  width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--border); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; color: var(--gold); transition: transform .35s, background .2s;
}
.faq-item.open .faq-q { color: var(--gold-lt); }
.faq-item.open .faq-icon { background: var(--gold); color: var(--black); transform: rotate(45deg); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .4s cubic-bezier(.16,1,.3,1);
}
.faq-a-inner {
  padding: 0 0 1.4rem;
  font-size: .76rem; line-height: 1.9; color: var(--muted);
}

/* ═══ TESTIMONIALS SLIDER ═══ */
.testi-slider .testi-card { display: none; }
.testi-slider .testi-card.active { display: block; animation: fadeUp .5s ease; }
.testi-dots { display: flex; justify-content: center; gap: .6rem; margin-top: 1.5rem; }
.testi-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(201,168,76,.25); border: none; cursor: pointer; transition: background .25s, transform .25s; padding: 0; }
.testi-dot.active { background: var(--gold); transform: scale(1.3); }
.testi-nav { display: flex; justify-content: center; gap: 1rem; margin-top: 1.2rem; }
.testi-prev, .testi-next {
  background: none; border: 1px solid var(--border); color: var(--gold);
  width: 40px; height: 40px; border-radius: 50%; cursor: pointer;
  font-size: 1rem; transition: background .2s, border-color .2s;
}
.testi-prev:hover, .testi-next:hover { background: var(--gold); color: var(--black); border-color: var(--gold); }

/* ═══ PORTFOLIO HOVER EFFECTS ═══ */
body.portfolio-hover-tilt .port-item { transition: transform .3s; }
body.portfolio-hover-blur .port-item img, body.portfolio-hover-blur .port-placeholder { filter: blur(4px); transition: filter .4s; }
body.portfolio-hover-blur .port-item:hover img, body.portfolio-hover-blur .port-item:hover .port-placeholder { filter: blur(0); }

/* ═══ PRICING HOVER EFFECTS ═══ */
body.pricing-hover-glow .price-card:hover { border-color: var(--gold); box-shadow: 0 0 30px rgba(201,168,76,.2); transform: none; }

/* ═══ ACTIVE NAV LINK ═══ */
#primary-nav a.is-active { color: var(--gold) !important; }
#primary-nav a.is-active::after { transform: scaleX(1); transform-origin: left; }

/* ═══ FLOATING LABELS ═══ */
body.form-floating .form-group { position: relative; }
body.form-floating .form-group label { position: absolute; top: .85rem; left: 1rem; font-size: .72rem; font-weight: 300; letter-spacing: .05em; text-transform: none; color: var(--muted); pointer-events: none; transition: all .2s; }
body.form-floating .form-group input:focus ~ label, body.form-floating .form-group input:not(:placeholder-shown) ~ label, body.form-floating .form-group textarea:focus ~ label, body.form-floating .form-group textarea:not(:placeholder-shown) ~ label { top: -.5rem; font-size: .55rem; letter-spacing: .18em; color: var(--gold); text-transform: uppercase; }

/* ═══ PORTFOLIO SLIDE-UP ═══ */
body.portfolio-hover-slideup .port-overlay { opacity: 1; background: linear-gradient(0deg, rgba(10,10,10,.95) 0%, rgba(10,10,10,.95) 40%, transparent 100%); transform: translateY(100%); transition: transform .4s cubic-bezier(.25,.46,.45,.94); }
body.portfolio-hover-slideup .port-item:hover .port-overlay { transform: translateY(0); }

/* ═══ KEYFRAMES ═══ */
@keyframes fadeUp  { from { opacity:0; transform:translateY(14px); } to { opacity:1; transform:translateY(0); } }
@keyframes loadBar { to { width:100%; } }
@keyframes scrollPulse { 0%,100%{opacity:.3;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(1.1)} }
@keyframes marqueeRun { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ═══════════════════════════════════════════════════
   OUR STORY SECTION
═══════════════════════════════════════════════════ */
#our-story {
  background: var(--black);
  padding: 0;
  overflow: hidden;
  position: relative;
}
.story-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 80vh;
}
.story-text-side {
  padding: 7rem 5vw 7rem 5vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
}
.story-image-side {
  position: relative;
  overflow: hidden;
}
.story-image-side img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 8s ease;
}
#our-story:hover .story-image-side img {
  transform: scale(1.04);
}
.story-image-accent {
  position: absolute;
  top: 2.5rem;
  right: -1px;
  writing-mode: vertical-rl;
  font-family: var(--mono);
  font-size: .55rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--black);
  background: var(--gold);
  padding: 1.2rem .6rem;
  z-index: 3;
}
.story-eyebrow {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.6rem;
}
.story-eyebrow-line {
  width: 36px;
  height: 1px;
  background: var(--gold);
}
.story-eyebrow span {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .28em;
  color: var(--gold);
  text-transform: uppercase;
}
.story-headline {
  font-family: var(--serif);
  font-size: clamp(2.6rem, 4.5vw, 4.2rem);
  font-weight: 300;
  line-height: 1.05;
  color: var(--white);
  margin-bottom: 1.8rem;
}
.story-headline em {
  font-style: italic;
  color: var(--gold-lt);
  display: block;
}
.story-body {
  font-size: .78rem;
  line-height: 1.95;
  color: var(--muted);
  max-width: 46ch;
  margin-bottom: 1.2rem;
}
.story-link {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 1.5rem;
  border-bottom: 1px solid rgba(201,168,76,.3);
  padding-bottom: 2px;
  text-decoration: none;
  transition: gap .3s, border-color .3s;
}
.story-link:hover {
  gap: 1rem;
  color: var(--gold-lt);
  border-color: var(--gold);
}
.story-stats-row {
  display: flex;
  gap: 2.5rem;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(201,168,76,.12);
}
.story-stat .snum {
  font-family: var(--serif);
  font-size: 2.2rem;
  font-weight: 300;
  color: var(--gold-lt);
  display: block;
  line-height: 1;
}
.story-stat .slbl {
  font-family: var(--mono);
  font-size: .52rem;
  letter-spacing: .18em;
  color: var(--muted);
  text-transform: uppercase;
  margin-top: .3rem;
  display: block;
}

/* ═══════════════════════════════════════════════════
   PREMIUM PORTFOLIO REDESIGN
═══════════════════════════════════════════════════ */
#portfolio {
  background: var(--black);
  padding: 6rem 0 0;
}
.port-section-header {
  padding: 0 5vw 3rem;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: flex-end;
  gap: 2rem;
}
.port-filter-tabs {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
}
.port-tab {
  font-family: var(--mono);
  font-size: .55rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  background: none;
  border: none;
  border-right: 1px solid var(--border);
  padding: .6rem 1.1rem;
  cursor: pointer;
  transition: all .25s;
  white-space: nowrap;
}
.port-tab:last-child { border-right: none; }
.port-tab.active, .port-tab:hover {
  background: var(--gold);
  color: var(--black);
}

/* Featured showcase row */
.port-showcase {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 2px;
  margin-bottom: 2px;
}
.port-showcase-main {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
  cursor: pointer;
}
.port-showcase-stack {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 2px;
}
/* Standard grid below */
.port-masonry {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}
.port-cell {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1;
  cursor: pointer;
  background: var(--blk-mid);
}
.port-cell.span2 {
  grid-column: span 2;
  aspect-ratio: 2/1;
}
.port-cell img,
.port-showcase-main img,
.port-showcase-stack .port-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .7s cubic-bezier(.25,.46,.45,.94);
}
.port-cell:hover img,
.port-showcase-main:hover img {
  transform: scale(1.07);
}
.port-cell-overlay,
.port-showcase-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(10,10,10,.9) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .35s;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.2rem 1.4rem;
}
.port-cell:hover .port-cell-overlay,
.port-showcase-main:hover .port-showcase-overlay {
  opacity: 1;
}
.port-cell-cat {
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .2em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 3px;
}
.port-cell-title {
  font-family: var(--serif);
  font-size: 1rem;
  font-weight: 300;
  color: var(--white);
  line-height: 1.2;
}
.port-placeholder-cell {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  transition: transform .7s cubic-bezier(.25,.46,.45,.94);
}
.port-cell:hover .port-placeholder-cell {
  transform: scale(1.07);
}
/* View all strip */
.port-view-all {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.8rem;
  border-top: 1px solid var(--border);
  gap: 1rem;
}
.port-count {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .18em;
  color: var(--muted);
  text-transform: uppercase;
}
.port-load-more {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  background: none;
  border: 1px solid var(--border);
  padding: .6rem 1.5rem;
  cursor: pointer;
  transition: all .25s;
}
.port-load-more:hover {
  background: var(--gold);
  color: var(--black);
  border-color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   BEFORE / AFTER SLIDER
═══════════════════════════════════════════════════ */
#before-after {
  background: var(--blk-mid);
  padding: 6rem 5vw;
}
.ba-header {
  margin-bottom: 3rem;
}
.ba-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
}
.ba-slider-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: col-resize;
  user-select: none;
  background: var(--black);
}
.ba-before, .ba-after {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.ba-before img, .ba-after img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}
.ba-after {
  clip-path: inset(0 50% 0 0);
  transition: clip-path 0s;
}
.ba-handle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 3px;
  background: var(--gold);
  transform: translateX(-50%);
  cursor: col-resize;
  z-index: 10;
}
.ba-handle::before,
.ba-handle::after {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--gold);
  top: 50%;
  margin-top: -20px;
}
.ba-handle::after {
  width: 32px;
  height: 32px;
  margin-top: -16px;
  background: var(--black);
}
.ba-arrows {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  z-index: 11;
  display: flex;
  gap: 6px;
  pointer-events: none;
  color: var(--gold);
  font-size: .9rem;
  font-weight: 700;
}
.ba-label {
  position: absolute;
  bottom: 1rem;
  font-family: var(--mono);
  font-size: .52rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--white);
  background: rgba(10,10,10,.75);
  padding: .3rem .7rem;
  z-index: 5;
}
.ba-label.before-lbl { left: 1rem; }
.ba-label.after-lbl  { right: 1rem; }
.ba-info {
  padding: 1.2rem 1.4rem;
  background: var(--black);
  border-top: 1px solid var(--border);
}
.ba-info-title {
  font-family: var(--serif);
  font-size: .95rem;
  color: var(--white);
  margin-bottom: .25rem;
}
.ba-info-tag {
  font-family: var(--mono);
  font-size: .52rem;
  letter-spacing: .18em;
  color: var(--gold);
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════
   PREMIUM PRICING REDESIGN
═══════════════════════════════════════════════════ */
#pricing {
  background: var(--black);
  padding: 7rem 5vw 4rem;
}

/* Main tier cards — inspired by screenshot */
.pricing-tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: 3.5rem;
  background: var(--border);
  border: 1px solid var(--border);
}
.ptier-card {
  background: var(--blk-mid);
  padding: 2.8rem 2.4rem;
  position: relative;
  transition: background .35s;
  display: flex;
  flex-direction: column;
}
.ptier-card.featured {
  background: #0f0e0a;
  border: 1px solid var(--gold);
  margin: -1px;
  z-index: 2;
}
.ptier-card:not(.featured):hover {
  background: #111009;
}
.ptier-badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--gold);
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .22em;
  color: var(--black);
  padding: .32rem 1.1rem;
  text-transform: uppercase;
  white-space: nowrap;
  font-weight: 700;
}
.ptier-label {
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .26em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: .4rem;
}
.ptier-name {
  font-family: var(--serif);
  font-size: 2.2rem;
  font-weight: 300;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: .4rem;
}
.ptier-tagline {
  font-family: var(--serif);
  font-style: italic;
  font-size: .88rem;
  color: var(--muted);
  margin-bottom: 1.8rem;
}
.ptier-price-row {
  display: flex;
  align-items: baseline;
  gap: .3rem;
  margin-bottom: .3rem;
}
.ptier-currency {
  font-family: var(--serif);
  font-size: 1.5rem;
  color: var(--gold-lt);
  font-weight: 300;
}
.ptier-amount {
  font-family: var(--serif);
  font-size: 3.8rem;
  font-weight: 300;
  color: var(--white);
  line-height: 1;
}
.ptier-price-note {
  font-family: var(--sans);
  font-size: .65rem;
  color: var(--muted);
  margin-bottom: 2rem;
}
.ptier-divider {
  height: 1px;
  background: rgba(201,168,76,.15);
  margin-bottom: 1.8rem;
}
.ptier-features {
  list-style: none;
  flex: 1;
  margin-bottom: 2rem;
}
.ptier-features li {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-size: .72rem;
  color: rgba(245,242,238,.72);
  padding: .55rem 0;
  border-bottom: 1px solid rgba(201,168,76,.06);
  line-height: 1.4;
}
.ptier-features li::before {
  content: '';
  width: 18px;
  height: 1px;
  background: var(--gold);
  flex-shrink: 0;
  margin-top: .55rem;
}
.ptier-cta {
  display: block;
  text-align: center;
  font-family: var(--sans);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  padding: 1rem 1.5rem;
  text-decoration: none;
  transition: background .3s, color .3s, border-color .3s;
  border: 1px solid var(--gold);
  color: var(--gold);
}
.ptier-cta:hover,
.ptier-card.featured .ptier-cta {
  background: var(--gold);
  color: var(--black);
}

/* Add-on module strips A-F */
.pricing-addons-section {
  margin-top: 4rem;
}
.addons-label {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .26em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 1.2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.addons-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}
.addons-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
.addon-cell {
  background: var(--blk-mid);
  padding: 1.6rem 1.2rem;
  text-align: center;
  position: relative;
  transition: background .3s;
  cursor: pointer;
}
.addon-cell:hover { background: #111009; }
.addon-letter {
  font-family: var(--serif);
  font-size: 2rem;
  font-weight: 300;
  color: rgba(201,168,76,.35);
  line-height: 1;
  display: block;
  margin-bottom: .5rem;
  transition: color .3s;
}
.addon-cell:hover .addon-letter { color: var(--gold); }
.addon-name {
  font-family: var(--sans);
  font-size: .6rem;
  font-weight: 400;
  letter-spacing: .1em;
  color: var(--muted);
  text-transform: uppercase;
  display: block;
}
.addon-price {
  font-family: var(--mono);
  font-size: .6rem;
  color: var(--gold);
  margin-top: .4rem;
  display: block;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .25s, transform .25s;
}
.addon-cell:hover .addon-price {
  opacity: 1;
  transform: none;
}

/* Matrix CSS removed — replaced by Loyalty & Rewards cards */

@media (max-width:1080px) {
  .pricing-tiers { grid-template-columns: 1fr; }
  .addons-grid { grid-template-columns: repeat(3,1fr); }
  .story-layout { grid-template-columns: 1fr; }
  .story-image-side { height: 50vw; }
  .port-masonry { grid-template-columns: repeat(2,1fr); }
  .ba-grid { grid-template-columns: 1fr; }
  .port-showcase { grid-template-columns: 1fr; }
  .port-showcase-stack { grid-template-rows: auto auto; grid-template-columns: 1fr 1fr; }
}
@media (max-width:700px) {
  .port-section-header { grid-template-columns: 1fr; }
  .addons-grid { grid-template-columns: repeat(2,1fr); }
  .pricing-tiers { grid-template-columns: 1fr; }
  .story-stats-row { gap: 1.5rem; flex-wrap: wrap; }
}

/* ═══ BEFORE/AFTER MOBILE TOUCH FIX ═══
   Prevent iOS elastic bounce and Android
   overscroll from interfering with the slider */
.ba-slider-wrap {
  touch-action: pan-y;        /* allow vertical page scroll, block horizontal */
  -webkit-user-select: none;
  user-select: none;
  overscroll-behavior: none;
}
.ba-slider-wrap img {
  pointer-events: none;       /* images don't capture their own touch events */
  -webkit-user-drag: none;
}
.ba-handle {
  touch-action: none;         /* handle captures all touch — no browser interference */
}

/* ═══ LOYALTY & REWARDS CARDS ═══ */
.pricing-rewards {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid var(--border);
}
.rewards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
.reward-card {
  background: var(--blk-mid);
  padding: 2.6rem 2.2rem;
  position: relative;
  transition: background .3s;
  display: flex;
  flex-direction: column;
}
.reward-card:hover { background: #0f0e0a; }
.reward-icon {
  font-size: 1.8rem;
  color: rgba(201,168,76,.3);
  line-height: 1;
  margin-bottom: .9rem;
  transition: color .3s;
}
.reward-card:hover .reward-icon { color: var(--gold); }
.reward-badge {
  font-family: var(--mono);
  font-size: .52rem;
  letter-spacing: .28em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: .5rem;
}
.reward-title {
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 300;
  color: var(--white);
  line-height: 1.15;
  margin-bottom: 1.2rem;
}
.reward-code {
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .1em;
  color: var(--muted);
  margin-bottom: 1rem;
  background: rgba(201,168,76,.08);
  border: 1px dashed rgba(201,168,76,.3);
  padding: .5rem .8rem;
  display: inline-block;
  border-radius: 2px;
}
.reward-code span {
  color: var(--gold-lt);
  font-weight: 600;
  letter-spacing: .18em;
}
.reward-body {
  font-size: .72rem;
  line-height: 1.85;
  color: var(--muted);
  flex: 1;
  margin-bottom: 1.8rem;
}
.reward-cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px solid rgba(201,168,76,.3);
  padding-bottom: 2px;
  transition: gap .25s, border-color .25s, color .25s;
  align-self: flex-start;
}
.reward-cta:hover {
  gap: .9rem;
  color: var(--gold-lt);
  border-color: var(--gold);
}

@media (max-width: 900px) {
  .rewards-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE RESPONSIVE — full site
   ======================================================= */

/* Tablets 768–1080px */
@media (max-width: 1080px) {
  .hero-headline { font-size: clamp(2.8rem, 7vw, 5rem); }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .testi-grid    { grid-template-columns: repeat(2, 1fr); }
  .process-layout { grid-template-columns: 1fr; gap: 3rem; }
  .process-visual { display: none; } /* hide side image on tablet — keeps layout clean */
  .why-layout    { grid-template-columns: 1fr; gap: 2.5rem; }
  .why-items     { grid-template-columns: repeat(2, 1fr); }
  .contact-layout { grid-template-columns: 1fr; gap: 3rem; }
  .pricing-tiers { grid-template-columns: 1fr; max-width: 500px; margin: 3.5rem auto 0; }
  .ptier-card.featured { margin: 0; }
  .addons-grid   { grid-template-columns: repeat(3, 1fr); }
  .rewards-grid  { grid-template-columns: 1fr; }
  .story-layout  { grid-template-columns: 1fr; }
  .story-image-side { min-height: 60vw; order: -1; }
  .story-image-accent { display: none; }
  .port-masonry  { grid-template-columns: repeat(2, 1fr); }
  .port-showcase { grid-template-columns: 1fr; }
  .port-showcase-stack { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .ba-grid       { grid-template-columns: 1fr; }
  .footer-grid   { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .footer-brand  { grid-column: span 2; }
}

/* Mobile 480–768px */
@media (max-width: 768px) {
  .dfc-section { padding: 5rem 6vw; }
  #site-header { padding: 0 6vw; height: 68px; }
  #mobile-nav  { top: 68px; }
  #primary-nav { display: none; }
  .menu-toggle { display: flex; }
  .hero-content { padding: 0 6vw 10vh; }
  .hero-headline { font-size: clamp(2.4rem, 10vw, 4rem); max-width: 100%; }
  .hero-stats { display: none; }  /* too cramped on small screens */
  .hero-scroll { display: none; }
  .services-grid { grid-template-columns: 1fr; }
  .testi-grid { grid-template-columns: 1fr; }
  .why-items { grid-template-columns: 1fr; }
  .port-section-header { grid-template-columns: 1fr; }
  .port-masonry { grid-template-columns: 1fr 1fr; }
  .port-cell.span2 { grid-column: span 2; aspect-ratio: 16/9; }
  .pricing-tiers { max-width: 100%; }
  .ptier-card { padding: 2rem 1.6rem; }
  .ptier-amount { font-size: 3rem; }
  .addons-grid { grid-template-columns: repeat(2, 1fr); }
  .addon-price { opacity: 1; transform: none; } /* always show price on mobile */
  .ba-slider-wrap { aspect-ratio: 3/2; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-brand { grid-column: auto; }
  .form-row { grid-template-columns: 1fr; }
  .story-stats-row { gap: 1.5rem; flex-wrap: wrap; }
  .story-headline { font-size: clamp(2rem, 8vw, 3rem); }
  .section-title { font-size: clamp(1.8rem, 6vw, 3rem); }
  .rewards-grid { grid-template-columns: 1fr; }
  .reward-card { padding: 2rem 1.5rem; }
  .faq-grid { max-width: 100%; }
  .cta-band { text-align: center; }
  .cta-band h2 { font-size: clamp(1.8rem, 6vw, 2.8rem); }
}

/* Small mobile < 480px */
@media (max-width: 480px) {
  .dfc-section { padding: 4rem 5vw; }
  .hero-headline { font-size: clamp(2rem, 11vw, 3rem); }
  .port-masonry { grid-template-columns: 1fr; }
  .port-cell.span2 { grid-column: auto; aspect-ratio: 4/3; }
  .port-showcase { display: flex; flex-direction: column; }
  .port-showcase-stack { grid-template-columns: 1fr; }
  .addons-grid { grid-template-columns: repeat(2, 1fr); }
  .ba-slider-wrap { aspect-ratio: 4/3; }
  .ptier-amount { font-size: 2.6rem; }
  .story-text-side { padding: 3rem 5vw; }
  .process-badge { left: 1rem; right: 1rem; bottom: 1rem; }
}

/* ═══════════════════════════════════════════════════════
   MOBILE NAV HEIGHT ADJUSTMENTS
   ======================================================= */
@media (max-width: 768px) {
/* Mobile scroll and height corrections */
@media (max-width: 768px) {
  /* No padding-top on body — hero handles its own height */
  #hero { min-height: 100svh; min-height: 100vh; } /* svh for modern, vh fallback */
}
}

/* ═══════════════════════════════════════════════════════
   MISC POLISH
   ======================================================= */

/* overflow-x is handled on #page-wrapper above */

/* Smoother image loading */
img { transition: opacity .3s ease; }
img[loading="lazy"] { opacity: 0; }
img.loaded, img:not([loading="lazy"]) { opacity: 1; }

/* Better focus ring for accessibility */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

/* Contact form on mobile */
@media (max-width: 768px) {
  .contact-form { padding: 0; }
  .contact-areas { margin-top: 1.2rem; }
}

/* Portfolio filter tabs on mobile — scroll horizontally */
@media (max-width: 768px) {
}

/* Testimonials slider arrows on mobile */
@media (max-width: 768px) {
  .testi-nav { margin-bottom: 1.5rem; }
  .testi-prev, .testi-next { width: 36px; height: 36px; font-size: .85rem; }
}

/* Before/after grid — single column, full width on mobile */
@media (max-width: 768px) {
  #before-after { padding: 4rem 0; }
  .ba-header { padding: 0 6vw; }
  .ba-grid { gap: 0; }
  .ba-info { padding: 1rem 1.2rem; }
}

/* Pricing section padding on mobile */
@media (max-width: 768px) {
  #pricing .dfc-section { padding: 4rem 5vw 2rem; }
  .pricing-addons-section { margin-top: 2.5rem; }
  .pricing-rewards { margin-top: 2.5rem; padding-top: 2rem; }
  .addons-label, .section-label { font-size: .5rem; }
}

/* FAQ on mobile */
@media (max-width: 768px) {
  .faq-q { font-size: 1rem; }
  .faq-a-inner { font-size: .72rem; padding-bottom: 1rem; }
}

/* Footer on mobile */
@media (max-width: 768px) {
  #site-footer { padding: 3rem 6vw 2rem; }
  .footer-bottom { flex-direction: column; gap: .75rem; text-align: center; }
  .footer-certs { justify-content: center; }
}

/* Our Story section on mobile */
@media (max-width: 768px) {
  #our-story .story-text-side { padding: 4rem 6vw; }
  .story-stats-row { margin-top: 2rem; padding-top: 1.5rem; }
  .story-stat .snum { font-size: 1.8rem; }
}

/* Announcement bar on mobile */
@media (max-width: 768px) {
  #dfc-topbar { padding: .45rem 2.5rem .45rem 1rem; font-size: .55rem; }
  .topbar-close { right: .6rem; }
}

/* ═══ FOOTER IMPROVEMENTS ═══ */
#site-footer {
  background: #050504;
  border-top: 1px solid var(--border);
}
.footer-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 4rem;
  padding: 5rem 5vw 4rem;
}
.footer-logo-link {
  display: flex;
  align-items: center;
  gap: .7rem;
  text-decoration: none;
  margin-bottom: 1.2rem;
}
.footer-logo-link svg { width: 28px; height: 28px; flex-shrink: 0; }
.footer-brand-name {
  font-family: var(--serif);
  font-size: .95rem;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--white);
}
.footer-tagline {
  font-size: .68rem;
  line-height: 1.8;
  color: var(--muted);
  margin-bottom: 1.2rem;
  max-width: 34ch;
}
.footer-contact-links {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-bottom: 1.2rem;
}
.footer-contact-item {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .1em;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.footer-contact-item:hover { color: var(--gold); }
.footer-contact-item svg { color: var(--gold); flex-shrink: 0; }
.footer-social {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-top: .5rem;
}
.footer-social-link {
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .15em;
  color: var(--muted);
  border: 1px solid rgba(201,168,76,.2);
  padding: .3rem .6rem;
  text-decoration: none;
  transition: all .2s;
}
.footer-social-link:hover {
  background: var(--gold);
  color: var(--black);
  border-color: var(--gold);
}
.footer-col h5 {
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.2rem;
  font-weight: 400;
}
.footer-col ul li {
  margin-bottom: .55rem;
}
.footer-col ul li a {
  font-family: var(--sans);
  font-size: .68rem;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
  letter-spacing: .04em;
}
.footer-col ul li a:hover { color: var(--gold-lt); }
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.4rem 5vw;
  border-top: 1px solid rgba(201,168,76,.1);
  flex-wrap: wrap;
  gap: .75rem;
}
.footer-copy {
  font-family: var(--mono);
  font-size: .55rem;
  letter-spacing: .12em;
  color: rgba(122,115,106,.55);
  text-transform: uppercase;
}
.footer-certs {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}
.cert-pill {
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .14em;
  color: var(--gold);
  border: 1px solid rgba(201,168,76,.25);
  padding: .25rem .65rem;
  text-transform: uppercase;
}

@media (max-width: 1080px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .footer-brand { grid-column: span 2; }
}
@media (max-width: 600px) {
  .footer-top { grid-template-columns: 1fr; padding: 3.5rem 6vw 2.5rem; }
  .footer-brand { grid-column: auto; }
  .footer-tagline { max-width: 100%; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ═══════════════════════════════════════════════════════
   REFERRAL POPUP
   ======================================================= */

/* Overlay */
.rpop-overlay {
  position: fixed;
  inset: 0;
  z-index: 8000;
  background: rgba(5,5,4,.88);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  transition: opacity .35s ease;
}
.rpop-overlay:not([hidden]) {
  opacity: 1;
}
.rpop-overlay[hidden] {
  display: none;
}

/* Box */
.rpop-box {
  background: var(--blk-mid);
  border: 1px solid var(--border);
  width: 100%;
  max-width: 860px;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  padding: 3rem 3rem 2.5rem;
  transform: translateY(18px);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.rpop-overlay:not([hidden]) .rpop-box {
  transform: translateY(0);
}

/* Close button */
.rpop-close {
  position: absolute;
  top: 1.2rem;
  right: 1.4rem;
  background: none;
  border: 1px solid var(--border);
  color: var(--muted);
  width: 32px;
  height: 32px;
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  line-height: 1;
}
.rpop-close:hover {
  background: var(--gold);
  color: var(--black);
  border-color: var(--gold);
}

/* Header */
.rpop-header {
  margin-bottom: 2rem;
  padding-bottom: 1.6rem;
  border-bottom: 1px solid rgba(201,168,76,.15);
}
.rpop-eyebrow {
  font-family: var(--mono);
  font-size: .52rem;
  letter-spacing: .3em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: .7rem;
}
.rpop-title {
  font-family: var(--serif);
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  font-weight: 300;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: .85rem;
}
.rpop-title em {
  color: var(--gold-lt);
  font-style: italic;
}
.rpop-intro {
  font-size: .76rem;
  line-height: 1.75;
  color: var(--muted);
  max-width: 60ch;
}
.rpop-intro strong { color: var(--gold-lt); }

/* Two-column form layout */
.rpop-cols {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0;
  margin-bottom: 1.2rem;
}
.rpop-col { padding: 0 1.5rem 0 0; }
.rpop-col:last-child { padding: 0 0 0 1.5rem; }
.rpop-divider-v {
  width: 1px;
  background: rgba(201,168,76,.15);
  margin: .5rem 0;
}
.rpop-col-label {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-family: var(--mono);
  font-size: .55rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.2rem;
}
.rpop-col-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--gold);
  color: var(--black);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .58rem;
  flex-shrink: 0;
}

/* Fields */
.rpop-field {
  display: flex;
  flex-direction: column;
  gap: .28rem;
  margin-bottom: .85rem;
}
.rpop-field label {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .12em;
  color: rgba(245,242,238,.5);
  text-transform: uppercase;
}
.rpop-opt {
  font-weight: 300;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(122,115,106,.6);
}
.rpop-field input,
.rpop-field textarea {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 2px;
  padding: .65rem .85rem;
  font-family: var(--sans);
  font-size: .82rem;
  color: var(--white);
  width: 100%;
  transition: border-color .2s, background .2s;
}
.rpop-field input::placeholder,
.rpop-field textarea::placeholder { color: rgba(122,115,106,.5); }
.rpop-field input:focus,
.rpop-field textarea:focus {
  outline: none;
  border-color: var(--gold);
  background: rgba(201,168,76,.04);
}
.rpop-field textarea { resize: none; min-height: 68px; }

/* Reward preview strip */
.rpop-reward-preview {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: rgba(10,10,10,.6);
  border: 1px solid rgba(201,168,76,.2);
  margin: 1.5rem 0;
}
.rpop-reward-item {
  flex: 1;
  padding: 1.2rem 1.5rem;
  text-align: center;
}
.rpop-reward-sep {
  width: 1px;
  background: rgba(201,168,76,.15);
  flex-shrink: 0;
}
.rpop-reward-who {
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .2em;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: .4rem;
}
.rpop-reward-benefit {
  font-family: var(--serif);
  font-size: 2rem;
  font-weight: 300;
  color: var(--gold-lt);
  line-height: 1;
  margin-bottom: .4rem;
}
.rpop-reward-desc {
  font-size: .65rem;
  color: rgba(122,115,106,.7);
  line-height: 1.5;
}

/* Submit button */
.rpop-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  width: 100%;
  background: var(--gold);
  color: var(--black);
  border: none;
  padding: 1rem 2rem;
  font-family: var(--sans);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .25s;
}
.rpop-submit:hover { background: var(--gold-lt); }
.rpop-submit:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* Error state */
.rpop-error {
  margin-top: .75rem;
  padding: .7rem 1rem;
  background: rgba(180,40,40,.12);
  border: 1px solid rgba(180,40,40,.35);
  color: #e07070;
  font-size: .72rem;
  font-family: var(--mono);
  letter-spacing: .06em;
  border-radius: 2px;
}

/* Success state */
.rpop-success {
  text-align: center;
  padding: 2.5rem 2rem;
}
.rpop-success[hidden] { display: none; }
.rpop-success-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(201,168,76,.15);
  border: 2px solid var(--gold);
  color: var(--gold);
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.4rem;
}
.rpop-success h3 {
  font-family: var(--serif);
  font-size: 1.8rem;
  font-weight: 300;
  color: var(--white);
  margin-bottom: .85rem;
}
.rpop-success p {
  font-size: .8rem;
  line-height: 1.8;
  color: var(--muted);
  max-width: 44ch;
  margin: 0 auto 1.8rem;
}
.rpop-success p strong { color: var(--gold-lt); }
.rpop-close-success {
  background: none;
  border: 1px solid var(--border);
  color: var(--gold);
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .6rem 1.6rem;
  cursor: pointer;
  transition: all .2s;
}
.rpop-close-success:hover {
  background: var(--gold);
  color: var(--black);
  border-color: var(--gold);
}

/* reward-cta as button (for popup trigger) */
button.reward-cta {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-family: inherit;
  text-align: left;
}

/* Mobile */
@media (max-width: 680px) {
  .rpop-box { padding: 2rem 1.4rem 1.8rem; }
  .rpop-cols {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .rpop-col { padding: 0; }
  .rpop-col:last-child { padding: 0; }
  .rpop-divider-v {
    height: 1px;
    width: auto;
    margin: 1rem 0;
  }
  .rpop-reward-preview { flex-direction: column; }
  .rpop-reward-sep { width: auto; height: 1px; }
  .rpop-title { font-size: 1.5rem; }
}

/* ═══ PORTFOLIO VIDEO ═══ */
.port-video-thumb {
  position: absolute;
  inset: 0;
  cursor: pointer;
}
.port-video-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .65s cubic-bezier(.25,.46,.45,.94);
}
.port-cell:hover .port-video-thumb img { transform: scale(1.05); }
.port-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10,10,10,.35);
  transition: background .3s;
}
.port-video-thumb:hover .port-play-btn { background: rgba(10,10,10,.55); }
.port-play-btn svg {
  width: 52px;
  height: 52px;
  color: #fff;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.5));
  transition: transform .25s;
}
.port-video-thumb:hover .port-play-btn svg { transform: scale(1.1); }

/* ═══ VIDEO LIGHTBOX ═══ */
/* VIDEO LIGHTBOX — display controlled entirely by JS inline style */
#port-video-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9500;
  display: none;  /* JS sets to flex when open */
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background: rgba(5,5,4,.92);
}
.pvl-overlay {
  position: absolute;
  inset: 0;
  cursor: pointer;
}
.pvl-box {
  position: relative;
  width: 100%;
  max-width: 900px;
  background: #0a0a0a;
  border: 1px solid rgba(201,168,76,.3);
  z-index: 1;
}
.pvl-close {
  position: absolute;
  top: -40px;
  right: 0;
  background: rgba(10,10,10,.8);
  border: 1px solid rgba(245,242,238,.4);
  color: #f5f2ee;
  width: 36px;
  height: 36px;
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  line-height: 1;
}
.pvl-close:hover { background: #c9a84c; color: #0a0a0a; border-color: #c9a84c; }
.pvl-embed-wrap {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}
.pvl-embed-wrap iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ═══════════════════════════════════════════════════════
   PORTFOLIO — CLEAN UNIFORM GRID (redesign)
   ======================================================= */

/* Section header — tag, title, filter tabs */
.port-section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1.5rem;
  padding-bottom: 2rem;
}



/* The grid */
.port-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3px;
  padding: 0 5vw;
}

/* Every cell — locked 4:3 aspect ratio */
.port-grid-cell {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--blk-mid);
  cursor: pointer;
}

/* Wide item spans 2 columns, keeps same height */
.port-grid-wide {
  grid-column: span 2;
  aspect-ratio: 8 / 3;  /* 2× wide, same height */
}

/* Images fill the cell perfectly */
.port-grid-cell img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .65s cubic-bezier(.25,.46,.45,.94);
  display: block;
}
.port-grid-cell:hover img {
  transform: scale(1.06);
}

/* Gradient placeholder when no image */
.port-grad-bg {
  position: absolute;
  inset: 0;
}

/* Hover overlay */
.port-grid-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(10,10,10,.82) 0%, rgba(10,10,10,.2) 50%, transparent 100%);
  opacity: 0;
  transition: opacity .3s;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.2rem 1.4rem;
  pointer-events: none;
}
.port-grid-cell:hover .port-grid-overlay {
  opacity: 1;
}
.port-grid-cat {
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .2em;
  color: var(--gold);
  text-transform: uppercase;
  display: block;
  margin-bottom: .25rem;
}
.port-grid-title {
  font-family: var(--serif);
  font-size: 1rem;
  font-weight: 300;
  color: var(--white);
  display: block;
  line-height: 1.2;
}
.port-grid-play-label {
  font-family: var(--mono);
  font-size: .5rem;
  letter-spacing: .15em;
  color: rgba(201,168,76,.8);
  text-transform: uppercase;
  display: block;
  margin-top: .3rem;
}

/* Video thumbnail inside grid cell */
.port-video-thumb {
  position: absolute;
  inset: 0;
  cursor: pointer;
}
.port-video-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .65s cubic-bezier(.25,.46,.45,.94);
  pointer-events: none;
}
.port-grid-cell:hover .port-video-thumb img {
  transform: scale(1.06);
}

/* Play button centered over video */
.port-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.port-play-btn svg {
  width: 56px;
  height: 56px;
  filter: drop-shadow(0 2px 12px rgba(0,0,0,.6));
  transition: transform .25s;
  opacity: .9;
}
.port-grid-cell:hover .port-play-btn svg {
  transform: scale(1.12);
  opacity: 1;
}

/* View all footer */
.port-view-all {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.4rem 5vw 3rem;
  border-top: 1px solid rgba(201,168,76,.1);
  margin-top: 3px;
}
.port-count {
  font-family: var(--mono);
  font-size: .55rem;
  letter-spacing: .15em;
  color: rgba(122,115,106,.5);
  text-transform: uppercase;
}
.port-load-more {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  border-bottom: 1px solid rgba(201,168,76,.3);
  padding-bottom: 2px;
  transition: gap .25s, border-color .25s;
}
.port-load-more:hover {
  color: var(--gold-lt);
  border-color: var(--gold);
}

/* Responsive */
@media (max-width: 1200px) {
  .port-grid { grid-template-columns: repeat(3, 1fr); }
  .port-grid-wide { aspect-ratio: 6 / 3; }
}
@media (max-width: 768px) {
  .port-section-header { flex-direction: column; align-items: flex-start; padding: 3rem 6vw 1.5rem; }
  .port-grid { grid-template-columns: repeat(2, 1fr); padding: 0 0; gap: 2px; }
  .port-grid-wide { grid-column: span 2; aspect-ratio: 4 / 3; }
  .port-grid-overlay { opacity: 1; } /* always show labels on mobile */
  .port-view-all { padding: 1rem 6vw 2.5rem; }
}
@media (max-width: 480px) {
  .port-grid { grid-template-columns: 1fr; }
  .port-grid-wide { grid-column: auto; aspect-ratio: 4 / 3; }
}

/* Native video files (.mov/.mp4) uploaded as portfolio items */
.port-native-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .65s cubic-bezier(.25,.46,.45,.94);
}
.port-grid-cell:hover .port-native-video {
  transform: scale(1.06);
}

/* ═══ PORTFOLIO FILTER TABS — consolidated, single definition ═══ */
.port-filter-tabs {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;          /* never wrap — always single row */
  overflow-x: auto;           /* scroll horizontally on all screen sizes */
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;      /* hide scrollbar Firefox */
  gap: 0;
  align-items: center;
  padding-bottom: 2px;        /* room for focus ring */
}
.port-filter-tabs::-webkit-scrollbar { display: none; } /* hide scrollbar Chrome/Safari */

.port-tab {
  flex-shrink: 0;             /* never shrink — keeps full text visible */
  font-family: var(--mono);
  font-size: .52rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
  background: none;
  border: none;
  border-right: 1px solid rgba(122,115,106,.2);
  padding: .55rem 1.2rem;
  cursor: pointer;
  transition: color .2s, background .2s;
  white-space: nowrap;
}
.port-tab:first-child { border-left: 1px solid rgba(122,115,106,.2); }
.port-tab:hover { color: var(--gold-lt); background: rgba(201,168,76,.06); }
.port-tab.active { color: var(--black); background: var(--gold); border-color: var(--gold); }
.port-tab.active + .port-tab { border-left: none; }

@media (max-width: 768px) {
  .port-tab { font-size: .5rem; padding: .5rem .9rem; }
}

/* ═══ FILTER TABS WRAPPER — full viewport width scroll ═══ */
.port-filter-tabs-wrap {
  width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch; /* iOS momentum scroll */
  scrollbar-width: none;
  border-top: 1px solid rgba(201,168,76,.12);
  border-bottom: 1px solid rgba(201,168,76,.12);
  margin-bottom: 3px;
}
.port-filter-tabs-wrap::-webkit-scrollbar { display: none; }

/* Tabs row — no overflow on this, the wrapper handles it */
.port-filter-tabs {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow: visible !important; /* wrapper handles scroll */
  width: max-content; /* expands to full tabs width so wrapper scrolls */
  min-width: 100%;
  padding: 0 5vw;
  gap: 0;
}

.port-tab {
  flex-shrink: 0 !important;
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
  background: none;
  border: none;
  border-right: 1px solid rgba(122,115,106,.15);
  padding: .8rem 1.4rem;
  cursor: pointer;
  transition: color .2s, background .2s;
  white-space: nowrap;
}
.port-tab:first-child { border-left: none; }
.port-tab:hover { color: var(--gold-lt); }
.port-tab.active {
  color: var(--gold);
  border-bottom: 2px solid var(--gold);
  margin-bottom: -2px;
}

/* ═══════════════════════════════════════════════════════
   VIBRANT THEME OVERRIDES
   Deep navy backgrounds, electric amber + cyan accents,
   glowing effects, high-energy feel
   ======================================================= */

/* Body — deep navy instead of pure black */
body {
  background: var(--black);
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(240,165,0,.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 80%, rgba(0,212,255,.05) 0%, transparent 50%);
}

/* Nav — glassy navy */
#site-header.scrolled {
  background: rgba(6,10,20,.95);
  border-bottom-color: rgba(240,165,0,.3);
  box-shadow: 0 4px 30px rgba(240,165,0,.08);
}

/* Logo brand name */
.brand-name { color: var(--white); letter-spacing: .22em; }

/* Nav links */
#primary-nav a { color: rgba(240,244,255,.6); }
#primary-nav a:hover { color: var(--white); }
#primary-nav a::after { background: var(--gold); }
#primary-nav a.is-active { color: var(--gold); }

/* Book button — electric amber */
.nav-book {
  background: var(--gold) !important;
  color: #060a14 !important;
}
.nav-book:hover {
  background: var(--gold-lt) !important;
}

/* Hero — deep navy with electric gradient overlay */
#hero { background-color: var(--black); }
.hero-bg::before {
  background: radial-gradient(ellipse 70% 60% at 60% 30%,
    rgba(240,165,0,.15) 0%,
    rgba(0,212,255,.08) 40%,
    transparent 70%);
}
.hero-bg::after {
  background: linear-gradient(0deg,
    rgba(6,10,20,.92) 0%,
    rgba(6,10,20,.45) 50%,
    rgba(6,10,20,.2) 100%);
}

/* Hero grid lines — more visible */
.hero-gridlines {
  background-image:
    linear-gradient(rgba(240,165,0,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(240,165,0,.06) 1px, transparent 1px);
}

/* Hero eyebrow — cyan accent */
.eyebrow-text { color: var(--cyan); }
.eyebrow-line { background: var(--cyan); }

/* Hero headline — white with amber em */
.hero-headline { color: var(--white); }
.hero-headline em { color: var(--gold-lt); text-shadow: 0 0 40px rgba(240,165,0,.4); }

/* Hero sub */
.hero-sub { color: rgba(240,244,255,.55); }

/* Hero stats — glassy cards */
.stat-item {
  background: rgba(6,10,20,.8);
  border-color: rgba(240,165,0,.2);
}
.stat-num { color: var(--gold-lt); text-shadow: 0 0 20px rgba(240,165,0,.3); }

/* Scroll indicator */
.scroll-line { background: linear-gradient(to bottom, var(--cyan), transparent); }

/* Marquee — vibrant amber band */
.dfc-marquee { background: linear-gradient(90deg, var(--gold-dk), var(--gold), var(--gold-dk)); }
.marquee-item { color: var(--black); }

/* Section tags — cyan */
.tag-line { background: var(--cyan); }
.tag-text { color: var(--cyan); }

/* Section titles */
.section-title em { color: var(--gold-lt); }

/* Buttons — vibrant amber */
.btn-primary {
  background: var(--gold);
  color: var(--black);
  box-shadow: 0 4px 24px rgba(240,165,0,.3);
}
.btn-primary:hover {
  background: var(--gold-lt);
  box-shadow: 0 4px 32px rgba(240,165,0,.5);
  color: var(--black);
}
.btn-ghost {
  color: rgba(240,244,255,.7);
  border-color: rgba(240,244,255,.35);
}
.btn-ghost:hover {
  color: var(--gold-lt);
  border-color: var(--gold);
}

/* Services section */
.dfc-section.section-dark,
.section-dark { background: var(--blk-mid); }
.section-black { background: var(--black); }

.service-card {
  background: var(--blk-mid);
  border: 1px solid rgba(240,165,0,.08);
}
.service-card:hover {
  background: rgba(12,18,32,1);
  border-color: rgba(240,165,0,.25);
  box-shadow: 0 0 30px rgba(240,165,0,.08);
}
.svc-num { color: var(--cyan); }
.svc-border { background: linear-gradient(90deg, var(--gold), var(--cyan)); }
.svc-link { color: var(--gold); }
.svc-link:hover { color: var(--gold-lt); }

/* Why Us — gold section */
.section-gold { background: linear-gradient(135deg, var(--gold-dk), var(--gold)); }
.why-headline { color: #060a14; }
.why-item h4 { color: #060a14; }
.why-item p { color: rgba(6,10,20,.7); }

/* Testimonials */
.testi-card { background: var(--blk-mid); border-top-color: var(--gold); }
.testi-stars { color: var(--gold); }
.quote-glyph { color: rgba(240,165,0,.15); }

/* Pricing — featured card glow */
.ptier-card.featured {
  border-color: var(--gold);
  box-shadow: 0 0 40px rgba(240,165,0,.15), 0 0 0 1px rgba(240,165,0,.3);
}
.ptier-badge { background: var(--gold); color: var(--black); }
.ptier-cta {
  border-color: var(--gold);
  color: var(--gold);
}
.ptier-card.featured .ptier-cta {
  background: var(--gold);
  color: var(--black);
}

/* FAQ */
.faq-item.open .faq-q { color: var(--gold-lt); }
.faq-toggle { color: var(--gold); }

/* CTA Band */
.cta-band {
  background: linear-gradient(135deg, var(--blk-mid) 0%, rgba(12,18,32,.95) 100%);
  border-color: rgba(240,165,0,.2);
}
.cta-band::before {
  background: radial-gradient(ellipse 60% 100% at 50% 50%,
    rgba(240,165,0,.07) 0%, transparent 70%);
}

/* Contact form */
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(240,165,0,.12);
}

/* Back to top */
#dfc-btt {
  background: var(--gold);
  color: var(--black);
  box-shadow: 0 4px 20px rgba(240,165,0,.4);
}
#dfc-btt:hover {
  background: var(--gold-lt);
}

/* Loader */
.loader-bar { background: linear-gradient(90deg, var(--gold), var(--cyan)); }

/* Cursor */
#dfc-dot { background: var(--gold); }
#dfc-ring { border-color: rgba(240,165,0,.6); }

/* Story section */
.story-eyebrow span { color: var(--cyan); }
.story-eyebrow-line { background: var(--cyan); }
.story-headline em { color: var(--gold-lt); }
.story-link { color: var(--gold); }
.story-link:hover { color: var(--gold-lt); }
.story-accent-text { color: rgba(240,165,0,.35); }
.snum { color: var(--gold-lt); text-shadow: 0 0 20px rgba(240,165,0,.3); }

/* Portfolio */
.port-tab.active {
  color: var(--black);
  background: var(--gold);
  border-color: var(--gold);
}
.port-grid-cat { color: var(--gold); }
.port-play-btn svg circle { stroke: rgba(240,165,0,.9); }

/* Reward cards */
.reward-card:hover .reward-icon { color: var(--gold); }
.reward-badge { color: var(--gold); }
.reward-code span { color: var(--gold-lt); }
.reward-cta { color: var(--gold); }

/* Process steps */
.step-n { color: var(--cyan); }

/* Footer */
#site-footer { background: #04080f; }
.footer-col h5 { color: var(--gold); }
.footer-social-link:hover { background: var(--gold); color: var(--black); border-color: var(--gold); }
.cert-pill { color: var(--gold); border-color: rgba(240,165,0,.3); }

/* Glow on hover for cards */
.service-card:hover,
.testi-card:hover,
.reward-card:hover {
  transform: translateY(-2px);
  transition: transform .3s, box-shadow .3s, background .3s;
}

/* Cyan highlights for links */
a { color: var(--gold); }
a:hover { color: var(--gold-lt); }
em { color: var(--gold-lt); }

/* Referral popup */
.rpop-title em { color: var(--gold-lt); }
.rpop-eyebrow { color: var(--gold); }
.rpop-submit { background: var(--gold); color: var(--black); }
.rpop-submit:hover { background: var(--gold-lt); }

/* ── Camera + Drone cursor trail ── */
#dfc-drone-trail {
  position: fixed;
  z-index: 9997;
  top: 0; left: 0;
  pointer-events: none;
  transform: translate(-50%,-50%);
  color: var(--gold);
  opacity: 0.7;
  transition: opacity .2s;
}
#dfc-drone-trail svg {
  width: 32px;
  height: 32px;
  filter: drop-shadow(0 0 6px rgba(240,165,0,.5));
}

/* ═══ EFFECTS & WOW — portfolio + pricing hover CSS ═══ */
.port-hover-slide-up .port-grid-overlay { opacity:1; transform:translateY(100%); transition:transform .35s cubic-bezier(.25,.46,.45,.94); }
.port-hover-slide-up .port-grid-cell:hover .port-grid-overlay { transform:translateY(0); }
.port-hover-blur-reveal .port-grid-cell img, .port-hover-blur-reveal .port-native-video { filter:blur(6px); transform:scale(1.04); transition:filter .4s ease, transform .4s ease; }
.port-hover-blur-reveal .port-grid-cell:hover img, .port-hover-blur-reveal .port-grid-cell:hover .port-native-video { filter:blur(0); transform:scale(1); }
.port-hover-glitch .port-grid-cell:hover img { animation:glitchShift .4s steps(2) forwards; }
@keyframes glitchShift { 0%{transform:translate(0,0) scale(1);filter:none} 20%{transform:translate(-4px,2px) scale(1.01);filter:hue-rotate(90deg)} 40%{transform:translate(4px,-2px) scale(1.01);filter:hue-rotate(-90deg)} 60%{transform:translate(-2px,4px) scale(1.02);filter:saturate(2)} 80%{transform:translate(2px,-1px) scale(1.01);filter:none} 100%{transform:translate(0,0) scale(1.06);filter:none} }
.port-hover-glitch .port-grid-overlay { opacity:0; transition:opacity .2s .2s; }
.port-hover-glitch .port-grid-cell:hover .port-grid-overlay { opacity:1; }
.pricing-hover-glow .ptier-card:hover { box-shadow:0 0 40px rgba(240,165,0,.25),0 0 0 1px rgba(240,165,0,.4); border-color:var(--gold); transform:none; }
.pricing-hover-flip .ptier-card:hover { transform:rotateY(8deg) scale(1.02); box-shadow:-12px 12px 30px rgba(0,0,0,.4); }
.pricing-hover-expand .ptier-features { max-height:120px; overflow:hidden; transition:max-height .5s ease; }
.pricing-hover-expand .ptier-card:hover .ptier-features { max-height:600px; }

/* ═══════════════════════════════════════════════════════
   IMAGE LIGHTBOX (added 2.1.0)
   Click any portfolio photo to view full-size
   ═══════════════════════════════════════════════════════ */
#port-image-lightbox{
  position:fixed; inset:0; z-index:9600;
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity .3s ease;
}
#port-image-lightbox.open{ opacity:1; pointer-events:auto; }
#port-image-lightbox .pil-overlay{
  position:absolute; inset:0;
  background:rgba(4,6,12,.94);
  cursor:zoom-out;
}
.pil-stage{
  position:relative;
  max-width:96vw; max-height:92vh;
  margin:0; padding:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  z-index:2;
}
#port-image-lightbox img{
  max-width:96vw; max-height:84vh;
  width:auto; height:auto;
  object-fit:contain;
  display:block;
  box-shadow:0 30px 80px rgba(0,0,0,.7);
  background:#0a0a0a;
  user-select:none;
  -webkit-user-drag:none;
}
.pil-caption{
  margin-top:.9rem;
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--white);
  text-align:center;
  max-width:80vw;
  padding:0 1rem;
  text-shadow:0 1px 8px rgba(0,0,0,.6);
}
.pil-counter{
  position:absolute; top:-2.4rem; left:50%; transform:translateX(-50%);
  font-family:var(--mono); font-size:.55rem; letter-spacing:.2em;
  color:rgba(245,242,238,.5); text-transform:uppercase;
}
.pil-close,.pil-prev,.pil-next{
  position:absolute; z-index:3;
  width:48px; height:48px;
  border-radius:50%;
  background:rgba(10,10,10,.55);
  border:1px solid rgba(245,242,238,.18);
  color:var(--white);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition:background .2s, border-color .2s, transform .2s;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.pil-close:hover,.pil-prev:hover,.pil-next:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
}
.pil-close:focus-visible,.pil-prev:focus-visible,.pil-next:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
}
.pil-close{ top:1.4rem; right:1.4rem; }
.pil-prev { left:1.4rem;  top:50%; transform:translateY(-50%); }
.pil-next { right:1.4rem; top:50%; transform:translateY(-50%); }
.pil-prev:hover,.pil-next:hover{ transform:translateY(-50%) scale(1.05); }

/* Loading spinner */
.pil-spinner{
  position:absolute; top:50%; left:50%;
  width:42px; height:42px; margin:-21px 0 0 -21px;
  border:2px solid rgba(245,242,238,.18);
  border-top-color:var(--gold);
  border-radius:50%;
  opacity:0; pointer-events:none;
  transition:opacity .2s;
}
#port-image-lightbox.pil-loading .pil-spinner{
  opacity:1;
  animation:pil-spin 1s linear infinite;
}
@keyframes pil-spin{ to { transform:rotate(360deg); } }

/* Lock the page scroll while lightbox is open */
body.pil-locked{ overflow:hidden; }

/* Show the zoom cursor on photo cells */
.port-zoomable{ cursor:zoom-in; }
.port-zoomable:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:-2px;
}

/* Mobile — bring nav buttons to corners, smaller targets */
@media (max-width:640px){
  .pil-close{ top:.8rem; right:.8rem; width:42px; height:42px; }
  .pil-prev { left:.5rem;  width:42px; height:42px; }
  .pil-next { right:.5rem; width:42px; height:42px; }
  .pil-counter{ top:-2rem; }
  #port-image-lightbox img{ max-height:78vh; }
}

/* ═══════════════════════════════════════════════════════
   GOOGLE REVIEWS — summary header + verified badge
   ═══════════════════════════════════════════════════════ */
.testi-google-summary{
  display:inline-flex; align-items:center; gap:.65rem;
  margin-top:.9rem;
  padding:.55rem 1rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(245,242,238,.1);
  border-radius:999px;
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:.12em;
  color:rgba(245,242,238,.7);
  flex-wrap:wrap;
}
.testi-google-stars{
  font-family:Georgia,serif; letter-spacing:1px;
  color:var(--gold); font-size:.85rem;
}
.testi-google-rating{
  font-weight:700; color:var(--white); font-size:.78rem;
}
.testi-google-count{ text-transform:uppercase; }
.testi-google-link{
  color:var(--gold); text-decoration:none;
  border-bottom:1px solid rgba(240,165,0,.4);
  padding-bottom:1px;
  text-transform:uppercase; font-size:.55rem; letter-spacing:.18em;
}
.testi-google-link:hover{ color:var(--gold-lt); border-color:var(--gold-lt); }
.testi-source-badge{
  display:inline-flex; align-items:center; gap:.4rem;
  margin-top:1rem;
  font-family:var(--mono);
  font-size:.5rem; letter-spacing:.18em;
  color:rgba(245,242,238,.4);
  text-transform:uppercase;
}
.testi-source-badge svg{ flex-shrink:0; }

/* ═══════════════════════════════════════════════════════
   ACCESSIBILITY — focus styles & reduced motion
   ═══════════════════════════════════════════════════════ */
a:focus-visible, button:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible,
[role="button"]:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{ opacity:1 !important; transform:none !important; }
}

/* ═══════════════════════════════════════════════════════
   COOKIE CONSENT BANNER (added 2.1.0)
   ═══════════════════════════════════════════════════════ */
#dfc-cookie-banner{
  position:fixed; left:1rem; right:1rem; bottom:1rem;
  max-width:560px; margin:0 auto;
  background:rgba(10,10,10,.96);
  border:1px solid var(--border);
  padding:1.1rem 1.2rem;
  z-index:9700;
  font-family:var(--sans);
  color:var(--white);
  display:none;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-radius:4px;
}
#dfc-cookie-banner.show{ display:block; animation:cb-rise .5s ease; }
@keyframes cb-rise{ from{ transform:translateY(20px); opacity:0; } to{ transform:none; opacity:1; } }
.dfc-cb-text{
  font-size:.78rem; line-height:1.6;
  color:rgba(245,242,238,.8); margin:0 0 .9rem;
}
.dfc-cb-text a{ color:var(--gold); text-decoration:underline; }
.dfc-cb-actions{ display:flex; gap:.6rem; flex-wrap:wrap; }
.dfc-cb-btn{
  font-family:var(--mono); font-size:.55rem; letter-spacing:.2em;
  text-transform:uppercase;
  padding:.6rem 1.2rem; cursor:pointer;
  border:1px solid rgba(245,242,238,.2);
  background:none; color:var(--white);
  transition:all .2s;
}
.dfc-cb-btn:hover{ border-color:var(--gold); color:var(--gold); }
.dfc-cb-btn.primary{
  background:var(--gold); border-color:var(--gold); color:var(--black); font-weight:700;
}
.dfc-cb-btn.primary:hover{ background:var(--gold-lt); border-color:var(--gold-lt); color:var(--black); }
@media (max-width:520px){
  #dfc-cookie-banner{ left:.5rem; right:.5rem; bottom:.5rem; padding:.9rem 1rem; }
  .dfc-cb-text{ font-size:.72rem; }
}

/* ═══════════════════════════════════════════════════════
   v2.2.0 — EQUIPMENT MARQUEE
   ═══════════════════════════════════════════════════════ */
.dfc-equipment-section{
  padding:5rem 5vw 4rem;
  background:linear-gradient(180deg,#040608 0%,#070b10 50%,#040608 100%);
  border-top:1px solid rgba(245,242,238,.05);
  border-bottom:1px solid rgba(245,242,238,.05);
  overflow:hidden;
  position:relative;
}
.dfc-equipment-headline{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.6rem,3vw,2.4rem);
  text-align:center;
  color:var(--white);
  margin:.5rem 0 2.5rem;
  line-height:1.2;
}
.dfc-equipment-headline em{
  color:var(--gold);
  font-style:italic;
  font-family:var(--serif);
}
.equip-marquee{
  width:100%;
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent 0,black 10%,black 90%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,black 10%,black 90%,transparent 100%);
}
.equip-track{
  display:flex; gap:1.5rem;
  animation:equip-scroll 38s linear infinite;
  width:max-content;
}
.equip-marquee:hover .equip-track{ animation-play-state:paused; }
@keyframes equip-scroll{ to { transform:translateX(-50%); } }

.equip-pill{
  flex:0 0 auto;
  display:inline-flex; align-items:center; gap:.7rem;
  padding:.85rem 1.5rem;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(245,242,238,.08);
  border-radius:999px;
  white-space:nowrap;
  transition:border-color .3s, background .3s;
}
.equip-pill:hover{
  border-color:rgba(201,168,76,.4);
  background:rgba(201,168,76,.05);
}
.equip-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 10px rgba(201,168,76,.6);
  flex-shrink:0;
}
.equip-name{
  font-family:var(--sans); font-weight:600;
  font-size:.85rem; color:var(--white);
}
.equip-cat{
  font-family:var(--mono); font-size:.55rem;
  letter-spacing:.15em; text-transform:uppercase;
  color:rgba(245,242,238,.5);
  border-left:1px solid rgba(245,242,238,.15);
  padding-left:.7rem;
}
.equip-footnote{
  text-align:center; margin:2rem auto 0; max-width:780px;
  font-family:var(--mono); font-size:.6rem;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(245,242,238,.4); line-height:1.8;
}
@media (prefers-reduced-motion:reduce){
  .equip-track{ animation:none; }
  .equip-marquee{ overflow-x:auto; }
}

/* ═══════════════════════════════════════════════════════
   SERVICE AREA MAP (Leaflet)
   ═══════════════════════════════════════════════════════ */
.dfc-map-intro{
  font-family:var(--sans); font-size:.95rem;
  color:rgba(245,242,238,.6); max-width:640px;
  margin-top:1rem;
}
.dfc-map-wrap{
  margin-top:2.5rem;
  position:relative;
  border:1px solid rgba(245,242,238,.08);
  border-radius:6px;
  overflow:hidden;
  background:#040608;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.6);
}
#dfc-service-map{
  width:100%;
  height:clamp(380px,55vh,560px);
  background:#040608;
  position:relative;
}
.dfc-map-loading{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:#040608;
  z-index:1;
}
.dfc-map-loading-text{
  font-family:var(--mono); font-size:.62rem;
  letter-spacing:.2em; text-transform:uppercase;
  color:rgba(245,242,238,.4);
}
.leaflet-container{
  background:#040608 !important;
  font-family:var(--sans);
}
.leaflet-popup-content-wrapper{
  background:#0a0a0a;
  color:var(--white);
  border:1px solid rgba(201,168,76,.3);
  border-radius:3px;
  box-shadow:0 10px 30px rgba(0,0,0,.7);
}
.leaflet-popup-content{
  font-size:.78rem;
  margin:.6rem .9rem;
  line-height:1.5;
}
.leaflet-popup-content strong{ color:var(--gold); font-family:var(--serif); font-size:.95rem; font-weight:400; }
.leaflet-popup-content a{ color:var(--gold); text-decoration:none; font-family:var(--mono); font-size:.55rem; letter-spacing:.15em; text-transform:uppercase; }
.leaflet-popup-tip{ background:#0a0a0a; }
.leaflet-control-attribution{
  background:rgba(10,10,10,.7) !important;
  color:rgba(245,242,238,.4) !important;
  font-size:.55rem !important;
}
.leaflet-control-attribution a{ color:rgba(201,168,76,.6) !important; }
/* Hide attribution when admin opts out (set by body class from feat_hide_map_attr).
   Note: OSM and CARTO require attribution by their license terms. Hiding it
   visually is technically a TOS violation. Use a paid tile provider (Mapbox,
   etc) if you need a no-attribution map for compliance reasons. */
body.dfc-hide-map-attr .leaflet-control-attribution{ display:none !important; }
.leaflet-control-zoom a{
  background:#0a0a0a !important;
  color:var(--white) !important;
  border:1px solid rgba(245,242,238,.15) !important;
}
.leaflet-control-zoom a:hover{
  background:var(--gold) !important;
  color:var(--black) !important;
}
.dfc-map-pin{
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));
}

/* ═══════════════════════════════════════════════════════
   LIGHTBOX v2 — thumbs strip, Flight Log, share, toast
   ═══════════════════════════════════════════════════════ */
.pil-img-frame{
  position:relative;
  display:flex; align-items:center; justify-content:center;
  max-width:96vw; max-height:78vh;
  overflow:hidden;
  touch-action:pinch-zoom;
}
#port-image-lightbox img{
  max-width:96vw; max-height:78vh;
  transition:transform .25s ease;
  transform-origin:center center;
}
#port-image-lightbox img[data-zoom]{ cursor:grab; }

/* Share + Flight Log toggle buttons (top corners) */
.pil-share, .pil-info-toggle{
  position:absolute; z-index:3;
  background:rgba(10,10,10,.55);
  border:1px solid rgba(245,242,238,.18);
  color:var(--white);
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s, color .2s;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.pil-share{
  top:1.4rem; right:5.4rem;
  width:42px; height:42px;
  border-radius:50%;
}
.pil-info-toggle{
  top:1.4rem; left:1.4rem;
  height:38px; padding:0 .9rem;
  border-radius:999px;
  gap:.45rem;
  font-family:var(--mono); font-size:.55rem;
  letter-spacing:.18em; text-transform:uppercase;
}
.pil-info-toggle span{ display:inline-block; }
.pil-share:hover, .pil-info-toggle:hover,
.pil-share:focus-visible, .pil-info-toggle:focus-visible{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
}
.pil-info-toggle[aria-expanded="true"]{
  background:rgba(201,168,76,.2);
  border-color:var(--gold);
  color:var(--gold);
}

/* Flight Log panel — slides up from bottom of stage */
.pil-flight-log{
  margin-top:1.2rem;
  width:min(720px, 92vw);
  background:linear-gradient(180deg, rgba(10,12,16,.92), rgba(6,8,12,.96));
  border:1px solid rgba(201,168,76,.25);
  border-radius:4px;
  padding:1rem 1.2rem;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transform:translateY(8px);
  transition:max-height .35s ease, opacity .25s ease, transform .35s ease, padding .35s ease;
  padding-top:0; padding-bottom:0;
}
.pil-flight-log.open{
  max-height:340px;
  opacity:1;
  transform:none;
  padding-top:1rem; padding-bottom:1rem;
}
.pil-flight-log.empty.open::after{
  content:"No flight log entered for this photo yet.";
  display:block;
  font-family:var(--mono); font-size:.6rem;
  letter-spacing:.15em; text-transform:uppercase;
  color:rgba(245,242,238,.35);
  text-align:center;
  padding:.5rem 0;
}
.pil-fl-header{
  display:flex; align-items:center; gap:.6rem;
  padding-bottom:.7rem;
  border-bottom:1px dashed rgba(201,168,76,.2);
  margin-bottom:.85rem;
}
.pil-fl-icon{
  display:inline-flex; align-items:center;
  color:var(--gold);
}
.pil-fl-title{
  font-family:var(--serif); font-weight:400; font-style:italic;
  font-size:.95rem; color:var(--white);
}
.pil-fl-divider{
  flex:1;
  height:1px;
  background:linear-gradient(90deg, rgba(201,168,76,.3), transparent);
}
.pil-fl-tag{
  font-family:var(--mono); font-size:.5rem;
  letter-spacing:.2em; text-transform:uppercase;
  color:rgba(201,168,76,.7);
}
.pil-fl-grid{
  display:grid;
  grid-template-columns:auto 1fr auto 1fr;
  gap:.55rem 1.2rem;
  margin:0;
  font-family:var(--mono);
}
.pil-fl-grid dt{
  display:inline-flex; align-items:center; gap:.4rem;
  font-size:.5rem; letter-spacing:.15em; text-transform:uppercase;
  color:rgba(201,168,76,.7);
  white-space:nowrap;
}
.pil-fl-grid dd{
  margin:0;
  font-size:.72rem;
  color:var(--white);
  font-family:var(--sans);
  font-weight:500;
}
@media (max-width:680px){
  .pil-fl-grid{ grid-template-columns:auto 1fr; }
  .pil-flight-log.open{ max-height:480px; }
}

/* Thumbnail strip */
/* ──────────────────────────────────────────────
   LIGHTBOX THUMBNAIL NAVIGATION STRIP (v2.6.2)
   Glassmorphic floating bar with gold accents.
   Active thumb has a brand-coloured glow + scale.
   ────────────────────────────────────────────── */
.pil-thumbs{
  position:absolute;
  bottom:1.4rem; left:50%;
  transform:translateX(-50%);
  z-index:3;
  display:flex; gap:.5rem;
  max-width:88vw;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-behavior:smooth;
  padding:.45rem .55rem;
  background:linear-gradient(180deg, rgba(20,16,10,.72) 0%, rgba(10,8,5,.78) 100%);
  border:1px solid rgba(201,168,76,.18);
  border-radius:6px;
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  box-shadow:
    0 8px 24px rgba(0,0,0,.45),
    0 1px 0 rgba(255,255,255,.04) inset,
    0 0 0 1px rgba(0,0,0,.4);
  scrollbar-width:thin;
  scrollbar-color:rgba(201,168,76,.3) transparent;
  opacity:1;
  transition:opacity .35s ease, transform .35s cubic-bezier(.22,.61,.36,1);
}
.pil-thumbs.pil-thumbs-hidden{
  display:none;
}
.pil-thumbs::-webkit-scrollbar{ height:4px; }
.pil-thumbs::-webkit-scrollbar-track{ background:transparent; }
.pil-thumbs::-webkit-scrollbar-thumb{ background:rgba(201,168,76,.35); border-radius:4px; }
.pil-thumbs::-webkit-scrollbar-thumb:hover{ background:rgba(201,168,76,.55); }

/* When Flight Log panel is open, slide the strip up so it sits above
   the panel rather than fading away. Photos stay navigable. */
#port-image-lightbox.fl-open .pil-thumbs{
  transform:translateX(-50%) translateY(-7rem);
}

/* Each thumb is a button — image inside or numeric fallback if image fails */
.pil-thumb{
  flex:0 0 auto;
  position:relative;
  width:72px; height:52px;
  padding:0;
  border:1.5px solid rgba(245,242,238,.08);
  background:linear-gradient(135deg, rgba(201,168,76,.08), rgba(20,15,10,.4));
  cursor:pointer;
  border-radius:3px;
  overflow:hidden;
  opacity:.55;
  transform:scale(1) translateY(0);
  transition:
    opacity .25s ease,
    border-color .25s ease,
    transform .3s cubic-bezier(.22,.61,.36,1),
    box-shadow .3s ease;
}
#port-image-lightbox .pil-thumb img,
.pil-thumb img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:cover !important;
  display:block;
  background:transparent !important;
  filter:saturate(.85);
  transition:filter .3s ease;
  box-shadow:none !important;
}
.pil-thumb-num{
  display:flex; align-items:center; justify-content:center;
  width:100%; height:100%;
  font-family:var(--mono); font-size:.7rem;
  letter-spacing:.12em;
  color:rgba(201,168,76,.65);
  background:linear-gradient(135deg, rgba(201,168,76,.12), rgba(40,30,20,.6));
}

/* Hover state — lift slightly, brighter image */
.pil-thumb:hover{
  opacity:.92;
  border-color:rgba(201,168,76,.4);
  transform:scale(1.05) translateY(-2px);
}
.pil-thumb:hover img{ filter:saturate(1); }

/* Active state — gold border, gold glow, fully opaque, slight scale-up,
   and a subtle "lift" with shadow. The visual focal point of the strip. */
.pil-thumb.active{
  opacity:1;
  border-color:var(--gold);
  transform:scale(1.08) translateY(-3px);
  box-shadow:
    0 4px 14px rgba(201,168,76,.35),
    0 0 0 1px var(--gold),
    0 0 16px rgba(201,168,76,.25);
}
.pil-thumb.active img{ filter:saturate(1.05) brightness(1.05); }

/* Small gold indicator dot above the active thumb — like a "you are here" pin */
.pil-thumb.active::before{
  content:"";
  position:absolute;
  top:-7px; left:50%;
  transform:translateX(-50%);
  width:4px; height:4px;
  background:var(--gold);
  border-radius:50%;
  box-shadow:0 0 6px rgba(201,168,76,.7);
  animation:pil-thumb-pulse 2s ease-in-out infinite;
}
@keyframes pil-thumb-pulse{
  0%, 100% { opacity:.7; transform:translateX(-50%) scale(1); }
  50%      { opacity:1;  transform:translateX(-50%) scale(1.3); }
}

/* Focused state for keyboard users */
.pil-thumb:focus-visible{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(201,168,76,.5);
}

/* Failed image — keep visible with the numeric placeholder, slight
   gold-tint background so it doesn't look like a black hole */
.pil-thumb.pil-thumb-failed{
  background:linear-gradient(135deg, rgba(201,168,76,.18), rgba(40,30,20,.7));
}

/* Toast for share-link copied */
.pil-toast{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%, -50%) translateY(20px);
  z-index:4;
  background:var(--gold);
  color:var(--black);
  padding:.7rem 1.4rem;
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  border-radius:3px;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s, transform .25s;
  box-shadow:0 10px 30px rgba(0,0,0,.4);
}
.pil-toast.show{
  opacity:1;
  transform:translate(-50%, -50%);
}

@media (max-width:640px){
  .pil-info-toggle{ top:.8rem; left:.8rem; height:34px; padding:0 .7rem; font-size:.5rem; }
  .pil-info-toggle span{ display:none; }
  .pil-share{ top:.8rem; right:5rem; width:38px; height:38px; }
  .pil-thumbs{ bottom:.7rem; max-width:94vw; padding:.35rem .45rem; gap:.35rem; }
  .pil-thumb{ width:54px; height:40px; }
  #port-image-lightbox.fl-open .pil-thumbs{ transform:translateX(-50%) translateY(-5.5rem); }
  #port-image-lightbox img{ max-height:64vh; }
  .pil-img-frame{ max-height:64vh; }
}

/* ═══════════════════════════════════════════════════════
   JUSTIFIED PORTFOLIO LAYOUT
   ═══════════════════════════════════════════════════════ */
.port-grid--justified{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:6px !important;
  grid-template-columns:none !important;
  grid-template-rows:none !important;
  grid-auto-rows:auto !important;
  grid-auto-flow:row !important;
}
.port-grid--justified .port-grid-cell{
  /* width and height are set inline by JS */
  grid-column:auto !important;
  grid-row:auto !important;
}
.port-grid--justified .port-grid-cell img,
.port-grid--justified .port-grid-cell video{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
/* Fallback while JS measures images — square-ish placeholder */
.port-grid--justified .port-grid-cell:not([style*="width"]){
  width:300px; height:225px;
}

/* New overlay element: location pill on photos with Flight Log location */
.port-grid-location{
  display:inline-flex; align-items:center; gap:.3rem;
  margin-top:.45rem;
  font-family:var(--mono); font-size:.5rem;
  letter-spacing:.15em; text-transform:uppercase;
  color:rgba(245,242,238,.7);
}

/* ═══════════════════════════════════════════════════════
   HERO PERF GUARD — disable parallax on touch
   ═══════════════════════════════════════════════════════ */
body.dfc-no-parallax .hero-bg,
body.dfc-no-parallax .process-img-wrap img{
  transform:none !important;
}

/* ═══════════════════════════════════════════════════════
   v2.4.0 — PRICING BROCHURE MODAL + CHECKLIST MODAL
   Dark + gold palette translation of the user's brochure.
   Brochure structure (3 tier columns + sqft tables + promo)
   is preserved; cream/blue is reskinned to black/gold/copper.
   ═══════════════════════════════════════════════════════ */

/* ── Generic modal engine ───────────────────────────── */
.dfc-modal{
  position:fixed; inset:0; z-index:9700;
  display:flex; align-items:flex-start; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity .35s ease;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.dfc-modal.open{ opacity:1; pointer-events:auto; }
.dfc-modal-overlay{
  position:fixed; inset:0;
  background:rgba(4,6,12,.94);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  cursor:pointer;
  z-index:0;
}
.dfc-modal-stage{
  position:relative;
  z-index:2;
  margin:auto;
  width:min(1240px, 96vw);
  padding:3rem 2.5rem;
  transform:translateY(20px);
  opacity:0;
  transition:transform .45s cubic-bezier(.25,.8,.3,1) .1s, opacity .35s ease .1s;
}
.dfc-modal.open .dfc-modal-stage{ transform:none; opacity:1; }
.dfc-modal-close{
  position:fixed; top:1.4rem; right:1.4rem;
  z-index:5;
  width:46px; height:46px; border-radius:50%;
  background:rgba(10,10,10,.7);
  border:1px solid rgba(245,242,238,.18);
  color:var(--white);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition:background .2s, border-color .2s, color .2s, transform .2s;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.dfc-modal-close:hover,
.dfc-modal-close:focus-visible{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
  transform:rotate(90deg);
}
body.dfc-modal-locked{ overflow:hidden; }

/* ── "Explore Pricing in Detail" button ─────────────── */
.pricing-explore-wrap{
  display:flex; flex-direction:column; align-items:center;
  gap:.6rem;
  margin:2.8rem auto 1.5rem;
  text-align:center;
}
.pricing-explore-btn{
  display:inline-flex; align-items:center; gap:.7rem;
  padding:1rem 2rem;
  background:linear-gradient(180deg, rgba(201,168,76,.08), rgba(201,168,76,.02));
  border:1px solid rgba(201,168,76,.4);
  color:var(--white);
  font-family:var(--mono);
  font-size:.65rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:600;
  cursor:pointer;
  border-radius:2px;
  position:relative;
  overflow:hidden;
  transition:all .35s cubic-bezier(.25,.8,.3,1);
}
.pricing-explore-btn::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(201,168,76,.18) 50%, transparent 100%);
  transform:translateX(-100%);
  transition:transform .7s ease;
}
.pricing-explore-btn:hover{
  border-color:var(--gold);
  background:linear-gradient(180deg, rgba(201,168,76,.18), rgba(201,168,76,.06));
  letter-spacing:.26em;
  box-shadow:0 10px 30px -10px rgba(201,168,76,.4);
}
.pricing-explore-btn:hover::before{ transform:translateX(100%); }
.pricing-explore-btn .pe-icon{
  display:inline-flex; align-items:center;
  color:var(--gold);
}
.pricing-explore-btn .pe-arrow{
  font-size:.8rem;
  transition:transform .25s ease;
  color:var(--gold);
}
.pricing-explore-btn:hover .pe-arrow{ transform:translateX(4px); }
.pricing-explore-hint{
  font-family:var(--mono); font-size:.55rem;
  letter-spacing:.16em; text-transform:uppercase;
  color:rgba(245,242,238,.4);
  max-width:520px;
}

/* ── Brochure header ────────────────────────────────── */
.dfc-brochure-header{
  text-align:center;
  margin-bottom:3rem;
}
.dfc-brochure-eyebrow,
.dfc-cl-eyebrow{
  display:flex; align-items:center; justify-content:center;
  gap:.85rem;
  margin-bottom:1.4rem;
}
.bh-line{
  flex:0 0 auto;
  width:36px; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.bh-tag{
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--gold);
}
.dfc-brochure-title,
.dfc-cl-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem, 3.5vw, 2.8rem);
  color:var(--white);
  line-height:1.15;
  margin:0 0 1rem;
  letter-spacing:-.01em;
}
.dfc-brochure-title em,
.dfc-cl-title em{
  font-style:italic;
  color:var(--gold);
  font-family:var(--serif);
}
.dfc-brochure-sub,
.dfc-cl-sub{
  font-family:var(--sans);
  font-size:.95rem;
  color:rgba(245,242,238,.6);
  max-width:620px;
  margin:0 auto 1.6rem;
  line-height:1.6;
}
.dfc-brochure-actions,
.dfc-cl-actions{
  display:flex; gap:.7rem; justify-content:center; flex-wrap:wrap;
}
.db-action-btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.65rem 1.2rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(245,242,238,.16);
  color:var(--white);
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
  cursor:pointer;
  text-decoration:none;
  transition:all .25s;
  border-radius:2px;
}
.db-action-btn:hover{
  background:rgba(201,168,76,.12);
  border-color:rgba(201,168,76,.5);
  color:var(--gold);
}
.db-action-primary{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
  font-weight:700;
}
.db-action-primary:hover{
  background:var(--gold-lt, #e0bf6c);
  border-color:var(--gold-lt, #e0bf6c);
  color:var(--black);
}

/* ── Brochure tier grid (3-column on desktop, stack on mobile) ── */
.dfc-brochure-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.4rem;
  margin-bottom:2.5rem;
}
.dfc-tier{
  display:flex; flex-direction:column;
  background:linear-gradient(180deg, rgba(255,255,255,.025) 0%, rgba(255,255,255,.01) 100%);
  border:1px solid rgba(245,242,238,.08);
  border-top:3px solid var(--gold);
  padding:2rem 1.6rem;
  border-radius:2px;
  position:relative;
  transition:border-color .3s, transform .3s;
}
.dfc-tier:hover{
  transform:translateY(-3px);
  border-color:rgba(201,168,76,.25);
  border-top-color:var(--gold);
}
.dfc-tier--gold{ border-top-color:#c9a84c; }
.dfc-tier--platinum{
  border-top-color:#a3b4c4;
  background:linear-gradient(180deg, rgba(163,180,196,.04) 0%, rgba(255,255,255,.01) 100%);
}
.dfc-tier--copper{
  border-top-color:#c08050;
  background:linear-gradient(180deg, rgba(192,128,80,.04) 0%, rgba(255,255,255,.01) 100%);
}
.dfc-tier-head{
  text-align:center;
  padding-bottom:1.4rem;
  margin-bottom:1.5rem;
  border-bottom:1px dashed rgba(245,242,238,.1);
}
.dfc-tier-badge{
  display:inline-block;
  font-family:var(--mono);
  font-size:.5rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:rgba(201,168,76,.7);
  margin-bottom:.6rem;
}
.dfc-tier--platinum .dfc-tier-badge{ color:rgba(163,180,196,.85); }
.dfc-tier--copper   .dfc-tier-badge{ color:rgba(192,128,80,.85); }
.dfc-tier-name{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.5rem;
  color:var(--white);
  margin:0 0 .35rem;
  letter-spacing:.01em;
}
.dfc-tier-tagline{
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:600;
  color:var(--gold);
  margin:0;
  letter-spacing:.04em;
}
.dfc-tier--platinum .dfc-tier-tagline{ color:#bdcad6; }
.dfc-tier--copper   .dfc-tier-tagline{ color:#d99970; }

.dfc-tier-features{
  list-style:none;
  margin:0 0 1.6rem;
  padding:0;
  flex:1;
}
.dfc-tier-features li{
  display:flex; align-items:flex-start; gap:.55rem;
  padding:.4rem 0;
  font-family:var(--sans);
  font-size:.82rem;
  line-height:1.5;
  color:rgba(245,242,238,.85);
  border-bottom:1px solid rgba(245,242,238,.04);
}
.dfc-tier-features li:last-child{ border-bottom:none; }
.dfc-tier-features .dfc-feat-mark{
  flex-shrink:0;
  color:var(--gold);
  font-weight:700;
  font-size:.85rem;
  line-height:1.5;
  width:11px; text-align:center;
}
.dfc-tier--platinum .dfc-feat-mark{ color:#bdcad6; }
.dfc-tier--copper .dfc-feat-mark{ color:#d99970; }
.dfc-feat-inherit{
  font-style:italic;
  color:rgba(245,242,238,.55) !important;
  font-size:.78rem !important;
  background:rgba(201,168,76,.05);
  padding:.5rem .55rem !important;
  margin:0 -.55rem .35rem;
  border-radius:2px;
}

.dfc-tier-pricing{
  border-top:1px solid rgba(245,242,238,.1);
  padding-top:1.2rem;
}
.dfc-tier-pricing-head{
  display:grid; grid-template-columns:auto 1fr;
  gap:1rem;
  font-family:var(--mono);
  font-size:.5rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(245,242,238,.4);
  padding-bottom:.55rem;
  margin-bottom:.4rem;
  border-bottom:1px dashed rgba(245,242,238,.08);
}
.dfc-tier-pricing-row{
  display:grid; grid-template-columns:auto 1fr;
  gap:1rem;
  align-items:baseline;
  padding:.5rem 0;
  border-bottom:1px dashed rgba(245,242,238,.05);
}
.dfc-tier-pricing-row:last-child{ border-bottom:none; }
.dfc-tier-price{
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:400;
  color:var(--white);
  letter-spacing:-.01em;
}
.dfc-tier-sqft{
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(245,242,238,.6);
}

/* ── Promo callout ──────────────────────────────────── */
.dfc-brochure-promo{
  display:flex; align-items:center; gap:1.8rem;
  background:linear-gradient(135deg, rgba(201,168,76,.12) 0%, rgba(201,168,76,.04) 100%);
  border:1px solid rgba(201,168,76,.35);
  border-left:4px solid var(--gold);
  padding:1.6rem 2rem;
  margin:2rem 0 2.5rem;
  border-radius:2px;
  flex-wrap:wrap;
}
.dfc-promo-pct{
  display:flex; align-items:flex-start;
  font-family:var(--serif);
  color:var(--gold);
  line-height:1;
  flex-shrink:0;
}
.dfc-promo-num{
  font-size:clamp(3.2rem, 7vw, 4.8rem);
  font-weight:300;
}
.dfc-promo-sym{
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  font-weight:300;
  margin-top:.3rem;
}
.dfc-promo-body{ flex:1; min-width:250px; }
.dfc-promo-label{
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  display:block;
  margin-bottom:.3rem;
}
.dfc-promo-text{
  font-family:var(--serif);
  font-weight:300;
  font-size:1.4rem;
  color:var(--white);
  margin:0 0 .9rem;
  line-height:1.2;
}
.dfc-promo-code{
  display:inline-flex; align-items:center; gap:.5rem;
  flex-wrap:wrap;
}
.dfc-promo-code-label{
  font-family:var(--mono); font-size:.5rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:rgba(245,242,238,.5);
}
.dfc-promo-code code{
  font-family:'Courier New', monospace;
  font-size:.85rem;
  letter-spacing:.08em;
  color:var(--white);
  background:rgba(0,0,0,.5);
  padding:.45rem .9rem;
  border:1px dashed rgba(201,168,76,.5);
  border-radius:2px;
  font-weight:700;
}
.dfc-promo-copy{
  font-family:var(--mono); font-size:.5rem;
  letter-spacing:.18em; text-transform:uppercase;
  background:transparent;
  border:1px solid rgba(201,168,76,.4);
  color:var(--gold);
  padding:.45rem .9rem;
  cursor:pointer;
  border-radius:2px;
  transition:all .2s;
}
.dfc-promo-copy:hover,
.dfc-promo-copy.copied{
  background:var(--gold);
  color:var(--black);
  border-color:var(--gold);
}

/* ── Brochure footer ────────────────────────────────── */
.dfc-brochure-footer{
  text-align:center;
  padding-top:1.5rem;
  border-top:1px solid rgba(245,242,238,.08);
}
.dfc-brochure-footnote{
  font-family:var(--sans);
  font-size:.85rem;
  color:rgba(245,242,238,.55);
  margin:0 0 1rem;
}
.dfc-brochure-footer-cta{
  display:inline-block;
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  text-decoration:none;
  border-bottom:1px solid var(--gold);
  padding-bottom:2px;
  transition:letter-spacing .25s;
}
.dfc-brochure-footer-cta:hover{ letter-spacing:.28em; }

/* ── Brochure responsive ────────────────────────────── */
@media (max-width:920px){
  .dfc-brochure-grid{ grid-template-columns:1fr; }
  .dfc-tier{ padding:1.6rem 1.3rem; }
  .dfc-modal-stage{ padding:2rem 1.2rem; }
}
@media (max-width:560px){
  .dfc-brochure-promo{ padding:1.2rem 1.3rem; gap:1rem; }
  .dfc-promo-pct{ width:100%; justify-content:center; }
  .dfc-promo-body{ text-align:center; min-width:0; }
  .dfc-promo-code{ justify-content:center; }
}

/* ═══════════════════════════════════════════════════════
   PROCESS — Photo-Ready Checklist CTA
   ═══════════════════════════════════════════════════════ */
.process-checklist-cta{
  display:flex; align-items:center; gap:1rem;
  margin:3rem 5vw 0;
  padding:1.4rem 1.6rem;
  background:linear-gradient(180deg, rgba(201,168,76,.08) 0%, rgba(201,168,76,.02) 100%);
  border:1px solid rgba(201,168,76,.25);
  border-left:3px solid var(--gold);
  border-radius:2px;
  flex-wrap:wrap;
  transition:border-color .25s, transform .25s;
  max-width:calc(100% - 10vw);
}
.process-checklist-cta:hover{
  border-color:rgba(201,168,76,.5);
  transform:translateX(2px);
}
.pcc-icon{
  flex-shrink:0;
  width:42px; height:42px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(201,168,76,.15);
  border:1px solid rgba(201,168,76,.3);
  color:var(--gold);
  border-radius:50%;
}
.pcc-body{ flex:1; min-width:200px; }
.pcc-label{
  display:block;
  font-family:var(--mono);
  font-size:.5rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:.25rem;
}
.pcc-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.05rem;
  color:var(--white);
  margin:0;
  line-height:1.3;
}
.pcc-btn{
  flex-shrink:0;
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.7rem 1.2rem;
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  cursor:pointer;
  text-decoration:none;
  border-radius:2px;
  transition:all .25s;
}
.pcc-btn:hover{
  background:var(--gold);
  color:var(--black);
}
.pcc-btn span{ transition:transform .25s; }
.pcc-btn:hover span{ transform:translateX(3px); }

/* ═══════════════════════════════════════════════════════
   PHOTO-READY CHECKLIST MODAL
   ═══════════════════════════════════════════════════════ */
.dfc-cl-header{
  text-align:center;
  margin-bottom:2.5rem;
  position:relative;
}
.dfc-cl-icon-wrap{
  display:inline-flex; align-items:center; justify-content:center;
  width:64px; height:64px;
  margin:0 auto 1.2rem;
  background:rgba(201,168,76,.12);
  border:1px solid rgba(201,168,76,.3);
  border-radius:50%;
  color:var(--gold);
}
.dfc-cl-progress{
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  max-width:380px; margin:0 auto 1.5rem;
}
.dfc-cl-progress-track{
  width:100%; height:5px;
  background:rgba(245,242,238,.08);
  border-radius:99px;
  overflow:hidden;
}
.dfc-cl-progress-fill{
  height:100%;
  background:linear-gradient(90deg, var(--gold), #e8c97a);
  border-radius:99px;
  transition:width .4s cubic-bezier(.25,.8,.3,1);
  box-shadow:0 0 12px rgba(201,168,76,.5);
}
.dfc-cl-progress-label{
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(245,242,238,.5);
}
#dfc-cl-progress-num{ color:var(--gold); font-weight:700; }
.cl-complete .dfc-cl-progress-fill{
  animation:cl-pulse 1.5s ease-in-out infinite;
}
@keyframes cl-pulse{
  0%,100%{ box-shadow:0 0 12px rgba(201,168,76,.5); }
  50%   { box-shadow:0 0 24px rgba(201,168,76,.9); }
}

/* Checklist categories grid */
.dfc-cl-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:1.3rem 1.8rem;
  margin-bottom:2rem;
}
.dfc-cl-cat{
  background:rgba(255,255,255,.02);
  border:1px solid rgba(245,242,238,.06);
  border-radius:3px;
  padding:1.4rem 1.4rem 1.2rem;
  transition:border-color .25s;
}
.dfc-cl-cat:hover{ border-color:rgba(201,168,76,.18); }
.dfc-cl-cat-title{
  display:flex; align-items:center; gap:.55rem;
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:1.25rem;
  color:var(--gold);
  margin:0 0 1rem;
  padding-bottom:.7rem;
  border-bottom:1px dashed rgba(201,168,76,.2);
}
.dfc-cl-cat-icon{
  font-size:1.1rem;
  filter:saturate(.85);
}
.dfc-cl-items{
  list-style:none; margin:0; padding:0;
}
.dfc-cl-items li{ margin:0; }
.dfc-cl-item{
  display:flex; align-items:flex-start; gap:.7rem;
  padding:.55rem 0;
  cursor:pointer;
  transition:opacity .2s;
}
.dfc-cl-check{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.dfc-cl-tick{
  flex-shrink:0;
  width:18px; height:18px;
  border:1.5px solid rgba(201,168,76,.4);
  border-radius:3px;
  display:flex; align-items:center; justify-content:center;
  margin-top:2px;
  transition:all .2s;
  color:transparent;
  background:transparent;
}
.dfc-cl-item:hover .dfc-cl-tick{ border-color:var(--gold); }
.dfc-cl-check:checked + .dfc-cl-tick{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
}
.dfc-cl-text{
  font-family:var(--sans);
  font-size:.86rem;
  line-height:1.5;
  color:rgba(245,242,238,.82);
  flex:1;
  transition:opacity .2s;
}
.dfc-cl-text strong{
  color:var(--white);
  font-weight:600;
}
.dfc-cl-check:checked ~ .dfc-cl-text,
.dfc-cl-item:has(.dfc-cl-check:checked) .dfc-cl-text{
  opacity:.4;
  text-decoration:line-through;
  text-decoration-color:rgba(201,168,76,.3);
}
.dfc-cl-check:focus-visible + .dfc-cl-tick{
  outline:2px solid var(--gold);
  outline-offset:2px;
}

.dfc-cl-footer{
  text-align:center;
  padding-top:1.5rem;
  border-top:1px solid rgba(245,242,238,.08);
}
.dfc-cl-footnote{
  font-family:var(--sans);
  font-size:.85rem;
  color:rgba(245,242,238,.55);
  margin:0;
}
.dfc-cl-footnote a{
  color:var(--gold);
  text-decoration:none;
  border-bottom:1px solid rgba(201,168,76,.4);
  padding-bottom:1px;
}
.dfc-cl-footnote a:hover{ border-bottom-color:var(--gold); }


/* ═══════════════════════════════════════════════════════
   v2.4.0 — BRANDED PAGE TEMPLATES (Privacy, Terms, etc.)
   ═══════════════════════════════════════════════════════ */
.dfc-page{
  padding:6rem 5vw 4rem;
  min-height:60vh;
  max-width:880px;
  margin:0 auto;
  color:rgba(245,242,238,.85);
}
.dfc-page-article{
  background:rgba(255,255,255,.015);
  border:1px solid rgba(245,242,238,.05);
  padding:3rem 2.6rem;
  border-radius:3px;
}
.dfc-page-header{
  text-align:center;
  margin-bottom:2.5rem;
  padding-bottom:2rem;
  border-bottom:1px dashed rgba(245,242,238,.1);
}
.dfc-page-eyebrow{
  display:flex; align-items:center; justify-content:center;
  gap:.85rem;
  margin-bottom:1.2rem;
}
.dfc-page-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2rem, 4vw, 3rem);
  color:var(--white);
  line-height:1.15;
  margin:0 0 .8rem;
  letter-spacing:-.01em;
}
.dfc-page-meta{
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(245,242,238,.4);
  margin:0;
}
.dfc-page-content{
  font-family:var(--sans);
  font-size:.92rem;
  line-height:1.75;
  color:rgba(245,242,238,.78);
}
.dfc-page-content h2{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:1.4rem;
  color:var(--gold);
  margin:2.2rem 0 .8rem;
  letter-spacing:.01em;
}
.dfc-page-content h3{
  font-family:var(--sans);
  font-weight:600;
  font-size:1rem;
  color:var(--white);
  margin:1.6rem 0 .5rem;
}
.dfc-page-content p{
  margin:0 0 1rem;
}
.dfc-page-content ul,
.dfc-page-content ol{
  margin:0 0 1.2rem 1.4rem;
  padding:0;
}
.dfc-page-content li{ margin-bottom:.4rem; }
.dfc-page-content strong{
  color:var(--white);
  font-weight:600;
}
.dfc-page-content a{
  color:var(--gold);
  text-decoration:none;
  border-bottom:1px solid rgba(201,168,76,.4);
  padding-bottom:1px;
  transition:border-bottom-color .2s;
}
.dfc-page-content a:hover{ border-bottom-color:var(--gold); }
.dfc-page-content em{
  color:rgba(245,242,238,.55);
  font-style:italic;
}
.dfc-page-empty{
  text-align:center;
  padding:4rem 2rem;
  color:rgba(245,242,238,.4);
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

/* Checklist as standalone page */
.dfc-checklist-page{
  padding:3rem 0 4rem;
}
.dfc-checklist-page .dfc-cl-grid{
  margin-top:2rem;
}

/* ═══════════════════════════════════════════════════════
   404 ERROR PAGE — drone "out of range" treatment
   ═══════════════════════════════════════════════════════ */
.dfc-error-page{
  padding:5rem 5vw 6rem;
  min-height:80vh;
  display:flex; align-items:center; justify-content:center;
}
.dfc-err-stage{
  max-width:720px;
  text-align:center;
}
.dfc-err-glyph{
  margin:0 auto 1.5rem;
  color:var(--gold);
  opacity:.85;
  animation:dfc-err-float 4s ease-in-out infinite;
}
@keyframes dfc-err-float{
  0%,100%{ transform:translateY(0); }
  50%   { transform:translateY(-8px); }
}
.dfc-err-code{
  display:inline-block;
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--gold);
  background:rgba(201,168,76,.08);
  border:1px solid rgba(201,168,76,.3);
  padding:.35rem 1rem;
  border-radius:99px;
  margin-bottom:1.4rem;
}
.dfc-err-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.4rem, 6vw, 4rem);
  color:var(--white);
  line-height:1.05;
  margin:0 0 1rem;
  letter-spacing:-.02em;
}
.dfc-err-title em{
  font-style:italic;
  color:var(--gold);
  font-family:var(--serif);
}
.dfc-err-sub{
  font-family:var(--sans);
  font-size:1.05rem;
  color:rgba(245,242,238,.6);
  max-width:520px;
  margin:0 auto 2rem;
  line-height:1.55;
}
.dfc-err-search{
  margin-bottom:2rem;
}
.dfc-err-links{
  display:flex; gap:.6rem; justify-content:center; flex-wrap:wrap;
  margin-top:2rem;
}
.dfc-err-link{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.7rem 1.3rem;
  border:1px solid rgba(245,242,238,.18);
  color:var(--white);
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  text-decoration:none;
  border-radius:2px;
  transition:all .25s;
}
.dfc-err-link:hover{
  border-color:var(--gold);
  color:var(--gold);
  letter-spacing:.24em;
}
.dfc-err-link.primary{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
  font-weight:700;
}
.dfc-err-link.primary:hover{
  background:transparent;
  color:var(--gold);
}

/* ═══════════════════════════════════════════════════════
   SEARCH RESULTS PAGE
   ═══════════════════════════════════════════════════════ */
.dfc-search-page{
  padding:5rem 5vw 4rem;
  max-width:880px;
  margin:0 auto;
  min-height:60vh;
}
.dfc-search-header{
  text-align:center;
  margin-bottom:3rem;
  padding-bottom:2rem;
  border-bottom:1px dashed rgba(245,242,238,.1);
}
.dfc-search-eyebrow{
  display:inline-block;
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1rem;
}
.dfc-search-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem, 4vw, 2.6rem);
  color:var(--white);
  line-height:1.2;
  margin:0 0 1.5rem;
}
.dfc-search-title em{
  font-style:italic;
  color:var(--gold);
  font-family:var(--serif);
}
.dfc-search-title span{ color:var(--gold); }
.dfc-search-form-wrap{ max-width:480px; margin:0 auto; }
.dfc-search-results{
  display:flex; flex-direction:column; gap:.5rem;
}
.dfc-search-result{
  padding:1.5rem 0;
  border-bottom:1px solid rgba(245,242,238,.06);
  transition:padding .2s;
}
.dfc-search-result:hover{ padding-left:.4rem; }
.dsr-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.4rem;
  margin:0 0 .35rem;
}
.dsr-title a{
  color:var(--white);
  text-decoration:none;
  transition:color .2s;
}
.dsr-title a:hover{ color:var(--gold); }
.dsr-meta{
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(245,242,238,.4);
  margin-bottom:.7rem;
  display:flex; gap:.5rem; align-items:center;
}
.dsr-excerpt{
  font-family:var(--sans);
  font-size:.9rem;
  line-height:1.6;
  color:rgba(245,242,238,.7);
  margin-bottom:.6rem;
}
.dsr-readmore{
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold);
  text-decoration:none;
}
.dsr-readmore span{ display:inline-block; transition:transform .2s; }
.dsr-readmore:hover span{ transform:translateX(3px); }
.dfc-search-empty{
  text-align:center;
  padding:2rem 0;
}
.dse-text{
  font-family:var(--sans);
  font-size:1rem;
  color:rgba(245,242,238,.6);
  margin-bottom:1.5rem;
}
.dfc-search-pagination{
  margin-top:2.5rem;
  text-align:center;
}
.dfc-search-pagination .nav-links{
  display:inline-flex; gap:.4rem; flex-wrap:wrap; justify-content:center;
}
.dfc-search-pagination a,
.dfc-search-pagination .current,
.dfc-search-pagination .dots{
  display:inline-block;
  padding:.55rem .85rem;
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:rgba(245,242,238,.7);
  text-decoration:none;
  border:1px solid rgba(245,242,238,.12);
  border-radius:2px;
  transition:all .2s;
}
.dfc-search-pagination a:hover{
  border-color:var(--gold);
  color:var(--gold);
}
.dfc-search-pagination .current{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--black);
  font-weight:700;
}

/* ═══════════════════════════════════════════════════════
   SEARCH FORM (used in 404 + search header)
   ═══════════════════════════════════════════════════════ */
.dfc-searchform{ width:100%; }
.dfc-searchform-inner{
  display:flex; align-items:center; gap:0;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(245,242,238,.15);
  border-radius:2px;
  padding:.4rem .4rem .4rem 1rem;
  transition:border-color .2s;
}
.dfc-searchform-inner:focus-within{
  border-color:var(--gold);
}
.dfc-searchform-icon{
  flex-shrink:0;
  color:rgba(245,242,238,.4);
  margin-right:.6rem;
}
.dfc-searchform-field{
  flex:1;
  background:transparent;
  border:none;
  outline:none;
  font-family:var(--sans);
  font-size:.92rem;
  color:var(--white);
  padding:.65rem 0;
}
.dfc-searchform-field::placeholder{
  color:rgba(245,242,238,.35);
}
.dfc-searchform-submit{
  flex-shrink:0;
  display:inline-flex; align-items:center; gap:.4rem;
  background:var(--gold);
  border:none;
  color:var(--black);
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  padding:.65rem 1.2rem;
  cursor:pointer;
  border-radius:2px;
  transition:background .2s;
}
.dfc-searchform-submit:hover{
  background:#e0bf6c;
}

/* ═══════════════════════════════════════════════════════
   FOOTER LEGAL LINKS (Privacy / Terms)
   ═══════════════════════════════════════════════════════ */
.footer-legal{
  display:flex; gap:1.4rem; flex-wrap:wrap;
  margin-top:.5rem;
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.footer-legal a{
  color:rgba(245,242,238,.45);
  text-decoration:none;
  transition:color .2s;
}
.footer-legal a:hover{ color:var(--gold); }
@media (max-width:680px){
  .footer-legal{ width:100%; justify-content:center; }
}

/* ═══════════════════════════════════════════════════════════
   CINEMATIC MOTION (v2.8.0) — Mont-fort-style scroll choreo
   All styles here are scoped under classes added by JS,
   so they're inert when the feature flags are off.
   ═══════════════════════════════════════════════════════════ */

/* ── HEADING WORD-BY-WORD REVEALS ────────────────────────── */
.dfc-reveal-heading .dfc-rh-word{
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
  /* Explicit line-height so descenders (g/p/y/j) fit without clipping.
     Padding-bottom adds room for italic overhang. */
  line-height: 1.2;
  padding-bottom: 0.12em;
}
.dfc-reveal-heading .dfc-rh-w-inner{
  display: inline-block;
  /* Translate by 110% of the line-box height — large enough to start
     fully below the wrapper but not so far it lags during the cascade. */
  transform: translateY(105%);
  opacity: 0;
  line-height: 1.2;
  /* Stagger via CSS variable set by JS — each word fires 60ms after prev */
  transition:
    transform .9s cubic-bezier(.22,.61,.36,1) calc(var(--dfc-rh-i, 0) * 0.06s),
    opacity .9s cubic-bezier(.22,.61,.36,1) calc(var(--dfc-rh-i, 0) * 0.06s);
  will-change: transform, opacity;
}
.dfc-reveal-heading.dfc-rh-in .dfc-rh-w-inner{
  transform: translateY(0);
  opacity: 1;
}

/* ── SECTION NUMBER MARKERS ───────────────────────────────── */
.dfc-section-number{
  position: absolute;
  top: 4rem;
  left: 2vw;
  z-index: 4;
  pointer-events: none;
  font-family: var(--serif, Cormorant Garamond), serif;
  font-weight: 300;
  /* line-height: 1.15 leaves room for descenders / glyph baseline.
     padding-bottom is belt-and-suspenders against any -webkit clip-text
     anti-aliasing rounding that could nibble the bottom edge. */
  line-height: 1.15;
  padding-bottom: 0.08em;
  color: rgba(201, 168, 76, 0.18);
  font-size: clamp(5rem, 14vw, 12rem);
  opacity: 0;
  transform: translateY(2rem);
  transition: opacity 1.2s cubic-bezier(.22,.61,.36,1),
              transform 1.2s cubic-bezier(.22,.61,.36,1),
              color .6s ease;
  user-select: none;
}
.dfc-section-number.dfc-sn-active{
  opacity: 1;
  transform: translateY(0);
}
.dfc-section-number .dfc-sn-digit{
  display: block;
  letter-spacing: -.02em;
  /* Subtle gold gradient */
  background: linear-gradient(180deg, rgba(201, 168, 76, 0.32) 0%, rgba(201, 168, 76, 0.08) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* On smaller screens, tuck the number into a corner so it doesn't
   crowd content. On mobile, hide entirely — the visual debt isn't
   worth the screen real-estate. */
@media (max-width: 1100px){
  .dfc-section-number{
    top: 1rem;
    left: auto;
    right: 1.5vw;
    font-size: clamp(4rem, 11vw, 7rem);
  }
}
@media (max-width: 720px){
  .dfc-section-number{ display: none; }
}

/* ── MAGNETIC CTA BUTTONS ─────────────────────────────────── */
/* JS sets inline transform: translate(x, y) on hover.
   We add a fast-but-not-instant transition for return-to-center. */
.btn-primary[data-dfc-magnetic],
.dfc-cta-primary[data-dfc-magnetic],
.pcc-btn[data-dfc-magnetic]{
  transition:
    background .3s,
    color .3s,
    transform .3s cubic-bezier(.34, 1.56, .64, 1);
  will-change: transform;
}

/* ── SMOOTH-SCROLL — body tweaks while engine is running ─── */
/* Make scroll-anchored backgrounds work consistently with the
   smooth-scroll engine (which uses window.scrollTo, not transforms,
   so most things just work — but disable scroll-behavior:smooth on
   html so it doesn't fight our lerp). */
html{ scroll-behavior: auto; }

/* Reduced motion safety net — if the user prefers reduced motion,
   force everything cinematic to be instant/static, regardless of flags. */
@media (prefers-reduced-motion: reduce){
  .dfc-reveal-heading .dfc-rh-w-inner{
    transform: none !important;
    opacity: 1 !important;
    transition: none !important;
  }
  .dfc-section-number{
    transition: none !important;
  }
  .btn-primary[data-dfc-magnetic],
  .dfc-cta-primary[data-dfc-magnetic],
  .pcc-btn[data-dfc-magnetic]{
    transition: background .3s, color .3s !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   STAGE 2 CINEMATIC MOTION (v2.8.1)
   ═══════════════════════════════════════════════════════════ */

/* ── 6. IMAGE MASK REVEALS ────────────────────────────────── */
/* The cell stays visible; we add a gold "curtain" overlay that
   wipes off horizontally. The image starts slightly scaled down
   and zooms back to natural over the same animation window. */
.dfc-mask-reveal{
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.dfc-mask-reveal::after{
  content: '';
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background: linear-gradient(110deg,
    rgba(201, 168, 76, 0.95) 0%,
    rgba(212, 184, 96, 1) 45%,
    rgba(180, 145, 56, 0.95) 100%);
  transform-origin: right center;
  transform: scaleX(1);
  transition: transform 1.05s cubic-bezier(.76,0,.24,1);
}
.dfc-mask-reveal img,
.dfc-mask-reveal .port-grid-overlay,
.dfc-mask-reveal video{
  transform: scale(1.06);
  transition: transform 1.4s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}
.dfc-mask-reveal.dfc-mr-in::after{
  transform: scaleX(0);
}
.dfc-mask-reveal.dfc-mr-in img,
.dfc-mask-reveal.dfc-mr-in .port-grid-overlay,
.dfc-mask-reveal.dfc-mr-in video{
  transform: scale(1);
}

/* ── 7. SECTION TRANSITION STAGGER ────────────────────────── */
.dfc-stagger-item{
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity .9s cubic-bezier(.22,.61,.36,1) calc(var(--dfc-stagger-i, 0) * 0.08s),
    transform .9s cubic-bezier(.22,.61,.36,1) calc(var(--dfc-stagger-i, 0) * 0.08s);
  will-change: transform, opacity;
}
.dfc-stagger-in .dfc-stagger-item,
.dfc-stagger-item.dfc-stagger-in{
  opacity: 1;
  transform: translateY(0);
}
/* When a parent section has dfc-stagger-in, all child stagger items
   should fire — covers both selector cases above */
section.dfc-stagger-in .dfc-stagger-item{
  opacity: 1;
  transform: translateY(0);
}

/* ── 8. ANIMATED MAP — PIN DROP + GOLD PULSE ──────────────── */
/* Pre-drop state: pin floats above its final position, invisible.
   Drop-in state: settles to natural position with bounce easing. */
.leaflet-marker-icon.dfc-pin-pre-drop{
  opacity: 0;
  transform: translateY(-40px) scale(0.6);
  transition: opacity .6s ease, transform .8s cubic-bezier(.34, 1.6, .64, 1);
}
.leaflet-marker-icon.dfc-pin-drop-in{
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* The pulse ring — appended as a child <span> after drop-in completes */
.dfc-pin-pulse{
  position: absolute;
  left: 50%;
  top: 100%;       /* anchor at the pin's tip */
  width: 28px;
  height: 28px;
  margin: -14px 0 0 -14px;
  border: 2px solid var(--gold, #c9a84c);
  border-radius: 50%;
  pointer-events: none;
  opacity: 0.85;
  animation: dfcPinPulse 2.4s cubic-bezier(.16, .84, .44, 1) infinite;
}
@keyframes dfcPinPulse{
  0%   { transform: scale(0.4); opacity: 0.85; }
  70%  { opacity: 0.15; }
  100% { transform: scale(2.6); opacity: 0; }
}

/* Reduced-motion safety net for Stage 2 */
@media (prefers-reduced-motion: reduce){
  .dfc-mask-reveal::after{ transform: scaleX(0) !important; transition: none !important; }
  .dfc-mask-reveal img,
  .dfc-mask-reveal .port-grid-overlay,
  .dfc-mask-reveal video{ transform: none !important; transition: none !important; }
  .dfc-stagger-item{ opacity: 1 !important; transform: none !important; transition: none !important; }
  .leaflet-marker-icon.dfc-pin-pre-drop{ opacity: 1 !important; transform: none !important; transition: none !important; }
  .dfc-pin-pulse{ animation: none !important; opacity: 0 !important; }
}

/* ═══════════════════════════════════════════════════════════
   v2.9.0 — BUSINESS FEATURES STYLING
   Instagram strip, quick-quote modal+CTA, pricing calculator
   ═══════════════════════════════════════════════════════════ */

/* ── INSTAGRAM RECENT SHOOTS ─────────────────────────────── */
.dfc-ig-section{
  padding: 7vh 6vw;
  background: linear-gradient(180deg, transparent 0%, rgba(20, 16, 12, 0.4) 100%);
  position: relative;
}
.dfc-ig-head{
  text-align: center;
  max-width: 720px;
  margin: 0 auto 3rem;
}
.dfc-ig-head .section-eyebrow{
  display: inline-block;
  margin-bottom: 1rem;
  font-family: var(--mono);
  font-size: .75rem;
  letter-spacing: .2em;
  color: var(--gold-lt, #d4b860);
  text-transform: uppercase;
}
.dfc-ig-title{
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 300;
  color: var(--white, #f5f2ee);
  line-height: 1.1;
  margin: 0 0 .9rem;
}
.dfc-ig-subtitle{
  font-size: .95rem;
  line-height: 1.6;
  color: rgba(245, 242, 238, 0.65);
}
.dfc-ig-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .8rem;
  max-width: 1200px;
  margin: 0 auto;
}
.dfc-ig-cell{
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #1a1612;
  border: 1px solid rgba(201, 168, 76, 0.1);
  border-radius: 4px;
  text-decoration: none;
  transition: border-color .35s ease, transform .35s cubic-bezier(.22,.61,.36,1);
}
.dfc-ig-cell:hover{
  border-color: rgba(201, 168, 76, 0.45);
  transform: translateY(-3px);
}
.dfc-ig-cell .instagram-media,
.dfc-ig-cell iframe{
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: 100%;
  border: 0 !important;
  margin: 0 !important;
}
.dfc-ig-foot{
  text-align: center;
  margin-top: 2.5rem;
}
.dfc-ig-follow{
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .85rem 1.6rem;
  border: 1px solid var(--gold, #c9a84c);
  color: var(--gold-lt, #d4b860);
  font-family: var(--mono);
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  transition: background .3s ease, color .3s ease, transform .3s ease;
}
.dfc-ig-follow:hover{
  background: var(--gold, #c9a84c);
  color: #0a0806;
  transform: translateY(-1px);
}
@media (max-width: 800px){
  .dfc-ig-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px){
  .dfc-ig-grid{ grid-template-columns: 1fr; }
}

/* ── PRICING CALCULATOR WIDGET ───────────────────────────── */
.dfc-pcalc{
  max-width: 880px;
  margin: 2.5rem auto 3.5rem;
  padding: 2rem 1.8rem;
  background: linear-gradient(180deg, rgba(20, 16, 12, 0.5) 0%, rgba(15, 12, 9, 0.7) 100%);
  border: 1px solid rgba(201, 168, 76, 0.18);
  border-radius: 4px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.dfc-pcalc-head{
  text-align: center;
  margin-bottom: 1.6rem;
}
.dfc-pcalc-eyebrow{
  display: inline-block;
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold-lt, #d4b860);
  margin-bottom: .5rem;
}
.dfc-pcalc-title{
  font-family: var(--serif);
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  font-weight: 300;
  color: var(--white);
  margin: 0 0 .4rem;
}
.dfc-pcalc-sub{
  font-size: .85rem;
  color: rgba(245, 242, 238, 0.6);
  line-height: 1.5;
}
.dfc-pcalc-input-row{
  display: flex;
  align-items: center;
  gap: 1.2rem;
  margin-bottom: 1.2rem;
  flex-wrap: wrap;
  justify-content: center;
}
.dfc-pcalc-slider{
  flex: 1 1 300px;
  min-width: 200px;
  max-width: 480px;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: linear-gradient(90deg, var(--gold, #c9a84c) 0%, rgba(201, 168, 76, 0.2) 100%);
  border-radius: 2px;
  outline: none;
}
.dfc-pcalc-slider::-webkit-slider-thumb{
  -webkit-appearance: none;
  appearance: none;
  width: 22px;
  height: 22px;
  background: var(--gold, #c9a84c);
  border: 2px solid #0a0806;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,.5), 0 0 0 1px rgba(201, 168, 76, 0.3);
  transition: transform .2s ease;
}
.dfc-pcalc-slider::-webkit-slider-thumb:hover{ transform: scale(1.15); }
.dfc-pcalc-slider::-moz-range-thumb{
  width: 22px;
  height: 22px;
  background: var(--gold, #c9a84c);
  border: 2px solid #0a0806;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,.5);
}
.dfc-pcalc-num-wrap{
  display: inline-flex;
  align-items: baseline;
  gap: .35rem;
  background: rgba(20, 16, 12, 0.6);
  border: 1px solid rgba(201, 168, 76, 0.25);
  padding: .5rem .8rem;
  border-radius: 3px;
}
.dfc-pcalc-input{
  width: 80px;
  background: transparent;
  border: 0;
  color: var(--gold-lt, #d4b860);
  font-family: var(--mono);
  font-size: 1.05rem;
  font-weight: 600;
  text-align: right;
  outline: none;
}
/* Hide spinners — they look out of place */
.dfc-pcalc-input::-webkit-outer-spin-button,
.dfc-pcalc-input::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; }
.dfc-pcalc-input[type=number]{ -moz-appearance: textfield; }
.dfc-pcalc-unit{
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .15em;
  color: rgba(245, 242, 238, 0.55);
  text-transform: uppercase;
}
.dfc-pcalc-bracket{
  text-align: center;
  font-size: .85rem;
  color: rgba(245, 242, 238, 0.7);
  margin-bottom: 1.4rem;
}
.dfc-pcalc-bracket strong{
  color: var(--gold-lt, #d4b860);
  font-weight: 500;
}
.dfc-pcalc-results{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}
.dfc-pcalc-tier{
  text-align: center;
  padding: 1rem .8rem;
  background: rgba(20, 16, 12, 0.5);
  border: 1px solid rgba(201, 168, 76, 0.12);
  border-radius: 3px;
  transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease;
}
.dfc-pcalc-tier-pulse{
  border-color: var(--gold, #c9a84c);
  box-shadow: 0 0 0 1px var(--gold), 0 0 16px rgba(201, 168, 76, 0.25);
}
.dfc-pcalc-tier-name{
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .2em;
  color: rgba(245, 242, 238, 0.6);
  text-transform: uppercase;
  margin-bottom: .4rem;
}
.dfc-pcalc-tier-price{
  font-family: var(--serif);
  font-size: clamp(1.6rem, 3vw, 2rem);
  color: var(--gold-lt, #d4b860);
  font-weight: 300;
}
.dfc-pcalc-currency{
  font-size: .65em;
  vertical-align: super;
  margin-right: .12em;
  color: rgba(212, 184, 96, 0.6);
}
.dfc-pcalc-amount{
  transition: opacity .3s ease;
}
.dfc-pcalc-note{
  text-align: center;
  font-size: .82rem;
  color: rgba(245, 242, 238, 0.55);
}
.dfc-pcalc-note a{
  color: var(--gold-lt, #d4b860);
  text-decoration: none;
  border-bottom: 1px solid rgba(201, 168, 76, 0.4);
  transition: color .25s ease, border-color .25s ease;
}
.dfc-pcalc-note a:hover{
  color: var(--white);
  border-color: var(--white);
}

/* ═══════════════════════════════════════════════════════════
   v2.10.0 — EDITORIAL LAYOUT (Mont-fort-borrowed patterns)
   ═══════════════════════════════════════════════════════════ */

/* ── 1. INLINE NUMBERED SECTIONS ─────────────────────────── */

/* Process steps with inline-nums variant: replace the small
   'step-n' badge styling with a giant integrated numeral.
   Cards become a vertical flow with massive gold numbers as
   visual anchors, the way Mont-fort/Maritime renders 1/2/3. */
.steps-list-inline-nums{
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
}
.steps-list-inline-nums .step-item{
  display: grid;
  grid-template-columns: minmax(120px, 14%) 1fr;
  gap: 1.4rem;
  align-items: start;
  padding: 1.4rem 0;
  border-top: 1px solid rgba(201, 168, 76, 0.14);
}
.steps-list-inline-nums .step-item:first-child{ border-top: 0; }
.steps-list-inline-nums .step-n{
  /* Override the default tiny badge */
  font-family: var(--serif);
  font-size: clamp(3.2rem, 7vw, 5.5rem);
  font-weight: 300;
  /* Was 0.95 — risk of clipping. 1.1 + small pad-bottom keeps glyphs whole */
  line-height: 1.1;
  padding-bottom: 0.05em;
  letter-spacing: -.02em;
  background: linear-gradient(180deg, rgba(201, 168, 76, 0.85) 0%, rgba(201, 168, 76, 0.35) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  border: 0;
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
  width: auto;
  height: auto;
  display: block;
  /* Negate any existing positioning */
  position: static;
}
.steps-list-inline-nums .step-item h4{
  font-family: var(--serif);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 400;
  margin: 0 0 .5rem;
  color: var(--white);
}
.steps-list-inline-nums .step-item p{
  font-size: .96rem;
  line-height: 1.6;
  color: rgba(245, 242, 238, 0.72);
  margin: 0;
}
@media (max-width: 700px){
  .steps-list-inline-nums .step-item{
    grid-template-columns: 1fr;
    gap: .5rem;
  }
}

/* Pricing tier cards with inline numbers: huge translucent
   numeral floating top-right of each card, gives it editorial
   chapter-marker feel. */
.ptier-card-inline-num{
  position: relative;
  overflow: hidden;
}
.ptier-inline-num{
  position: absolute;
  top: 0.4rem;
  right: 0.6rem;
  z-index: 0;
  pointer-events: none;
  font-family: var(--serif);
  font-size: clamp(5rem, 9vw, 8rem);
  font-weight: 300;
  /* Was 0.85 — too tight for serif descenders; anything below 1 risks clipping */
  line-height: 1.05;
  padding-bottom: 0.05em;
  letter-spacing: -.05em;
  color: rgba(201, 168, 76, 0.08);
  user-select: none;
}
.ptier-card-inline-num.featured .ptier-inline-num{
  color: rgba(201, 168, 76, 0.16);
}
/* Make sure card content stays above the number */
.ptier-card-inline-num > *:not(.ptier-inline-num){
  position: relative;
  z-index: 1;
}

/* ── 2. MANIFESTO PULL-QUOTES ────────────────────────────── */

.dfc-manifesto{
  padding: 8vh 6vw;
  background:
    radial-gradient(circle at 30% 50%, rgba(201, 168, 76, 0.04), transparent 60%),
    linear-gradient(180deg, rgba(15, 12, 9, 0.4) 0%, rgba(20, 16, 12, 0.6) 100%);
  border-top: 1px solid rgba(201, 168, 76, 0.08);
  border-bottom: 1px solid rgba(201, 168, 76, 0.08);
}
.dfc-manifesto-inner{
  max-width: 1100px;
  margin: 0 auto;
  text-align: left;
}
.dfc-manifesto-eyebrow{
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold-lt, #d4b860);
  margin-bottom: 1.5rem;
  position: relative;
  padding-left: 3rem;
}
.dfc-manifesto-eyebrow::before{
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 2.2rem;
  height: 1px;
  background: var(--gold-lt, #d4b860);
}
.dfc-manifesto-text{
  font-family: var(--serif);
  font-size: clamp(1.6rem, 3.6vw, 2.8rem);
  font-weight: 300;
  font-style: italic;
  line-height: 1.25;
  letter-spacing: -.005em;
  color: rgba(245, 242, 238, 0.92);
  margin: 0;
  padding: 0;
  border: 0;
  max-width: 920px;
}
.dfc-manifesto-text em{
  color: var(--gold-lt, #d4b860);
  font-style: italic;
}
.dfc-manifesto-text strong{
  font-weight: 500;
  color: var(--white);
}
@media (max-width: 700px){
  .dfc-manifesto{ padding: 5vh 5vw; }
  .dfc-manifesto-eyebrow{ padding-left: 2rem; margin-bottom: 1rem; }
  .dfc-manifesto-eyebrow::before{ width: 1.4rem; }
}

/* ── 3. SERVICES ACCORDION ───────────────────────────────── */

.dfc-svc-accordion{
  max-width: 1200px;
  margin: 2.5rem auto 0;
  padding: 0 4vw;
}
.dfc-svc-row{
  border-top: 1px solid rgba(201, 168, 76, 0.18);
  position: relative;
}
.dfc-svc-row:last-child{
  border-bottom: 1px solid rgba(201, 168, 76, 0.18);
}
.dfc-svc-row-trigger{
  width: 100%;
  display: grid;
  grid-template-columns: minmax(60px, 8%) 1fr auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.6rem 0.5rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  transition: background .3s ease;
}
.dfc-svc-row-trigger:hover{
  background: linear-gradient(90deg, rgba(201, 168, 76, 0.04) 0%, transparent 80%);
}
.dfc-svc-row-trigger:focus-visible{
  outline: 2px solid rgba(201, 168, 76, 0.5);
  outline-offset: -2px;
}
.dfc-svc-row-num{
  font-family: var(--mono);
  font-size: .82rem;
  letter-spacing: .15em;
  color: var(--gold-lt, #d4b860);
  font-weight: 500;
}
.dfc-svc-row-title{
  font-family: var(--serif);
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  font-weight: 300;
  color: var(--white);
  letter-spacing: -.005em;
  line-height: 1.15;
}
.dfc-svc-row-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(201, 168, 76, 0.25);
  border-radius: 50%;
  color: var(--gold-lt, #d4b860);
  transition: transform .35s cubic-bezier(.65,.05,.36,1), background .3s ease, border-color .3s ease;
}
.dfc-svc-row.is-open .dfc-svc-row-icon{
  transform: rotate(45deg);
  background: var(--gold-lt, #d4b860);
  color: #0a0806;
  border-color: var(--gold-lt, #d4b860);
}
.dfc-svc-row-body{
  max-height: 0;
  overflow: hidden;
  transition: max-height .55s cubic-bezier(.65,.05,.36,1);
}
.dfc-svc-row.is-open .dfc-svc-row-body{
  max-height: 500px;  /* enough for typical body content */
}
.dfc-svc-row-body-inner{
  padding: 0 0.5rem 2rem;
  display: grid;
  grid-template-columns: minmax(60px, 8%) 1fr auto;
  gap: 1.5rem;
}
.dfc-svc-row-body-inner > p{
  grid-column: 2;
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(245, 242, 238, 0.7);
  max-width: 60ch;
  margin: 0 0 1.2rem;
}
.dfc-svc-row-body-inner > .svc-link{
  grid-column: 2;
}

@media (max-width: 700px){
  .dfc-svc-row-trigger{
    grid-template-columns: auto 1fr auto;
    gap: 1rem;
    padding: 1.2rem 0.3rem;
  }
  .dfc-svc-row-body-inner{
    grid-template-columns: 1fr;
    padding: 0 0.3rem 1.6rem;
  }
  .dfc-svc-row-body-inner > p,
  .dfc-svc-row-body-inner > .svc-link{
    grid-column: 1;
  }
}

/* Reduced-motion safety */
@media (prefers-reduced-motion: reduce){
  .dfc-svc-row-icon{ transition: none !important; }
  .dfc-svc-row-body{ transition: none !important; }
}

/* ═══════════════════════════════════════════════════════════
   v2.13.0 — IMAGE-REPLACEABLE SECTION BACKGROUNDS
   Admin can now set photos behind Contact, CTA band, Why Us,
   and Testimonials sections. The .dfc-section-bg layer holds
   the photo; a ::after pseudo-element places a gradient
   overlay for readability.
   ═══════════════════════════════════════════════════════════ */

.dfc-section.has-section-bg{
  position: relative;
  isolation: isolate;
}
.dfc-section.has-section-bg .dfc-section-bg{
  position: absolute;
  inset: 0;
  z-index: -1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  pointer-events: none;
  /* Subtle parallax-feel zoom hint — animates very slowly. Disabled
     by reduce-motion media query below. */
  transition: transform 1.6s cubic-bezier(.22,.61,.36,1);
}
.dfc-section.has-section-bg .dfc-section-bg::after{
  content: '';
  position: absolute;
  inset: 0;
  /* Dark gradient overlay for sections on dark/black bg.
     Strong enough that body text stays readable; weak enough
     that the photo still reads. */
  background:
    linear-gradient(180deg, rgba(8,11,18,.72) 0%, rgba(8,11,18,.85) 60%, rgba(8,11,18,.92) 100%),
    radial-gradient(ellipse 70% 60% at 30% 20%, rgba(201,168,76,0.05), transparent 60%);
}
/* Light-bg variant (Why Us section uses cream background, so we
   need a CREAM-toned overlay rather than a black one). */
.dfc-section.has-section-bg.has-section-bg-light .dfc-section-bg::after{
  background:
    linear-gradient(180deg, rgba(245,242,234,.92) 0%, rgba(245,242,234,.96) 60%, rgba(245,242,234,.99) 100%),
    radial-gradient(ellipse 70% 60% at 30% 20%, rgba(201,168,76,0.08), transparent 60%);
}
/* Make sure all section content sits above the bg layer */
.dfc-section.has-section-bg > *:not(.dfc-section-bg){
  position: relative;
  z-index: 1;
}

/* Reduced-motion safety */
@media (prefers-reduced-motion: reduce){
  .dfc-section.has-section-bg .dfc-section-bg{ transition: none !important; }
}
