/*
Theme Name: JetWithCasas Landing V2
Theme URI: https://jetwithcasas.com
Author: Jose Casas
Description: High-conversion private jet landing page theme.
Version: 1.1
Text Domain: jetwithcasas-landing
*/

:root {
  --bg-dark: #0f172a;
  --bg-section: #1e253a;
  --card-dark: #1a2335;
  --accent: #38bdf8;
  --text-light: #f8fafc;
  --text-dim: #94a3b8;
  --radius-lg: 1rem;
  --radius-xl: 2rem;
  --max-width: 1200px;
  --header-h: 4rem;
  --font-main: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  background-color: var(--bg-dark);
  color: var(--text-light);
  font-family: var(--font-main);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
}

a {
  color: var(--accent);
  text-decoration: none;
}

.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1rem;
}

.section {
  padding: 4rem 0;
}

@media (min-width: 768px) {
  .section {
    padding: 6rem 0;
  }
}

/* -------- HEADER / NAV -------- */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--header-h);
  background: rgba(15, 23, 42, 0.7);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(148, 163, 184, 0.1);
  z-index: 999;
  display: flex;
  align-items: center;
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
}

.brand {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-light);
  display: flex;
  align-items: baseline;
  gap: .4rem;
}
.brand span.logo-main {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-light);
}
.brand span.logo-sub {
  font-size: .7rem;
  color: var(--text-dim);
  letter-spacing: .05em;
  text-transform: uppercase;
}

.nav-links {
  display: none;
  flex-direction: column;
  position: absolute;
  top: var(--header-h);
  right: 1rem;
  background-color: var(--card-dark);
  padding: 1rem 1.25rem;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(148, 163, 184, 0.15);
  min-width: 200px;
}
.nav-links a {
  color: var(--text-light);
  font-size: .9rem;
  font-weight: 500;
  padding: .5rem 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.08);
}
.nav-links a:last-child {
  border-bottom: none;
}
.nav-links .cta-phone {
  display: flex;
  flex-direction: column;
  background-color: var(--accent);
  color: #0f172a;
  text-align: center;
  padding: .75rem 1rem;
  border-radius: var(--radius-lg);
  font-weight: 600;
  margin-top: .75rem;
}
.nav-links.active {
  display: flex;
}

@media (min-width: 768px) {
  .mobile-toggle {
    display: none;
  }
  .nav-links {
    background: transparent;
    border: 0;
    position: static;
    top: auto;
    right: auto;
    padding: 0;
    min-width: auto;
    display: flex !important;
    flex-direction: row;
    align-items: center;
    gap: 2rem;
  }
  .nav-links a {
    border: 0;
    padding: 0;
    font-size: .9rem;
    color: var(--text-dim);
    transition: color .2s;
  }
  .nav-links a:hover {
    color: var(--text-light);
  }
  .nav-links .cta-phone {
    margin-top: 0;
    background-color: var(--accent);
    color: #0f172a;
    border-radius: var(--radius-lg);
    padding: .6rem .9rem;
    font-size: .8rem;
    line-height: 1.2;
    font-weight: 600;
    box-shadow: 0 10px 30px rgba(56, 189, 248, .4);
  }
  .nav-links .cta-phone small {
    font-weight: 400;
    font-size: .7rem;
    color: #0f172a;
    opacity: .8;
  }
}

/* -------- HERO -------- */
.hero {
  min-height: 100vh;
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  align-items: center;
  padding-top: calc(var(--header-h) + 2rem);
  padding-bottom: 4rem;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 20%, rgba(56,189,248,.25) 0%, rgba(15,23,42,0) 60%);
  pointer-events: none;
}
.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 700px;
  display: grid;
  gap: 2rem;
}
.hero-eyebrow {
  font-size: .7rem;
  font-weight: 500;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.hero-headline {
  font-size: 2rem;
  line-height: 1.2;
  font-weight: 600;
  color: var(--text-light);
}
.hero-copy {
  color: var(--text-dim);
  font-size: 1rem;
  max-width: 38ch;
}
@media (min-width:768px){
  .hero-headline { font-size: 3rem; }
  .hero-copy { font-size: 1.05rem; }
}

/* Quote form card */
.quote-card {
  background-color: rgba(15,23,42,.75);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(148,163,184,.2);
  border-radius: var(--radius-xl);
  padding: 1.5rem;
  display: grid;
  gap: 1rem;
  max-width: 700px;
}
.quote-grid {
  display: grid;
  gap: .75rem;
}
@media (min-width:600px){
  .quote-grid {
    grid-template-columns: repeat(2,1fr);
  }
}
.quote-label {
  font-size: .7rem;
  color: var(--text-dim);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: .4rem;
  display:block;
}
.quote-input,
.quote-select {
  width: 100%;
  background-color: var(--card-dark);
  border: 1px solid rgba(148,163,184,.3);
  border-radius: .6rem;
  padding: .75rem .8rem;
  font-size: .9rem;
  color: var(--text-light);
  outline: none;
}
.quote-input:focus,
.quote-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(56,189,248,.3);
}

