/* =========================================================
   SILVER TRAILS — stylesheet
   Palette: "Royal Sunrise" — Navy / Gold / Coral on warm Cream
   Signature motif: the Sunrise Arc (horizon + rising sun),
   echoed in the hero, section dividers and footer.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Source+Sans+3:wght@400;500;600;700&display=swap');

:root{
  /* colour tokens */
  --navy:        #1C2B3A;
  --navy-deep:   #101A24;
  --navy-soft:   #2D4459;
  --gold:        #E8A23D;
  --gold-deep:   #C17F1F;
  --coral:       #FF6B45;
  --coral-deep:  #E0532E;
  --cream:       #FBF6EC;
  --cream-deep:  #F2E9D8;
  --ink:         #2A3340;
  --ink-soft:    #5C6776;
  --white:       #FFFFFF;
  --line:        rgba(28,43,58,.14);
  --shadow-sm:   0 6px 18px -10px rgba(16,26,36,.25);
  --shadow-lg:   0 24px 48px -22px rgba(16,26,36,.38);

  /* type */
  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Source Sans 3', -apple-system, Segoe UI, sans-serif;
  --fs-h1: clamp(2.3rem, 4.6vw, 3.7rem);
  --fs-h2: clamp(1.8rem, 3.2vw, 2.5rem);
  --fs-h3: clamp(1.25rem, 2vw, 1.5rem);
  --fs-body: 1.125rem;
  --fs-small: .95rem;

  --radius: 16px;
  --radius-sm: 10px;
  --container: 1180px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;}
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.15;
  margin:0 0 .5em;
  color:var(--navy);
}
p{margin:0 0 1em;}
button{font-family:inherit;cursor:pointer;}

:focus-visible{
  outline:3px solid var(--coral);
  outline-offset:3px;
  border-radius:4px;
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--font-body);
  font-weight:700;
  font-size:.8rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--coral-deep);
}
.eyebrow::before{
  content:"";
  width:18px;height:2px;
  background:var(--coral);
  border-radius:2px;
}

section{padding:72px 0;}
.section-head{
  max-width:680px;
  margin:0 0 40px;
}
.section-head.center{margin-inline:auto;text-align:center;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5em;
  padding:14px 28px;
  border-radius:999px;
  font-weight:700;
  font-size:1rem;
  border:2px solid transparent;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-gold{
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  color:var(--navy-deep);
  box-shadow:var(--shadow-sm);
}
.btn-gold:hover{box-shadow:var(--shadow-lg);}
.btn-outline{
  background:transparent;
  border-color:rgba(251,246,236,.55);
  color:var(--white);
}
.btn-outline:hover{background:rgba(251,246,236,.12);}
.btn-outline-navy{
  background:transparent;
  border-color:var(--navy);
  color:var(--navy);
}
.btn-outline-navy:hover{background:var(--navy);color:var(--white);}
.btn-coral{
  background:var(--coral);
  color:var(--white);
  box-shadow:var(--shadow-sm);
}
.btn-coral:hover{background:var(--coral-deep);}
.btn-block{width:100%;}
.btn-sm{padding:10px 20px;font-size:.92rem;}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,246,236,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
  gap:18px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand-mark{flex:none;}
.brand-name{
  font-family:var(--font-display);
  font-size:1.35rem;
  font-weight:600;
  color:var(--navy);
  letter-spacing:.01em;
}
.brand-name span{color:var(--coral-deep);}

.main-nav{display:flex;align-items:center;gap:30px;}
.main-nav a{
  font-weight:600;
  font-size:1rem;
  color:var(--ink);
  padding:6px 2px;
  border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s;
}
.main-nav a:hover,.main-nav a.active{
  color:var(--coral-deep);
  border-color:var(--coral);
}

.header-actions{display:flex;align-items:center;gap:14px;}
.header-actions .phone-link{
  display:none;
  font-weight:700;
  color:var(--navy);
}
.nav-toggle{
  display:none;
  background:none;border:none;
  width:42px;height:42px;
  border-radius:10px;
  align-items:center;justify-content:center;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";
  display:block;
  width:22px;height:2px;
  background:var(--navy);
  position:relative;
  transition:.2s;
}
.nav-toggle span::before{position:absolute;top:-7px;}
.nav-toggle span::after{position:absolute;top:7px;}

@media (min-width:880px){
  .header-actions .phone-link{display:inline-flex;align-items:center;gap:8px;}
}
@media (max-width:879px){
  .main-nav{
    position:fixed;
    inset:64px 0 auto auto;
    top:64px;right:0;
    background:var(--cream);
    flex-direction:column;
    align-items:flex-start;
    width:min(78vw,320px);
    padding:18px 26px 28px;
    border-left:1px solid var(--line);
    border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-lg);
    gap:16px;
    transform:translateX(110%);
    transition:transform .25s ease;
  }
  .main-nav.open{transform:translateX(0);}
  .nav-toggle{display:flex;}
}

