:root {
  --ink: #0a1020;
  --ink-2: #101a31;
  --ink-3: #182641;
  --paper: #f6f7fb;
  --paper-2: #e8edf6;
  --muted: #a7b4ca;
  --line: rgba(255,255,255,.13);
  --accent: #b4ff34;
  --accent-2: #8fe21c;
  --violet: #806bff;
  --deep: #070b15;
  --shadow: 0 24px 70px rgba(0,0,0,.28);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --max: 1200px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--ink); color: var(--paper); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; line-height: 1.55; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
img { max-width: 100%; display: block; }
::selection { background: var(--accent); color: var(--ink); }
.skip-link { position: fixed; left: 1rem; top: -4rem; z-index: 1000; background: var(--accent); color: var(--ink); padding: .65rem .9rem; border-radius: .5rem; font-weight: 800; transition: top .2s; }
.skip-link:focus { top: 1rem; }
.site-shell { overflow: clip; }
.container { width: min(var(--max), calc(100% - 2.25rem)); margin: 0 auto; }
.eyebrow { color: var(--accent); text-transform: uppercase; letter-spacing: .14em; font-weight: 800; font-size: .74rem; }
.section { padding: 5.75rem 0; position: relative; }
.section--light { background: var(--paper); color: var(--ink); }
.section--dark { background: linear-gradient(135deg, #0c1630 0%, #07111f 75%); }
.section--tight { padding-top: 3.75rem; padding-bottom: 3.75rem; }
.section-head { display:flex; align-items: end; justify-content: space-between; gap: 2rem; margin-bottom: 2.4rem; }
.section-title { max-width: 760px; font-size: clamp(2.1rem,4vw,4rem); line-height: 1.05; letter-spacing: -.055em; margin: .55rem 0 0; }
.section-intro { max-width: 570px; margin: .8rem 0 0; color: var(--muted); font-size: 1.05rem; }
.section--light .section-intro { color: #56647d; }
.header { position: sticky; top: 0; z-index: 100; background: rgba(7,11,21,.78); border-bottom: 1px solid transparent; backdrop-filter: blur(18px); transition: background .2s, border-color .2s; }
.header.is-scrolled { background: rgba(7,11,21,.95); border-color: rgba(255,255,255,.09); }
.nav { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.logo { display:flex; align-items:center; gap:.7rem; font-weight:900; letter-spacing:-.045em; font-size:1.1rem; white-space: nowrap; }
.logo-mark { width:34px; height:34px; border:1.5px solid var(--accent); border-radius:11px; position:relative; transform: rotate(45deg); flex:none; }
.logo-mark::before, .logo-mark::after { content:""; position:absolute; background:var(--accent); border-radius: 999px; }
.logo-mark::before { width: 15px; height: 2px; left: 8px; top: 15px; transform:rotate(-45deg); }
.logo-mark::after { width: 4px; height: 4px; left: 15px; top: 14px; }
.logo-text em { display:block; color:var(--muted); font-style:normal; text-transform:uppercase; letter-spacing:.15em; font-size:.49rem; margin-top:1px; }
.nav-links { list-style:none; display:flex; align-items:center; gap:1.65rem; padding:0; margin:0; }
.nav-links a { color:#d4dbea; font-size:.91rem; font-weight:700; position:relative; }
.nav-links a:not(.nav-cta)::after { content:""; position:absolute; left:0; right:0; bottom:-.55rem; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .18s; }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { transform:scaleX(1); }
.nav-cta, .button { display:inline-flex; align-items:center; justify-content:center; gap:.55rem; border:0; cursor:pointer; font-weight:850; border-radius:999px; transition: transform .2s, box-shadow .2s, background .2s; }
.nav-cta { padding:.7rem 1rem; background:var(--accent); color:var(--ink); }
.button { padding:.95rem 1.23rem; font-size:.95rem; }
.button:hover, .nav-cta:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(180,255,52,.18); }
.button--accent { background:var(--accent); color:var(--ink); }
.button--outline { border:1px solid rgba(255,255,255,.33); color:white; background:rgba(255,255,255,.03); }
.button--outline:hover { background:rgba(255,255,255,.1); }
.button--dark { background:var(--ink); color:white; }
.button--dark:hover { box-shadow:0 14px 26px rgba(10,16,32,.2); }
.menu-button { display:none; width:45px; height:42px; padding:0; border:1px solid var(--line); border-radius:11px; background:transparent; color:white; align-items:center; justify-content:center; }
.menu-button span, .menu-button::before, .menu-button::after { content:""; display:block; width:18px; height:2px; border-radius:2px; background:currentColor; transition:.2s; }
.menu-button::before { transform:translateY(-5px); }
.menu-button::after { transform:translateY(5px); }
.menu-button[aria-expanded="true"] span { opacity:0; }
.menu-button[aria-expanded="true"]::before { transform: translateY(2px) rotate(45deg); }
.menu-button[aria-expanded="true"]::after { transform: translateY(-2px) rotate(-45deg); }
.hero { min-height: 650px; position: relative; display:grid; align-items:center; background: #09111e; isolation:isolate; }
.hero::before { content:""; position:absolute; inset:0; z-index:-2; background:linear-gradient(90deg, rgba(7,11,21,.96) 0%, rgba(7,11,21,.77) 44%, rgba(7,11,21,.27) 100%), linear-gradient(180deg, rgba(7,11,21,.18) 0%, rgba(7,11,21,.82) 100%), url('../img/rv-interior-lounge.jpg') center/cover no-repeat; }
.hero::after { content:""; position:absolute; z-index:-1; right:-16rem; top:-12rem; width:43rem; height:43rem; border-radius:50%; background:radial-gradient(circle,rgba(128,107,255,.42),rgba(128,107,255,0) 65%); filter: blur(10px); }
.hero-grid { padding: 5.6rem 0 4.7rem; display:grid; grid-template-columns: 1.1fr .9fr; align-items:end; gap:2.5rem; }
.hero h1 { max-width:780px; margin:.7rem 0 1.2rem; font-size:clamp(3.25rem,7.1vw,7rem); letter-spacing:-.075em; line-height:.89; }
.hero h1 .accent-text { color:var(--accent); }
.hero-copy { max-width:590px; color:#d0d7e8; font-size:1.09rem; }
.hero-actions { display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }
.hero-proof { align-self:end; justify-self:end; width:min(100%,390px); display:grid; gap: .8rem; }
.hero-proof .proof-card { background:rgba(14,24,45,.78); border:1px solid var(--line); padding:1rem 1.1rem; border-radius: var(--radius-md); box-shadow:var(--shadow); backdrop-filter:blur(10px); }
.proof-label { display:block; color:var(--muted); font-size:.75rem; text-transform:uppercase; letter-spacing:.13em; font-weight:800; }
.proof-number { font-size:1.2rem; font-weight:900; letter-spacing:-.04em; margin-top:.2rem; display:block; }
.proof-card--split { display:grid; grid-template-columns:1fr 1fr; gap:.85rem; }
.proof-card--split > div + div { border-left:1px solid var(--line); padding-left:.85rem; }
.trust-strip { background:var(--accent); color:var(--ink); }
.trust-content { min-height:74px; display:flex; align-items:center; justify-content:space-between; gap:1rem; font-weight:850; font-size:.92rem; }
.trust-content span { display:flex; align-items:center; gap:.55rem; }
.trust-content i { width:9px; height:9px; display:block; background:var(--ink); border-radius:50%; }
.card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.service-card { padding:1.45rem; background:rgba(255,255,255,.035); border:1px solid var(--line); border-radius:var(--radius-md); min-height: 285px; position:relative; overflow:hidden; transition:transform .2s, border-color .2s, background .2s; }
.service-card:hover { transform:translateY(-5px); border-color:rgba(180,255,52,.7); background:rgba(255,255,255,.06); }
.service-icon { width:49px; height:49px; border-radius:14px; background:rgba(180,255,52,.1); border:1px solid rgba(180,255,52,.25); color:var(--accent); display:grid; place-items:center; margin-bottom:2.35rem; }
.service-icon svg { width:25px; height:25px; stroke:currentColor; fill:none; stroke-width:1.8; }
.service-card h3 { margin:0 0 .55rem; letter-spacing:-.035em; font-size:1.35rem; }
.service-card p { color:var(--muted); margin:0; font-size:.94rem; max-width:31ch; }
.service-card .card-link { display:inline-flex; align-items:center; gap:.42rem; margin-top:1.4rem; font-size:.85rem; font-weight:850; color:var(--accent); }
.service-card .card-link span { transition:transform .2s; }
.service-card:hover .card-link span { transform:translateX(4px); }
.stat-layout { display:grid; grid-template-columns:.86fr 1.14fr; gap:3rem; align-items:center; }
.stat-copy { max-width:480px; }
.check-list { display:grid; gap:.8rem; padding:0; margin:1.5rem 0 0; list-style:none; }
.check-list li { display:flex; gap:.75rem; align-items:start; color:#d9e0ee; }
.section--light .check-list li { color:#3e4c66; }
.check { flex:0 0 21px; width:21px; height:21px; display:grid; place-items:center; border-radius:50%; background:rgba(180,255,52,.18); color:var(--accent); font-size:.75rem; font-weight:900; transform: translateY(2px); }
.metrics { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
.metric { padding:1.45rem; min-height:156px; border-radius:var(--radius-md); background:#121e34; border:1px solid var(--line); }
.metric:nth-child(2) { background:#1a2042; }
.metric:nth-child(3) { background:#162d2f; }
.metric:nth-child(4) { background:#30233a; }
.metric strong { display:block; color:var(--accent); font-size:2.4rem; letter-spacing:-.07em; line-height:1; }
.metric span { display:block; margin-top:.6rem; color:#d9dfed; font-weight:750; max-width:13ch; font-size:.92rem; }
.process-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.8rem; counter-reset:steps; }
.process-card { position:relative; padding:1.1rem .2rem .25rem 0; counter-increment:steps; }
.process-card:not(:last-child)::after { content:""; position:absolute; height:1px; background:rgba(10,16,32,.18); top:2.25rem; left:calc(100% - .75rem); right:-1.15rem; }
.process-num { display:grid; place-items:center; height:45px; width:45px; background:var(--ink); color:var(--accent); border-radius:50%; font-weight:900; margin-bottom:1.1rem; }
.process-num::before { content:"0" counter(steps); }
.process-card h3 { margin:0 0 .45rem; font-size:1.18rem; letter-spacing:-.035em; }
.process-card p { margin:0; color:#59677e; font-size:.94rem; max-width:31ch; }
.project-feature { display:grid; grid-template-columns: 1.05fr .95fr; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:rgba(255,255,255,.035); }
.project-visual { position:relative; min-height:370px; background:linear-gradient(130deg, rgba(11,18,33,.15),rgba(11,18,33,.88)),url('../img/rv-media-center.jpg') center/cover; }
.project-visual .visual-tag { position:absolute; left:1.25rem; bottom:1.25rem; padding:.55rem .8rem; border:1px solid rgba(255,255,255,.2); border-radius:999px; background:rgba(7,11,21,.75); backdrop-filter:blur(10px); font-size:.78rem; font-weight:750; }
.project-copy { padding:clamp(1.8rem,4vw,4rem); display:flex; flex-direction:column; justify-content:center; }
.project-copy h3 { margin:.5rem 0 .75rem; font-size:clamp(1.8rem,3vw,2.8rem); line-height:1.06; letter-spacing:-.055em; }
.project-copy p { color:var(--muted); margin:0; max-width:39ch; }
.tag-row { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:1.55rem; }
.tag { border:1px solid var(--line); color:#cbd4e3; border-radius:999px; padding:.38rem .62rem; font-size:.71rem; font-weight:750; }
.feature-link { margin-top:1.6rem; color:var(--accent); font-size:.9rem; font-weight:850; }
.quote-band { background:linear-gradient(115deg,var(--accent) 0%,#c6ff4b 42%,#9ff227 100%); color:var(--ink); position:relative; overflow:hidden; }
.quote-band::after { content:""; position:absolute; right:-9rem; top:-12rem; width:31rem; height:31rem; border-radius:50%; border:40px solid rgba(7,11,21,.1); }
.quote-band-inner { min-height:315px; position:relative; display:flex; align-items:center; justify-content:space-between; gap:2rem; z-index:1; }
.quote-band h2 { max-width:680px; font-size:clamp(2.2rem,4.5vw,4.55rem); line-height:.98; letter-spacing:-.07em; margin:.45rem 0 0; }
.quote-band p { max-width:560px; margin:1rem 0 0; font-weight:650; color:rgba(7,11,21,.7); }
.quote-band .button { flex:none; }
.footer { background:#060a13; border-top:1px solid rgba(255,255,255,.08); padding:4.25rem 0 1.2rem; }
.footer-grid { display:grid; grid-template-columns:1.3fr .75fr .85fr .95fr; gap:2rem; padding-bottom:3.2rem; }
.footer p { color:var(--muted); font-size:.9rem; max-width:27ch; }
.footer h3 { font-size:.75rem; text-transform:uppercase; letter-spacing:.12em; color:#d4dbe8; margin:0 0 1rem; }
.footer-links { display:grid; gap:.62rem; }
.footer-links a { color:var(--muted); font-size:.9rem; }
.footer-links a:hover { color:var(--accent); }
.footer-bottom { display:flex; justify-content:space-between; gap:1rem; border-top:1px solid rgba(255,255,255,.1); padding-top:1.3rem; color:#68758d; font-size:.78rem; }
.page-hero { position:relative; padding:6rem 0 5rem; background: radial-gradient(circle at 77% 10%, rgba(128,107,255,.28), transparent 27%), linear-gradient(135deg,#0c1730,#08101d); }
.page-hero::after { content:""; position:absolute; right:-6%; bottom:-28%; width:30rem; height:30rem; border-radius:50%; border:1px solid rgba(180,255,52,.18); box-shadow:0 0 0 50px rgba(180,255,52,.03),0 0 0 100px rgba(180,255,52,.02); }
.page-hero .container { position:relative; z-index:1; }
.breadcrumb { color:var(--muted); font-size:.84rem; font-weight:700; display:flex; gap:.55rem; align-items:center; }
.breadcrumb span { color:var(--accent); }
.page-hero h1 { max-width:840px; margin:.9rem 0 0; font-size:clamp(3rem,6vw,6rem); line-height:.9; letter-spacing:-.075em; }
.page-hero p { margin:1.35rem 0 0; max-width:620px; color:#c5cedf; font-size:1.06rem; }
.service-detail-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
.service-detail { padding:1.65rem; min-height:275px; background:#f1f4f9; border:1px solid #dce3ee; border-radius:var(--radius-md); position:relative; overflow:hidden; }
.service-detail::after { content:""; position:absolute; width:130px; height:130px; border-radius:50%; background:radial-gradient(circle,rgba(128,107,255,.14),transparent 66%); right:-29px; top:-29px; }
.service-detail h3 { font-size:1.45rem; letter-spacing:-.045em; margin:1.4rem 0 .55rem; position:relative; z-index:1; }
.service-detail p { color:#56647a; font-size:.93rem; max-width:42ch; position:relative; z-index:1; margin:0; }
.icon-dark { color:#1a2440; background:rgba(128,107,255,.1); border-color:rgba(128,107,255,.23); }
.audience-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.1); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.audience-card { background:#0d1730; padding:2rem; min-height:242px; }
.audience-card:nth-child(2) { background:#151d38; }
.audience-card:nth-child(3) { background:#102727; }
.audience-card h3 { margin:.2rem 0 .65rem; font-size:1.45rem; letter-spacing:-.045em; }
.audience-card p { color:var(--muted); font-size:.92rem; margin:0; }
.gallery-toolbar { display:flex; gap:.55rem; flex-wrap:wrap; margin:1rem 0 2.2rem; }
.filter-btn { background:transparent; color:#4f5c73; border:1px solid #dbe2ed; border-radius:999px; padding:.54rem .85rem; cursor:pointer; font-size:.79rem; font-weight:800; transition:.2s; }
.filter-btn.active, .filter-btn:hover { background:var(--ink); color:white; border-color:var(--ink); }
.gallery-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:1rem; }
.gallery-card { grid-column:span 4; min-height:295px; border-radius:var(--radius-md); overflow:hidden; position:relative; background:linear-gradient(145deg,#192947,#0c1427); }
.gallery-card.wide { grid-column:span 8; }
.gallery-card.tall { min-height:475px; }
.gallery-card img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; transition: transform .5s; }
.gallery-card:hover img { transform:scale(1.06); }
.gallery-card::after { content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(5,9,17,.9) 0%, rgba(5,9,17,.03) 65%); }
.gallery-caption { position:absolute; bottom:0; left:0; z-index:1; padding:1.1rem; }
.gallery-caption small { text-transform:uppercase; letter-spacing:.12em; color:var(--accent); font-weight:850; font-size:.66rem; }
.gallery-caption strong { display:block; margin-top:.25rem; font-size:1.1rem; letter-spacing:-.035em; }
.gallery-card.visual-only { display:flex; align-items:end; background:radial-gradient(circle at 72% 14%,rgba(180,255,52,.22),transparent 18%),linear-gradient(135deg,#141f3c,#0b1627 65%); }
.gallery-card.visual-only .dashboard { position:absolute; width:78%; height:57%; right:-2%; top:11%; padding:.75rem; border:10px solid #1e2b47; border-radius:20px 0 0 20px; background:#0a1120; box-shadow:0 22px 40px rgba(0,0,0,.35); transform:rotate(-5deg); }
.dashboard::before { content:""; height:55%; display:block; border-radius:8px; background:linear-gradient(125deg,#4c70bd,#182547 55%,#b4ff34); opacity:.95; }
.dashboard::after { content:""; position:absolute; left:.75rem; right:.75rem; bottom:.75rem; height:25%; border-radius:7px; background:repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 12%,transparent 12% 16%); }
.gallery-card.hidden { display:none; }
.about-layout { display:grid; grid-template-columns: .9fr 1.1fr; gap:4rem; align-items:start; }
.large-quote { border-left:3px solid var(--accent); padding: .3rem 0 .3rem 1.5rem; margin-top:1.6rem; font-size:clamp(1.3rem,2vw,1.9rem); line-height:1.25; letter-spacing:-.035em; color:#e3e9f4; }
.value-list { display:grid; gap:1px; background:#dce3ee; border:1px solid #dce3ee; border-radius:var(--radius-md); overflow:hidden; }
.value-row { display:grid; grid-template-columns:53px 1fr; gap:1rem; padding:1.35rem; background:#f7f9fc; }
.value-row strong { display:block; font-size:1.03rem; margin-bottom:.25rem; letter-spacing:-.025em; }
.value-row p { margin:0; color:#59677c; font-size:.91rem; }
.value-index { font-size:.75rem; font-weight:900; color:#66708f; padding-top:.15rem; }
.contact-layout { display:grid; grid-template-columns:1.05fr .95fr; gap:1.2rem; align-items:start; }
.form-card { padding:clamp(1.25rem,3.3vw,2.4rem); background:#f8f9fc; border-radius:var(--radius-lg); color:var(--ink); }
.form-card h2 { margin:0; font-size:clamp(1.75rem,3vw,2.65rem); line-height:1.03; letter-spacing:-.055em; }
.form-card > p { color:#59677c; max-width:49ch; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; margin-top:1.6rem; }
.field { display:grid; gap:.36rem; }
.field--full { grid-column:1 / -1; }
.field label { color:#273349; font-weight:800; font-size:.8rem; }
.field input,.field select,.field textarea { width:100%; border:1px solid #cdd5e3; background:white; color:var(--ink); border-radius:10px; padding:.8rem .85rem; outline:none; transition:border-color .2s, box-shadow .2s; }
.field textarea { min-height:125px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus { border-color:var(--violet); box-shadow:0 0 0 4px rgba(128,107,255,.13); }
.form-note { font-size:.75rem; color:#68758a; margin:1rem 0 0; }
.contact-side { display:grid; gap:1rem; }
.contact-block { background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:var(--radius-md); padding:1.5rem; }
.contact-block h3 { margin:0 0 .75rem; font-size:1.05rem; letter-spacing:-.035em; }
.contact-block p, .contact-block address { color:var(--muted); margin:0; font-size:.92rem; font-style:normal; }
.contact-link { color:var(--accent); font-weight:850; display:inline-block; margin-top:.75rem; }
.hours { display:grid; gap:.55rem; }
.hours div { display:flex; justify-content:space-between; gap:1rem; color:var(--muted); font-size:.87rem; }
.hours span:last-child { color:#e0e6f1; font-weight:700; }
.notice { display:none; margin:.85rem 0 0; color:#2f5510; background:#e9ffd0; border:1px solid #c9f999; border-radius:10px; padding:.8rem .9rem; font-size:.84rem; font-weight:700; }
.notice.is-visible { display:block; }
.modal-backdrop { position:fixed; z-index:500; inset:0; display:none; align-items:center; justify-content:center; padding:1rem; background:rgba(2,5,11,.7); backdrop-filter:blur(8px); }
.modal-backdrop.is-open { display:flex; }
.modal { width:min(100%,620px); max-height:calc(100vh - 2rem); overflow:auto; background:#f8f9fc; color:var(--ink); border-radius:var(--radius-lg); padding:clamp(1.35rem,4vw,2.3rem); position:relative; box-shadow:0 30px 100px rgba(0,0,0,.5); }
.modal-close { position:absolute; right:1rem; top:1rem; width:37px; height:37px; border:1px solid #d6dee9; border-radius:50%; background:white; color:var(--ink); font-size:1.2rem; cursor:pointer; }
.modal h2 { margin:0; letter-spacing:-.05em; font-size:2rem; line-height:1; }
.modal .form-grid { margin-top:1.25rem; }
.toast { position:fixed; left:50%; bottom:1.4rem; z-index:600; transform:translate(-50%,120%); background:var(--accent); color:var(--ink); border-radius:999px; padding:.75rem 1rem; font-size:.83rem; font-weight:850; box-shadow:0 12px 34px rgba(0,0,0,.25); transition:transform .28s; }
.toast.is-visible { transform:translate(-50%,0); }
@media (max-width: 900px) {
  .nav-links { gap:1rem; }
  .nav-links .nav-cta { display:none; }
  .hero-grid { grid-template-columns:1fr; }
  .hero-proof { justify-self:start; grid-template-columns:1fr 1.1fr; width:100%; }
  .hero-proof .proof-card--split { grid-template-columns:1fr 1fr; }
  .stat-layout, .about-layout, .contact-layout { grid-template-columns:1fr; gap:2rem; }
  .footer-grid { grid-template-columns:1.5fr 1fr 1fr; }
  .footer-grid > :first-child { grid-column:span 3; }
  .project-feature { grid-template-columns:1fr; }
  .project-visual { min-height:320px; }
}
@media (max-width: 720px) {
  .container { width:min(var(--max),calc(100% - 1.4rem)); }
  .header { backdrop-filter:blur(13px); }
  .nav { min-height:68px; }
  .menu-button { display:flex; }
  .nav-links { display:flex; position:fixed; inset:68px 0 auto; min-height:calc(100vh - 68px); flex-direction:column; align-items:stretch; padding:1.25rem 1.4rem 2rem; background:#090f1c; transform:translateX(100%); transition:transform .24s ease; border-top:1px solid var(--line); gap:0; }
  .nav-links.is-open { transform:translateX(0); }
  .nav-links li { width:100%; border-bottom:1px solid rgba(255,255,255,.08); }
  .nav-links a { display:block; padding:1.05rem 0; font-size:1.07rem; }
  .nav-links a:not(.nav-cta)::after { bottom:.6rem; }
  .nav-links .nav-cta { display:inline-flex; margin-top:1.25rem; }
  .hero { min-height:640px; }
  .hero::before { background:linear-gradient(90deg,rgba(7,11,21,.94),rgba(7,11,21,.71)),linear-gradient(180deg,rgba(7,11,21,.08),rgba(7,11,21,.95)),url('../img/rv-interior-lounge.jpg') 59% center/cover no-repeat; }
  .hero-grid { padding:4.7rem 0 3rem; }
  .hero h1 { font-size:clamp(3.1rem,15vw,5rem); }
  .hero-proof { grid-template-columns:1fr; }
  .trust-content { justify-content:flex-start; overflow:auto; white-space:nowrap; padding:.8rem 0; }
  .trust-content span { padding-right:1rem; border-right:1px solid rgba(10,16,32,.2); }
  .trust-content span:last-child { border:0; }
  .section { padding:4rem 0; }
  .section-head { display:block; margin-bottom:1.8rem; }
  .card-grid, .process-grid, .audience-strip, .service-detail-grid { grid-template-columns:1fr; }
  .service-card { min-height:0; }
  .service-card .service-icon { margin-bottom:1.4rem; }
  .process-card { padding:0 0 1.2rem 3.8rem; }
  .process-card:not(:last-child)::after { width:1px; height:calc(100% - 46px); top:46px; left:22px; right:auto; }
  .process-num { position:absolute; left:0; top:0; }
  .metrics { gap:.75rem; }
  .metric { min-height:136px; padding:1.1rem; }
  .metric strong { font-size:2rem; }
  .project-copy { padding:1.6rem; }
  .quote-band-inner { padding:3.3rem 0; display:block; }
  .quote-band .button { margin-top:1.45rem; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem 1rem; }
  .footer-grid > :first-child { grid-column:span 2; }
  .footer-bottom { display:block; }
  .footer-bottom p { margin:.2rem 0; }
  .gallery-grid { grid-template-columns:1fr 1fr; gap:.75rem; }
  .gallery-card, .gallery-card.wide { grid-column:span 1; min-height:235px; }
  .gallery-card.tall { min-height:235px; }
  .gallery-card.wide { grid-column:span 2; }
  .page-hero { padding:4.5rem 0 3.9rem; }
  .page-hero h1 { font-size:clamp(3rem,15vw,5rem); }
  .form-grid { grid-template-columns:1fr; }
  .field--full { grid-column:auto; }
}
@media (max-width: 420px) {
  .logo-text { font-size:.99rem; }
  .hero-actions .button { width:100%; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-grid > :first-child { grid-column:span 1; }
  .gallery-grid { grid-template-columns:1fr; }
  .gallery-card, .gallery-card.wide { grid-column:span 1; }
}

.card-logos { display:flex; flex-wrap:wrap; gap:.55rem; align-items:center; justify-content:flex-end; }
.card-badge { display:inline-flex; align-items:center; justify-content:center; min-width:88px; padding:.42rem .72rem; border-radius:12px; font-size:.74rem; font-weight:800; letter-spacing:.02em; background:#ffffff; border:1px solid rgba(255,255,255,.16); box-shadow:0 10px 24px rgba(0,0,0,.12); }
.card-badge--visa { color:#1434cb; }
.card-badge--mc { color:#1a1f36; position:relative; overflow:hidden; }
.card-badge--mc::before, .card-badge--mc::after { content:""; width:14px; height:14px; border-radius:50%; position:absolute; top:50%; transform:translateY(-50%); opacity:.9; }
.card-badge--mc::before { left:10px; background:#eb001b; }
.card-badge--mc::after { left:18px; background:#f79e1b; mix-blend-mode:multiply; }
.card-badge--discover { color:#1a1f36; }
.card-badge--discover::after { content:""; display:inline-block; width:24px; height:6px; margin-left:8px; border-radius:999px; background:linear-gradient(90deg,#ff7a00,#ffb25a); }
.card-badge--amex { color:#016fd0; background:#eef8ff; border-color:#cfe8ff; }
@media (max-width: 720px) { .card-logos { justify-content:flex-start; margin-top:.5rem; } .card-badge { min-width:74px; } }


/* Professional payment cards footer refresh */
.footer-bottom {
  align-items: center;
}
.card-logos {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  align-items: center;
  justify-content: flex-end;
}
.card-badge {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 108px;
  height: 42px;
  padding: 0 .95rem;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #f2f6fb 100%);
  border: 1px solid rgba(201, 214, 228, .95);
  box-shadow: 0 10px 24px rgba(1, 12, 28, .22), inset 0 1px 0 rgba(255,255,255,.95);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .01em;
  text-transform: none;
}
.card-badge::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0) 46%);
}
.card-badge--visa {
  color: #1634b6;
  font-style: italic;
  letter-spacing: .06em;
}
.card-badge--visa::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 8px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #f7b600, #ffd76b);
  opacity: .95;
}
.card-badge--mc {
  color: #161b33;
  padding-left: 2.1rem;
  font-weight: 800;
}
.card-badge--mc::after,
.card-badge--mc span::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  transform: translateY(-50%);
}
.card-badge--mc::after {
  left: 13px;
  background: rgba(235, 0, 27, .92);
}
.card-badge--mc span::before {
  left: 22px;
  background: rgba(247, 158, 27, .92);
  mix-blend-mode: multiply;
}
.card-badge--discover {
  color: #1b2438;
  font-weight: 800;
}
.card-badge--discover::after {
  content: "";
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 8px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,0), #ff7f00 28%, #ffb156 68%, rgba(255,255,255,0));
}
.card-badge--amex {
  color: #ffffff;
  background: linear-gradient(180deg, #36a8ff 0%, #0077d8 100%);
  border-color: rgba(90, 188, 255, .88);
  box-shadow: 0 10px 24px rgba(0, 25, 53, .26), inset 0 1px 0 rgba(255,255,255,.28);
  text-transform: uppercase;
  letter-spacing: .04em;
}
@media (max-width: 720px) {
  .card-logos {
    justify-content: flex-start;
    margin-top: .55rem;
    gap: .55rem;
  }
  .card-badge {
    min-width: 92px;
    height: 38px;
    font-size: .72rem;
  }
}


/* One-line professional payment logo row */
.footer-bottom {
  align-items: center;
}
.card-logos {
  display: flex;
  flex-wrap: nowrap;
  gap: .65rem;
  align-items: center;
  justify-content: flex-end;
  overflow-x: auto;
  padding-bottom: .1rem;
}
.pay-logo {
  position: relative;
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  width: 112px;
  height: 58px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(205, 216, 229, .9);
  box-shadow: 0 12px 24px rgba(4, 12, 24, .18), inset 0 1px 0 rgba(255,255,255,.75);
  background: #fff;
}
.pay-logo::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,.38), rgba(255,255,255,0) 48%);
}
.pay-logo-text {
  position: relative;
  z-index: 1;
  display: inline-block;
  line-height: 1;
  white-space: nowrap;
}
.pay-logo--visa {
  background: linear-gradient(180deg, #fbfbfc 0%, #edf2f7 100%);
}
.pay-logo--visa .pay-logo-text {
  color: #1540c1;
  font-weight: 1000;
  font-size: 1.55rem;
  letter-spacing: .03em;
  font-style: italic;
  text-shadow: 0 1px 0 rgba(255,255,255,.8), 0 2px 8px rgba(9, 27, 79, .12);
}
.pay-logo--visa::after {
  content: "";
  position: absolute;
  top: 12px;
  left: 12px;
  width: 18px;
  height: 8px;
  border-radius: 0 12px 0 12px;
  background: linear-gradient(90deg,#f7a300,#ffc04a);
  transform: skewX(-26deg);
}
.pay-logo--mc {
  background: linear-gradient(180deg, #5fb0e8 0%, #2e88cd 100%);
}
.pay-logo--mc .pay-logo-text {
  color: #fff;
  font-weight: 900;
  font-size: 1rem;
  font-style: italic;
  text-shadow: 0 2px 6px rgba(0,0,0,.24);
}
.pay-logo--mc::after,
.pay-logo--mc::before {
  border-radius: 50%;
  width: 33px;
  height: 33px;
  top: 12px;
  background: #e30000;
  box-shadow: none;
}
.pay-logo--mc::before {
  left: 23px;
  background: rgba(227,0,0,.96);
}
.pay-logo--mc::after {
  content: "";
  position: absolute;
  left: 48px;
  background: rgba(255,164,0,.96);
}
.pay-logo--mc .pay-logo-text {
  z-index: 2;
}
.pay-logo--amex {
  background: linear-gradient(180deg, #62c4fa 0%, #1f8fdd 100%);
  border-color: rgba(145, 218, 255, .9);
}
.pay-logo--amex .pay-logo-text {
  color: #ffffff;
  font-weight: 1000;
  font-size: .8rem;
  letter-spacing: .02em;
  text-align: center;
  line-height: .95;
  padding: .16rem .38rem;
  border: 2px solid rgba(255,255,255,.92);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.25);
}
.pay-logo-text--stack { white-space: normal; }
.pay-logo--discover {
  background: linear-gradient(180deg, #fcfcfd 0%, #f2f4f7 100%);
}
.pay-logo--discover .pay-logo-text {
  color: #111827;
  font-weight: 1000;
  font-size: 1rem;
  letter-spacing: .015em;
  text-align: center;
}
.pay-logo--discover .pay-logo-text small {
  display: block;
  margin-top: .2rem;
  font-size: .58rem;
  font-weight: 900;
  letter-spacing: .08em;
}
.pay-logo--discover::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 70px;
  right: -28px;
  bottom: -35px;
  border-radius: 50%;
  background: linear-gradient(180deg, #ffa52e, #ff8600);
}
.pay-logo-text--discover::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-left: 2px;
  border-radius: 50%;
  background: radial-gradient(circle, #ffd7ae 0%, #ff9d30 45%, #f27400 100%);
  vertical-align: middle;
}
@media (max-width: 900px) {
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
  .card-logos {
    width: 100%;
    justify-content: flex-start;
    margin-top: .55rem;
  }
}
@media (max-width: 720px) {
  .pay-logo {
    width: 102px;
    height: 54px;
  }
  .pay-logo--visa .pay-logo-text { font-size: 1.4rem; }
  .pay-logo--mc .pay-logo-text { font-size: .92rem; }
  .pay-logo--amex .pay-logo-text { font-size: .73rem; }
  .pay-logo--discover .pay-logo-text { font-size: .92rem; }
}


/* Compact payment logos */
.card-logos { gap: .45rem; }
.pay-logo { width: 84px; height: 44px; border-radius: 11px; }
.pay-logo--visa .pay-logo-text { font-size: 1.12rem; }
.pay-logo--visa::after { left: 10px; right: 10px; bottom: 6px; height: 2px; }
.pay-logo--visa::before { top: 9px; left: 9px; width: 14px; height: 6px; }
.pay-logo--mc .pay-logo-text { font-size: .73rem; }
.pay-logo--mc::after, .pay-logo--mc::before { top: 8px; width: 25px; height: 25px; }
.pay-logo--mc::before { left: 17px; }
.pay-logo--mc::after { left: 36px; }
.pay-logo--amex .pay-logo-text { font-size: .57rem; border-width: 1.5px; padding: .13rem .24rem; }
.pay-logo--discover .pay-logo-text { font-size: .72rem; }
.pay-logo--discover .pay-logo-text small { margin-top: .13rem; font-size: .43rem; }
.pay-logo--discover::after { width: 52px; height: 52px; right: -21px; bottom: -27px; }
.pay-logo-text--discover::after { width: 9px; height: 9px; }
@media (max-width: 720px) {
  .pay-logo { width: 78px; height: 41px; }
  .pay-logo--visa .pay-logo-text { font-size: 1.03rem; }
  .pay-logo--mc .pay-logo-text { font-size: .68rem; }
  .pay-logo--amex .pay-logo-text { font-size: .53rem; }
  .pay-logo--discover .pay-logo-text { font-size: .68rem; }
}
