/* =========================================================
   CampVentures — design tokens
   ========================================================= */
:root{
  /* palette lifted from logo.jpg */
  --pine-950:#232f1c;
  --pine-800:#33431f;
  --pine-600:#556331;
  --pine-400:#89996a;
  --cream-50:#fbf7ea;
  --cream-100:#f4ecd6;
  --cream-200:#e8dcbb;
  --ocru-200:#f0d6a6;
  --ocru-300:#e6c184;
  --ocru-400:#d99a4e;
  --ocru-500:#c8863c;
  --ocru-600:#b0722c;
  --terracotta-500:#c1652f;
  --terracotta-600:#a34f21;
  --terracotta-700:#803d18;
  --ink:#20291a;

  --font-display:'Fraunces', serif;
  --font-body:'Plus Jakarta Sans', sans-serif;
  --font-mono:'JetBrains Mono', monospace;

  --radius-sharp:4px;
  --radius-balanced:14px;
  --radius-pill:999px;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-in:cubic-bezier(.55,0,.45,1);

  --shadow-soft:0 12px 32px rgba(35,47,28,.12);
  --shadow-lift:0 24px 48px rgba(35,47,28,.22);

  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream-50);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--font-display);color:var(--pine-950);line-height:1.08;margin:0 0 .5em}
p{line-height:1.65;margin:0 0 1em;color:var(--pine-800)}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}
@media(min-width:960px){ .container{padding:0 32px} }

.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--terracotta-600);
  margin:0 0 .8em;
}
.eyebrow.light{color:var(--ocru-300)}
.center{text-align:center}
.section-title{font-size:clamp(1.7rem,4vw,2.5rem);max-width:640px}
.section-title.center{margin-inline:auto}
.section-title.light{color:var(--cream-50)}
.section-lead{max-width:560px;margin:0 auto 2rem;color:var(--pine-600)}

section{padding:clamp(60px,10vw,110px) 0;position:relative}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.85em 1.6em;
  border-radius:var(--radius-pill);
  font-weight:600;font-size:.95rem;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease), color .3s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--terracotta-600);color:var(--cream-50);box-shadow:var(--shadow-soft)}
.btn--primary:hover{background:var(--terracotta-700);box-shadow:var(--shadow-lift)}
.btn--outline{background:transparent;color:var(--pine-800);border-color:var(--pine-600)}
.btn--outline:hover{background:var(--pine-800);color:var(--cream-50)}
.btn--ghost{background:rgba(251,247,234,.12);color:var(--cream-50);border-color:rgba(251,247,234,.55);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(251,247,234,.22)}
.btn--sm{padding:.75em 1.6em;font-size:.85rem}
.navmenu .btn--sm{padding:.85em 1.8em;text-shadow:none}
.btn--block{width:100%}

/* =========================================================
   Navbar
   ========================================================= */
