/*
Theme Name: GTA Corporate
Theme URI: https://www.puregrenada.com
Author: Grenada Tourism Authority
Author URI: https://www.puregrenada.com
Description: A modern, Apple-inspired corporate theme for the Grenada Tourism Authority. Fully customizable via the WordPress Customizer — change all images, text, icons, colors, and more without touching code.
Version: 1.0.0
Requires at least: 6.0
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: gta-theme
Tags: custom-logo, custom-menu, featured-images, theme-options, one-column, two-columns
*/

/* ═══════════════════════════════════════
   CSS VARIABLES — all overridable via Customizer
   ═══════════════════════════════════════ */
:root {
  --cr: #A4133C;
  --crd: #7A0E2D;
  --deep: #0f0f12;
  --w: #ffffff;
  --g50: #fafafa;
  --g100: #f5f5f7;
  --g200: #e8e8ed;
  --g400: #86868b;
  --g600: #6e6e73;
  --g800: #1d1d1f;
  --txt: #1d1d1f;
  --txs: #6e6e73;
  --e: cubic-bezier(.25,.1,.25,1);
  --r: 18px;
}

/* ═══════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--txt);background:var(--w);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}

/* ═══════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════ */
.nav-wrap{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.72);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(0,0,0,.04);transition:all .3s var(--e)}
.nav-wrap.scrolled{background:rgba(255,255,255,.94);box-shadow:0 .5px 0 rgba(0,0,0,.08)}
.site-nav{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:54px}
.nav-brand{display:flex;align-items:center;gap:10px}
.nav-brand img{height:30px;width:auto}
.nav-brand-text{font-size:16px;font-weight:700;color:var(--cr);letter-spacing:-.3px}

/* WP Nav Menu Styling */
.nav-menu{display:flex;align-items:center;gap:28px;list-style:none}
.nav-menu li{position:relative}
.nav-menu>li>a{font-size:13px;font-weight:500;color:var(--txt);padding:18px 0;display:flex;align-items:center;gap:4px;transition:color .15s}
.nav-menu>li>a:hover{color:var(--cr)}
.menu-item-has-children>a::after{content:'';display:inline-block;width:8px;height:8px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 5l3 3 3-3' stroke='currentColor' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;opacity:.45;transition:transform .2s}
.menu-item-has-children:hover>a::after{transform:rotate(180deg)}

/* Dropdown */
.nav-menu .sub-menu{position:absolute;top:calc(100% + 2px);left:50%;transform:translateX(-50%) translateY(6px);background:rgba(255,255,255,.98);backdrop-filter:blur(40px);border-radius:14px;padding:6px 0;min-width:230px;box-shadow:0 4px 40px rgba(0,0,0,.1),0 0 0 .5px rgba(0,0,0,.05);opacity:0;visibility:hidden;transition:opacity .2s,transform .2s,visibility .2s;pointer-events:none;list-style:none}
.nav-menu li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto}
.nav-menu .sub-menu a{display:block;padding:10px 20px;font-size:13px;font-weight:400;transition:background .12s,color .12s}
.nav-menu .sub-menu a:hover{background:var(--g100);color:var(--cr)}

.nav-cta{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--cr);color:#fff!important;border-radius:980px;font-size:13px;font-weight:600;transition:background .2s,transform .1s}
.nav-cta:hover{background:var(--crd);transform:scale(1.03)}
.nav-cta svg{width:14px;height:14px}

.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle svg{width:22px;height:22px;color:var(--txt)}

