/* ============================================================
   Vast Vision Photography — Static Preview Stylesheet
   Shared across all preview pages (index, about, services,
   portfolio, pricing, contact). This is a quick-look preview,
   not the production codebase (that's the Next.js project).
   ============================================================ */

:root{
  --charcoal-950:#07090c;
  --charcoal-900:#0c0f13;
  --charcoal-800:#11151a;
  --charcoal-700:#1a1f26;
  --ivory:#f7f6f3;
  --ink-500:#2f6aa3;
  --glow-300:#9ecdff;
  --glow-400:#479af3;
  --glow-500:#3e8fe0;
  --glow-900:#16355a;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--charcoal-950);
  color:var(--ivory);
  font-family:'Inter',Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
.preview-banner{
  background:var(--glow-500);
  color:var(--charcoal-950);
  text-align:center;
  font-family:'IBM Plex Mono',monospace;
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:10px;
}
.wrap{max-width:1280px;margin:0 auto;padding:0 24px;}
h1,h2,h3{font-family:'Sora',sans-serif;font-weight:600;margin:0;}
h1,h2{text-transform:uppercase;letter-spacing:0.03em;font-weight:500;}
.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--glow-300);
}
.horizon{
  height:1px;width:100%;
  background:linear-gradient(90deg,transparent,var(--ink-500) 20%,var(--glow-500) 50%,var(--glow-300) 65%,transparent);
}

/* NAV */
nav{
  position:sticky;top:0;z-index:50;
  background:rgba(7,9,12,0.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
nav .wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ivory);}
.logo-mark{width:34px;height:34px;border-radius:8px;background:var(--charcoal-900);border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.logo-img-nav{height:175px;width:auto;display:block;}
.logo-img-footer{height:220px;width:auto;display:block;margin-bottom:10px;}
.logo-text{font-family:'Sora',sans-serif;font-weight:600;font-size:15px;display:block;}
.logo-tag{font-family:'IBM Plex Mono',monospace;font-size:10px;color:rgba(247,246,243,0.4);text-transform:uppercase;letter-spacing:0.08em;}
.nav-links{display:flex;gap:32px;list-style:none;margin:0;padding:0;}
.nav-links a{color:rgba(247,246,243,0.8);text-decoration:none;font-size:14px;font-weight:500;}
.nav-links a:hover, .nav-links a.active{color:var(--glow-300);}
.nav-right{display:flex;align-items:center;gap:18px;}
.nav-toggle{display:none;background:none;border:1px solid rgba(255,255,255,0.15);color:var(--ivory);border-radius:8px;width:42px;height:42px;font-size:18px;cursor:pointer;}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  border-radius:999px;font-weight:500;font-size:14px;
  padding:13px 26px;text-decoration:none;cursor:pointer;
  transition:all .3s cubic-bezier(.16,1,.3,1);border:none;
}
.btn-primary{background:var(--glow-500);color:var(--charcoal-950);}
.btn-primary:hover{background:var(--glow-400);box-shadow:0 0 40px -8px rgba(62,143,224,.5);transform:translateY(-2px);}
.btn-secondary{border:1px solid rgba(247,246,243,0.25);color:var(--ivory);background:transparent;}
.btn-secondary:hover{border-color:var(--glow-400);color:var(--glow-300);transform:translateY(-2px);}

@media(max-width:860px){
  .nav-links{
    position:fixed;inset:0;top:70px;
    background:rgba(7,9,12,0.98);
    flex-direction:column;padding:30px 24px;gap:8px;
    display:none;
  }
  .nav-links.open{display:flex;}
  .nav-links a{font-size:22px;font-family:'Sora',sans-serif;padding:10px 0;}
  .nav-toggle{display:block;}
  .nav-right .btn-primary{display:none;}
}

/* PAGE HEADER (sub-pages) */
.page-header{padding:150px 0 60px;position:relative;overflow:hidden;}
.page-header::before{
  content:"";position:absolute;top:-150px;right:-100px;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle, rgba(62,143,224,0.18), transparent 70%);
}
.page-header h1{font-size:clamp(2rem,4vw,3rem);margin-top:10px;max-width:700px;position:relative;}
.page-header p{margin-top:16px;color:rgba(247,246,243,0.65);max-width:600px;position:relative;}

