/*
Theme Name: Vortex Spring Adventures
Theme URI: https://staging.vortexspring.com
Author: Gravity Web Designs
Author URI: https://gravitywebdesigns.com
Description: Custom hybrid block theme for Vortex Spring Adventures. Playful adventure-resort design with a navy / red / yellow / blue palette, chunky display headings, wavy section dividers and overlapping cards. The homepage is built from native, fully-editable Gutenberg blocks; structural styling and section dividers live in theme CSS so the design stays intact while content is editable.
Version: 1.2.5
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vortex-adventures
Tags: full-site-editing, block-patterns, custom-colors, custom-menu, featured-images, one-column, wide-blocks
*/

/* =========================================================
   Tokens (mirrored in theme.json for the editor)
   ========================================================= */
:root{
  --vx-navy:#0c2c4d; --vx-navy-deep:#08233f;
  --vx-blue:#1e7fc2; --vx-blue-bright:#2ba0db;
  --vx-blue-light:#e8f4fb; --vx-blue-pale:#d4eaf7;
  --vx-red:#e23b2e; --vx-red-dark:#c5281c;
  --vx-yellow:#f7b51c; --vx-gold:#ffc524;
  --vx-green:#4fa829; --vx-teal:#17b3aa; --vx-orange:#f08a24; --vx-purple:#7e57c2;
  --vx-ink:#1f2d3d; --vx-muted:#5b6b7b; --vx-white:#ffffff;
  --vx-display:"Luckiest Guy","Poppins",system-ui,sans-serif;
  --vx-script:"Pacifico",cursive;
  --vx-body:"Poppins",system-ui,-apple-system,"Segoe UI",sans-serif;
  --vx-container:1200px; --vx-radius:18px; --vx-shadow:0 18px 40px rgba(8,35,63,.12);
}

*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--vx-body);color:var(--vx-ink);background:var(--vx-white);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.vx-container{max-width:var(--vx-container);margin:0 auto;padding:0 24px}

/* =========================================================
   Buttons (core button overrides via utility classes)
   ========================================================= */