/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
.hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--deep)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);animation:heroZ 25s ease-in-out infinite alternate}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.65) 100%)}
@keyframes heroZ{0%{transform:scale(1.04)}100%{transform:scale(1.12)}}
.hero-content{position:relative;z-index:2;max-width:880px;padding:0 24px}
.hero-eyebrow{font-size:14px;font-weight:600;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:4px;margin-bottom:20px;opacity:0;animation:fadeUp .8s .2s forwards}
.hero h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(44px,7.5vw,82px);font-weight:700;line-height:1.06;letter-spacing:-1.5px;color:#fff;margin-bottom:22px;opacity:0;animation:fadeUp .8s .35s forwards}
.hero-desc{font-size:clamp(17px,2.2vw,21px);font-weight:300;color:rgba(255,255,255,.78);line-height:1.55;max-width:600px;margin:0 auto 44px;opacity:0;animation:fadeUp .8s .5s forwards}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .8s .65s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;animation:bounceY 2s infinite}
.scroll-hint svg{width:26px;height:26px;color:rgba(255,255,255,.4)}
@keyframes bounceY{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ═══════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════ */
.btn-p{display:inline-flex;align-items:center;gap:8px;padding:16px 34px;background:var(--cr);color:#fff;border-radius:980px;font-size:16px;font-weight:600;transition:background .2s,transform .1s;font-family:inherit;border:none;cursor:pointer}
.btn-p:hover{background:var(--crd);transform:scale(1.03)}
.btn-s{display:inline-flex;align-items:center;gap:8px;padding:16px 34px;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);color:#fff;border-radius:980px;font-size:16px;font-weight:600;border:1px solid rgba(255,255,255,.2);transition:background .2s,transform .1s}
.btn-s:hover{background:rgba(255,255,255,.22);transform:scale(1.03)}

/* ═══════════════════════════════════════
   SECTIONS
   ═══════════════════════════════════════ */
section{padding:120px 24px}
.inner{max-width:1120px;margin:0 auto}
.eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--cr);margin-bottom:14px}
.stitle{font-family:'Playfair Display',Georgia,serif;font-size:clamp(34px,4.5vw,54px);font-weight:600;line-height:1.1;letter-spacing:-1px;color:var(--txt);margin-bottom:14px}
.ssub{font-size:17px;font-weight:400;color:var(--txs);line-height:1.55;max-width:560px}

/* ═══════════════════════════════════════
   ISLANDS
   ═══════════════════════════════════════ */