.navbar{
  --nav-fg:var(--cream-50);
  --nav-fg-muted:rgba(251,247,234,.85);
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:14px 0;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
}
.navbar.scrolled{
  --nav-fg:var(--pine-950);
  --nav-fg-muted:var(--pine-800);
  background:rgba(251,247,234,.88);
  backdrop-filter:blur(14px);
  box-shadow:0 8px 24px rgba(35,47,28,.1);
  padding:10px 0;
}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:10px}
.navtoggle__bar{fill:var(--nav-fg);transition:fill .4s var(--ease)}
.brand__mark{flex-shrink:0;width:42px;height:42px;filter:drop-shadow(0 2px 6px rgba(35,47,28,.3));transition:transform .3s var(--ease)}
.brand:hover .brand__mark{transform:translateY(-1px)}
.brand:hover .brand__mark .svg-bg{transform:scale(1.05)}
.brand:hover .brand__mark .svg-core{transform:translateY(-1px)}
.brand:hover .brand__mark .svg-accent{transform:translateY(-2px) scale(1.06)}
.brand__word{
  font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--nav-fg);
  transition:color .4s var(--ease), text-shadow .4s var(--ease);
  text-shadow:0 1px 12px rgba(35,47,28,.35);
}
.navbar.scrolled .brand__word{text-shadow:none}
.navmenu{display:none;align-items:center;gap:28px}
.navmenu a{font-size:.92rem;font-weight:600;position:relative;padding:4px 0}
.navmenu a:not(.btn){
  color:var(--nav-fg-muted);
  transition:color .4s var(--ease), text-shadow .4s var(--ease);
  text-shadow:0 1px 10px rgba(35,47,28,.4);
}
.navbar.scrolled .navmenu a:not(.btn){text-shadow:none}
.navmenu a:not(.btn):after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--ocru-300);
  transition:width .3s var(--ease);
}
.navbar.scrolled .navmenu a:not(.btn):after{background:var(--terracotta-600)}
.navmenu a:not(.btn):hover{color:var(--nav-fg)}
.navmenu a:not(.btn):hover:after{width:100%}
.navtoggle{background:none;border:none;cursor:pointer;padding:6px}
@media(min-width:900px){
  .navmenu{display:flex}
  .navtoggle{display:none}
}
@media(max-width:899px){
  .navmenu{
    display:flex;
    position:fixed;inset:64px 16px auto 16px;
    background:var(--cream-50);border-radius:var(--radius-balanced);
    flex-direction:column;align-items:stretch;text-align:center;gap:4px;
    padding:14px;box-shadow:var(--shadow-lift);
    transform:translateY(-12px) scale(.98);opacity:0;pointer-events:none;
    transition:transform .32s var(--ease), opacity .32s var(--ease);
  }
  .navmenu.open{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
  .navmenu a{padding:12px 8px;border-radius:var(--radius-balanced)}
  .navmenu a:not(.btn){color:var(--pine-800);text-shadow:none}
  .navmenu a:not(.btn):hover{background:var(--cream-100);color:var(--pine-950)}
  .navmenu a:not(.btn):after{display:none}
  .navmenu .btn{margin-top:6px}
}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:flex-end;
  padding-top:120px;overflow:hidden;
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero__scrim{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(35,47,28,.15) 0%, rgba(35,47,28,.35) 55%, rgba(35,47,28,.88) 100%);
}
.hero__content{position:relative;z-index:1;padding-bottom:90px;max-width:760px}
.hero__title{color:var(--cream-50);font-size:clamp(2.1rem,6vw,3.6rem);font-weight:500}
.hero__subtitle{color:var(--cream-100);max-width:520px;font-size:1.05rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.6em}
.hero__scroll{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  z-index:1;animation:bob 2.6s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* word rotator */
.wr-wrap{display:inline-grid;vertical-align:bottom;overflow:hidden;padding-bottom:.06em}
.wr-word{
  grid-area:1/1;white-space:nowrap;pointer-events:none;
  color:var(--ocru-300);
  opacity:0;transform:translateY(110%);
  transition:opacity .62s var(--ease),transform .62s var(--ease);
}
.wr-word.active{opacity:1;transform:translateY(0);pointer-events:auto}
.wr-word.out{opacity:0;transform:translateY(-90%);transition:opacity .3s var(--ease-in),transform .3s var(--ease-in)}

/* =========================================================
   Reveal on scroll
   ========================================================= */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in-view{opacity:1;transform:translateY(0)}
.hero__content .reveal{transition-delay:.1s}
.hero__content .reveal:nth-child(2){transition-delay:.2s}
.hero__content .reveal:nth-child(3){transition-delay:.32s}

/* =========================================================
   Stamp frame (postage edge)
   ========================================================= */
.stamp-frame{
  position:relative;
  border-radius:var(--radius-sharp);
  overflow:visible;
}
.stamp-frame > img, .service-card__media, .story__media .stamp-frame img{
  display:block;border-radius:var(--radius-sharp);
}
.stamp-frame::before, .stamp-frame::after{
  content:"";position:absolute;left:6px;right:6px;height:14px;z-index:2;
  background-image:radial-gradient(circle at 10px 7px, var(--cream-50) 6px, transparent 6.6px);
  background-size:20px 14px;background-repeat:repeat-x;
}
.stamp-frame::before{top:-7px}
.stamp-frame::after{bottom:-7px;transform:rotate(180deg)}
.story__media .stamp-frame::before,
.story__media .stamp-frame::after,
.service-card.stamp-frame::before,
.service-card.stamp-frame::after,
.price-card::before,
.price-card::after{background-image:radial-gradient(circle at 10px 7px, var(--cream-50) 6px, transparent 6.6px)}
.testimonials .stamp-frame::before,
.testimonials .stamp-frame::after{background-image:radial-gradient(circle at 10px 7px, var(--pine-950) 6px, transparent 6.6px)}

/* =========================================================
   Story
   ========================================================= */
.story__grid{display:grid;gap:44px;align-items:center}
@media(min-width:900px){.story__grid{grid-template-columns:1fr 1fr;gap:64px}}
.story__media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.story__text h2{font-size:clamp(1.8rem,4vw,2.6rem)}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:2em}
.stat{display:flex;flex-wrap:wrap;align-items:baseline;gap:2px}
.stat__num{font-family:var(--font-display);font-size:2.1rem;font-weight:600;color:var(--terracotta-600)}
.stat__suffix{font-family:var(--font-display);font-size:2.1rem;font-weight:600;color:var(--terracotta-600)}
.stat__label{flex-basis:100%;font-size:.82rem;color:var(--pine-600)}

