/*
Theme Name: ERA Travel
Theme URI: https://example.com/
Author: ChatGPT
Author URI: https://example.com/
Description: Family-friendly, coastal-modern WordPress theme for ERA Travel. Rounded UI, airy spacing, accessible typography, and an ocean-path inspired palette.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: era-travel
Tags: custom-colors, custom-logo, editor-style, featured-images, block-styles, wide-blocks
*/

/* -----------------------------
   ERA TRAVEL DESIGN TOKENS
------------------------------ */
:root {
  --era-deep-ocean: #1B4E7A;
  --era-ocean-teal: #2CA6B1;
  --era-soft-aqua: #DFF6F8;
  --era-golden-sun: #F6B93B;
  --era-warm-coral: #FF7F50;
  --era-sand-neutral: #F8F4EC;
  --era-text: #2F3A45;
  --era-white: #FFFFFF;

  --era-radius-sm: 10px;
  --era-radius-md: 14px;
  --era-radius-lg: 20px;

  --era-shadow-sm: 0 6px 20px rgba(27, 78, 122, 0.12);
  --era-shadow-md: 0 12px 34px rgba(27, 78, 122, 0.16);

  --era-container: 1120px;

  --era-font-heading: "Nunito", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --era-font-body: "Lato", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Base */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: var(--era-font-body);
  color: var(--era-text);
  background: linear-gradient(180deg, var(--era-white) 0%, var(--era-sand-neutral) 100%);
  line-height: 1.6;
}
img{ max-width:100%; height:auto; }
a{
  color: var(--era-ocean-teal);
  text-decoration: none;
}
a:hover, a:focus{ text-decoration: underline; }

.container{
  width: min(100% - 2rem, var(--era-container));
  margin-inline: auto;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(44, 166, 177, 0.18);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  padding: 0.9rem 0;
}
.site-title a{
  font-family: var(--era-font-heading);
  color: var(--era-deep-ocean);
  font-weight: 900;
  letter-spacing: 0.2px;
  font-size: 1.15rem;
}
.site-tagline{
  font-size: 0.9rem;
  opacity: 0.85;
}

.nav-primary ul{
  display:flex;
  list-style:none;
  margin:0;
  padding:0;
  gap: 0.2rem;
  flex-wrap: wrap;
  align-items:center;
}
.nav-primary a{
  display:inline-block;
  padding: 0.6rem 0.85rem;
  border-radius: 999px;
  font-weight: 700;
  color: var(--era-deep-ocean);
}
.nav-primary a:hover{
  background: rgba(44, 166, 177, 0.10);
  text-decoration: none;
}

/* Buttons */
.button, .wp-block-button__link, button, input[type="submit"]{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 0.5rem;
  border: 0;
  border-radius: 12px;
  padding: 0.75rem 1.05rem;
  font-weight: 800;
  cursor: pointer;
  transition: transform .05s ease, box-shadow .2s ease, background .2s ease;
}
.wp-block-button__link, input[type="submit"], .button--primary{
  background: var(--era-golden-sun);
  color: #1f2b35;
  box-shadow: var(--era-shadow-sm);
}
.wp-block-button__link:hover, input[type="submit"]:hover, .button--primary:hover{
  background: var(--era-warm-coral);
  text-decoration:none;
}
.button--secondary{
  background: rgba(44, 166, 177, 0.16);
  color: var(--era-deep-ocean);
}
.button:active, .wp-block-button__link:active, input[type="submit"]:active{
  transform: translateY(1px);
}

/* Cards */
.card{
  background: var(--era-white);
  border-radius: var(--era-radius-lg);
  box-shadow: var(--era-shadow-sm);
  border: 1px solid rgba(27, 78, 122, 0.08);
}
.card-pad{ padding: 1.25rem; }