.islands{background:var(--g100)}
.islands-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.i-card{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;display:block}
.i-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--e)}
.i-card:hover img{transform:scale(1.07)}
.i-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.72) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:30px;transition:background .4s;z-index:2}
.i-card:hover .i-overlay{background:linear-gradient(180deg,transparent 15%,rgba(0,0,0,.78) 100%)}
.i-overlay h3{font-family:'Playfair Display',serif;font-size:26px;font-weight:600;color:#fff;margin-bottom:5px}
.i-overlay p{font-size:13px;color:rgba(255,255,255,.7);line-height:1.5}
.i-arrow{position:absolute;top:18px;right:18px;width:34px;height:34px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(6px);transition:.3s;z-index:3}
.i-card:hover .i-arrow{opacity:1;transform:translateY(0)}
.i-arrow svg{width:15px;height:15px;color:#fff}

/* ═══════════════════════════════════════
   PLAN YOUR TRIP
   ═══════════════════════════════════════ */
.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:60px}
.p-item{display:flex;align-items:center;gap:18px;padding:26px;background:var(--g100);border-radius:16px;transition:background .15s,transform .12s,box-shadow .2s}
.p-item:hover{background:var(--g50);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.05)}
.p-icon{width:46px;height:46px;background:var(--cr);border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.p-icon svg{width:20px;height:20px;color:#fff}
.p-text h4{font-size:16px;font-weight:600;margin-bottom:3px}
.p-text p{font-size:13px;color:var(--txs);line-height:1.45}

/* ═══════════════════════════════════════
   PROGRAMS
   ═══════════════════════════════════════ */
.programs{background:var(--deep);color:#fff;position:relative;overflow:hidden}
.programs::before{content:'';position:absolute;top:-200px;right:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(164,19,60,.15) 0%,transparent 70%)}
.programs .eyebrow{color:rgba(255,255,255,.4)}.programs .stitle{color:#fff}.programs .ssub{color:rgba(255,255,255,.55)}
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px;position:relative}
.prog-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);padding:34px 26px;transition:background .2s,border-color .2s,transform .12s;display:block}
.prog-card:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.14);transform:translateY(-3px)}
.prog-badge{display:inline-block;padding:5px 11px;background:var(--cr);border-radius:7px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:18px}
.prog-card h4{font-size:20px;font-weight:600;color:#fff;margin-bottom:10px}
.prog-card p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.6}
.lm{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-size:13px;color:#e8506a;font-weight:600;transition:gap .2s}
.prog-card:hover .lm{gap:10px}.lm svg{width:13px;height:13px}

/* ═══════════════════════════════════════
   PAYMENT
   ═══════════════════════════════════════ */
.payment{background:linear-gradient(135deg,var(--cr) 0%,#5c0a22 100%);text-align:center;padding:80px 24px;position:relative;overflow:hidden}
.payment::before{content:'';position:absolute;top:-40%;right:-15%;width:550px;height:550px;border-radius:50%;background:rgba(255,255,255,.04)}
.payment .inner{position:relative;z-index:2}
.payment h2{font-family:'Playfair Display',serif;font-size:clamp(34px,4.5vw,50px);font-weight:600;color:#fff;margin-bottom:14px}
.payment .pay-desc{font-size:17px;color:rgba(255,255,255,.72);max-width:500px;margin:0 auto 20px;line-height:1.5}
.pay-toggle{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:#fff;color:var(--cr);border-radius:980px;font-size:16px;font-weight:700;border:none;cursor:pointer;font-family:inherit;transition:transform .12s,box-shadow .2s;margin-bottom:28px}
.pay-toggle:hover{transform:scale(1.04);box-shadow:0 8px 30px rgba(0,0,0,.2)}
.pay-toggle svg{width:18px;height:18px}
.portal-wrap{max-width:1100px;margin:0 auto;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3);background:#fff;display:none}
.portal-wrap.open{display:block;animation:fadeUp .4s}
.portal-wrap iframe{width:100%;height:700px;border:none;display:block}
.portal-note{font-size:12px;color:rgba(255,255,255,.45);margin-top:16px}

/* ═══════════════════════════════════════
   INFO STRIP
   ═══════════════════════════════════════ */
.info{background:var(--g100);padding:80px 24px}
.info-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr 1px 1fr;gap:56px;align-items:start}
.info-div{width:1px;background:var(--g200);align-self:stretch}
.info-block h3{font-family:'Playfair Display',serif;font-size:26px;font-weight:600;margin-bottom:16px}
.info-block p{font-size:15px;color:var(--txs);line-height:1.7;margin-bottom:10px}
.info-block a.la{color:var(--cr);font-weight:600}.info-block a.la:hover{text-decoration:underline}
.c-line{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-size:15px;color:var(--txs)}
.c-line svg{width:17px;height:17px;color:var(--cr);flex-shrink:0}
.c-line a{color:var(--cr);font-weight:500}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.site-footer{background:var(--deep);padding:52px 24px 24px}
.f-inner{max-width:1120px;margin:0 auto}
.f-top{display:flex;justify-content:space-between;gap:36px;flex-wrap:wrap;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.07)}
.f-col h5{font-size:11px;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:1.8px;margin-bottom:14px}
.f-col a{display:block;font-size:13px;color:rgba(255,255,255,.6);padding:3px 0;transition:color .15s}
.f-col a:hover{color:#fff}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;flex-wrap:wrap;gap:14px}
.f-bottom p{font-size:12px;color:rgba(255,255,255,.3)}
.f-socials{display:flex;gap:12px}
.f-socials a{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.06);transition:background .2s}
.f-socials a:hover{background:rgba(255,255,255,.14)}
.f-socials svg{width:15px;height:15px;color:rgba(255,255,255,.55)}

/* ═══════════════════════════════════════
   PAGE HERO (inner pages)
   ═══════════════════════════════════════ */
.page-hero{position:relative;height:50vh;min-height:380px;display:flex;align-items:center;justify-content:center;text-align:center;background-size:cover;background-position:center;margin-top:54px}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.55) 100%)}
.page-hero-content{position:relative;z-index:2;max-width:700px;padding:0 24px}
.page-hero-content h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(36px,6vw,64px);font-weight:700;color:#fff;letter-spacing:-1px;margin-bottom:12px}
.page-hero-content p{font-size:clamp(16px,2vw,19px);color:rgba(255,255,255,.75);line-height:1.5}

