/* Explore Northern Ireland — theme styles */

:root{
  --forest:#1a3f2b;--forest-deep:#0e2318;--forest-mid:#1f4a34;--forest-panel:#0b1f16;
  --gold:#c8a24a;--gold-deep:#a9853a;--gold-soft:#d8bd7e;
  --cream:#f3ecdd;--cream-2:#faf6ec;--paper:#fffdf8;
  --ink:#183726;--text:#5c574b;--muted:#8a8474;--line:#e7dcc6;--line-dk:rgba(255,255,255,.12);
  --wash:249,245,235;
  --teal:#2a9d8f;--green-bright:#57a23f;--green-deep:#4a8f34;--green-ring:#7cc191;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:'Jost',sans-serif;color:var(--text);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Playfair Display',serif;color:var(--ink);line-height:1.08;font-weight:700;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 30px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:12px;top:12px;background:#fff;padding:10px 16px;z-index:999;border-radius:6px}

.eyebrow{font-family:'Jost';font-weight:600;font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.eyebrow--gold{color:var(--gold-deep)}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Jost';font-weight:600;font-size:12.5px;letter-spacing:.13em;
  text-transform:uppercase;padding:14px 26px;border-radius:6px;cursor:pointer;border:none;transition:transform .22s,background .22s,color .22s,box-shadow .22s}
.btn--forest{background:var(--forest);color:#f4ecd9}
.btn--forest:hover{background:var(--forest-deep);transform:translateY(-2px)}
.btn--gold{background:var(--gold);color:var(--forest-deep)}
.btn--gold:hover{background:var(--gold-soft);transform:translateY(-2px)}
.btn--outline-dark{background:transparent;border:1.5px solid var(--forest);color:var(--forest)}
.btn--outline-dark:hover{background:var(--forest);color:#f4ecd9}
.btn--outline-light{background:transparent;border:1.5px solid rgba(255,255,255,.6);color:#f6efe0}
.btn--outline-light:hover{background:rgba(255,255,255,.14);border-color:#fff}

/* ---------- header ---------- */
.site-header{position:absolute;top:0;left:0;right:0;z-index:40}
.head{display:flex;align-items:center;justify-content:space-between;height:106px}
.site-logo img{height:88px;width:auto}
.main-nav{display:flex;align-items:center;gap:30px}
.nav-menu{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0}
.nav-menu a{font-family:'Jost';font-weight:500;font-size:12.5px;letter-spacing:.15em;text-transform:uppercase;color:#f2ead6;transition:color .2s}
.nav-menu a:hover{color:var(--gold-soft)}
.nav-cta{background:var(--gold)!important;color:var(--forest-deep)!important}
.nav-cta:hover{background:var(--gold-soft)!important}
.nav-toggle{display:none;background:none;border:0;color:#f2ead6;font-size:26px;cursor:pointer}
body:not(.home) .site-header{position:relative;background:var(--forest-deep)}
@media(max-width:980px){
  .nav-menu,.nav-cta{display:none}
  .nav-toggle{display:block}
  .main-nav.open{position:absolute;top:106px;left:0;right:0;background:var(--forest-deep);border-top:1px solid rgba(255,255,255,.1);
    flex-direction:column;align-items:stretch;gap:0;padding:10px 30px 22px;box-shadow:0 20px 40px rgba(6,20,12,.45)}
  .main-nav.open .nav-menu{display:flex;flex-direction:column;align-items:stretch;gap:0}
  .main-nav.open .nav-menu li{border-bottom:1px solid rgba(255,255,255,.1)}
  .main-nav.open .nav-menu a{display:block;padding:14px 2px}
  .main-nav.open .nav-cta{display:inline-flex;justify-content:center;margin-top:16px}
}

/* ---------- hero (branding left, builder right) ---------- */
.hero{position:relative;min-height:auto;display:flex;align-items:center;overflow:hidden;padding:112px 0 50px;
  background-size:cover;background-position:center right;background-color:#25302b}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(10,26,17,.52) 0%,rgba(10,26,17,.32) 34%,rgba(10,26,17,.08) 56%,rgba(10,26,17,0) 78%),
             linear-gradient(180deg,rgba(10,26,17,.34) 0%,rgba(10,26,17,0) 16%),
             linear-gradient(0deg,rgba(10,26,17,.20) 0%,rgba(10,26,17,0) 22%)}
.hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,4vw,64px);align-items:center;width:100%}
.hero-copy{max-width:560px}
.hero-lockup{margin:16px 0 0;line-height:1}
.explore-script{width:clamp(210px,22vw,330px);height:auto;display:block;filter:drop-shadow(0 3px 14px rgba(0,0,0,.35))}
.ni-line{display:block;font-family:'Playfair Display',serif;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  font-size:clamp(19px,2.4vw,32px);color:#f6efe0;margin-top:6px;padding-left:6px}
.hero-sub{max-width:42ch;color:#e7ddc7;font-size:17px;font-weight:300;margin:22px 0 30px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.featrow{display:flex;flex-wrap:wrap;gap:0;margin-top:32px}
.feat{display:flex;align-items:center;gap:10px;padding:2px 16px;position:relative}
.feat:first-child{padding-left:0}
.feat:not(:first-child)::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:32px;background:rgba(255,255,255,.28)}
.feat .ring{width:36px;height:36px;flex:0 0 auto;border:1.5px solid rgba(124,193,145,.55);border-radius:50%;display:grid;place-items:center;color:#9bd3ab;font-size:17px}
.feat b{font-family:'Jost';font-weight:600;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#efe6d0;line-height:1.3}
@media(max-width:980px){.hero{padding-top:118px;min-height:0}.hero-grid{grid-template-columns:1fr;gap:34px}.hero-copy{max-width:none}}

/* ---------- build your perfect tour (hero right column) ---------- */
.hero-builder{position:relative;z-index:3}
.build-shell{background:var(--cream-2);border-radius:16px;padding:30px 32px 28px;box-shadow:0 40px 90px rgba(6,20,12,.5);border:1px solid var(--line);max-width:520px;margin-left:auto}
.build-head{text-align:center;margin-bottom:16px}
.build-head .shamrock{color:var(--gold);font-size:20px;display:block;margin-bottom:4px}
.build-head h2{font-size:28px}
.build-head p{font-size:14px;color:var(--text);margin:6px 0 0}
.bfields{display:grid;grid-template-columns:1fr;gap:14px}
.bfield label{display:block;font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.bsel{border:1px solid var(--line);border-radius:8px;padding:12px 14px;background:#fff;display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--ink)}
.bsel i{color:var(--gold-deep)}
.bcreate{justify-content:center;margin-top:4px}
.chips{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.chip{display:flex;flex-direction:column;align-items:center;gap:8px}
.chip-ph{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:19px;border:2px solid var(--line)}
.chip b{font-family:'Jost';font-weight:500;font-size:12px;color:var(--ink)}
.build-note{text-align:center;font-size:11px;color:var(--muted);margin:14px 0 0}
@media(max-width:980px){.build-shell{margin:0 auto}}

/* ---------- category strip ---------- */
.cats{background:var(--forest);padding:38px 0}
.catgrid{display:grid;grid-template-columns:repeat(8,1fr);gap:16px}
.cat{text-align:center}
.cat .ring{width:62px;height:62px;margin:0 auto 12px;border:1.5px solid var(--green-ring);border-radius:50%;display:grid;place-items:center;color:#a6dcb4;font-size:26px;transition:all .25s}
.cat:hover .ring{background:var(--green-bright);color:#fff;border-color:var(--green-bright);transform:translateY(-3px)}
.cat b{font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:#e9e0cb;line-height:1.3}
@media(max-width:900px){.catgrid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:520px){.catgrid{grid-template-columns:repeat(2,1fr)}}

/* ---------- section heading ---------- */
.sec-head{text-align:center;max-width:640px;margin:0 auto 40px}
.sec-head h2{font-size:clamp(30px,4vw,46px);margin-top:10px}
.sec-head p{margin-top:12px;font-size:16px}

/* ---------- experiences ---------- */
.exps{padding:78px 0;background:var(--paper)}
.expgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.expcard{border-radius:14px;overflow:hidden;box-shadow:0 12px 30px rgba(14,35,24,.12);transition:transform .3s,box-shadow .3s;background:#111}
.expcard img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .5s}
.expcard:hover{transform:translateY(-6px);box-shadow:0 24px 46px rgba(14,35,24,.2)}
.expcard:hover img{transform:scale(1.05)}
@media(max-width:1000px){.expgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.expgrid{grid-template-columns:1fr}}

/* ---------- AI tour builder showcase ---------- */
.ai{background:var(--forest-deep);color:#d7d1c2;padding:82px 0}
.ai-grid{display:grid;grid-template-columns:.9fr 1.25fr .85fr;gap:34px;align-items:stretch}
.ai h2{color:#f4ecd9;font-size:clamp(30px,3.6vw,44px);margin:12px 0 22px}
.ai-list{list-style:none;margin:0 0 28px;padding:0}
.ai-list li{display:flex;align-items:center;gap:12px;padding:9px 0;font-size:15px;color:#e6dfce}
.ai-list li i{color:var(--gold);font-size:20px}
.itin{background:var(--forest-panel);border:1px solid var(--line-dk);border-radius:16px;padding:20px;display:grid;grid-template-columns:170px 1fr;gap:16px}
.itin-ttl{font-family:'Jost';font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:12px}
.day{display:flex;gap:11px;align-items:center;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.day:last-child{border:0}
.day .thumb{width:42px;height:42px;border-radius:8px;flex:0 0 auto;background:linear-gradient(135deg,#2c5a3f,#1a3f2b)}
.day .d{display:block;font-family:'Jost';font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft)}
.day .n{display:block;font-family:'Playfair Display',serif;font-size:17px;color:#f2ecdb;font-weight:600;line-height:1.1}
.itin-map{background:#10261a;border-radius:12px;overflow:hidden;min-height:230px}
.itin-map svg{width:100%;height:100%}
.quote{background:var(--forest-panel);border:1px solid var(--line-dk);border-radius:16px;padding:26px;display:flex;flex-direction:column;justify-content:center}
.quote .q{color:var(--gold);font-size:40px;font-family:'Playfair Display',serif;line-height:0;height:22px}
.quote p{font-family:'Playfair Display',serif;font-style:italic;font-size:19px;color:#eae3d2;line-height:1.4;margin:0 0 16px}
.quote .stars{color:var(--gold);font-size:15px;letter-spacing:3px;margin-bottom:14px}
.quote .powered{font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
@media(max-width:1000px){.ai-grid{grid-template-columns:1fr}}
@media(max-width:560px){.itin{grid-template-columns:1fr}}


/* ---------- route CTA band (banner motif) ---------- */
.cta-band{background:linear-gradient(100deg,var(--green-bright) 0%,var(--green-deep) 100%);position:relative;overflow:hidden}
.cta-band .inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:30px;padding:42px 0;flex-wrap:wrap}
.cta-band h2{color:#fff;font-size:clamp(26px,3vw,36px);margin:0}
.cta-band p{color:rgba(255,255,255,.92);font-family:'Jost';font-weight:600;font-size:14px;letter-spacing:.14em;text-transform:uppercase;margin:6px 0 0}
.cta-band .btn{background:#fff;color:var(--green-deep)}
.cta-band .btn:hover{background:#f4ecd9;transform:translateY(-2px)}
.cta-band .route{position:absolute;right:0;top:0;height:100%;width:46%;z-index:1;opacity:.55;pointer-events:none}
@media(max-width:640px){.cta-band .route{display:none}}

/* ---------- tour builder entry card (hero) ---------- */
.tb-entry{background:var(--cream-2);border-radius:18px;padding:30px 32px 24px;box-shadow:0 40px 90px rgba(6,20,12,.52);border:1px solid var(--line);max-width:522px;margin-left:auto}
.tb-entry__head{text-align:center;margin-bottom:22px}
.tb-eyebrow{font-family:'Jost';font-weight:600;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.tb-entry__head h2{font-family:'Playfair Display',serif;font-weight:700;font-size:30px;color:var(--ink);margin:9px 0 0;line-height:1.08}
.tb-rule{width:46px;height:2px;background:var(--gold);border-radius:2px;margin:14px auto 0}
.tb-opts{display:flex;flex-direction:column;gap:13px}
.tb-opt{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:17px 19px;text-decoration:none;transition:border-color .22s,transform .22s,box-shadow .22s}
.tb-opt:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 16px 34px rgba(14,35,24,.13)}
.tb-opt__ic{width:50px;height:50px;flex:0 0 auto;border-radius:13px;background:var(--forest);color:var(--gold-soft);display:grid;place-items:center;font-size:23px;transition:background .22s,color .22s}
.tb-opt:hover .tb-opt__ic{background:var(--gold);color:var(--forest-deep)}
.tb-opt__body{flex:1;min-width:0}
.tb-opt__t{display:flex;align-items:center;gap:9px;font-family:'Playfair Display',serif;font-weight:600;font-size:20px;color:var(--ink);line-height:1.1;margin-bottom:3px}
.tb-opt__tag{font-family:'Jost';font-weight:600;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--forest-deep);background:var(--gold-soft);padding:3px 8px;border-radius:999px;white-space:nowrap}
.tb-opt__d{font-family:'Jost';font-size:13px;color:var(--text);line-height:1.5}
.tb-opt__go{align-self:center;color:var(--gold-deep);font-size:20px;transition:transform .2s;flex:0 0 auto}
.tb-opt:hover .tb-opt__go{transform:translateX(3px)}
.tb-foot{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
.tb-foot span{font-family:'Jost';font-size:11.5px;letter-spacing:.03em;color:var(--muted);display:flex;align-items:center;gap:6px}
.tb-foot i{color:var(--gold-deep);font-size:15px}
@media(max-width:980px){.tb-entry{margin:0 auto}}

/* ---------- build your tour page ---------- */
.bt-hero{background:var(--cream);text-align:center;padding:52px 0 38px;border-bottom:1px solid var(--line)}
.bt-hero .eyebrow{color:var(--gold-deep)}
.bt-hero h1{font-family:'Playfair Display',serif;color:var(--ink);font-size:clamp(34px,4.6vw,52px);margin:10px 0 8px}
.bt-hero p{color:var(--text);max-width:52ch;margin:0 auto;font-size:16px}
.bt-wrap{max-width:1040px;margin:0 auto;padding:44px 30px 80px}
.bt-wrap .build-shell{margin:0 auto}

/* ---------- footer ---------- */


.site-footer{background:var(--forest-panel);color:#b3ac9c;padding:60px 0 30px}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
.flogo{height:118px;width:auto;margin-bottom:10px}
.fbrand p{font-size:14px;line-height:1.7;max-width:32ch;margin:0}
.fcol h4{color:#f0e8d5;font-family:'Jost';font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin:0 0 16px;font-weight:600}
.fcol ul{list-style:none;margin:0;padding:0}
.fcol li{margin-bottom:9px;font-size:14px}
.fcol a:hover{color:var(--gold-soft)}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:38px;padding-top:20px;font-size:13px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
@media(max-width:820px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.fgrid{grid-template-columns:1fr}}

/* ---------- generic content pages ---------- */
.page-body{max-width:820px;margin:0 auto;padding:120px 30px 70px}
.page-body h1,.page-body h2,.page-body h3{margin:1.2em 0 .5em}
.page-body p,.page-body li{font-size:17px}
.page-hero{padding:130px 0 30px;text-align:center;background:var(--cream)}
.page-hero h1{font-size:clamp(34px,5vw,56px)}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
