
:root {
  --bg-dark: #a2d4ff;
  --bg-page: #f4f0e8;
  --text-light: #105a99;
  --text-dark: #1b1a17;
  --muted: rgba(255,255,255,.78);
  --muted-dark: #615c51;
  --line: rgba(255,255,255,.12);
  --card: #f7f3ec;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--bg-page);color:var(--text-dark)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100vw - 32px));margin:0 auto}
.site-header{position:fixed;top:0;left:0;right:0;z-index:10;background:linear-gradient(to bottom,rgba(0,0,0,.45),rgba(0,0,0,0));padding:20px 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand,.main-nav a,.site-header .btn{color:#fff}
.brand{font-weight:700;letter-spacing:.02em}
.brand img{max-width: 200px; height: auto;}
.main-nav{display:flex;gap:26px;font-size:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:999px;font-weight:600;border:1px solid rgba(255,255,255,.22);transition:transform .25s ease,background .25s ease}
.btn:hover{transform:translateY(-1px)}
.btn-light{background:rgba(255,255,255,.08);backdrop-filter:blur(10px)}
.btn-primary{background:#fff;color:#111;border-color:#fff}
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:#111}
.hero-media,.hero-media img,.hero-overlay{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-overlay{background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.56) 55%,rgba(0,0,0,.76))}
.hero-content{position:relative;z-index:1;color:#fff;padding:160px 0 48px}
.eyebrow{margin:0 0 18px;text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:600;color:rgba(255,255,255,.8)}
.dark-text{color:#6e654c}
.hero h1,.section-heading h2,.feature-copy h2,.contact-copy h2{font-family:"Libre Baskerville",Georgia,serif;font-weight:400;line-height:1.04;margin:0}
.hero h1{font-size:clamp(44px,7vw,88px);max-width:10ch}
.hero-bottom{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:end;margin-top:28px;max-width:900px}
.hero-bottom p{margin:0;color:rgba(255,255,255,.84);max-width:540px;font-size:15px;line-height:1.65}
.feature-section{background:var(--bg-dark);color:var(--text-light);padding:96px 0;border-top:1px solid var(--line)}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.feature-grid.reverse .feature-copy{order:2}
.feature-grid.reverse .feature-media{order:1}
.feature-copy h2{font-size:clamp(32px,4vw,52px);margin-bottom:18px;max-width:12ch}
.feature-copy p{color:var(--muted);font-size:17px;max-width:54ch}
.feature-copy ul{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:14px}
.feature-copy li{position:relative;padding-left:28px;color:#fff}
.feature-copy li::before{content:"✓";position:absolute;left:0;top:0;color:#d7c37a}
.card-frame{border-radius:22px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 60px rgba(0,0,0,.25)}
.card-frame img{width:100%;aspect-ratio:4/3;object-fit:cover}
.services,.testimonials,.contact{padding:96px 0}
.section-heading{margin-bottom:30px}
.section-heading h2{font-size:clamp(32px,4vw,54px);max-width:12ch}
.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.service-card{background:var(--card);border-radius:22px;overflow:hidden;box-shadow:0 10px 28px rgba(0,0,0,.06)}
.service-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.service-card__body{padding:18px}
.service-card__body h3{margin:0 0 10px;font-size:20px}
.service-card__body p{margin:0;color:var(--muted-dark);line-height:1.6}
.testimonials{background:#efe9dd}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.testimonial{background:#fff;border-radius:22px;padding:28px;min-height:240px;box-shadow:0 10px 30px rgba(0,0,0,.06);display:flex;flex-direction:column;justify-content:space-between}
.testimonial p{margin:0 0 18px;line-height:1.8;color:#2c2924}
.testimonial strong{display:block;font-size:16px}
.testimonial span,.contact-highlight a{color:#6b6459}
.contact-highlight{background:var(--bg-dark);color:#fff}
.contact-highlight a{display:block;color:#fff;margin-top:10px}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:32px;align-items:start}
.contact-copy h2{font-size:clamp(30px,4vw,50px);margin-bottom:14px;max-width:12ch}
.contact-copy p{color:#4f493f;line-height:1.8}
.contact-details{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:14px}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:16px;background:#fff;padding:24px;border-radius:24px;box-shadow:0 14px 40px rgba(0,0,0,.08)}
.contact-form label{display:grid;gap:8px;font-size:14px;font-weight:500}
.contact-form .full-width{grid-column:1/-1}
.contact-form input,.contact-form textarea{width:100%;padding:14px 16px;border:1px solid #ddd4c7;border-radius:16px;font:inherit;background:#fcfbf8}
.contact-form button{justify-self:start}
.site-footer{background:var(--bg-dark);color:#fff;padding:34px 0;border-top:1px solid var(--line)}
.footer-inner{display:flex;justify-content:space-between;gap:24px;align-items:flex-start}
.footer-inner p{margin:.5rem 0 0;color:var(--muted);max-width:620px;line-height:1.7}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s ease,transform .8s ease}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
@media (max-width: 980px){
  .feature-grid,.contact-grid,.testimonials-grid{grid-template-columns:1fr}
  .feature-grid.reverse .feature-copy,.feature-grid.reverse .feature-media{order:initial}
  .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-bottom{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .main-nav{display:none}
  .site-header .btn{display:none}
  .hero-content{padding-top:120px}
  .card-grid{grid-template-columns:1fr}
  .contact-form{grid-template-columns:1fr}
  .footer-inner{flex-direction:column}
}





.virtual-tour-promo{
  background:#111;
  color:#fff;
  padding:96px 0;
}

.tour-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:36px;
  align-items:center;
}

.tour-copy h2{
  font-family:"Libre Baskerville",Georgia,serif;
  font-weight:400;
  font-size:clamp(34px,4vw,58px);
  line-height:1.05;
  margin:0 0 18px;
  max-width:12ch;
}

.tour-copy p{
  color:rgba(255,255,255,.78);
  line-height:1.75;
  max-width:54ch;
  margin:0 0 24px;
}

.tour-preview{
  position:relative;
  display:block;
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 28px 70px rgba(0,0,0,.35);
}

.tour-preview img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  transition:transform .45s ease;
}

.tour-preview:hover img{
  transform:scale(1.04);
}

.tour-play{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:92px;
  height:92px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.92);
  color:#111;
  font-weight:800;
  box-shadow:0 18px 45px rgba(0,0,0,.35);
}

.pricing{
  background:#efe9dd;
  padding:96px 0;
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}

.price-card{
  background:#fff;
  border-radius:20px;
  padding:22px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  gap:14px;
  min-height:130px;
}

.price-card span{
  color:#4f493f;
  line-height:1.4;
}

.price-card strong{
  font-size:24px;
  color:#111;
}

.pricing-note{
  margin-top:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  background:#fff;
  border-radius:22px;
  padding:22px;
  box-shadow:0 10px 28px rgba(0,0,0,.05);
}

.pricing-note p{
  margin:0;
  color:#615c51;
  line-height:1.6;
}

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

  .pricing-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

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

  .pricing-note{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* =========================================================
   ARTSEASONS 360 APP SHOWCASE - COMPACT WEBSITE SECTION
========================================================= */

.app-showcase{
  background:linear-gradient(135deg,#06111d 0%,#0b1723 55%,#071018 100%);
  color:#fff;
  padding:76px 0;
  overflow:hidden;
}

.app-showcase-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:42px;
  align-items:center;
}

.app-logo{
  width:150px;
  margin-bottom:18px;
}

.app-eyebrow{
  color:#d7aa57;
  letter-spacing:.16em;
  font-size:12px;
  margin:0 0 10px;
}

.app-showcase-copy h2{
  margin:0 0 12px;
  font-family:"Libre Baskerville",Georgia,serif;
  font-weight:400;
  font-size:clamp(34px,4vw,52px);
  line-height:1.05;
}

.app-showcase-copy h2 span{
  color:#d7aa57;
}

.app-intro{
  font-size:clamp(20px,2.2vw,28px);
  line-height:1.35;
  max-width:520px;
  margin:0 0 14px;
}

.app-description{
  color:rgba(255,255,255,.72);
  line-height:1.75;
  max-width:620px;
  margin:0 0 22px;
  font-size:15px;
}

.app-features{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:24px;
}

.app-features article{
  display:flex;
  gap:12px;
  padding:14px;
  border-radius:16px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.07);
}

.feature-icon{
  width:36px;
  height:36px;
  border-radius:10px;
  background:rgba(215,170,87,.12);
  color:#d7aa57;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  flex:0 0 36px;
}

.app-features strong{
  display:block;
  font-size:14px;
  margin-bottom:4px;
}

.app-features span{
  color:rgba(255,255,255,.66);
  font-size:13px;
  line-height:1.45;
}

.app-cta{
  display:inline-flex;
  align-items:center;
  gap:12px;
  min-height:46px;
  padding:0 22px;
  border-radius:999px;
  background:#d7aa57;
  color:#111;
  font-weight:800;
}

.app-download-buttons{
  display:flex;
  gap:12px;
  align-items:center;
  margin-top:16px;
}

  .store-btn img{
    height:120px;
    width:auto;
  }

.app-secure{
  margin-top:16px;
  color:rgba(255,255,255,.56);
  font-size:13px;
}

.app-showcase-media{
  min-width:0;
}

.phones-wrap{
  position:relative;
  height:430px;
  overflow:visible;
}

.phone{
  position:absolute;
  width:170px;
  max-width:none;
  border-radius:28px;
  filter:drop-shadow(0 24px 38px rgba(0,0,0,.48));
}

.phone-1{left:0%; top:70px; z-index:1;}
.phone-2{left:17%; top:36px; z-index:4;}
.phone-3{left:36%; top:68px; z-index:3;}
.phone-4{left:55%; top:42px; z-index:2;}
.phone-5{left:74%; top:78px; z-index:1;}

@media (max-width:980px){
  .app-showcase-grid{
    grid-template-columns:1fr;
  }

  .phones-wrap{
    height:390px;
  }

  .phone{
    width:158px;
  }

  .phone-1{left:0%;}
  .phone-2{left:18%;}
  .phone-3{left:37%;}
  .phone-4{left:56%;}
  .phone-5{left:75%;}
}

@media (max-width:720px){
  .app-showcase{
    padding:58px 0;
  }

  .app-logo{
    width:118px;
  }

  .app-features{
    grid-template-columns:1fr;
  }

  .phones-wrap{
    height:auto;
    display:flex;
    gap:14px;
    overflow-x:auto;
    padding:8px 0 14px;
    scroll-snap-type:x mandatory;
  }

  .phone{
    position:relative;
    left:auto !important;
    top:auto !important;
    width:168px;
    flex:0 0 168px;
    scroll-snap-align:start;
  }

  .app-download-buttons{
    flex-wrap:wrap;
  }

  .store-btn img{
    height:120px;
    width:auto;
  }
}






/* =========================================================
   ARTSEASONS - Email SECTION
========================================================= */


.contact-form input,
.contact-form textarea{
  width:100%;
  background:#ffffff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:16px;
  padding:16px 18px;
  color:#111111 !important;
  font-size:15px;
  outline:none;
  transition:.25s;
  margin-bottom:16px;
}

.contact-form textarea{
  min-height:180px;
  resize:vertical;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color:rgba(0,0,0,.42);
}

.contact-form input:focus,
.contact-form textarea:focus{
  border-color:#d7aa57;
  box-shadow:0 0 0 4px rgba(215,170,87,.12);
}
#form-status{
  margin-top:16px;
  font-size:14px;
  font-weight:600;
}
.contact-form button{
  height:52px;
  border:none;
  border-radius:999px;
  background:#d7aa57;
  color:#111;
  font-weight:700;
  padding:0 28px;
  cursor:pointer;
  transition:.25s;
}

.contact-form button:hover{
  transform:translateY(-2px);
}