/* ---------- Theme ---------- */
:root{
  --accent: #e1a357; /* subtle gold */
  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.25);

  /* Light (default) */
  --bg: #ffffff;
  --surface: #f6f7f9;
  --card: #ffffff;
  --text: #13161a;
  --muted: #606a78;
  --border: #e5e9f0;
  --link: #0f62fe;
}

@media (prefers-color-scheme: dark){
  :root{
    --bg: #0c0f14;
    --surface: #10141b;
    --card: #121823;
    --text: #e7eaf0;
    --muted: #a4acba;
    --border: #1b2431;
    --link: #8ab4ff;
  }
}

html[data-theme="light"]{
  --bg: #ffffff;
  --surface: #f6f7f9;
  --card: #ffffff;
  --text: #13161a;
  --muted: #606a78;
  --border: #e5e9f0;
  --link: #0f62fe;
}
html[data-theme="dark"]{
  --bg: #0c0f14;
  --surface: #10141b;
  --card: #121823;
  --text: #e7eaf0;
  --muted: #a4acba;
  --border: #1b2431;
  --link: #8ab4ff;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  padding-top:72px; /* top padding for fixed header */
}
a{color:var(--link)}

.section{padding-block:clamp(56px,8vw,40px)}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card.padded{padding:28px 24px}

h1,h2,h3{line-height:1.2;margin:0 0 12px}
h1{font-size:clamp(36px,5vw,60px);letter-spacing:-0.02em}
h2{font-size:clamp(24px,3vw,34px)}
p.lead{font-size:18px;color:var(--muted)}

a.button,.button,button{
  text-decoration:none;
  border:1px solid var(--border);
  background:var(--btn-bg,transparent);
  color:var(--text);
  border-radius:12px;
  padding:10px 14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  line-height:1;
  transition:transform .12s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow:none;
  cursor:pointer;
}
a.button:hover,.button:hover,button:hover{
  transform:translateY(-1px);
  border-color:rgba(0,0,0,.12);
  box-shadow:0 6px 14px rgba(0,0,0,.08)
}
a.button:focus-visible,.button:focus-visible,button:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(225,163,87,.35)
}
.button.primary{
  background:var(--btn-primary-bg,rgba(225,163,87,.12));
  border-color:rgba(225,163,87,.35);
  font-weight:bolder;
}
.button.primary:hover{background:var(--btn-primary-bg-hover,rgba(225,163,87,.18))}
.button.ghost{background:transparent}

header.nav{
  position:fixed;top:0;left:0;right:0;z-index:20;
  backdrop-filter:blur(10px);
  background:var(--header-bg);
  border-bottom:1px solid var(--header-border)
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.brand-wrap{display: contents;}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;cursor:pointer;white-space:nowrap}
.brand-dot{width:10px;height:10px;background:var(--accent);border-radius:50%}
.nav a{color:var(--text);text-decoration:none;opacity:.85}
.nav a:hover{opacity:1}

.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:900px){.grid.cols-3{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}

.controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:8px 0 4px}
.control{display:flex;align-items:center;gap:6px}
input[type="number"],input[type="text"],input[type="email"],input[type="tel"]{
  background:var(--surface);border:1px solid var(--border);color:var(--text);
  border-radius:10px;padding:8px 10px;width:120px;
}


/* --- Services grid-as-cards (scoped to Services section) --- */
.service-grid {
  align-items: stretch;
}

.service-grid .service {
  padding: 25px;
  min-height: 100%;
}

.service-grid .service .service-title {
  font-weight: 700;
  margin-bottom: 15px;
  line-height: 1.25;
}

.service-grid .service .service-includes .chip {
  display: none;
}

.service-grid .service .includes {
  max-height: none;
  overflow: visible;
  margin-top: 8px;
  padding-left: 18px;
}


.portfolio-item{
  overflow:hidden;border-radius:calc(var(--radius) - 4px);border:1px solid var(--border);
  background:var(--surface);
}
.portfolio-item img{width:100%;height:auto;display:block}
.portfolio-caption{padding:12px;color:var(--muted);font-size:14px;line-height:1.5}


