/* LocalWeddingVideo.com styles (self-contained)
   Moved from /localweddingvideo.com/styles.css on 2025-10-17 */
:root{
  --bg:#05070f;
  --bg-alt:#0d1324;
  --glow:rgba(255,138,181,0.32);
  --ink:#f5f4f2;
  --muted:#c1c6d1;
  --muted-dark:#9096a3;
  --accent:#ff8fab;
  --accent-strong:#ff6f94;
  --accent-soft:#7de3ff;
  --card:rgba(255,255,255,0.06);
  --border:rgba(255,255,255,0.12);
}

*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  background:radial-gradient(circle at top right, rgba(125,227,255,0.18), transparent 42%), var(--bg);
  color:var(--ink);
  font:16px/1.6 'IBM Plex Sans', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  min-height:100%;
}

body{
  position:relative;
  overflow-x:hidden;
}

.background-glow{
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(600px circle at 20% 10%, rgba(255,143,171,0.35), transparent 65%),
    radial-gradient(420px circle at 82% 12%, rgba(125,227,255,0.2), transparent 60%);
  z-index:-1;
}

.wrap{
  max-width:1100px;
  margin:0 auto;
  padding:0 24px;
}

.lwv-header{
  position:sticky;
  top:0;
  z-index:10;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(6,8,15,0.75);
  border-bottom:1px solid var(--border);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:68px;
}

.brand{
  letter-spacing:2.8px;
  font-weight:600;
  font-size:0.95rem;
  text-decoration:none;
  color:var(--ink);
}

.brand .dot{color:var(--accent)}

.primary-nav{
  display:flex;
  align-items:center;
  gap:20px;
  font-size:0.95rem;
}

.primary-nav a{
  color:var(--muted);
  text-decoration:none;
  transition:color .2s ease, transform .2s ease;
}

.primary-nav a:hover,
.primary-nav a:focus{color:var(--ink);transform:translateY(-1px)}

.primary-nav .nav-cta{
  padding:8px 16px;
  border-radius:999px;
  background:linear-gradient(120deg,var(--accent),var(--accent-soft));
  color:#08101c;
  font-weight:600;
}

.hero{
  padding:96px 0 72px;
}

.hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:48px;
  align-items:start;
}

.hero-copy h1{
  margin:12px 0 16px;
  font-size:2.5rem;
  line-height:1.15;
}

.hero-badge{
  display:inline-block;
  font-size:0.85rem;
  letter-spacing:1px;
  text-transform:uppercase;
  background:rgba(255,143,171,0.16);
  border:1px solid rgba(255,143,171,0.35);
  color:var(--accent);
  padding:6px 12px;
  border-radius:999px;
}

.lede{
  color:var(--muted);
  max-width:620px;
}

.hero-meta{
  list-style:none;
  margin:24px 0 0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.hero-meta li{
  background:var(--card);
  border:1px solid var(--border);
  padding:10px 14px;
  border-radius:12px;
  color:var(--muted);
  font-size:0.95rem;
}

.cta-row{
  display:flex;
  gap:14px;
  margin-top:24px;
  flex-wrap:wrap;
}

.btn{
  appearance:none;
  border:none;
  background:linear-gradient(130deg,var(--accent),var(--accent-strong));
  color:#07111d;
  padding:12px 20px;
  border-radius:12px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:600;
  transition:transform .2s ease, box-shadow .2s ease;
  cursor:pointer;
}

.btn:hover,
.btn:focus{transform:translateY(-1px);box-shadow:0 12px 20px rgba(255,143,171,0.28)}

.btn.ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--border);
}

.btn.ghost:hover,
.btn.ghost:focus{
  border-color:var(--accent);
  color:var(--accent);
  box-shadow:none;
}

.hero-note{
  margin-top:18px;
  color:var(--muted-dark);
  font-size:0.9rem;
}

.hero-card{
  background:linear-gradient(160deg,rgba(13,19,36,0.9),rgba(8,12,22,0.75));
  border:1px solid rgba(255,255,255,0.08);
  border-radius:20px;
  padding:32px;
  box-shadow:0 40px 80px rgba(4,8,20,0.42);
}

.hero-price{
  font-size:2.8rem;
  font-weight:600;
  color:var(--accent);
  margin-bottom:12px;
}