/* =========================================================
   Services
   ========================================================= */
.services{background:var(--cream-100)}
.services__grid{display:grid;gap:56px;margin-top:52px}
@media(min-width:860px){.services__grid{grid-template-columns:1fr 1fr;gap:40px}}
.service-card{
  background:var(--cream-50);
  box-shadow:var(--shadow-soft);
  transition:transform .12s linear, box-shadow .3s var(--ease);
  transform-style:preserve-3d;
  will-change:transform;
}
.service-card__media{height:220px;overflow:hidden}
.service-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.service-card:hover .service-card__media img{transform:scale(1.06)}
.service-card__body{padding:32px 28px 30px}
.service-card__icon{width:56px;height:56px;margin-bottom:14px}
.service-card__list{margin:16px 0 22px;display:flex;flex-direction:column;gap:8px}
.service-card__list li{padding-left:22px;position:relative;font-size:.92rem;color:var(--pine-800)}
.service-card__list li::before{content:"";position:absolute;left:0;top:8px;width:10px;height:10px;border-radius:2px;background:var(--ocru-400);transform:rotate(45deg)}

/* =========================================================
   Amenities
   ========================================================= */
.amenities__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:52px;
}
@media(min-width:700px){.amenities__grid{grid-template-columns:repeat(3,1fr)}}
.amenity{text-align:center;padding:26px 14px}
.amenity h3{font-size:1.05rem;margin-bottom:.35em}
.amenity p{font-size:.88rem}
.amenity__icon{width:64px;height:64px;margin-bottom:16px}
.amenity__icon, .brand__mark{animation:idle-pulse 1.5s var(--ease) infinite;animation-play-state:paused}
@keyframes idle-pulse{
  0%,100%{transform:scale(1) translateY(0)}
  50%{transform:scale(1.06) translateY(-3px)}
}
/* idle pulse fires via JS-triggered class to control 10-15s spacing precisely */
.amenity__icon.pulse, .brand__mark.pulse{animation-play-state:running}

/* =========================================================
   Gallery
   ========================================================= */