/* About breathing space */
#about .card.padded{padding:32px 28px}
.about h3{margin:8px 0 4px}

/* Right-aligned header nav */
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav-right .pipe{opacity:.35}

/* Nav separators */
.nav a{position:relative;padding:0 8px}
.nav .sep{opacity:.35;margin:0 2px}

/* Main nav */
.nav-main{margin-left:auto;display:flex;align-items:center;gap:8px}
header.nav,.nav,.nav a{pointer-events:auto}

/* Theme switch (pill) */
.theme-switch{
  -webkit-appearance:none;appearance:none;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  width:64px;height:32px;border-radius:999px;
  position:relative;display:inline-flex;align-items:center;justify-content:space-between;
  padding:0 8px;cursor:pointer;overflow:hidden;
}
.theme-switch:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(225,163,87,.35)}
.theme-switch .sun,.theme-switch .moon{width:16px;height:16px;display:block;opacity:.65;transition:opacity .2s ease}
.theme-switch .thumb{
  position:absolute;left:3px;width:26px;height:26px;border-radius:50%;
  background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.15);
  transition:transform .25s ease, background .2s ease;
}
:root[data-theme="dark"] .theme-switch .thumb{transform:translateX(32px);background:#0f141c}
:root[data-theme="dark"] .theme-switch .moon{opacity:1}
:root[data-theme="dark"] .theme-switch .sun{opacity:.4}
:root[data-theme="light"] .theme-switch .sun{opacity:1}
:root[data-theme="light"] .theme-switch .moon{opacity:.4}

/* Toggle visibility fix */
.theme-switch{position:relative}
.theme-switch .thumb{z-index:0}
.theme-switch svg{z-index:1;position:relative;pointer-events:none;stroke:currentColor;fill:none}
.theme-switch .moon path{fill:currentColor;stroke:none}

/* Theme variables (light/dark) */
:root[data-theme="light"]{
  --bg:#ffffff;
  --card:#f7f8fb;
  --muted:#667085;
  --text:#111317;
  --accent:#e1a357;
  --border:#E2E5ED;
  --btn-bg:#ffffff;
  --btn-primary-bg:rgba(225,163,87,.12);
  --btn-primary-bg-hover:rgba(225,163,87,.18);
  --header-bg:rgba(255,255,255,.8);
  --header-border:#E2E5ED;
  --clients-bg:#f5f7fb
}
:root[data-theme="dark"]{
  --bg:#0b0f15;
  --card:#10151d;
  --muted:#aab2c0;
  --text:#e9edf3;
  --accent:#e1a357;
  --border:#1b2230;
  --btn-bg:#121722;
  --btn-primary-bg:rgba(225,163,87,.14);
  --btn-primary-bg-hover:rgba(225,163,87,.22);
  --header-bg:rgba(11,11,12,.6);
  --header-border:#1b2230;
  --clients-bg:#0f141c
}
body{background:var(--bg);color:var(--text)}
.card{background:var(--card)}

picture{display:block}
picture img{width:100%;height:auto;display:block}

/* Typographic rhythm */
:root{
  --space-1:6px;
  --space-2:10px;
  --space-3:14px;
  --space-4:18px;
  --space-5:24px;
  --space-6:32px;
}
h1{line-height:1.15;margin:var(--space-4) 0 var(--space-3)}
h2{line-height:1.2;margin:var(--space-4) 0 var(--space-3)}
h3{line-height:1.25;margin:var(--space-3) 0 var(--space-2)}
p{margin:var(--space-2) 0;line-height:1.65}
.lead{line-height:1.6;margin:var(--space-2) 0 var(--space-3)}
.includes li{margin:4px 0}

/* Core hero image support */
.hero-art picture,.hero-art img{display:block}
.hero-art img{width:100%;height:100%;object-fit:cover}

/* Portrait-only hero (no card) */
.hero-portrait-only img{
  width:min(560px,42vw);
  height:auto;
  display:block;
  object-fit:contain;
  filter:none;
}
@media (max-width:1080px){
  .hero-portrait-only img{width:min(520px,84vw)}
}

/* Anchor offset for fixed header */
section{scroll-margin-top:84px}

/* Hero equal columns + 2:3 portrait placeholder */
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;z-index:1}
.hero-media{justify-self:end;position:relative;z-index:1}
.hero-media picture,.hero-media img{display:block}
.hero-media img{
  max-width:min(560px,40vw);
  width:100%;
  height:auto;
  aspect-ratio:2/3;
  object-fit:cover;
  border-radius:16px;
  display:block;
}
.hero-copy{position:relative;z-index:2}
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-media{justify-self:center}
  .hero-media img{width:min(520px,84vw)}
}