/* ═══════════════════════════════════════
   CONTENT STYLES (WP Editor / Gutenberg)
   ═══════════════════════════════════════ */
.content-section{padding:80px 24px}
.entry-content p{margin-bottom:18px}
.entry-content h2{font-family:'Playfair Display',Georgia,serif;font-size:32px;font-weight:600;margin:40px 0 16px;color:var(--txt)}
.entry-content h3{font-family:'Playfair Display',Georgia,serif;font-size:24px;font-weight:600;margin:32px 0 12px;color:var(--txt)}
.entry-content h4{font-size:18px;font-weight:600;margin:24px 0 10px}
.entry-content ul,.entry-content ol{margin:0 0 18px 24px;color:var(--txs)}
.entry-content li{margin-bottom:6px;line-height:1.7}
.entry-content blockquote{border-left:4px solid var(--cr);padding:16px 24px;margin:24px 0;background:var(--g100);border-radius:0 12px 12px 0}
.entry-content img{border-radius:12px;margin:24px 0}
.entry-content a{color:var(--cr);font-weight:500}
.entry-content a:hover{text-decoration:underline}
.entry-content table{width:100%;border-collapse:collapse;margin:24px 0}
.entry-content th,.entry-content td{padding:12px 16px;border-bottom:1px solid var(--g200);text-align:left;font-size:14px}
.entry-content th{font-weight:600;color:var(--txt)}

/* ═══════════════════════════════════════
   SCROLL REVEAL
   ═══════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--e),transform .65s var(--e)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════
   PAGE TEMPLATE LAYOUTS
   ═══════════════════════════════════════ */
.gta-content-grid{display:grid;grid-template-columns:1fr 340px;gap:60px;align-items:start}
@media(max-width:960px){.gta-content-grid{grid-template-columns:1fr!important}}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
/* WP Pagination */
.nav-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.nav-links a,.nav-links span{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;font-size:14px;font-weight:600;transition:all .2s}
.nav-links a{background:var(--g100);color:var(--txt)}
.nav-links a:hover{background:var(--cr);color:#fff}
.nav-links .current{background:var(--cr);color:#fff}

/* WP Admin Bar Adjustment */
.admin-bar .nav-wrap{top:32px}
@media(max-width:782px){.admin-bar .nav-wrap{top:46px}}

/* Mobile Menu */
@media(max-width:960px){
  .nav-menu{display:none;position:absolute;top:54px;left:0;right:0;background:rgba(255,255,255,.98);backdrop-filter:blur(40px);padding:16px 24px;flex-direction:column;gap:0;box-shadow:0 8px 30px rgba(0,0,0,.1)}
  .nav-menu.mobile-open{display:flex}
  .nav-menu li{border-bottom:1px solid var(--g200)}
  .nav-menu>li>a{padding:14px 0}
  .nav-menu .sub-menu{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;box-shadow:none;backdrop-filter:none;border-radius:0;padding:0 0 8px 16px;min-width:auto}
  .mobile-toggle{display:block}
  .islands-grid,.prog-grid{grid-template-columns:1fr}
  .i-card{aspect-ratio:16/10}
  .plan-grid{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
  .info-div{display:none}
  .f-top{flex-direction:column}
}