/* HERO (home only) */
.hero{
  position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:flex-end;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(62,143,224,0.18), transparent 55%),
    linear-gradient(180deg, var(--charcoal-950) 0%, #0e2236 55%, var(--charcoal-950) 100%);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background-image:repeating-linear-gradient(100deg, rgba(255,255,255,0.025) 0px, rgba(255,255,255,0.025) 1px, transparent 1px, transparent 80px);
  opacity:.4;
}
.hero-video-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;z-index:0;
}
.hero-video-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(7,9,12,0.25) 0%, rgba(7,9,12,0.35) 45%, rgba(7,9,12,0.9) 100%),
    linear-gradient(90deg, rgba(7,9,12,0.55) 0%, rgba(7,9,12,0.1) 45%, rgba(7,9,12,0.55) 100%);
}
.hero-inner{position:relative;z-index:2;padding:160px 24px 90px;width:100%;}
.hero h1{font-size:clamp(2.4rem,5vw,4.4rem);line-height:1.05;max-width:780px;}
.glow-text{background:linear-gradient(90deg,var(--glow-300),var(--glow-500));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero p{max-width:560px;color:rgba(247,246,243,0.72);font-size:1.05rem;line-height:1.6;margin-top:20px;}
.hero .eyebrow{display:block;margin-bottom:18px;}
.hero-ctas{display:flex;gap:16px;margin-top:36px;flex-wrap:wrap;}

section{padding:96px 0;}
.section-head{max-width:640px;margin-bottom:48px;}
.section-head h2{font-size:clamp(1.7rem,3vw,2.5rem);margin-top:10px;line-height:1.15;}
.section-head p{color:rgba(247,246,243,0.65);margin-top:14px;line-height:1.6;}
.section-alt{background:var(--charcoal-900);}
.center{text-align:center;margin-left:auto;margin-right:auto;}

/* GRID / CARDS */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.card{
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;padding:30px;transition:all .35s cubic-bezier(.16,1,.3,1);
}
.card:hover{transform:translateY(-5px);border-color:rgba(62,143,224,0.4);background:rgba(255,255,255,0.05);}
.icon-box{
  width:46px;height:46px;border-radius:12px;background:var(--charcoal-700);
  display:flex;align-items:center;justify-content:center;color:var(--glow-400);
  margin-bottom:20px;font-size:20px;
}
.card:hover .icon-box{background:var(--glow-500);color:var(--charcoal-950);}
.card h3{font-size:1.15rem;margin-bottom:10px;}
.card p{color:rgba(247,246,243,0.6);font-size:0.9rem;line-height:1.55;margin:0;}
.card ul{list-style:none;padding:0;margin:14px 0 0;border-top:1px solid rgba(255,255,255,0.07);padding-top:14px;}
.card li{font-size:0.85rem;color:rgba(247,246,243,0.6);padding:4px 0;display:flex;gap:8px;}
.card li::before{content:"✓";color:var(--glow-400);}

/* STATS / VALUES */
.stat-row{display:flex;gap:34px;margin-top:34px;flex-wrap:wrap;}
.stat strong{display:block;font-family:'Sora',sans-serif;font-size:1.6rem;color:var(--glow-300);}
.stat span{font-size:0.78rem;color:rgba(247,246,243,0.55);}
.badge-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px;}
.badge-pill{
  border:1px solid rgba(255,255,255,0.12);border-radius:999px;padding:9px 18px;
  font-size:0.82rem;color:rgba(247,246,243,0.8);display:inline-flex;align-items:center;gap:8px;
}
.badge-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--glow-400);}

/* PORTFOLIO */
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px;}
.tab-btn{
  border:1px solid rgba(255,255,255,0.1);background:transparent;color:rgba(247,246,243,0.7);
  border-radius:999px;padding:10px 20px;font-size:0.85rem;cursor:pointer;font-family:'Inter',sans-serif;
}
.tab-btn.active{background:var(--glow-500);color:var(--charcoal-950);border-color:transparent;}