/* Hero column balance (final) */
.hero-grid{grid-template-columns:min(520px,1.2fr) minmax(420px,1fr)}
@media (max-width:1080px){.hero-grid{grid-template-columns:1fr;gap:28px}}

/* Portrait image sizing (light) */
:root[data-theme="light"] .hero-portrait img{width:92%;height:auto;object-fit:contain;display:block}
@media (max-width:980px){.hero-portrait img{width:94%}}

/* Redesigned hero copy */
.hero-copy h1{margin:8px 0 14px;line-height:1.08}
.hero-copy .lead{max-width:62ch}

/* Hero: grid areas & responsive reorder */
.hero-copy{grid-area:copy}
.hero-media{grid-area:media}
.hero-grid{grid-template-areas:"copy media"}
@media (max-width:1080px){
  .hero-grid{
    grid-template-columns:1fr;
    grid-template-areas:
      "media"
      "copy";
    gap:28px;
  }
  .hero-media{justify-self:center}
}
@media (max-width:768px){
  .hero-grid{display:flex;flex-direction:column}
  .hero-media{order:-1;margin-bottom:16px;text-align:center}
  .hero-media img{max-width:90%;width:90%;height:auto}
}

/* Global container & rhythm */
.container{max-width:1200px;padding-inline:clamp(20px,5vw,48px);margin-inline:auto}
main.section{padding-top:clamp(12px,2vw,18px)}

