:root {
    --ak-green: #017501;
    --ak-green-light: #4caf50;
    --ak-dark: #021408;
    --ak-light: #f5f7f5;
    --ak-white: #ffffff;
}

/* Global */

body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background-color: #ffffff;
    color: #222;
}

a {
    text-decoration: none;
}

.ak-logo {
    height: 38px;
}

.ak-navbar { position: static; top: auto; z-index: 1030; background: transparent; padding-top: 0; padding-bottom: 0; }

.ak-navbar .navbar-brand span {
    color: var(--ak-white);
    letter-spacing: 0.06em;
}

.ak-navbar .nav-link {
    color: #e0f2e9;
    font-size: 0.9rem;
    margin-left: 1rem;
}

.ak-navbar .nav-link.active,
.ak-navbar .nav-link:hover {
    color: var(--ak-green-light);
}

.btn-ak-primary {
    background: var(--ak-green);
    border-color: var(--ak-green);
    color: var(--ak-white);
    border-radius: 999px;
}

.btn-ak-primary:hover {
    background: #015b01;
    border-color: #015b01;
    color: var(--ak-white);
}

.btn-ak-outline {
    border-radius: 999px;
    border: 1px solid var(--ak-green);
    color: var(--ak-green);
    background: transparent;
}

.btn-ak-outline:hover {
    background: var(--ak-green);
    color: var(--ak-white);
}

/* Hero */

.hero-section {
    position: relative;
    min-height: 100vh;
    background-image: url("../img/evn.jpg");
    background-size: cover;
    background-position: center;
    color: var(--ak-white);
}

/* Hero background slideshow */
.hero-slideshow { position:absolute; inset:0; overflow:hidden; z-index:0; }
.hero-slideshow .slide { position:absolute; inset:0; background-size:cover; background-position:center; transform: scale(1.06); opacity:0; transition: opacity 1.2s ease-in-out; will-change: opacity, transform; }
.hero-slideshow .slide.active { opacity:1; }
.hero-section .container { position: relative; z-index: 2; }

/* Fix for bullet content set in inline styles */
body .ak-checklist li::before { content: "\2022" !important; }

.hero-overlay { position: absolute; inset: 0; background: linear-gradient(120deg, rgba(0,0,0,0.55), rgba(0,0,0,0.75)); }

.hero-title {
    font-size: 3rem;
    font-weight: 800;
}

.hero-title span {
    color: #fffbf0;
}

.hero-subtitle {
    font-size: 1.1rem;
    max-width: 550px;
    margin-top: 1rem;
}

.hero-section .container {
    padding-top: 7rem;
    padding-bottom: 5rem;
}

.hero-search .form-select,
.hero-search .form-control {
    border-radius: 999px;
    border: none;
    padding-left: 1.2rem;
}

/* Sections */

.section-title {
    font-weight: 700;
    color: var(--ak-dark);
}

.section-header p {
    color: #666;
}

/* Cards */