/* ---------- hero (sunrise arc signature) ---------- */
.hero{
  position:relative;
  background:radial-gradient(120% 140% at 50% 120%, var(--navy-soft) 0%, var(--navy) 45%, var(--navy-deep) 100%);
  color:var(--white);
  overflow:hidden;
  padding:110px 0 0;
}
.hero-inner{
  position:relative;z-index:2;
  max-width:760px;margin:0 auto;
  text-align:center;
  padding:0 24px 64px;
}
.hero .eyebrow{color:var(--gold);}
.hero .eyebrow::before{background:var(--gold);}
.hero h1{
  color:var(--white);
  font-size:var(--fs-h1);
  margin:.4em 0 .55em;
}
.hero h1 em{
  font-style:normal;
  color:var(--gold);
}
.hero p.lede{
  font-size:1.2rem;
  color:rgba(251,246,236,.86);
  max-width:560px;margin:0 auto 2em;
}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

.sunrise-stage{
  position:absolute;left:0;right:0;bottom:0;
  height:46%;
  z-index:1;
  pointer-events:none;
}
.sunrise-stage svg{width:100%;height:100%;display:block;}

.trust-strip{
  position:relative;z-index:2;
  background:var(--navy-deep);
  border-top:1px solid rgba(251,246,236,.1);
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:22px;
  padding:26px 24px;
  max-width:var(--container);margin:0 auto;
}
.trust-item{
  display:flex;align-items:center;gap:12px;
  color:rgba(251,246,236,.92);
  font-size:.96rem;
  font-weight:600;
}
.trust-item svg{flex:none;width:26px;height:26px;color:var(--gold);}

/* ---------- divider (echo of the sunrise arc) ---------- */
.arc-divider{
  display:flex;align-items:center;justify-content:center;
  gap:14px;
  padding:8px 0 48px;
  color:var(--gold-deep);
}
.arc-divider svg{width:120px;height:18px;}
.arc-divider span{
  font-family:var(--font-display);
  font-size:.85rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
}

/* ---------- why cards ---------- */
.why-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:26px;
}
.why-card{
  background:var(--white);
  border-radius:var(--radius);
  padding:32px 28px;
  border-top:4px solid var(--gold);
  box-shadow:var(--shadow-sm);
}
.why-card .icon-badge{margin-bottom:18px;}
.why-card h3{font-size:var(--fs-h3);margin-bottom:.4em;}
.why-card p{color:var(--ink-soft);margin:0;}

.icon-badge{
  width:54px;height:54px;
  border-radius:50%;
  background:var(--cream-deep);
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);
}
.icon-badge svg{width:28px;height:28px;}

/* ---------- urgency banner ---------- */
.urgency-banner{
  background:linear-gradient(100deg,var(--coral) 0%, var(--coral-deep) 100%);
  color:var(--white);
  border-radius:var(--radius);
  padding:26px 30px;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
  box-shadow:var(--shadow-lg);
}
.urgency-banner strong{font-family:var(--font-display);font-size:1.25rem;font-weight:600;display:block;}
.urgency-banner .pulse-dot{
  display:inline-block;width:9px;height:9px;border-radius:50%;
  background:var(--white);margin-right:8px;
  animation:pulse 1.8s infinite;
}
@media (prefers-reduced-motion:reduce){.pulse-dot{animation:none;}}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.35;}}

/* ---------- featured tour ---------- */
.feature-tour{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:0;
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.feature-art{
  background:linear-gradient(160deg,var(--navy-soft),var(--navy));
  position:relative;
  min-height:320px;
}
.feature-art svg{position:absolute;inset:0;width:100%;height:100%;}
.feature-body{padding:40px;}
.feature-body .badge{margin-bottom:14px;}
.feature-list{display:grid;gap:10px;margin:20px 0 26px;}
.feature-list li{
  display:flex;gap:10px;align-items:flex-start;
  list-style:none;color:var(--ink-soft);
}
.feature-list svg{flex:none;width:20px;height:20px;color:var(--gold-deep);margin-top:2px;}
.feature-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.price-tag{font-family:var(--font-display);font-size:1.05rem;color:var(--navy);}
.price-tag small{display:block;color:var(--ink-soft);font-family:var(--font-body);font-size:.82rem;font-weight:600;}

@media (max-width:760px){
  .feature-tour{grid-template-columns:1fr;}
  .feature-art{min-height:200px;}
}

/* ---------- badges ---------- */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.78rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;
  padding:6px 13px;border-radius:999px;
}
.badge-filling{background:rgba(255,107,69,.14);color:var(--coral-deep);}
.badge-open{background:rgba(232,162,61,.18);color:var(--gold-deep);}
.badge-sold{background:rgba(28,43,58,.1);color:var(--ink-soft);}