/* Portfolio grids */
.grid.tiles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.grid.tiles .card{margin:0;background:transparent;position:relative}
.grid.tiles img{display:block;width:100%;height:auto;border-radius:12px}
.grid.tiles figcaption{margin-top:8px;font-weight:600;line-height:1.25;color:white}
@media (max-width:900px){.grid.tiles{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:560px){.grid.tiles{grid-template-columns:1fr}}

/* Card caption placement & no underline */
.grid.tiles a.tile{text-decoration:none!important}
.grid.tiles a.tile:hover{text-decoration:none!important}
.grid.tiles figcaption{text-decoration:none!important}
.grid.tiles .card figcaption{
  position:absolute;left:50%;transform:translateX(-50%);
  bottom:10px;width:calc(100% - 20px);margin:0;
  padding:6px 10px 4px;text-align:center;font-weight:600;line-height:1.25;
}
:root[data-theme="light"] .grid.tiles .card figcaption{color:#fff}

/* Filters */
.filter-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filter-btn{border:1px solid var(--border,#ddd);background:var(--card,#f9f9f9);padding:.5rem .75rem;border-radius:999px;cursor:pointer}
.filter-btn[aria-pressed="true"]{outline:2px solid var(--border,#ddd)}
.filter-search input{padding:.5rem .75rem;border:1px solid var(--border,#ddd);border-radius:8px;background:var(--card,#fff);color:inherit}
.proj-meta{display:flex;gap:24px;margin:10px 0 4px;font-size:.95rem;color:var(--muted,#667);flex-wrap:wrap}
.proj-meta span{color:inherit;font-weight:600;margin-right:6px}
.proj-desc{margin:10px 0 18px;max-width:78ch}

/* Remove shadow from hero placeholder */
.hero,.hero *,.hero-media,.hero-media *,.hero-placeholder,.hero-placeholder *{
  box-shadow:none!important;filter:none!important;
}

/* Section titles */
.section-title{
  font-size:clamp(28px,4vw,40px);
  line-height:1.1;
  font-weight:800;
  margin:0 0 14px 0;
}

/* Project pager */
.proj-pager{display:flex;justify-content:space-between;gap:12px;margin-top:16px;align-items:center;flex-wrap:wrap}
.proj-pager .spacer{flex:1 1 auto}

/* Mobile Nav (dropdown) with Lucide hamburger */
.nav-toggle{
  display:none;
  border:1px solid var(--border);
  background:var(--card);
  width:42px;height:36px;border-radius:10px;
  align-items:center;justify-content:center;cursor:pointer;padding:0;
}
.nav-toggle .icon{width:22px;height:22px;display:block}
.nav-toggle .icon-close{display:none}
.nav-toggle.active .icon-menu{display:none}
.nav-toggle.active .icon-close{display:block}

@media (max-width:900px){
  .nav-toggle{display:inline-flex}
  .nav-main .sep{display:none}
  .nav-main{
    position:absolute;top:64px;right:24px;left:24px;
    display:flex;flex-direction:column;gap:6px;
    padding:10px;background:var(--card);
    border:1px solid var(--border);border-radius:14px;
    box-shadow:var(--shadow);
    opacity:0;transform:translateY(-8px);
    pointer-events:none;transition:opacity .18s ease, transform .18s ease;z-index:25;
  }
  .nav-main a{padding:10px 12px;border-radius:10px}
  .nav-main a:hover,.nav-main a:focus-visible{background:var(--surface)}
  .nav-main.open{opacity:1;transform:translateY(0);pointer-events:auto}
}
@media (min-width:901px){
  .nav-main{position:static;opacity:1;transform:none;pointer-events:auto}
}

/* Back to top */
#backToTop{
  position:fixed;right:16px;bottom:16px;height:44px;
  border:1px solid var(--border);border-radius:50%;
  background:var(--card);color:var(--text);
  display:none;align-items:center;justify-content:center;
  cursor:pointer;transition:opacity .2s ease, transform .2s ease;
  box-shadow:0 6px 14px rgba(0,0,0,.08);
}
#backToTop:hover{transform:translateY(-2px)}
#backToTop svg{stroke:currentColor}

/* Contact cards */
.contact-grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.contact-grid{grid-template-columns:1fr}}
.contact-card{
  display:flex;align-items:center;gap:12px;
  border:1px solid var(--border);border-radius:14px;padding:14px 16px;
  text-decoration:none;color:var(--text);background:var(--card);
  transition:transform .12s ease, border-color .2s ease;
}
.contact-card:hover{transform:translateY(-1px);border-color:rgba(0,0,0,.12)}
.contact-card .label{font-size:12px;color:var(--muted)}
.contact-card .value{font-weight:600}
.contact-card svg{width:20px;height:20px;opacity:.9}
.contact-card.primary{border-color:rgba(225,163,87,.35)}
.clients-row.resorts img{height:44px}
.clients-row.ministries img{height:38px}

/* Footer & misc */
footer{padding:5px 0;color:var(--muted);font-size:14px}
hr{border:0;border-top:1px solid var(--border);margin:16px 0}
.small{font-size:13px;color:var(--muted)}
.a{color:var(--accent)}

/* Quote page */
.quote-wrap{margin-top:8px}
.quote-intro{margin-bottom:16px}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:900px){.quote-grid{grid-template-columns:1fr}}
.panel{display:flex;flex-direction:column;gap:12px}
.panel h3{margin:0;font-size:clamp(18px,2.2vw,22px)}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
@media (max-width:640px){.checks{grid-template-columns:1fr}}
.check{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border:1px solid var(--border);
  background:var(--surface);border-radius:12px;cursor:pointer;user-select:none;
  transition:transform .12s ease, border-color .2s ease, box-shadow .2s ease;
}
.check:hover{transform:translateY(-1px);border-color:rgba(0,0,0,.12);box-shadow:0 6px 14px rgba(0,0,0,.06)}
.check input{accent-color:var(--accent)}
.field{display:grid;grid-template-columns:1fr;gap:6px}
.field label{font-size:13px;color:var(--muted)}
.field input,.field textarea{
  width:100%;background:var(--surface);border:1px solid var(--border);
  color:var(--text);border-radius:10px;padding:10px 12px;
}
textarea#notes{min-height:160px;resize:vertical}
.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:20px}
.hint{font-size:12px;color:var(--muted)}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border:1px solid var(--border);
  border-radius:999px;background:var(--card);font-size:12px;
}

.embla {
  margin: auto;
  --slide-height: 19rem;
  --slide-spacing: 1rem;
  --slide-size: 25%;
  mask-image:linear-gradient(to right, transparent, black 6%, black 94%, transparent);
}
@media (max-width: 1024px) {.embla {--slide-size: 33.33%;}}
@media (max-width: 768px) {.embla {--slide-size: 40%;}}
@media (max-width: 480px) {.embla {--slide-size: 40%;}}
.embla__viewport {
  overflow: hidden;
  cursor: pointer;
}
.embla__container {
  display: flex;
  touch-action: pan-y pinch-zoom;
  margin-left: calc(var(--slide-spacing) * -1);
}
.embla__slide {
  transform: translate3d(0, 0, 0);
  flex: 0 0 var(--slide-size);
  min-width: 0;
  padding-left: var(--slide-spacing);
}
.embla__slide img {
  height: 200px; width: auto; object-fit: contain; display: block; opacity: .98; background: transparent; border: 0; box-shadow: none;
}
@media (max-width: 900px){ .embla__slide img { height: 150px; } }
:root[data-theme="dark"] .embla__slide img { filter: brightness(0) invert(1); opacity: 1; }
.embla__slide__number {
  box-shadow: inset 0 0 0 0.2rem var(--detail-medium-contrast);
  border-radius: 1.8rem;
  font-size: 4rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--slide-height);
  user-select: none;
}
.embla__controls {
  display: grid;
  grid-template-columns: auto 1fr;
  justify-content: space-between;
  gap: 1.2rem;
  margin-top: 1.8rem;
}
.embla__buttons {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.6rem;
  align-items: center;
}
.embla__button {
  -webkit-tap-highlight-color: rgba(var(--text-high-contrast-rgb-value), 0.5);
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  touch-action: manipulation;
  display: inline-flex;
  text-decoration: none;
  cursor: pointer;
  border: 0;
  padding: 0;
  margin: 0;
  box-shadow: inset 0 0 0 0.2rem var(--detail-medium-contrast);
  width: 3.6rem;
  height: 3.6rem;
  z-index: 1;
  border-radius: 50%;
  color: var(--text-body);
  display: flex;
  align-items: center;
  justify-content: center;
}
.embla__button:disabled {
  color: var(--detail-high-contrast);
}
.embla__button__svg {
  width: 35%;
  height: 35%;
}
.embla__play {
  -webkit-tap-highlight-color: rgba(var(--text-high-contrast-rgb-value), 0.5);
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  touch-action: manipulation;
  display: inline-flex;
  text-decoration: none;
  cursor: pointer;
  border: 0;
  padding: 0;
  margin: 0;
  box-shadow: inset 0 0 0 0.2rem var(--detail-medium-contrast);
  border-radius: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self: flex-end;
  color: var(--text-body);
  font-weight: 700;
  font-size: 1.4rem;
  padding: 0 2.4rem;
  min-width: 8.4rem;
}
.embla__progress {
  border-radius: 1.8rem;
  box-shadow: inset 0 0 0 0.2rem var(--detail-medium-contrast);
  background-color: var(--background-site);
  position: relative;
  height: 0.6rem;
  justify-self: flex-end;
  align-self: center;
  width: 13rem;
  max-width: 90%;
  overflow: hidden;
}
.embla__progress__bar {
  background-color: var(--text-body);
  position: absolute;
  width: 100%;
  top: 0;
  bottom: 0;
  left: -100%;
}
.embla__controls {
  grid-template-columns: auto 1fr auto;
}
.embla__progress {
  justify-self: center;
  transition: opacity 0.3s ease-in-out;
  width: 8rem;
}
.embla__progress--hidden {
  opacity: 0;
}
.embla__progress__bar {
  animation-name: autoplay-progress;
  animation-timing-function: linear;
  animation-iteration-count: 1;
}
.embla__progress--hidden .embla__progress__bar {
  animation-play-state: paused;
}
@keyframes autoplay-progress {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(100%, 0, 0);
  }
}