.gallery__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:48px;
}
@media(min-width:700px){.gallery__grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.gallery__grid{grid-template-columns:repeat(4,1fr)}}
.gallery__item{
  position:relative;border:none;padding:0;border-radius:var(--radius-balanced);
  overflow:hidden;cursor:zoom-in;aspect-ratio:4/5;background:none;
}
.gallery__item:nth-child(3){aspect-ratio:1/1}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery__caption{
  position:absolute;left:0;right:0;bottom:0;padding:14px;
  background:linear-gradient(0deg, rgba(35,47,28,.85), transparent);
  color:var(--cream-50);font-size:.82rem;font-weight:600;text-align:left;
  opacity:0;transform:translateY(8px);
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.gallery__item:hover img{transform:scale(1.08)}
.gallery__item:hover .gallery__caption{opacity:1;transform:translateY(0)}

/* =========================================================
   Location
   ========================================================= */
.location__grid{display:grid;gap:40px;align-items:center}
@media(min-width:900px){.location__grid{grid-template-columns:1fr 1fr;gap:64px}}
.location__map{border-radius:var(--radius-balanced);overflow:hidden}

/* =========================================================
   Pricing
   ========================================================= */
.pricing__grid{display:grid;gap:44px;margin-top:52px;max-width:840px;margin-inline:auto}
@media(min-width:700px){.pricing__grid{grid-template-columns:1fr 1fr}}
.price-card{
  background:var(--cream-50);padding:36px 30px;text-align:center;
  box-shadow:var(--shadow-soft);position:relative;
}
.price-card.featured{background:var(--pine-950);color:var(--cream-50)}
.price-card.featured h3{color:var(--cream-50)}
.price-card.featured p, .price-card.featured li{color:var(--cream-100)}
.price-card__badge{
  position:absolute;top:-20px;left:50%;transform:translateX(-50%);
  background:var(--terracotta-600);color:var(--cream-50);
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 16px;border-radius:var(--radius-pill);white-space:nowrap;
  z-index:3;box-shadow:0 4px 12px rgba(35,47,28,.25);
}
.price-card__value{font-family:var(--font-display);font-size:1.5rem;margin:.6em 0}
.price-card__value strong{color:var(--terracotta-600);font-size:1.3em}
.price-card.featured .price-card__value strong{color:var(--ocru-300)}
.price-card__value span{font-size:.7em;font-family:var(--font-body);color:var(--pine-600)}
.price-card ul{margin:18px 0 26px;display:flex;flex-direction:column;gap:8px;font-size:.9rem}
.pricing__note{text-align:center;font-size:.8rem;color:var(--pine-600);margin-top:28px}

/* =========================================================
   Testimonials
   ========================================================= */
.testimonials{position:relative;overflow:hidden;color:var(--cream-50)}
.testimonials__media{position:absolute;inset:0;z-index:0}
.testimonials__media img{width:100%;height:100%;object-fit:cover;filter:blur(2px) saturate(0.9)}
.testimonials__scrim{position:absolute;inset:0;background:linear-gradient(180deg, rgba(35,47,28,.82), rgba(35,47,28,.9))}
.testimonials .container{position:relative;z-index:1}
.testimonials__grid{display:grid;gap:24px;margin-top:48px}
@media(min-width:820px){.testimonials__grid{grid-template-columns:repeat(3,1fr)}}
.glass{
  background:rgba(251,247,234,.1);
  border:1px solid rgba(251,247,234,.22);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-radius:var(--radius-balanced);
  padding:30px 26px;
}
.testimonial__stars{color:var(--ocru-300);letter-spacing:.15em;margin-bottom:14px;font-size:.9rem}
.testimonial blockquote{margin:0 0 16px;font-family:var(--font-display);font-size:1.05rem;font-style:italic;color:var(--cream-50);line-height:1.5}
.testimonial figcaption{font-family:var(--font-mono);font-size:.78rem;color:var(--ocru-200)}

/* =========================================================
   FAQ
   ========================================================= */
.faq__list{max-width:720px;margin:48px auto 0;display:flex;flex-direction:column;gap:12px}
.faq__item{background:var(--cream-100);border-radius:var(--radius-balanced);overflow:hidden}
.faq__question{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:20px 22px;background:none;border:none;text-align:left;cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:.98rem;color:var(--pine-950);
}
.faq__chevron{transition:transform .3s var(--ease);flex-shrink:0}
.faq__item.open .faq__chevron{transform:rotate(180deg)}
.faq__answer{max-height:0;overflow:hidden;transition:max-height .35s var(--ease);padding:0 22px}
.faq__answer p{padding-bottom:20px;margin:0;color:var(--pine-600)}

/* =========================================================
   Contact
   ========================================================= */
.contact{position:relative;overflow:hidden;color:var(--cream-50)}
.contact__media{position:absolute;inset:0;z-index:0}
.contact__media img{width:100%;height:100%;object-fit:cover}
.contact__scrim{position:absolute;inset:0;background:linear-gradient(120deg, rgba(35,47,28,.94) 35%, rgba(35,47,28,.55))}
.contact .container{position:relative;z-index:1}
.contact__grid{display:grid;gap:44px}
@media(min-width:920px){.contact__grid{grid-template-columns:1fr 1fr;align-items:start}}
.contact__intro h2{font-size:clamp(1.7rem,3.6vw,2.3rem)}
.light{color:var(--cream-50)}
.light-muted{color:var(--cream-200)}
.contact__chips{display:flex;flex-direction:column;gap:12px;margin-top:26px}
.contact-chip{
  display:flex;align-items:center;gap:10px;font-size:.92rem;font-weight:600;
  padding:10px 4px;transition:opacity .25s;
}
.contact-chip:hover{opacity:.75}
.contact__form{
  background:var(--cream-50);border-radius:var(--radius-balanced);
  padding:32px 28px;box-shadow:var(--shadow-lift);
  display:flex;flex-direction:column;gap:16px;position:relative;
}
.contact__form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:var(--pine-800)}
.form-row{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:480px){.form-row{grid-template-columns:1fr 1fr}}
.contact__form input, .contact__form select, .contact__form textarea{
  font-family:var(--font-body);font-size:.95rem;padding:11px 14px;
  border:1.5px solid var(--cream-200);border-radius:var(--radius-balanced);
  background:var(--cream-100);color:var(--ink);
  transition:border-color .25s;resize:vertical;
}
.contact__form input:focus, .contact__form select:focus, .contact__form textarea:focus{
  outline:none;border-color:var(--terracotta-500);
}
.form-success{
  display:none;text-align:center;font-weight:600;color:var(--pine-800);
  background:var(--ocru-200);padding:12px;border-radius:var(--radius-balanced);margin:0;
}
.contact__form.submitted .form-success{display:block}
.contact__form.submitted input, .contact__form.submitted select, .contact__form.submitted textarea, .contact__form.submitted button{display:none}