/* Hero (optional via block pattern or template) */
.hero{
  padding: 3.2rem 0 2.2rem;
  background:
    radial-gradient(circle at 15% 10%, rgba(44,166,177,0.20), transparent 50%),
    radial-gradient(circle at 85% 20%, rgba(246,185,59,0.22), transparent 50%),
    linear-gradient(180deg, var(--era-white) 0%, var(--era-soft-aqua) 60%, var(--era-sand-neutral) 100%);
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 1.4rem;
  align-items:center;
}
@media (max-width: 860px){
  .hero-grid{ grid-template-columns: 1fr; }
}
.hero h1{
  font-family: var(--era-font-heading);
  color: var(--era-deep-ocean);
  font-size: clamp(2rem, 3vw + 1rem, 3.1rem);
  line-height: 1.1;
  margin: 0 0 0.75rem;
}
.hero p{
  font-size: 1.08rem;
  max-width: 55ch;
  margin: 0 0 1.1rem;
}
.badges{
  display:flex; flex-wrap:wrap; gap:0.5rem;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  padding: 0.38rem 0.7rem;
  border-radius: 999px;
  background: rgba(223, 246, 248, 0.9);
  border: 1px solid rgba(44,166,177,0.22);
  font-weight: 800;
  color: var(--era-deep-ocean);
  font-size: 0.92rem;
}

/* Content */
.site-main{
  padding: 1.8rem 0 2.8rem;
}
.entry-title{
  font-family: var(--era-font-heading);
  color: var(--era-deep-ocean);
}
.entry-content p{
  margin: 0 0 1rem;
}

/* Forms */
input[type="text"], input[type="email"], input[type="tel"], textarea, select{
  width: 100%;
  padding: 0.8rem 0.9rem;
  border-radius: 12px;
  border: 1px solid rgba(27, 78, 122, 0.16);
  background: rgba(255,255,255,0.9);
}
input:focus, textarea:focus, select:focus{
  outline: 3px solid rgba(44,166,177,0.22);
  border-color: rgba(44,166,177,0.6);
}

/* Footer */
.site-footer{
  background: var(--era-deep-ocean);
  color: rgba(255,255,255,0.9);
  padding: 2rem 0;
}
.site-footer a{ color: var(--era-soft-aqua); }

/* Accessibility */
.screen-reader-text{
  border:0; clip: rect(1px,1px,1px,1px);
  clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden;
  padding: 0; position: absolute; width: 1px; white-space: nowrap;
}

/* Gutenberg wide alignment support */
.wp-site-blocks, .wp-block-group{
  max-width: var(--era-container);
  margin-inline: auto;
}


/* === ERA EXTRA HOMEPAGE STYLES === */

/* Layout helpers */
.section{ padding: 2.6rem 0; }
.section--soft{
  background: linear-gradient(180deg, var(--era-soft-aqua) 0%, rgba(223,246,248,0.35) 100%);
}
.section--sand{ background: var(--era-sand-neutral); }
.section-header{ margin-bottom: 1.1rem; }
.lede{ margin: .35rem 0 0; font-size: 1.05rem; max-width: 70ch; }