/* ---------- tour cards ---------- */
.tour-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:26px;
}
.tour-card{
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  transition:transform .18s ease, box-shadow .18s ease;
}
.tour-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.tour-thumb{
  height:160px;position:relative;
  display:flex;align-items:flex-end;
}
.tour-thumb svg{position:absolute;inset:0;width:100%;height:100%;}
.tour-thumb .badge{position:relative;z-index:2;margin:14px;}
.tour-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1;}
.tour-body h3{font-size:1.2rem;margin-bottom:0;}
.tour-meta{font-size:.86rem;font-weight:600;color:var(--ink-soft);}
.tour-tags{font-size:.92rem;color:var(--ink-soft);}
.tour-foot{
  margin-top:auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding-top:8px;border-top:1px solid var(--line);
}

/* ---------- gift banner ---------- */
.gift-banner{
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-deep) 100%);
  color:var(--white);
  border-radius:var(--radius);
  padding:54px 40px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.gift-banner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 90% at 50% 0%, rgba(232,162,61,.18), transparent 70%);
}
.gift-banner h2{color:var(--white);position:relative;}
.gift-banner p{
  position:relative;
  max-width:620px;margin:0 auto 1.2em;
  font-size:1.1rem;color:rgba(251,246,236,.85);
}
.gift-banner .btn{position:relative;}

/* ---------- testimonials ---------- */
.testi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
}
.testi-card{
  background:var(--white);
  border-radius:var(--radius);
  padding:30px 28px;
  box-shadow:var(--shadow-sm);
  position:relative;
}
.testi-stars{color:var(--gold);font-size:1rem;margin-bottom:12px;letter-spacing:2px;}
.testi-quote{font-style:normal;color:var(--ink);font-size:1.04rem;}
.testi-name{margin-top:16px;font-weight:700;color:var(--navy);}
.testi-name span{display:block;font-weight:500;color:var(--ink-soft);font-size:.88rem;}

/* ---------- closing CTA ---------- */
.closing-cta{
  background:var(--cream-deep);
  border-radius:var(--radius);
  padding:48px 40px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.closing-cta h2{margin-bottom:.2em;}
.closing-cta .links{display:flex;gap:14px;flex-wrap:wrap;}

/* ---------- footer ---------- */
.site-footer{
  background:var(--navy-deep);
  color:rgba(251,246,236,.78);
  padding:64px 0 0;
}
.footer-top{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:36px;
  padding-bottom:46px;
  border-bottom:1px solid rgba(251,246,236,.12);
}
.footer-brand .brand-name{color:var(--cream);}
.footer-brand p{color:rgba(251,246,236,.62);max-width:300px;margin-top:14px;}
.footer-col h4{
  color:var(--cream);
  font-family:var(--font-body);
  font-size:.86rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.footer-col ul{display:grid;gap:11px;}
.footer-col a{color:rgba(251,246,236,.72);transition:color .15s;}
.footer-col a:hover{color:var(--gold);}
.footer-social{display:flex;gap:12px;margin-top:6px;}
.footer-social a{
  width:38px;height:38px;border-radius:50%;
  background:rgba(251,246,236,.08);
  display:flex;align-items:center;justify-content:center;
}
.footer-social a:hover{background:var(--gold);color:var(--navy-deep);}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;flex-wrap:wrap;
  padding:24px 0 30px;
  font-size:.86rem;
  color:rgba(251,246,236,.55);
}
.footer-bottom a:hover{color:var(--gold);}

@media (max-width:880px){
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr;}
  .closing-cta{flex-direction:column;text-align:center;}
}

/* ---------- page header (non-home pages) ---------- */
.page-header{
  background:linear-gradient(160deg,var(--navy-soft),var(--navy) 60%, var(--navy-deep));
  color:var(--white);
  padding:74px 0 56px;
  text-align:center;
}
.page-header h1{color:var(--white);margin-bottom:.3em;}
.page-header p{color:rgba(251,246,236,.82);max-width:580px;margin:0 auto;font-size:1.08rem;}
.breadcrumb{
  font-size:.85rem;color:rgba(251,246,236,.6);margin-bottom:14px;
  display:flex;gap:8px;justify-content:center;
}
.breadcrumb a:hover{color:var(--gold);}