.tour-card {
    border: none;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 12px 25px rgba(0,0,0,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tour-card img {
    height: 210px;
    object-fit: cover;
}

.tour-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(0,0,0,0.12);
}

.tour-card .price {
    font-weight: 700;
    color: var(--ak-green);
}

/* Checklist & bullets */

.ak-checklist {
    list-style: none;
    padding-left: 0;
}

.ak-checklist li::before {
    content: "✓";
    color: var(--ak-green);
    margin-right: 0.5rem;
    font-weight: 700;
}

.ak-bullets {
    padding-left: 1.2rem;
}

/* Testimonials */

.testimonial-card {
    background: var(--ak-white);
    border-radius: 1rem;
    padding: 1.5rem;
    box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.testimonial-message {
    font-style: italic;
}

.testimonial-name {
    margin-top: 1rem;
    font-weight: 600;
    color: var(--ak-dark);
}

.testimonial-rating {
    color: #ffc107;
    font-size: 0.9rem;
}

/* CTA */

.ak-cta { background: linear-gradient(135deg, #0b1611, #0e1b15); color: var(--ak-white); }

/* Page header */

.page-header {
    background: var(--ak-light);
    padding: 3rem 0 2rem;
    border-bottom: 1px solid #e5ece6;
}

.page-title {
    font-weight: 700;
    color: var(--ak-dark);
}

/* Tour hero */

.tour-hero {
    position: relative;
    height: 320px;
    color: var(--ak-white);
    margin-bottom: 2rem;
}

.tour-hero-bg img {
    width: 100%;
    height: 320px;
    object-fit: cover;
}

.tour-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(2, 20, 8, 0.9), rgba(1, 117, 1, 0.7));
}

.tour-hero-content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 2.5rem;
}

.tour-hero .price {
    font-size: 1.4rem;
    font-weight: 700;
}

/* Booking box */

.booking-box {
    background: var(--ak-light);
    padding: 1.5rem;
    border-radius: 1rem;
    box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

/* Event cards (home) */
.event-card { border-radius: 1rem; overflow: hidden; box-shadow: 0 10px 25px rgba(0,0,0,0.08); background: #fff; height: 100%; }
.event-image-wrapper { position: relative; }
.event-image-wrapper img { width: 100%; height: 180px; object-fit: cover; }
.event-badge { position: absolute; top: 10px; left: 10px; background: var(--ak-green); color: #fff; padding: 0.2rem 0.7rem; border-radius: 999px; font-size: 0.7rem; letter-spacing: 0.05em; text-transform: uppercase; }

/* Footer */

.ak-footer {
    background: var(--ak-dark);
    color: #d8e6dd;
}

.ak-footer h5 {
    color: var(--ak-white);
}

.ak-footer a {
    color: #b6d8c4;
}

.ak-footer a:hover {
    color: var(--ak-green-light);
}

.ak-footer iframe { border-radius: 0.75rem; margin-top: 0.75rem; }

/* Forms */

form .form-control,
form .form-select,
form textarea {
    border-radius: 0.7rem;
}

/* Responsive */

@media (max-width: 768px) {
    .hero-title {
        font-size: 2.2rem;
    }
    .hero-section .container {
        padding-top: 5rem;
    }
}

/* ===== Enhancements & Animations ===== */

/* Navbar shrink on scroll */
.ak-navbar { position: static; top: auto; z-index: 1030; background: transparent; padding-top: 0; padding-bottom: 0; }
.ak-navbar.navbar-scrolled {
    background: rgba(2, 20, 8, 0.95);
    box-shadow: 0 10px 30px rgba(0,0,0,0.25);
}

/* Reveal on scroll */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.reveal.show { opacity: 1; transform: translateY(0); }
.reveal.fade { transform: none; }

/* Hover effects */
.hover-raise { transition: transform .25s ease, box-shadow .25s ease; }
.hover-raise:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,0.12); }
.hover-zoom img { transition: transform .3s ease; }
.hover-zoom:hover img { transform: scale(1.05); }

/* Stars */
.stars { color: #ffc107; letter-spacing: 2px; }

/* Stats */
.stats { background: var(--ak-light); }
.stat { text-align: center; }
.stat .num { font-weight: 800; font-size: 2rem; color: var(--ak-green); }
.stat .label { color: #4b5b50; }

/* Focus visibility */
:focus-visible { outline: 3px solid var(--ak-green-light); outline-offset: 2px; }

/* ===== Overrides for dynamic island navbar and hero ===== */
.ak-navbar { background: transparent !important; position: sticky; top: 12px; z-index: 1030; padding-top: 0; padding-bottom: 0; }
.ak-island { display: flex; align-items: center; gap: 1rem; padding: .55rem .9rem; border-radius: 999px; background: rgba(2,20,8,0.65); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 20px 40px rgba(0,0,0,0.25); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); margin: 8px auto; max-width: 100%; justify-content: space-between; }
.ak-navbar.navbar-scrolled .ak-island { background: rgba(2,20,8,0.85); box-shadow: 0 18px 40px rgba(0,0,0,0.35); }
.ak-island .navbar-collapse { flex-grow: 0; }
.btn-icon { width: 38px; height: 38px; padding: 0; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; }
.btn-icon svg { display: block; }
.hero-overlay { background: linear-gradient(120deg, rgba(0,0,0,0.25), rgba(0,0,0,0.65)) !important; }
.ak-cta { background: linear-gradient(135deg, #0b1611, #0e1b15) !important; color: var(--ak-white); }

@media (max-width: 991.98px) { .ak-island { border-radius: 20px; } }

.ak-island { display:flex; align-items:center; gap:1rem; padding:.5rem .9rem; border-radius:999px; background: rgba(2,20,8,0.65); border:1px solid rgba(255,255,255,0.08); box-shadow:0 20px 40px rgba(0,0,0,0.25); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);} 
@media (max-width: 991.98px){ .ak-island { border-radius:20px; } }

/* Homepage overlay navbar so hero background extends to top */
.ak-navbar-overlay { position: absolute !important; top: 0; left: 0; right: 0; background: transparent !important; z-index: 1040; }

/* Center the island like iPhone Dynamic Island while keeping brand on the left */
.ak-navbar .container { position: relative; display: block; }
.ak-navbar { min-height: 64px; }
@media (min-width: 992px) {
  .ak-navbar .ak-island { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); }
  .ak-navbar .navbar-brand { position: absolute; left: 0; top: 50%; transform: translateY(-50%); margin: 0; }
}

/* Pull the island closer to the top on the homepage overlay to avoid the background looking "lowered" */
.ak-navbar .ak-island { margin: 0 auto !important; }
.ak-navbar.ak-navbar-overlay .ak-island { margin-top: 0 !important; }
.ak-navbar.ak-navbar-overlay { padding-top: 0 !important; }
/* Safe top inset for mobile to prevent clipping near device notches/status bar */
@media (max-width: 991.98px) {
  .ak-navbar.ak-navbar-overlay .container { padding-top: calc(env(safe-area-inset-top, 0px) + 12px) !important; }
}

/* ===== Section Background Helpers ===== */
.section-bg { position: relative; background-size: cover; background-position: center; background-repeat: no-repeat; }
.section-bg .section-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.35)); }
.section-bg > .container, .section-bg > .container-fluid { position: relative; z-index: 1; }
.parallax-bg { background-attachment: scroll; }
@media (min-width: 992px) { .parallax-bg { background-attachment: fixed; } }
.page-header.section-bg { color: #fff; padding: 4rem 0 3rem; }
.page-header .page-title { color: #fff; text-shadow: 0 6px 24px rgba(0,0,0,0.45); }
.text-shadow { text-shadow: 0 6px 24px rgba(0,0,0,0.45); }

/* Subtle Ken Burns effect for background containers (JS toggles .kenburns-active if desired) */
@keyframes ak-pan {
  0% { background-position: 50% 50%; }
  50% { background-position: 48% 46%; }
  100% { background-position: 50% 50%; }
}
.kenburns-active { animation: ak-pan 18s ease-in-out infinite; }

/* Decorative bubbles (opt-in) */
.bubbles { position: relative; overflow: hidden; }
.bubble { position: absolute; bottom: -40px; background: rgba(255,255,255,0.25); border-radius: 50%; animation: floatUp linear infinite; }
@keyframes floatUp { to { transform: translateY(-110vh); opacity: 0; } }


/* Force navbar to scroll (non-sticky) except homepage overlay */
.ak-navbar:not(.ak-navbar-overlay) { position: static !important; top: auto !important; }
/* Ensure homepage overlay navbar lets hero background reach the very top */
.ak-navbar.ak-navbar-overlay { position: absolute !important; top: 0 !important; left: 0; right: 0; background: transparent !important; z-index: 1040; }

/* Booking form polish */
.input-group-text{background:var(--ak-light);border:none;color:var(--ak-dark)}
.input-group>.form-control,.input-group>.form-select{border-left:0}
.input-group .form-control:focus{box-shadow:none}
.booking-box{border:1px solid #e5ece6; border-radius:16px}
.booking-box h4{font-weight:700}
/* Compact footer styles */
.footer-compact .container { padding-top: 1rem !important; padding-bottom: 1rem !important; }
.footer-link { color: #b6d8c4; }
.footer-link:hover { color: var(--ak-green-light); }
.footer-icon { color: #b6d8c4; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); }
.footer-icon:hover { color: #ffffff; border-color: var(--ak-green-light); }