/* =========================================================
   Footer
   ========================================================= */
.footer{background:var(--pine-950);color:var(--cream-100);padding:70px 0 0}
.footer__grid{display:grid;gap:40px;padding-bottom:50px}
@media(min-width:820px){.footer__grid{grid-template-columns:1.2fr 1fr}}
.footer__brand p{color:var(--cream-200);max-width:340px;margin-top:14px}
.footer .brand__word{color:var(--cream-50)}
.footer__social{display:flex;gap:12px;margin-top:18px}
.social-icon{
  width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(251,247,234,.08);transition:background .25s, transform .25s;
}
.social-icon:hover{background:rgba(251,247,234,.16);transform:translateY(-2px)}
.footer__nav{display:flex;flex-wrap:wrap;gap:16px 26px;align-content:flex-start;font-size:.9rem}
.footer__nav a{color:var(--cream-200);transition:color .25s}
.footer__nav a:hover{color:var(--cream-50)}
.footer__bottom{border-top:1px solid rgba(251,247,234,.12);padding:22px 0;font-size:.78rem;color:var(--cream-200);opacity:.75}

/* =========================================================
   Lightbox
   ========================================================= */
.lb-overlay{
  position:fixed;inset:0;z-index:9000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(20,26,15,.92);backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
}
.lb-overlay.open{opacity:1;pointer-events:auto}
.lb-inner{max-width:92vw;max-height:90vh;display:flex;align-items:center;justify-content:center}
.lb-img{
  max-width:92vw;max-height:90vh;
  object-fit:contain;border-radius:8px;
  transform:scale(.94);
  transition:transform .35s var(--ease);
  box-shadow:0 32px 80px rgba(0,0,0,.6);
}
.lb-overlay.open .lb-img{transform:scale(1)}
.lb-close{
  position:absolute;top:20px;right:20px;
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.1);backdrop-filter:blur(6px);
  color:#fff;display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;
}
.lb-close:hover{background:rgba(255,255,255,.2);transform:scale(1.08)}
.lb-close svg{width:20px;height:20px}

/* =========================================================
   Rich SVG hover / idle behaviour (shared)
   ========================================================= */
svg g{transition:transform .4s var(--ease), opacity .4s var(--ease)}
.service-card:hover .svg-bg, .amenity:hover .svg-bg{transform:scale(1.05)}
.service-card:hover .svg-core, .amenity:hover .svg-core{transform:translateY(-2px)}
.service-card:hover .svg-accent, .amenity:hover .svg-accent{transform:translateY(-4px) scale(1.1)}

@media(prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important; transition-duration:.001ms !important}
  html{scroll-behavior:auto}
}