.grid-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.grid-2{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media (max-width: 860px){
  .grid-3{ grid-template-columns: 1fr; }
  .grid-2{ grid-template-columns: 1fr; }
}

.h3{
  font-family: var(--era-font-heading);
  color: var(--era-deep-ocean);
  margin: 0 0 .35rem;
}

.cta-row{ display:flex; gap:.75rem; flex-wrap:wrap; }

/* Trust strip pills */
.trust-strip{ display:flex; flex-wrap:wrap; gap:.55rem; margin-top: 1rem; }
.trust-pill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding: .45rem .75rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(44,166,177,0.22);
  box-shadow: 0 8px 18px rgba(27, 78, 122, 0.08);
  font-weight: 900;
  color: var(--era-deep-ocean);
  font-size: .93rem;
}
.trust-pill svg{
  width: 18px; height: 18px;
  fill: none;
  stroke: var(--era-ocean-teal);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Hero card details */
.hero-card .note{
  padding: .75rem .85rem;
  border-radius: 14px;
  background: rgba(223,246,248,0.65);
  border: 1px solid rgba(44,166,177,0.22);
  font-weight: 700;
}
.mini-list{ display:grid; gap:.4rem; margin-top: .9rem; }
.mini-item{ font-weight: 800; opacity: .92; }

/* Wave divider */
.wave{
  height: 56px;
  background:
    radial-gradient(circle at 10% 30%, rgba(44,166,177,0.25), transparent 55%),
    radial-gradient(circle at 85% 50%, rgba(246,185,59,0.25), transparent 55%),
    linear-gradient(180deg, transparent 0%, rgba(248,244,236,0.9) 100%);
  clip-path: path("M0,40 C160,70 320,10 480,40 C640,70 800,10 960,40 C1120,70 1280,10 1440,40 L1440,80 L0,80 Z");
}
@supports not (clip-path: path("M0,0 L1,1")) {
  .wave{ clip-path: polygon(0 30%, 100% 0, 100% 100%, 0 100%); }
}

/* Testimonials */
.testimonial blockquote{
  margin:0;
  font-size: 1.05rem;
  font-weight: 700;
}
.testimonial figcaption{
  margin-top: .75rem;
  font-weight: 900;
  color: rgba(27, 78, 122, 0.9);
}

/* CTA banner */
.cta-banner{
  margin-top: 1.2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  background:
    radial-gradient(circle at 10% 30%, rgba(44,166,177,0.18), transparent 55%),
    radial-gradient(circle at 90% 40%, rgba(255,127,80,0.20), transparent 55%),
    var(--era-white);
}
@media (max-width: 680px){
  .cta-banner{ flex-direction:column; align-items:flex-start; }
}

/* Center CTA */
.center-cta{ display:flex; justify-content:center; margin-top: 1rem; }


/* === ERA MOBILE NAV + CPT STYLES === */

/* Mobile menu toggle */
.menu-toggle{
  display:none;
  background: rgba(44, 166, 177, 0.10);
  border: 1px solid rgba(44, 166, 177, 0.22);
  border-radius: 999px;
  padding: .55rem .7rem;
  box-shadow: 0 10px 22px rgba(27, 78, 122, 0.10);
}
.menu-toggle__bar{
  display:block;
  width: 22px;
  height: 2px;
  background: var(--era-deep-ocean);
  margin: 4px 0;
  border-radius: 10px;
}

/* Desktop menu */
.nav-primary .primary-menu{
  display:flex;
  list-style:none;
  margin:0;
  padding:0;
  gap: .2rem;
  flex-wrap: wrap;
  align-items:center;
}

/* Mobile menu overlay */
@media (max-width: 860px){
  .menu-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .nav-primary{
    position: fixed;
    inset: 72px 1rem auto 1rem;
    max-width: 520px;
    margin-inline: auto;
    background: rgba(255,255,255,0.96);
    border: 1px solid rgba(27, 78, 122, 0.10);
    border-radius: 18px;
    box-shadow: 0 20px 60px rgba(27, 78, 122, 0.22);
    padding: .65rem;
    transform: translateY(-10px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
  }
  body.nav-open .nav-primary{
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .nav-primary .primary-menu{
    display:grid;
    gap: .35rem;
  }
  .nav-primary a{
    width: 100%;
    padding: .75rem .85rem;
    border-radius: 14px;
    background: rgba(223,246,248,0.55);
  }
  body.nav-open::before{
    content:"";
    position: fixed;
    inset:0;
    background: rgba(47,58,69,0.38);
    backdrop-filter: blur(2px);
    z-index: 998;
  }
  .site-header{ z-index: 999; }
}

/* Page template helpers */
.page-hero{
  padding: 2.2rem 0 1.2rem;
  background:
    radial-gradient(circle at 12% 18%, rgba(44,166,177,0.18), transparent 55%),
    radial-gradient(circle at 88% 28%, rgba(246,185,59,0.18), transparent 55%),
    linear-gradient(180deg, var(--era-white) 0%, rgba(223,246,248,0.55) 100%);
}
.page-hero h1{
  font-family: var(--era-font-heading);
  color: var(--era-deep-ocean);
  margin: 0 0 .5rem;
}
.kicker{ font-weight: 900; color: rgba(27,78,122,.92); opacity: .95; }
.icon-list{ display:grid; gap:.55rem; margin: .9rem 0 0; }
.icon-list .item{ display:flex; gap:.55rem; align-items:flex-start; font-weight: 800; }

/* Destinations (CPT) */
.destinations-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
@media (max-width: 980px){
  .destinations-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px){
  .destinations-grid{ grid-template-columns: 1fr; }
}
.destination-card .thumb{
  aspect-ratio: 4 / 3;
  border-radius: 18px;
  overflow:hidden;
  background: rgba(223,246,248,0.6);
  border: 1px solid rgba(27, 78, 122, 0.10);
  margin-bottom: .75rem;
}
.destination-card .thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.destination-card .meta{
  font-weight: 900;
  color: rgba(27,78,122,0.86);
  font-size: .95rem;
}


/* === ERA FEATURED DESTINATIONS TWEAKS === */
/* Featured destinations polish */
.destination-card .entry-content { opacity: .95; }
.destination-card .entry-title { color: var(--era-deep-ocean); }
.destination-card a:hover .entry-title { text-decoration: underline; }
.destination-card .thumb:empty {
  display:flex;
  align-items:center;
  justify-content:center;
}


/* === ERA NAV DROPDOWNS + CTA + SHRINK === */

/* Sticky header shrink */
body.header-shrink .header-inner{
  padding: 0.55rem 0;
}
body.header-shrink .site-title a{
  font-size: 1.05rem;
}

/* CTA menu item (Start Planning) */
.nav-primary .menu-cta > a{
  background: var(--era-golden-sun);
  color: #1f2b35;
  box-shadow: var(--era-shadow-sm);
}
.nav-primary .menu-cta > a:hover{
  background: var(--era-warm-coral);
}

/* Dropdowns (desktop) */
.nav-primary .menu-item-has-children{ position: relative; }
.nav-primary .menu-item-has-children > a::after{
  content: "▾";
  margin-left: .35rem;
  font-size: .9em;
  opacity: .8;
}
.nav-primary ul ul{
  list-style:none;
  margin: 0;
  padding: .5rem;
  position: absolute;
  top: calc(100% + .35rem);
  left: 0;
  min-width: 220px;
  background: rgba(255,255,255,0.98);
  border: 1px solid rgba(27, 78, 122, 0.10);
  border-radius: 16px;
  box-shadow: 0 18px 55px rgba(27, 78, 122, 0.22);
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity .15s ease, transform .15s ease;
  z-index: 999;
}
.nav-primary ul ul a{
  display:block;
  padding: .6rem .75rem;
  border-radius: 12px;
  color: var(--era-deep-ocean);
  font-weight: 800;
}
.nav-primary ul ul a:hover{
  background: rgba(223,246,248,0.75);
  text-decoration:none;
}
.nav-primary .menu-item-has-children:hover > ul,
.nav-primary .menu-item-has-children:focus-within > ul{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Mobile submenu controls */
.submenu-toggle{
  display:none;
  background: transparent;
  border: 0;
  padding: .55rem .65rem;
  border-radius: 12px;
  font-weight: 900;
  color: var(--era-deep-ocean);
}
@media (max-width: 860px){
  .nav-primary .menu-item-has-children > a::after{ content: ""; }
  .submenu-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .nav-primary .menu-item-has-children{
    display:grid;
    grid-template-columns: 1fr auto;
    align-items:center;
  }
  .nav-primary .menu-item-has-children > ul{
    position: static;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    box-shadow: none;
    border-radius: 14px;
    border: 1px solid rgba(27,78,122,0.10);
    background: rgba(255,255,255,0.85);
    padding: .35rem;
    grid-column: 1 / -1;
    display:none;
  }
  .nav-primary .menu-item-has-children.submenu-open > ul{
    display:block;
  }
}


/* === Destination Template Layout === */

.destination-layout {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1.5rem;
  margin-top: 1.5rem;
}

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

.destination-hero-image img {
  width: 100%;
  height: auto;
  border-radius: 18px;
  display: block;
}

.destination-meta-badges {
  margin-top: .75rem;
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}

.destination-highlights {
  list-style: none;
  padding: 0;
  margin: .75rem 0 0;
}

.destination-highlights li {
  margin-bottom: .5rem;
  font-weight: 700;
}

.sidebar-box {
  margin-bottom: 1rem;
}

.cta-box {
  background: linear-gradient(
    180deg,
    rgba(246,185,59,0.15) 0%,
    rgba(255,127,80,0.15) 100%
  );
}



/* === ERA DYNAMIC DESTINATION SIDEBAR + RELATED === */
.destination-sidebar .card{ position: relative; }
@media (min-width: 981px) {
  .destination-sidebar .cta-box{ position: sticky; top: 96px; }
}
.destination-highlights strong{ font-weight: 900; }


/* === ERA TILE OPTION C (FLIGHT + EXCERPT) === */
.tile-flight{
  margin-top: .1rem;
  font-weight: 900;
  color: rgba(27,78,122,0.86);
  font-size: .95rem;
}
.destination-card__link{
  display:block;
  color: inherit;
}
.destination-card__link:hover .destination-card__title{
  text-decoration: underline;
}
.destination-card__title{
  margin:0 0 .25rem;
  font-size: 1.15rem;
}
.destination-card__excerpt{
  margin-top: .55rem;
  opacity: .95;
}