.vx-btn--red>.wp-block-button__link,
.vx-btn--ghost>.wp-block-button__link,
.vx-btn--yellow>.wp-block-button__link,
.vx-btn--blue>.wp-block-button__link{
  border-radius:50px;font-family:var(--vx-body);font-weight:700;font-size:14px;
  letter-spacing:.5px;text-transform:uppercase;padding:15px 30px;border:none;line-height:1;
  transition:transform .15s ease,background .15s ease,box-shadow .15s ease;
}
.vx-btn--red>.wp-block-button__link:hover,
.vx-btn--ghost>.wp-block-button__link:hover,
.vx-btn--yellow>.wp-block-button__link:hover,
.vx-btn--blue>.wp-block-button__link:hover{transform:translateY(-3px)}
.vx-btn--red>.wp-block-button__link{background:var(--vx-red);color:#fff;box-shadow:0 10px 22px rgba(226,59,46,.35)}
.vx-btn--red>.wp-block-button__link:hover{background:var(--vx-red-dark)}
.vx-btn--yellow>.wp-block-button__link{background:var(--vx-gold);color:var(--vx-navy);box-shadow:0 10px 22px rgba(247,181,28,.4)}
.vx-btn--yellow>.wp-block-button__link:hover{background:var(--vx-yellow)}
.vx-btn--blue>.wp-block-button__link{background:var(--vx-blue);color:#fff;box-shadow:0 10px 22px rgba(30,127,194,.3)}
.vx-btn--ghost>.wp-block-button__link{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.85)}
.vx-btn--ghost>.wp-block-button__link:hover{background:#fff;color:var(--vx-navy)}

/* Eyebrow + section titles */
.vx-eyebrow{font-family:var(--vx-body);font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:14px;color:var(--vx-blue);margin:0 0 10px;display:flex;align-items:center;gap:10px}
.has-text-align-center.vx-eyebrow{justify-content:center}
.vx-eyebrow::before,.vx-eyebrow::after{content:"🌿";font-size:15px}
.vx-section-title{font-family:var(--vx-display);font-weight:400;font-size:clamp(34px,5vw,56px);line-height:1.05;margin:0 0 14px;color:var(--vx-navy);letter-spacing:.5px}
.vx-section-title mark.has-inline-color{background:transparent}

/* =========================================================
   HEADER (unchanged markup pattern)
   ========================================================= */
.vortex-header{position:sticky;top:0;z-index:999;background:var(--vx-navy);box-shadow:0 4px 18px rgba(8,35,63,.25)}
.vortex-header__inner{max-width:1280px;margin:0 auto;padding:10px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.vortex-logo{display:flex;align-items:center;gap:11px}
.vortex-logo__mark{height:58px;width:58px}
.vortex-logo__text{display:flex;flex-direction:column;line-height:.86}
.vortex-logo__text .vx-l1{font-family:var(--vx-display);font-size:23px;color:var(--vx-red);letter-spacing:1px;-webkit-text-stroke:.6px #fff}
.vortex-logo__text .vx-l2{font-family:var(--vx-script);font-size:20px;color:var(--vx-gold);margin:-2px 0 -1px 2px}
.vortex-logo__text .vx-l3{font-family:var(--vx-body);font-weight:800;font-size:10px;letter-spacing:3px;color:#fff}
.vortex-footer .vortex-logo__text .vx-l3{color:#cdddea}
.vortex-logo--custom{gap:0}
.vortex-header .custom-logo{height:60px;width:auto;display:block}
.vortex-header .custom-logo-link{display:flex;align-items:center;line-height:0}
.vortex-footer .custom-logo{height:78px;width:auto;display:block;margin-bottom:16px}
.vortex-footer .custom-logo-link{display:inline-flex;line-height:0}
.vortex-nav{display:flex;align-items:center;gap:30px}
.vortex-nav ul{list-style:none;display:flex;gap:26px;margin:0;padding:0}
.vortex-nav li{list-style:none;margin:0;padding:0}
.vortex-nav a{color:#fff;font-weight:600;font-size:14px;letter-spacing:1px;text-transform:uppercase;transition:color .15s}
.vortex-nav a:hover{color:var(--vx-gold)}
.vortex-nav .active>a,.vortex-nav .current-menu-item>a,.vortex-nav .current_page_item>a,.vortex-nav .current-menu-ancestor>a{color:var(--vx-gold)}
.vortex-nav .sub-menu{display:none}
.vortex-header .vx-book{background:var(--vx-gold);color:var(--vx-navy);font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:14px;padding:13px 26px;border-radius:50px;display:inline-flex;align-items:center;gap:9px;box-shadow:0 8px 18px rgba(247,181,28,.4);transition:transform .15s}
.vortex-header .vx-book:hover{transform:translateY(-2px)}
.vortex-burger{display:none;background:none;border:none;color:#fff;font-size:28px;cursor:pointer}

/* =========================================================
   Homepage wrapper resets (tame default block spacing)
   ========================================================= */
.vortex-home{--wp--style--block-gap:0}
.vortex-home>.wp-block-post-content{margin:0}
.vortex-home :where(.vortex-hero,.vortex-features,.vortex-attractions,.vortex-getaway,.vortex-testimonials,.vortex-cta){margin-block:0}
/* Remove the gap/white lines between header, main and footer (top-level blocks) */
.wp-site-blocks>*{margin-block:0!important}
.wp-block-post-content>:first-child{margin-top:0!important}
.wp-block-post-content>:last-child{margin-bottom:0!important}

/* =========================================================
   HERO (core/cover)
   ========================================================= */
.vortex-hero.wp-block-cover{min-height:88vh;align-items:center;justify-content:flex-start;color:#fff;position:relative;overflow:hidden}
.vortex-hero .wp-block-cover__background{background:linear-gradient(100deg,rgba(8,35,63,.88) 0%,rgba(8,35,63,.55) 42%,rgba(8,35,63,.05) 74%)!important;opacity:1!important}
.vortex-hero .wp-block-cover__inner-container{width:100%;max-width:1280px;margin:0 auto;padding:90px 24px;z-index:2}
.vortex-hero__content{max-width:640px;text-align:left;margin:0!important}
.vortex-hero__content>*{margin-top:0}
.vortex-hero__l1,.vortex-hero__l2,.vortex-hero__l3{font-family:var(--vx-display);font-weight:400;line-height:.92;margin:0;font-size:clamp(46px,8vw,100px);text-shadow:3px 4px 0 rgba(8,35,63,.35)}
.vortex-hero__l1{color:#fff;-webkit-text-stroke:2px var(--vx-blue)}
.vortex-hero__l2{color:#fff}
.vortex-hero__l3{color:var(--vx-gold)}
.vortex-hero__ribbon{display:inline-block;background:var(--vx-blue);color:#fff;font-weight:600;letter-spacing:.5px;padding:11px 22px;border-radius:8px;margin:22px 0 26px!important;font-size:clamp(15px,2vw,19px);box-shadow:0 8px 18px rgba(8,35,63,.3)}
.vortex-hero__btns{display:flex;gap:16px;flex-wrap:wrap}
.vortex-hero__sign{position:absolute;top:50%;right:24px;transform:translateY(-50%);z-index:3;background:linear-gradient(#9c6b3f,#7c5230);border:4px solid #5e3d22;border-radius:14px;padding:14px 22px;text-align:center;box-shadow:var(--vx-shadow);max-width:210px}
.vortex-hero__sign .label{font-family:var(--vx-display);font-size:15px;letter-spacing:1px;color:var(--vx-gold);margin:0}
.vortex-hero__sign .time{font-weight:700;font-size:19px;color:#fff;margin:4px 0 0}
/* white wave divider into the features/white area */
.vortex-hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:84px;z-index:4;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 84' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,42 C300,90 520,8 760,40 C980,70 1180,12 1440,44 L1440,84 L0,84 Z'/%3E%3C/svg%3E") no-repeat center/100% 100%}

/* =========================================================
   FEATURES (core/columns floating card)
   ========================================================= */
.vortex-features{position:relative;z-index:5;margin-top:-72px!important;padding:0 24px}
.vortex-features__card.wp-block-columns{background:#fff;border-radius:26px;box-shadow:var(--vx-shadow);padding:42px 26px;gap:0;margin:0;align-items:flex-start}
.vortex-feature.wp-block-column{text-align:center;padding:0 22px;position:relative}
.vortex-features__card>.wp-block-column+.wp-block-column::before{content:"";position:absolute;left:0;top:6px;bottom:6px;border-left:2px dotted #cfdded}
.vortex-feature__icon{width:66px;height:66px;border-radius:50%;margin:0 auto 14px!important;display:flex;align-items:center;justify-content:center;font-size:30px;line-height:1;border:2px solid transparent}
.vf-1 .vortex-feature__icon{background:#e3f3d8;border-color:var(--vx-green)}
.vf-2 .vortex-feature__icon{background:#fce0dd;border-color:var(--vx-red)}
.vf-3 .vortex-feature__icon{background:#dcecf8;border-color:var(--vx-blue)}
.vf-4 .vortex-feature__icon{background:#fce6d2;border-color:var(--vx-orange)}
.vortex-feature h3{font-family:var(--vx-body);font-weight:800;font-size:16px;letter-spacing:.5px;text-transform:uppercase;margin:0 0 6px;color:var(--vx-navy)}
.vortex-feature p{margin:0;font-size:14px;color:var(--vx-muted);line-height:1.5}

/* =========================================================
   ATTRACTIONS (core/group carousel)
   ========================================================= */
.vortex-attractions{background:var(--vx-blue-light);padding:96px 0 100px!important;position:relative}
/* white wave coming down from the white features band */
.vortex-attractions::before{content:"";position:absolute;top:-1px;left:0;width:100%;height:68px;z-index:2;pointer-events:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 68' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,0 H1440 V34 C1160,68 980,8 720,36 C470,64 250,10 0,40 Z'/%3E%3C/svg%3E") no-repeat center/100% 100%}
.vortex-attractions__head{align-items:flex-end;margin-bottom:38px;gap:20px}
.vortex-attractions__head .titles{text-align:left}
.vortex-carousel{position:relative}
.vortex-track{display:flex!important;flex-wrap:nowrap!important;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:18px 12px 40px;-ms-overflow-style:none;scrollbar-width:none;margin:0 -12px}
.vortex-track::-webkit-scrollbar{display:none}
.vortex-card.wp-block-group{flex:0 0 278px;scroll-snap-align:start;background:#fff;border-radius:var(--vx-radius);overflow:hidden;box-shadow:0 12px 26px rgba(8,35,63,.1);transition:transform .2s;margin:0;padding:0}
.vortex-card:hover{transform:translateY(-8px)}
.vortex-card__img{position:relative;margin:0!important;padding:0}
.vortex-card__photo{margin:0!important}
.vortex-card__photo img{width:100%;height:200px;object-fit:cover;display:block;border-radius:0}
.vortex-card__tag{position:absolute;left:50%;bottom:-14px;transform:translateX(-50%);color:#fff;font-weight:700;font-size:12px;letter-spacing:1px;text-transform:uppercase;padding:8px 18px;border-radius:50px;white-space:nowrap;margin:0;box-shadow:0 6px 14px rgba(8,35,63,.25)}
.vortex-card__title{font-family:var(--vx-body);font-weight:800;font-size:17px;text-transform:uppercase;color:var(--vx-navy);text-align:center;margin:0;padding:30px 16px 26px;line-height:1.3}
.tag-red{background:var(--vx-red)}.tag-blue{background:var(--vx-blue)}.tag-green{background:var(--vx-green)}
.tag-orange{background:var(--vx-orange)}.tag-teal{background:var(--vx-teal)}.tag-purple{background:var(--vx-purple)}
.tag-yellow{background:var(--vx-yellow);color:var(--vx-navy)}.tag-navy{background:var(--vx-navy)}
.vortex-arrow{position:absolute;top:42%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:#fff;border:none;box-shadow:0 8px 18px rgba(8,35,63,.18);color:var(--vx-blue);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:4;transition:background .15s,color .15s}
.vortex-arrow:hover{background:var(--vx-blue);color:#fff}
.vortex-arrow--prev{left:-18px}.vortex-arrow--next{right:-18px}

/* =========================================================
   ADVENTURE GETAWAY (core/columns)
   ========================================================= */
.vortex-getaway.wp-block-columns{gap:0!important;margin:0;align-items:stretch;background:transparent;position:relative}
/* light-blue wave flowing down from the attractions band into this section */
.vortex-getaway::before{content:"";position:absolute;top:-1px;left:0;width:100%;height:60px;z-index:6;pointer-events:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath fill='%23e8f4fb' d='M0,0 H1440 V30 C1160,60 980,6 720,30 C470,56 250,8 0,32 Z'/%3E%3C/svg%3E") no-repeat center/100% 100%}
.vortex-getaway__left.wp-block-column{background:var(--vx-red);padding:70px 60px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;flex:0 0 56%;width:56%;max-width:56%;min-height:540px}
.vortex-getaway__left .kicker{font-family:var(--vx-display);color:#fff;font-size:clamp(22px,3vw,32px);letter-spacing:1px;margin:0}
.vortex-getaway__left .big{font-family:var(--vx-script);color:var(--vx-gold);font-size:clamp(44px,6vw,80px);line-height:1;margin:2px 0 24px!important;text-shadow:2px 3px 0 rgba(8,35,63,.25);font-weight:400}
.vortex-getaway__list{list-style:none;margin:0 0 28px!important;padding:0;display:flex;flex-direction:column;gap:12px}
.vortex-getaway__list li{display:flex;align-items:center;gap:12px;color:#fff;font-weight:600;font-size:17px}
.vortex-getaway__list li::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#fff;color:var(--vx-red);font-weight:800;font-size:14px;flex:none}
.vortex-getaway__right.wp-block-column{padding:0;position:relative;z-index:2;flex:0 0 56%;width:56%;max-width:56%;min-height:540px;margin-left:-12%;clip-path:polygon(16% 0,100% 0,100% 100%,0 100%)}
.vortex-getaway__cover.wp-block-cover{min-height:540px;height:100%}
.vortex-getaway__badge{position:absolute;top:50%;right:44px;transform:translateY(-50%);width:158px;height:158px;border-radius:50%;background:var(--vx-gold);color:var(--vx-navy);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:var(--vx-shadow);border:5px solid #fff}
.vortex-getaway__badge .sm{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;line-height:1.2;margin:0;padding:0 14px}
.vortex-getaway__badge .price{font-family:var(--vx-display);font-size:40px;line-height:1;margin:2px 0}
.vortex-getaway__badge .per{font-size:10px;font-weight:700;text-transform:uppercase;margin:0}

/* =========================================================
   TESTIMONIALS (core/columns)
   ========================================================= */
.vortex-testimonials{background:#fff;padding:90px 0 100px!important;text-align:center}
.vortex-testimonials .vx-eyebrow::before,.vortex-testimonials .vx-eyebrow::after{content:"✦"}
.vortex-reviews.wp-block-columns{gap:26px;margin-top:42px}
.vortex-review.wp-block-column{background:#fff;border:1px solid #e6eef5;border-radius:var(--vx-radius);padding:34px 28px 30px;box-shadow:0 12px 26px rgba(8,35,63,.07);text-align:center}
.vortex-review__avatar{margin:0 auto 14px!important}
.vortex-review__avatar img{width:74px;height:74px;border-radius:50%;object-fit:cover;border:4px solid var(--vx-blue-light)}
.vortex-review__stars{color:var(--vx-gold);font-size:18px;letter-spacing:2px;margin:0 0 14px}
.vortex-review__title{font-weight:800;color:var(--vx-navy);font-size:18px;margin:0 0 8px}
.vortex-review__text{color:var(--vx-muted);font-size:15px;margin:0 0 16px}
.vortex-review__name{font-weight:700;color:var(--vx-red);font-size:14px;margin:0}
.vortex-review__name::before{content:"– "}

/* =========================================================
   CTA BAND (core/group)
   ========================================================= */
.vortex-cta{background:linear-gradient(120deg,var(--vx-blue) 0%,var(--vx-blue-bright) 100%);color:#fff;text-align:center;padding:64px 24px!important;position:relative;overflow:hidden}
.vortex-cta::before{content:"";position:absolute;top:0;left:0;width:100%;height:140px;opacity:.18;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 140' preserveAspectRatio='none'%3E%3Cpath fill='%230c2c4d' d='M0 140 L240 60 L420 120 L640 40 L860 120 L1080 50 L1260 120 L1440 70 L1440 140 Z'/%3E%3C/svg%3E") no-repeat center/100% 100%}
.vortex-cta__inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}
.vortex-cta .text{text-align:left}
.vortex-cta__title{font-family:var(--vx-display);font-size:clamp(28px,4vw,46px);margin:0;letter-spacing:.5px}
.vortex-cta .text p{margin:6px 0 0;font-size:17px;opacity:.92}

/* =========================================================
   FOOTER (unchanged markup pattern)
   ========================================================= */
.vortex-footer{background:var(--vx-navy);color:#cdddea;position:relative;padding:80px 0 0}
.vortex-footer__grid{max-width:1200px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:34px}
.vortex-footer__brand img,.vortex-footer__brand svg{height:74px;margin-bottom:16px}
.vortex-footer__brand p{font-size:14px;color:#9fb6c9;line-height:1.7;max-width:260px}
.vortex-footer h4{color:#fff;font-family:var(--vx-body);font-weight:800;text-transform:uppercase;letter-spacing:1px;font-size:15px;margin:0 0 18px}
.vortex-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.vortex-footer ul a{font-size:14px;color:#9fb6c9;transition:color .15s}
.vortex-footer ul a:hover{color:var(--vx-gold)}
.vortex-footer__contact p{font-size:14px;color:#9fb6c9;margin:0 0 10px;line-height:1.6}
.vortex-footer__bottom{margin-top:60px;border-top:1px solid rgba(255,255,255,.12);padding:22px 24px;text-align:center}
.vortex-footer__bottom .vx-container{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;color:#9fb6c9}
.vortex-footer__bottom a:hover{color:var(--vx-gold)}
.vortex-footer .vx-mountains{position:absolute;top:0;left:0;width:100%;opacity:.18;line-height:0}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .vortex-features__card.wp-block-columns{flex-wrap:wrap}
  .vortex-feature.wp-block-column{flex-basis:48%!important;margin-bottom:24px}
  .vortex-features__card>.wp-block-column+.wp-block-column::before{display:none}
  .vortex-getaway__left.wp-block-column{clip-path:none}
  .vortex-footer__grid{grid-template-columns:1fr 1fr 1fr}
}
@media(max-width:860px){
  .vortex-nav ul{display:none}
  .vortex-burger{display:block}
  .vortex-hero__sign{display:none}
  .vortex-getaway.wp-block-columns{flex-direction:column}
  .vortex-getaway__left.wp-block-column{flex:1 1 auto;width:auto;max-width:none;clip-path:none;min-height:auto}
  .vortex-getaway__right.wp-block-column{flex:1 1 auto;width:auto;max-width:none;margin-left:0;clip-path:none;min-height:320px}
  .vortex-getaway__badge{right:24px;width:130px;height:130px}
  .vortex-cta__inner{flex-direction:column}
  .vortex-cta .text{text-align:center}
  .vortex-footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .vortex-feature.wp-block-column{flex-basis:100%!important}
  .vortex-footer__grid{grid-template-columns:1fr}
}

/* Mobile nav drawer */
.vortex-nav.open ul{display:flex;flex-direction:column;position:absolute;top:84px;left:0;right:0;background:var(--vx-navy-deep);padding:20px 24px;gap:16px}