/* ---------- about page specifics ---------- */
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.pillar{
  text-align:center;padding:26px 18px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--white);
}
.pillar .icon-badge{margin:0 auto 14px;}
@media (max-width:700px){.pillars{grid-template-columns:1fr;}}

.story-wrap{
  display:grid;grid-template-columns:1fr;gap:0;
  max-width:760px;margin:0 auto;
}
.story-wrap p{font-size:1.08rem;color:var(--ink);}
.story-wrap ul{margin:0 0 1.2em;padding-left:1.4em;color:var(--ink-soft);}
.story-wrap li{margin-bottom:.4em;}
.pull-quote{
  font-family:var(--font-display);
  font-size:1.5rem;
  color:var(--navy);
  border-left:4px solid var(--gold);
  padding:6px 0 6px 22px;
  margin:32px 0;
}
.story-sign{
  font-family:var(--font-display);
  font-size:1.25rem;color:var(--coral-deep);
  margin-top:32px;
}
.founders-art{
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:40px;
  box-shadow:var(--shadow-sm);
}
.founders-art svg{width:100%;display:block;}

/* ---------- tours page ---------- */
.note-card{
  background:var(--cream-deep);
  border-radius:var(--radius-sm);
  padding:18px 22px;
  font-size:.95rem;
  color:var(--ink-soft);
  margin-bottom:30px;
  border:1px dashed var(--gold-deep);
}

/* ---------- FAQ accordion ---------- */
.faq-categories{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px;}
.faq-tab{
  padding:10px 18px;border-radius:999px;
  border:1px solid var(--line);
  background:var(--white);
  font-weight:600;font-size:.92rem;
  color:var(--ink-soft);
}
.faq-tab.active{
  background:var(--navy);color:var(--white);border-color:var(--navy);
}
.faq-group{display:none;}
.faq-group.active{display:block;}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-q{
  width:100%;text-align:left;background:none;border:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 4px;font-weight:700;font-size:1.04rem;color:var(--navy);
}
.faq-q .plus{
  flex:none;width:24px;height:24px;position:relative;
}
.faq-q .plus::before,.faq-q .plus::after{
  content:"";position:absolute;background:var(--coral);
  top:50%;left:50%;transform:translate(-50%,-50%);
}
.faq-q .plus::before{width:16px;height:2px;}
.faq-q .plus::after{width:2px;height:16px;transition:transform .2s;}
.faq-item.open .plus::after{transform:translate(-50%,-50%) rotate(90deg) scaleY(0);}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .25s ease;
  color:var(--ink-soft);
}
.faq-a-inner{padding:0 4px 20px;}
.faq-item.open .faq-a{max-height:600px;}

/* ---------- contact page ---------- */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:start;
}
.contact-card{
  background:var(--white);border-radius:var(--radius);
  padding:36px;box-shadow:var(--shadow-sm);
}
.contact-info-list{display:grid;gap:22px;margin-top:20px;}
.contact-info-item{display:flex;gap:14px;align-items:flex-start;}
.contact-info-item .icon-badge{flex:none;}
.contact-info-item h4{margin-bottom:.2em;font-size:1rem;color:var(--navy);}
.contact-info-item p{margin:0;color:var(--ink-soft);}
.contact-info-item a{color:var(--coral-deep);font-weight:600;}

.form-field{margin-bottom:18px;}
.form-field label{
  display:block;font-weight:700;font-size:.92rem;
  margin-bottom:6px;color:var(--navy);
}
.form-field input,
.form-field select,
.form-field textarea{
  width:100%;
  padding:13px 16px;
  border:1.5px solid var(--line);
  border-radius:var(--radius-sm);
  font-family:inherit;font-size:1rem;
  background:var(--cream);
  color:var(--ink);
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;border-color:var(--gold-deep);
  background:var(--white);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-note{font-size:.85rem;color:var(--ink-soft);margin-top:10px;}

@media (max-width:820px){
  .contact-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
}

/* ---------- utility ---------- */
.bg-cream-deep{background:var(--cream-deep);}
.bg-navy{background:var(--navy);color:var(--white);}
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.stack-gap section + section{border-top:none;}
.visually-hidden{
  position:absolute !important;width:1px;height:1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;
}