.quote-cta-row {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
@media (min-width:600px){
  .quote-cta-row {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}
.btn-primary {
  background-color: var(--accent);
  color: #0f172a;
  border: 0;
  border-radius: var(--radius-lg);
  font-size: .9rem;
  font-weight: 600;
  line-height: 1.2;
  padding: .9rem 1.1rem;
  cursor: pointer;
  box-shadow: 0 20px 40px rgba(56,189,248,.4);
  text-align: center;
  display: inline-block;
}
.btn-primary:hover {
  filter: brightness(1.05);
}
.helper-text {
  font-size: .75rem;
  color: var(--text-dim);
  line-height: 1.4;
}
.helper-text strong {
  color: var(--text-light);
  font-weight: 600;
}

/* -------- HOW IT WORKS -------- */
.how {
  background-color: var(--bg-section);
}
.section-head {
  text-align: center;
  max-width: 650px;
  margin: 0 auto 3rem auto;
}
.section-eyebrow {
  font-size: .7rem;
  font-weight: 500;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .5rem;
}
.section-title {
  font-size: 1.6rem;
  line-height: 1.2;
  font-weight: 600;
  color: var(--text-light);
  margin-bottom: 1rem;
}
.section-desc {
  color: var(--text-dim);
  font-size: .95rem;
}
@media (min-width:768px){
  .section-title { font-size:2rem; }
  .section-desc { font-size:1rem; }
}

.steps-grid {
  display: grid;
  gap: 1.5rem;
}
@media (min-width:768px){
  .steps-grid {
    grid-template-columns: repeat(3,1fr);
  }
}
.step-card {
  background-color: var(--card-dark);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(148,163,184,.15);
  padding: 1.5rem;
  display: grid;
  gap: .5rem;
}
.step-num {
  font-size: .8rem;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.step-title {
  font-size: 1.1rem;
  color: var(--text-light);
  font-weight: 600;
  line-height: 1.3;
}
.step-copy {
  font-size: .9rem;
  color: var(--text-dim);
  line-height: 1.4;
}

/* -------- FLEET -------- */
.fleet {
  background-color: var(--bg-dark);
}
.fleet-grid {
  display: grid;
  gap: 1.5rem;
}
@media (min-width:768px){
  .fleet-grid {
    grid-template-columns: repeat(3,1fr);
  }
}
.aircraft-card {
  background-color: var(--card-dark);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(148,163,184,.15);
  padding: 1rem 1rem 1.5rem;
  display: grid;
  gap: .75rem;
}
.aircraft-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.aircraft-type {
  font-size: .8rem;
  font-weight: 500;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.aircraft-name {
  color: var(--text-light);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.3;
}
.aircraft-about {
  font-size: .85rem;
  color: var(--text-dim);
  line-height: 1.4;
}
.aircraft-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1rem;
  font-size: .8rem;
  color: var(--text-light);
}
.aircraft-meta span {
  background-color: rgba(148,163,184,.12);
  padding: .4rem .6rem;
  border-radius: .5rem;
  line-height: 1.2;
  display: inline-block;
  color: var(--text-light);
  font-weight: 500;
}

/* -------- ABOUT / AUTHORITY -------- */
.about {
  background-color: var(--bg-section);
}
.about-wrap {
  display: grid;
  gap:2rem;
}
@media(min-width:900px){
  .about-wrap {
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }
}
.about-block h3 {
  font-size:1.4rem;
  font-weight:600;
  line-height:1.25;
  color:var(--text-light);
  margin-bottom:1rem;
}
.about-block p {
  color:var(--text-dim);
  font-size:.95rem;
  line-height:1.5;
  margin-bottom:1rem;
}
.badges-row {
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}
.badge-pill {
  background-color:rgba(148,163,184,.12);
  color:var(--text-light);
  border-radius:999px;
  font-size:.75rem;
  font-weight:500;
  padding:.5rem .75rem;
  line-height:1.2;
  display:inline-block;
}

/* -------- SUBSCRIBE / NEWSLETTER -------- */
.subscribe {
  background-color: var(--bg-dark);
  border-top:1px solid rgba(148,163,184,.15);
  border-bottom:1px solid rgba(148,163,184,.15);
}
.subscribe-inner {
  max-width:700px;
  margin:0 auto;
  text-align:center;
  display:grid;
  gap:1.5rem;
}
.subscribe-headline {
  font-size:1.4rem;
  font-weight:600;
  line-height:1.3;
  color:var(--text-light);
}
.subscribe-copy {
  font-size:.95rem;
  color:var(--text-dim);
  line-height:1.4;
}
.subscribe-card {
  background-color: rgba(15,23,42,.75);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(148,163,184,.2);
  border-radius: var(--radius-xl);
  padding:1.5rem;
  display:grid;
  gap:1rem;
}
.subscribe-grid {
  display:grid;
  gap:.75rem;
}
@media(min-width:600px){
  .subscribe-grid {
    grid-template-columns: repeat(2,1fr);
  }
}
.sub-label {
  font-size:.7rem;
  color:var(--text-dim);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.07em;
  margin-bottom:.4rem;
  display:block;
}
.sub-input,
.sub-select {
  width:100%;
  background-color: var(--card-dark);
  border:1px solid rgba(148,163,184,.3);
  border-radius:.6rem;
  padding:.75rem .8rem;
  font-size:.9rem;
  color:var(--text-light);
  outline:none;
}
.sub-input:focus,
.sub-select:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(56,189,248,.3);
}
.sub-cta-row {
  display:flex;
  flex-direction:column;
  gap:.75rem;
}
@media(min-width:600px){
  .sub-cta-row {
    flex-direction:row;
    align-items:flex-end;
    justify-content:space-between;
  }
}

/* -------- CTA STRIP -------- */
.cta-strip {
  background: radial-gradient(circle at 10% 10%, rgba(56,189,248,.2) 0%, rgba(15,23,42,0) 60%), var(--bg-dark);
  border-top:1px solid rgba(148,163,184,.15);
  border-bottom:1px solid rgba(148,163,184,.15);
}
.cta-box {
  text-align:center;
  display:grid;
  gap:1rem;
  max-width:700px;
  margin:0 auto;
}
.cta-headline {
  font-size:1.4rem;
  font-weight:600;
  line-height:1.3;
  color:var(--text-light);
}
.cta-copy {
  font-size:.95rem;
  color:var(--text-dim);
  line-height:1.4;
}
.cta-actions {
  display:flex;
  flex-direction:column;
  gap:.75rem;
}
@media(min-width:500px){
  .cta-actions {
    flex-direction:row;
    justify-content:center;
  }
}
.btn-outline {
  background-color:transparent;
  color:var(--accent);
  border:1px solid var(--accent);
  border-radius:var(--radius-lg);
  font-size:.9rem;
  font-weight:600;
  line-height:1.2;
  padding:.9rem 1.1rem;
  text-align:center;
  display:inline-block;
  cursor:pointer;
}
.btn-outline:hover {
  background-color:rgba(56,189,248,.08);
}

/* -------- CONTACT / FOOTER -------- */
.contact {
  background-color: var(--bg-section);
}
.contact-grid {
  display:grid;
  gap:2rem;
}
@media(min-width:768px){
  .contact-grid {
    grid-template-columns:1fr 1fr;
  }
}
.contact-card {
  background-color:var(--card-dark);
  border-radius:var(--radius-lg);
  border:1px solid rgba(148,163,184,.15);
  padding:1.5rem;
  display:grid;
  gap:1rem;
}
.contact-card h4 {
  color:var(--text-light);
  font-size:1.1rem;
  font-weight:600;
}
.contact-card p{
  font-size:.9rem;
  color:var(--text-dim);
  line-height:1.4;
}
.contact-list{
  font-size:.9rem;
  color:var(--text-light);
  line-height:1.5;
  display:grid;
  gap:.5rem;
}
.contact-list a{
  color:var(--accent);
  font-weight:500;
  text-decoration:none;
}
.footer-bottom {
  text-align:center;
  font-size:.75rem;
  color:var(--text-dim);
  padding:2rem 0 4rem;
  line-height:1.4;
  max-width:600px;
  margin:0 auto;
}
.footer-bottom strong{
  color:var(--text-light);
  font-weight:600;
}

/* -------- UTILITIES -------- */
.text-accent {
  color: var(--accent);
}
.mt-2 { margin-top:.5rem; }
.mt-3 { margin-top:1rem; }
.mt-4 { margin-top:1.5rem; }
.mt-6 { margin-top:2rem; }

.max-w-ch {
  max-width: 60ch;
}

.hide-mobile {
  display:none;
}
@media(min-width:768px){
  .hide-mobile { display:inline; }
}
/* -------- INSIGHTS / BLOG LIST -------- */
.insights-grid {
  display: grid;
  gap: 1.5rem;
}
@media(min-width:768px){
  .insights-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.insight-meta {
  font-size:.75rem;
  color:var(--text-dim);
  line-height:1.4;
}

.insight-title {
  color:var(--text-light);
  font-size:1.1rem;
  font-weight:600;
  line-height:1.3;
  margin-top:.25rem;
  margin-bottom:.5rem;
}

.insight-excerpt {
  font-size:.9rem;
  color:var(--text-dim);
  line-height:1.4;
}

/* -------- SINGLE ARTICLE PAGE -------- */
.article-wrap {
  max-width:800px;
  margin:0 auto;
  display:grid;
  gap:2rem;
  padding-top:6rem; /* clear fixed header */
}

.article-headline {
  font-size:1.8rem;
  font-weight:600;
  line-height:1.2;
  color:var(--text-light);
}
@media(min-width:768px){
  .article-headline {
    font-size:2.2rem;
  }
}

.article-meta {
  font-size:.8rem;
  color:var(--text-dim);
  margin-bottom:.5rem;
}

.article-body {
  font-size:1rem;
  line-height:1.6;
  color:var(--text-dim);
}
.article-body p {
  margin-bottom:1rem;
}
.article-body h2 {
  color:var(--text-light);
  font-size:1.2rem;
  font-weight:600;
  line-height:1.3;
  margin:2rem 0 1rem;
}
.article-body ul {
  margin-left:1.25rem;
  margin-bottom:1rem;
  color:var(--text-dim);
  font-size:1rem;
  line-height:1.5;
}
.article-body li {
  margin-bottom:.5rem;
}
/* --- Trip type selector inside quote form --- */
.full-row {
  grid-column: 1 / -1;
}

.triptype-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.triptype-option {
  background-color: var(--card-dark);
  border: 1px solid rgba(148,163,184,.3);
  border-radius: .6rem;
  padding: .6rem .8rem;
  color: var(--text-light);
  font-size: .8rem;
  font-weight: 500;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;
  user-select: none;
}

.triptype-option input[type="radio"] {
  accent-color: var(--accent);
  width: .9rem;
  height: .9rem;
  cursor: pointer;
}

/* hide return field by default (JS will show it if roundtrip) */
.return-field {
  display: none;
}
/* --- Cleaner grid for the quote form --- */
.full-row { grid-column: 1 / -1; }

.triptype-row { display:flex; flex-wrap:wrap; gap:.75rem; }
.triptype-option {
  background-color: var(--card-dark);
  border: 1px solid rgba(148,163,184,.3);
  border-radius: .6rem;
  padding: .6rem .8rem;
  color: var(--text-light);
  font-size: .8rem; font-weight: 500; line-height: 1.2;
  display:flex; align-items:center; gap:.5rem;
  cursor: pointer; user-select: none;
}
.triptype-option input[type="radio"]{ accent-color: var(--accent); width:.9rem; height:.9rem; }

.return-field { display:none; } /* JS will slideDown when Round trip */
/* --- Social / personal brand section --- */
.social {
  background-color: var(--bg-dark);
  border-top:1px solid rgba(148,163,184,.15);
  border-bottom:1px solid rgba(148,163,184,.15);
}
.social-inner {
  max-width:1000px;
  margin:0 auto;
}
.social-grid {
  display:grid;
  gap:1.5rem;
}
@media(min-width:900px){
  .social-grid {
    grid-template-columns:repeat(3,1fr);
  }
}

.social-card {
  background-color:var(--card-dark);
  border-radius:var(--radius-lg);
  border:1px solid rgba(148,163,184,.15);
  padding:1.5rem;
  display:grid;
  gap:1rem;
  text-align:left;
}

.social-head {
  display:flex;
  flex-direction:column;
  gap:.25rem;
}
.social-platform {
  font-size:.8rem;
  font-weight:600;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:.07em;
}
.social-handle {
  font-size:.9rem;
  font-weight:600;
  color:var(--text-light);
  line-height:1.3;
}
.social-copy {
  font-size:.9rem;
  color:var(--text-dim);
  line-height:1.4;
}