.hero-card p{
  margin:0;
  color:var(--muted);
  font-size:0.95rem;
}

.confidence{
  padding:70px 0 60px;
  border-top:1px solid rgba(255,255,255,0.05);
}

.confidence h2{margin-bottom:28px}

.highlight-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:24px;
}

.highlight-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:180px;
}

.highlight-card h3{
  margin:0;
  font-size:1.1rem;
  color:var(--ink);
}

.highlight-card p{
  margin:0;
  color:var(--muted);
}

.fine-print{
  margin-top:18px;
  color:var(--muted-dark);
  font-size:0.85rem;
}

.package{
  padding:72px 0;
}

.section-heading{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:32px;
}

.section-heading p{
  margin:0;
  color:var(--muted);
  max-width:520px;
}

.package-grid{
  display:grid;
  grid-template-columns: minmax(0,1.05fr) minmax(0,1fr);
  gap:36px;
}

.package-intro{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:24px;
  color:var(--muted);
}

.package-note{
  margin-top:18px;
  font-size:0.9rem;
  color:var(--muted-dark);
}

.specs{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;
  padding:0;
  margin:0;
  list-style:none;
}

.specs li{
  background:rgba(13,19,36,0.78);
  border:1px solid var(--border);
  border-radius:16px;
  padding:16px;
  color:var(--muted);
  font-size:0.95rem;
}

.specs strong{
  color:var(--ink);
  font-weight:600;
}

.timeline{
  padding:70px 0;
  border-top:1px solid rgba(255,255,255,0.05);
}

.timeline-list{
  counter-reset:steps;
  list-style:none;
  margin:32px 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:24px;
}

.timeline-step{
  position:relative;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:26px 24px 24px;
  color:var(--muted);
}

.timeline-step::before{
  counter-increment:steps;
  content:counter(steps);
  position:absolute;
  top:-16px;
  left:22px;
  width:36px;
  height:36px;
  border-radius:50%;
  background:linear-gradient(140deg,var(--accent),var(--accent-soft));
  color:#08101c;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:600;
}

.step-title{
  display:block;
  color:var(--ink);
  font-weight:600;
  margin-bottom:10px;
  font-size:1.05rem;
}

.faq{
  padding:70px 0;
}

.faq-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:24px;
}

.faq-item{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:24px;
  color:var(--muted);
}

.faq-item h3{
  margin:0 0 12px;
  color:var(--ink);
  font-size:1.05rem;
}

.book{
  padding:70px 0 90px;
  border-top:1px solid rgba(255,255,255,0.05);
}

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

.grid .full{
  grid-column:1 / -1;
}

.grid label{
  display:flex;
  flex-direction:column;
  gap:8px;
}

label span{
  font-size:0.9rem;
  letter-spacing:0.2px;
  color:var(--muted-dark);
}

input,
textarea{
  background:rgba(11,16,27,0.9);
  border:1px solid rgba(255,255,255,0.12);
  color:var(--ink);
  padding:12px 14px;
  border-radius:12px;
  font:inherit;
  transition:border-color .2s ease, box-shadow .2s ease;
}

textarea{resize:vertical;min-height:120px}

input:focus,
textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(255,143,171,0.2);
}

.form-actions{
  margin-top:24px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.fine{
  color:var(--muted-dark);
  font-size:0.9rem;
  margin-top:18px;
}

.lwv-footer{
  border-top:1px solid rgba(255,255,255,0.05);
  padding:26px 0;
  background:rgba(6,8,15,0.82);
}

.footer-inner{
  display:flex;
  flex-wrap:wrap;
  gap:12px 24px;
  align-items:center;
  justify-content:space-between;
  color:var(--muted);
  font-size:0.95rem;
}

.footer-link{
  color:var(--accent);
  text-decoration:none;
}

.footer-link:hover{color:var(--accent-soft)}

@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr}
  .hero-card{order:-1;max-width:340px}
  .primary-nav{gap:14px;font-size:0.9rem}
}

@media (max-width:720px){
  .header-inner{flex-direction:column;gap:12px;padding:12px 0}
  .primary-nav{flex-wrap:wrap;justify-content:center}
  .hero{padding:80px 0 64px}
  .hero-card{width:100%}
  .package-grid{grid-template-columns:1fr}
  .timeline-list{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{transition-duration:0s!important}
}