.lightbox{
  position:fixed;inset:0;z-index:999;background:rgba(7,9,12,0.96);
  display:none;align-items:center;justify-content:center;
}
.lightbox.open{display:flex;}
.lightbox img{
  max-width:88vw;max-height:86vh;border-radius:10px;
  box-shadow:0 20px 60px rgba(0,0,0,0.6);
}
.lightbox-close{
  position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:var(--ivory);
  font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.lightbox-close:hover{background:rgba(255,255,255,0.16);}
.lightbox-arrow{
  position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:var(--ivory);
  font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.lightbox-arrow:hover{background:rgba(255,255,255,0.16);}
.lightbox-prev{left:20px;}
.lightbox-next{right:20px;}
@media(max-width:700px){
  .lightbox-arrow{width:44px;height:44px;font-size:22px;}
  .lightbox-prev{left:8px;}
  .lightbox-next{right:8px;}
}
.masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.square-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.square-grid .tile{aspect-ratio:1/1;}
@media(max-width:900px){
  .square-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:600px){
  .square-grid{grid-template-columns:repeat(2,1fr);}
  .hero-inner{padding:130px 20px 70px;}
  .hero p{max-width:100%;}
}
.tile{
  position:relative;border-radius:14px;overflow:hidden;
  background-color:var(--charcoal-800);
  background-size:cover;background-position:center;
  border:1px solid rgba(255,255,255,0.06);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  aspect-ratio:4/3;cursor:pointer;
}
.tile.tall{aspect-ratio:3/4;}
.tile:hover{border-color:rgba(62,143,224,0.4);}
.tile .tag{position:absolute;bottom:14px;left:14px;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--glow-300);opacity:0;transition:opacity .3s;}
.tile:hover .tag{opacity:1;}
.tile-icon{width:50px;height:50px;border:2px solid var(--glow-300);border-radius:10px;opacity:.5;}
.tile.hidden{display:none;}

/* PRICING */
.grid-pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.price-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:32px;position:relative;}
.price-card.featured{border-color:rgba(62,143,224,0.5);box-shadow:0 0 40px -10px rgba(62,143,224,0.4);}
.badge{position:absolute;top:-12px;left:28px;background:var(--glow-500);color:var(--charcoal-950);font-size:11px;font-weight:600;padding:4px 12px;border-radius:999px;}
.price-card h3{font-size:1.2rem;}
.price-card .blurb{color:rgba(247,246,243,0.55);font-size:0.85rem;margin-top:6px;}
.price-amount{font-family:'Sora',sans-serif;font-size:2.2rem;font-weight:600;margin-top:20px;}
.price-amount span{font-size:0.85rem;color:rgba(247,246,243,0.4);font-weight:400;margin-left:4px;}
.price-card ul{list-style:none;padding:0;margin:24px 0;}
.price-card li{font-size:0.85rem;color:rgba(247,246,243,0.65);padding:6px 0;display:flex;gap:8px;}
.price-card li::before{content:"✓";color:var(--glow-400);}
.addon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.compare{
  position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;
  border:1px solid rgba(255,255,255,0.08);background:var(--charcoal-800);
  touch-action:pan-y;
}
.compare-after,.compare-before{
  position:absolute;inset:0;background-size:cover;background-position:center;
}
.compare-before{clip-path:inset(0 50% 0 0);}
.compare-handle{
  position:absolute;top:0;bottom:0;left:50%;width:0;pointer-events:none;
}
.compare-handle::before{
  content:"";position:absolute;top:0;bottom:0;left:0;width:2px;
  background:var(--ivory);transform:translateX(-1px);
}
.compare-handle span{
  position:absolute;top:50%;left:0;transform:translate(-50%,-50%);
  width:42px;height:42px;border-radius:50%;background:var(--ivory);
  color:var(--charcoal-950);display:flex;align-items:center;justify-content:center;
  font-size:16px;box-shadow:0 4px 14px rgba(0,0,0,0.4);
}
.compare-range{
  position:absolute;inset:0;width:100%;height:100%;opacity:0;margin:0;cursor:ew-resize;
}
.compare-tag{
  position:absolute;top:12px;font-family:'IBM Plex Mono',monospace;font-size:10px;
  letter-spacing:0.08em;text-transform:uppercase;color:var(--glow-300);
  background:rgba(7,9,12,0.6);padding:4px 9px;border-radius:5px;pointer-events:none;
}
.compare-tag-before{left:12px;}
.compare-tag-after{right:12px;}
.play-btn{
  width:64px;height:64px;border-radius:50%;background:rgba(247,246,243,0.95);
  color:var(--charcoal-950);display:flex;align-items:center;justify-content:center;
  font-size:22px;box-shadow:0 8px 24px rgba(0,0,0,0.4);
}
@media(max-width:700px){
  .ba-grid{grid-template-columns:1fr;}
}
.addon{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:18px;}
.addon p{margin:0;font-size:0.85rem;}
.addon .amt{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:600;color:var(--glow-300);margin-top:8px;}
.addon .amt span{font-size:0.7rem;color:rgba(247,246,243,0.4);font-weight:400;margin-left:4px;}
.note{display:flex;gap:10px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:16px;font-size:0.85rem;color:rgba(247,246,243,0.6);}

/* TESTIMONIAL */
.testimonial{max-width:680px;margin:0 auto;text-align:center;}
.testimonial blockquote{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:500;line-height:1.5;margin:0;}
.testimonial .who{margin-top:24px;font-size:0.9rem;color:rgba(247,246,243,0.8);}
.testimonial .who span{display:block;color:var(--glow-400);font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;margin-top:4px;}
.testimonial-link{display:block;text-decoration:none;color:inherit;border-radius:18px;padding:8px;transition:background .3s;}
.testimonial-link:hover{background:rgba(255,255,255,0.03);}
.testimonial-link:hover blockquote{color:var(--glow-300);}
.read-more-cue{
  display:inline-flex;align-items:center;gap:6px;margin-top:20px;
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--glow-400);
}

/* REVIEWS PAGE */
.review-card{
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;padding:36px;max-width:720px;margin:0 auto 28px;
}
.review-card p{color:rgba(247,246,243,0.7);line-height:1.75;margin-bottom:16px;font-size:0.97rem;}
.review-card .who{margin-top:22px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.08);font-size:0.9rem;color:rgba(247,246,243,0.85);}
.review-card .who span{display:block;color:var(--glow-400);font-family:'IBM Plex Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;margin-top:4px;}

/* FAQ */
.faq-item{border-bottom:1px solid rgba(255,255,255,0.08);}
.faq-q{padding:20px 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:'Sora',sans-serif;font-weight:500;}
.faq-a{padding:0 0 20px;color:rgba(247,246,243,0.6);font-size:0.92rem;line-height:1.6;display:none;max-width:680px;}
.faq-item.open .faq-a{display:block;}
.faq-item.open .faq-plus{transform:rotate(45deg);}
.faq-plus{transition:transform .3s;color:var(--glow-400);font-size:1.2rem;}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:50px;}
label{display:block;font-size:0.85rem;color:rgba(247,246,243,0.8);margin-bottom:8px;}
input,textarea{
  width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;padding:12px 14px;color:var(--ivory);font-family:'Inter',sans-serif;font-size:0.9rem;margin-bottom:18px;
}
input:focus,textarea:focus{outline:none;border-color:var(--glow-400);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.info-row{display:flex;gap:14px;margin-bottom:18px;align-items:flex-start;}
.info-icon{width:38px;height:38px;border-radius:50%;background:var(--charcoal-800);border:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;color:var(--glow-400);flex-shrink:0;font-size:15px;}
.info-row p{margin:0;font-size:0.9rem;}
.info-row .lbl{font-family:'IBM Plex Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:rgba(247,246,243,0.4);margin:0;}
.map-frame{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,0.08);aspect-ratio:16/10;}
.map-frame iframe{width:100%;height:100%;border:0;filter:invert(92%) hue-rotate(180deg) contrast(0.9);}
.form-note{font-size:0.78rem;color:rgba(247,246,243,0.4);margin-top:-8px;margin-bottom:18px;}

.service-group{margin-bottom:22px;}
.service-group-title{
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(247,246,243,0.45);margin:0 0 10px;
}
.service-options{display:flex;flex-wrap:wrap;gap:8px;}
.service-pill{
  position:relative;display:inline-flex;align-items:center;
  border:1px solid rgba(255,255,255,0.12);border-radius:999px;
  padding:9px 16px 9px 14px;cursor:pointer;transition:all .25s ease;
  font-size:0.83rem;color:rgba(247,246,243,0.75);background:rgba(255,255,255,0.02);
}
.service-pill:hover{border-color:rgba(62,143,224,0.4);}
.service-pill input{position:absolute;opacity:0;width:0;height:0;}
.service-pill input:checked ~ span{color:var(--charcoal-950);}
.service-pill:has(input:checked){background:var(--glow-500);border-color:transparent;}
.service-pill.is-checked{background:var(--glow-500);border-color:transparent;}
.service-pill.is-checked span{color:var(--charcoal-950);}
.service-pill span{pointer-events:none;}

.form-status{
  margin-top:16px;padding:14px 16px;border-radius:10px;font-size:0.88rem;line-height:1.5;
}
.form-status-success{background:rgba(62,143,224,0.12);border:1px solid rgba(62,143,224,0.35);color:var(--glow-300);}
.form-status-error{background:rgba(220,80,80,0.1);border:1px solid rgba(220,80,80,0.35);color:#f3a3a3;}

@media(max-width:600px){
  .service-options{gap:6px;}
  .service-pill{font-size:0.8rem;padding:8px 14px 8px 12px;}
}

/* FOOTER */
footer{padding:60px 0 30px;border-top:1px solid rgba(255,255,255,0.06);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;}
footer h4{font-family:'IBM Plex Mono',monospace;font-size:11px;color:rgba(247,246,243,0.4);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;}
footer p, footer a{color:rgba(247,246,243,0.6);font-size:0.85rem;text-decoration:none;line-height:1.8;}
footer a:hover{color:var(--glow-300);}
.copyright{font-size:12px;color:rgba(247,246,243,0.35);text-align:center;padding-top:24px;border-top:1px solid rgba(255,255,255,0.05);}
.brand-caps{text-transform:uppercase;font-family:'Sora',sans-serif;font-weight:600;letter-spacing:0.04em;color:rgba(247,246,243,0.55);}

@media(max-width:900px){
  .grid-3,.grid-pricing,.masonry,.addon-grid,.contact-grid,.grid-2{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .grid-3,.grid-pricing,.masonry,.addon-grid,.form-row,.grid-2{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
}
