
@keyframes fadeUp { from{opacity:0;transform:translateY(40px)} to{opacity:1;transform:translateY(0)} }
body{
	background-color: #f1f1f1;
}
.header{
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 50px;
    height: 125px;
    background: rgba(255, 252, 247, 0.97);
    border-bottom: 1px solid rgba(212, 168, 67, 0.25);
    backdrop-filter: blur(12px);
    box-shadow: 0 2px 24px rgba(60, 50, 30, 0.08);
}
.header .navbar-brand {
    width: 90px;
    height: 89px;
    object-fit: contain;
    filter: drop-shadow(0 2px 8px rgba(212, 168, 67, 0.3));
    display: flex !important;
}
.header .navbar-brand img {
    width: 100%;
}
.header ul.navbar-nav{
    display: flex;
    align-items: center;
    gap: 34px;
    list-style: none;
}
.header .nav-item a {
    text-decoration: none;
    font-size: 16px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #6b7a96;          /* was #a0a8c8 — darker for light bg readability */
    transition: color 0.25s;
    font-weight: 600;
}
.header .nav-item a:hover {
    color: #b08830;          /* was #e8c96a — warmer, readable on light bg */
}
.header.fixed {
    position: fixed;
}

/* ── arrowLink — rethemed to match warm gold/navy palette ── */
.arrowLink {
  padding: 8px 36px 8px 14px!important; 
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  max-width: 190px;
  background: linear-gradient(135deg, #b08830 0%, #D4A843 100%);
  border: 1px solid #c49030;
  box-shadow: 0 2px 10px rgba(176, 136, 48, 0.25), inset 0 1px 0 rgba(255, 230, 130, 0.3);
  transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
  z-index: 10;
  min-height: 34px;
  cursor: pointer;
  border-radius: 0;
}
.arrowLink .arrowText {
  color: #1E2744;            /* dark navy — crisp on gold bg */
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
  font-family: 'Cinzel', serif;
  white-space: nowrap;
}
.arrowLink .arrowIcon {
   background: #1E2744;
    /* border-radius: 4px; */
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    min-height: 100%;
    position: absolute;
    height: calc(100% - 10px);
    right: 0;
    top: 0;
    bottom: 0;
    margin: 0;
    transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
    color: #EDD98A;
}
.arrowLink:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #c49030 0%, #EDD98A 100%);
  box-shadow: 0 6px 20px rgba(176, 136, 48, 0.35), inset 0 1px 0 rgba(255, 240, 160, 0.4);
  border-color: #D4A843;
}
.arrowLink:hover .arrowIcon {
  width: 100%;
  height: 100%;
  left: 0; right: 0;
  top: 0; bottom: 0;
  margin: auto;
  border-radius: 0px;
  background: #1E2744;
  color: #EDD98A;
}

/* ─── BANNER ─── */
#BannerSec{
    position: relative;
    height: 50vh;
    min-height: 700px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.InnerBanner{
    height: 50vh !important;
    min-height: 450px !important;
}
#BannerSec .banner_grid{
    position: absolute;
    inset: 0;
        display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(1, 1fr);
    gap: 3px;
}
#BannerSec .banner_cell img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* Lifted from near-black to a visible warm-desaturated tone */
    filter: saturate(0.3) brightness(0.55) sepia(0.2);
    transform: scale(1.06);
    transition: transform 8s ease;
}
#BannerSec .bars_overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 2;
   background: repeating-linear-gradient(90deg, transparent, transparent 44px, rgba(20, 15, 5, 0.35) 44px, rgba(20, 15, 5, 0.35) 49px);
	    /* background: linear-gradient(to bottom, rgba(30, 20, 5, 0.25) 0%, rgb(187 145 54) 100%);*/
}
#BannerSec .banner_overlay {
    position: absolute;
    inset: 0;
    z-index: 3;
    /* Lighter gradient — warm parchment tones instead of pitch navy */
    background: linear-gradient(to bottom, rgba(30, 20, 5, 0.25) 0%, rgba(30, 20, 5, 0.65) 100%);
}
#BannerSec .banner_content {
    position: relative;
    z-index: 4;
    text-align: center;
    padding: 0 20px;
    animation: fadeUp 1.2s ease both;
}
#BannerSec .banner_logo {
    width: 100px;
    height: 100px;
    object-fit: contain;
    margin-bottom: 24px;
    filter: drop-shadow(0 4px 20px rgba(212, 168, 67, 0.5));
    animation: fadeUp 1s ease 0.2s both;
}
#BannerSec .banner_tag {
    font-size: 14px;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: #EDD98A;           /* was #c8a84b — softer honey */
    margin-bottom: 18px;
    font-weight: 600;
}
#BannerSec .banner_title {
    font-family: 'Cinzel', serif;
    font-size: clamp(48px, 8vw, 100px);
    letter-spacing: 6px;
    line-height: 0.95;
    color: #FFF8EC;           /* was stark #fff — warmer white */
    text-shadow: 0 4px 40px rgba(0, 0, 0, 0.45);
    margin-bottom: 12px;
    font-weight: bold;
}
#BannerSec .banner_title em {
    font-style: italic;
    font-family: 'Crimson Text', serif;
    color: #EDD98A;           /* was #e8c96a */
    font-size: 0.65em;
    display: block;
    letter-spacing: 4px;
    margin-top: 8px;
}
#BannerSec .banner_sub {
    font-size: 15px;
    color: #d8cdb8;           /* was #a0a8c8 — warm rather than blue-grey */
    max-width: 500px;
    margin: 20px auto 40px;
    font-weight: 300;
    line-height: 1.75;
}
.carousel-control-prev, .carousel-control-next{
	opacity:1!important;
}
.carousel-control-next-icon, .carousel-control-prev-icon{
	background-color:rgb(252, 206, 127);
	border-radius:5px;
}
.mainTitle h2{
	font-family: Cinzel, serif;
    font-size: clamp(30px, 3.5vw, 48px);
    letter-spacing: 2px;
    line-height: 1.05;
    color: #1E2744;
    margin-bottom: 18px; 
}
.mainTitle h2 span{ 
	color: rgb(252, 206, 127);
    font-weight: bold;
}
.mainTitle h4{
	font-family: Cinzel, serif;
    font-size: 24px;
    letter-spacing: 2px;
    line-height: 1.05;
    color: #1E2744;
    margin-bottom: 18px; 
}
.mainTitle h6{
	font-size: 9px;
    letter-spacing: 5px;
    text-transform: uppercase;
    /*color: rgb(249, 226, 111);*/
	color:#000;
    margin-bottom: 10px;
    font-weight: 700;
}
.mainTitle p{
	font-size: 14px;
    line-height: 1.8;
    color: rgb(143, 143, 142);
    font-weight: 300; 
    margin-bottom: 36px;
}

.about-area {
    margin-bottom: 80px;
}
.main-header .exp-desc{
	max-width:750px!important;
}
.about-box {
    padding: 25px 100px 15px 30px;
    margin-bottom: 20px;
    position: relative;
    text-align: right;
    transition: background-color 0.3s ease-in;
}
.about-box .icon {
    width: 56px;
    height: 100%;
    line-height: 150px;
    text-align: center;
    color: #fff;
    font-size: 24px;
    background-color: #212526;
    position: absolute;
    top: 0px;
    right: 0px;
    transition: all 0.25s ease-in;
}
.about-box h4{
    font-size: 14px;
    text-transform: uppercase;
	font-weight: bold;
}
.about-area .row > div:nth-child(even) .about-box {
    padding: 25px 30px 15px 100px;
    text-align: left;
}
.about-area .row > div:nth-child(even) .about-box .icon {
    right: auto;
    left: 0px;
}
.about-box:hover {
    background-color: #fff;
}
.about-box:hover .iconic {
	    background-color: #0ba4d6;
}

/* ─── SERVICE PANELS ─── */
.serviceExp{
	background-image: url('../images/bgImage.png');
	    background-attachment: fixed;
		background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
}
.serviceCardSec{
    position: relative;
    z-index: 3;
}
.imgCard img {
    border: 5px solid #fff;
}
.serviceCardSec:after {
    content: '';
    outline: 2px solid #bd9437;
    width: 80%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    outline-offset: -72px;
    z-index: -1;
    margin: auto;
    left: 0;
    right: 0;
    bottom: 0;
}
#ServiceSec .exp-panel{
    position: relative;
    overflow: hidden;
    padding: 80px 60px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 320px;
}
#ServiceSec .exp-panel::before {
    content: '';
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
/*    filter: saturate(0.25) brightness(0.85) sepia(0.15);*/
    filter: saturate(0.25) brightness(0.45) sepia(0.15);
    transition: filter 0.6s, transform 0.6s;
    transform: scale(1.05);
}
#ServiceSec .exp-panel::after {
    /*content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(25, 18, 5, 0.8) 0%, rgba(25, 18, 5, 0.3) 60%, transparent 100%);
    z-index: 1;
    pointer-events: none;*/
	content: '';
    position: absolute;
    inset: 0;
    background: #d7d7d7;
    z-index: 1;
    pointer-events: none;
    opacity: 0.5;
}
#ServiceSec .exp-content {
    position: relative;
    z-index: 2;
}
#ServiceSec .ServiceLeft::before {
	background-image: url('../images/JailAnubav.jpg');
}
#ServiceSec .ServiceRight::before {
	background-image: url('../images/image2.jpg');
}
#ServiceSec .exp-panel:hover::before {
    filter: saturate(0.4) brightness(0.55) sepia(0.1);
    transform: scale(1);
}
#ServiceSec .exp-icon {
    font-size: 38px;
    margin-bottom: 18px;
    display: block;
}
#ServiceSec .exp-tag {
    font-size: 13px;
    letter-spacing: 5px;
    text-transform: uppercase;
    /*color: #f9e26f;  */         /* was #c8a84b */
	    color: #1e2744;
    margin-bottom: 10px;
    font-weight: 700;
}
#ServiceSec .exp-title {
    font-family: 'Cinzel', serif;
    font-size: clamp(30px, 3.5vw, 48px);
    letter-spacing: 2px;
    line-height: 1.05;
    /*color: #fcce7f; */          /* was #fff */
	    color: #1e2744;
    margin-bottom: 18px;
    font-weight: bold;
}
#ServiceSec .exp-desc {
    font-size: 14px;
    line-height: 1.8;
    /*color: #8f8f8e;  */         /* was #a0a8c8 */
	    color: #161414;
    font-weight: 300;
    max-width: 360px;
    margin-bottom: 36px;
}

/* ─── ABOUT SECTION ─── */
#AboutUsSec{    
    padding: 120px 60px;
    /*background: #fffcf1cc;      /* was #141a5a — now a calm pale slate-blue */
    position: relative;
    overflow: hidden;
}
#AboutUsSec::before {
    content: 'ABOUT';
    position: absolute;
    top: 30px;
    right: -10px;
    font-family: 'Cinzel', serif;
    font-size: 180px;
    color: rgba(212, 168, 67, 0.06);
    letter-spacing: 10px;
    pointer-events: none;
    line-height: 1;
}
#AboutUsSec::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, #fab002 30%, #ffb300 70%, transparent);
}


/* Rcard — now on a light bg, so border adjusted */
.Rcard{
    background: rgba(109, 72, 7, 0.85);
    border: 1px solid rgba(212, 168, 67, 0.22);
    border-top: 2px solid rgba(212, 168, 67, 0.6);
    padding: 10px 15px;
    transition: border-color 0.3s, transform 0.3s, background 0.3s;
}

/* ─── EXPERIENCE / CARDS SECTION ─── */
#expSev{
    padding: 110px 8%;
    background: #F9F5EE;      /* was #0b1e3d — now warm parchment */
    position: relative;
    overflow: hidden;
}
#expSev .section-eyebrow {
    font-family: 'Cinzel', Georgia, serif;
    font-size: 10px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #b08830;           /* was #c8a84b — darkened for light bg */
    margin-bottom: 16px;
}
#expSev .section-title {
    font-family: 'Cinzel', Georgia, serif;
    font-size: clamp(30px, 4vw, 54px);
    font-weight: 900;
    line-height: 1.1;
    color: #1E2744;           /* was #ede8dc — now rich dark navy */
    margin-bottom: 18px;
}
#expSev .section-sub {
    font-size: 16px;
    color: #6b7a96;           /* was #8fa3c0 — adjusted for light bg */
    font-style: italic;
}

/* cards-grid — no change needed, card colors handle it */
.cards-grid  {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    position: relative;
    z-index: 1;
}

/* Individual cards — now light surface instead of dark navy */
.card {
    background: #FFFCF7;      /* was #0f2549 */
    padding: 48px 32px;
    border-top: 3px solid transparent;
    border: 1px solid #e8e0d0;
    transition: border-color 0.3s, background 0.3s, box-shadow 0.3s;
    position: relative;
}
.card:hover {
    border-top-color: #D4A843;
    background: #fff8ee;      /* was #162d56 */
    box-shadow: 0 4px 24px rgba(60, 50, 20, 0.08);
}
.card-num {
    font-family: 'Cinzel', Georgia, serif;
    font-size: 56px;
    font-weight: 900;
    color: rgba(176, 136, 48, 0.14); /* was rgba(200,168,75,0.12) — same feel */
    line-height: 1;
    margin-bottom: 16px;
}
.card-title {
    font-family: var(--serif);
    font-size: 20px;
    font-weight: 700;
    color: #a07018;           /* was #e2c572 — warm gold readable on light bg */
    margin-bottom: 12px;
}
.card-text {
    font-size: 15px;
    color: #5a6a80;           /* was #8fa3c0 — adjusted for light bg */
    line-height: 1.7;
}

/* ─── FOOTER ─── */
#footer {
    background: #1E2744;      /* was #080c2e — lifted to mid navy */
    border-top: 1px solid rgba(212, 168, 67, 0.2);
    padding: 80px 60px 0px;
    position: relative;
}
#footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, #D4A843 20%, #EDD98A 50%, #D4A843 80%, transparent);
}
#footer .footer-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 0;
}
#footer .footer-name {
    font-family: 'Cinzel', serif;
    font-size: 18px;
    letter-spacing: 3px;
    color: #D4A843;           /* was #c8a84b — consistent */
    margin-bottom: 4px;
}
#footer .footer-about, #footer ul li {
    font-size: 13px;
    line-height: 1.85;
    color: #b0bcd4;           /* was #a0a8c8 — slightly lighter */
    font-weight: 300;
    opacity: 0.85;
}
#footer .footer-tagline {
    font-size: 9px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #b0bcd4;
    opacity: 0.6;
    margin-bottom: 20px;
}
#footer .footer-col-title {
    font-family: 'Cinzel', serif;
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #D4A843;
    margin-bottom: 22px;
}
#footer .footer-links a {
    text-decoration: none;
    font-size: 13px;
    color: #b0bcd4;
    opacity: 0.75;
    transition: opacity 0.2s, color 0.2s, padding-left 0.2s;
}
#footer .footer-bottom {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px;
    padding-top: 40px;
    border-top: 1px solid rgba(212, 168, 67, 0.2);
}
#footer .footer-copy {
    font-size: 11px;
    color: #b0bcd4;
    opacity: 0.45;
    letter-spacing: 1px;
}
#footer .socialMedia a {
    color: #bb9236;
    border: 1px solid #bb9236;
    padding: 3px 7px;
    border-radius: 3px;
}
#footer .socialMedia a:hover {
    color: #fffdf8;
    border: 1px solid #bb9236; 
    background: #be9437;
}

/* ─── EXP CONTENT LIST ─── */
.exp_Content ul li b{
    font-family: 'Cinzel', serif;
    font-size: 16px;
    letter-spacing: 2px;
    line-height: 1.05;
    color: #b08830;           /* was #c8a84b — readable on light bg */
    margin-bottom: 18px;
    font-weight: bold;
}
.exp_Content ul li p{
    font-size: 14px; 
    color: #3a3020;           /* was #1a1c21 — kept dark, slightly warmer */
    margin-bottom: 10px;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 991.98px) {
    .header {
            padding: 0 30px!important;
    }
    .header .menuBar #navbar, .fixed .menuBar #navbar {
        position: absolute;
        background: #FFFCF7;  /* was #0b1039 — light mobile menu */
        width: 100%;
        left: 0;
        right: 0;
        padding-bottom: 20px;
        top: 115px;
        border-bottom: 1px solid rgba(212, 168, 67, 0.2);
        box-shadow: 0 8px 24px rgba(60, 50, 20, 0.08);
    } 
    .cards-grid {
        grid-template-columns: 1fr;
    }
    .header .navbar-brand {
        width: 70px;
        height: 70px; 
    }
    #BannerSec { 
        min-height: 450px; 
    }
    #carouselExampleIndicators{
        height:100%;
    }
    .carousel-inner{
        height:100%;
    }
    .carousel-item{
        height:100%;
    }
    .carousel-item img{
        height: 100%;
    }
    #ServiceSec .exp-panel { 
        padding: 73px 40px!important; 
        min-height: 280px!important;
    }
}

.blog-inner-banner {
  position: relative;
  height: 50vh;
  min-height: 420px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 82px; 
}
.blog-banner-bg {
  position: absolute;
  inset: 0;
}
.blog-banner-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.25) brightness(0.45) sepia(0.2);
  transform: scale(1.04);
}
.blog-banner-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to bottom, rgba(30,20,5,0.2) 0%, rgba(30,20,5,0.7) 100%);
}
.blog-banner-bars {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: repeating-linear-gradient(
    90deg,
    transparent, transparent 44px,
    rgba(20,15,5,0.3) 44px,
    rgba(20,15,5,0.3) 49px
  );
}
.blog-banner-content {
  position: relative;
  z-index: 4;
  text-align: center;
  animation: fadeUp 1.1s ease both;
}

.section-eyebrow-blog {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: #b08830;
  margin-bottom: 12px;
}
.section-title-blog {
  font-family: 'Cinzel', serif;
  font-size: clamp(28px, 3.5vw, 46px);
  font-weight: 700;
  color: #1E2744;
  line-height: 1.1;
  margin-bottom: 14px;
}
.section-sub-blog {
  font-size: 15px;
  color: #6b7a96;
  font-style: italic;
  font-weight: 300;
}

.blog-featured-hero {
  background: #F2EDE4;
  padding: 0;
}
.featured-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 560px;
}
.featured-img-wrap {
  position: relative;
  overflow: hidden;
}
.featured-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.3) brightness(0.55) sepia(0.15);
  transition: transform 6s ease;
  transform: scale(1.04);
}
.featured-img-wrap:hover .featured-img {
  transform: scale(1);
}
.featured-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, transparent 60%, #F2EDE4 100%);
  pointer-events: none;
}
.featured-text-wrap {
  display: flex;
  align-items: center;
  background: #F2EDE4;
  padding: 60px 60px 60px 48px;
}
.featured-text-inner {
  max-width: 480px;
}
.blog-eyebrow {
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: #b08830;
  display: block;
  margin-bottom: 16px;
}
.blog-meta-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.blog-tag {
  background: rgba(176,136,48,0.12);
  border: 1px solid rgba(176,136,48,0.3);
  color: #8a6420;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 4px 10px;
  font-weight: 600;
}
.blog-date {
  font-size: 12px;
  color: #9a8a70;
  letter-spacing: 1px;
}
.featured-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 700;
  color: #1E2744;
  line-height: 1.1;
  margin-bottom: 20px;
}
.featured-title em {
  font-family: 'Crimson Text', serif;
  font-style: italic;
  color: #b08830;
  font-size: 1.1em;
  display: block;
  margin-top: 4px;
}
.featured-excerpt {
  font-size: 15px;
  color: #4a4030;
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 28px;
}
.featured-author-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  padding-top: 20px;
  border-top: 1px solid rgba(176,136,48,0.2);
}
.author-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(176,136,48,0.15);
  border: 1px solid rgba(176,136,48,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  font-weight: 700;
  color: #b08830;
  flex-shrink: 0;
}
.author-name {
  font-size: 13px;
  font-weight: 600;
  color: #1E2744;
  letter-spacing: 0.5px;
}
.author-role {
  font-size: 11px;
  color: #9a8a70;
  letter-spacing: 0.5px;
}

.exhibit-grid-sec {
  padding: 100px 0;
  background: #F9F5EE;
}
.exhibit-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}
.exhibit-card {
  background: #FFFCF7;
  border: 1px solid #e8e0d0;
  transition: box-shadow 0.3s, transform 0.3s;
  position: relative;
}
.exhibit-card:hover {
  box-shadow: 0 8px 32px rgba(60,50,20,0.1);
  transform: translateY(-3px);
  z-index: 1;
}
.exhibit-card--featured {
  border-top: 3px solid #D4A843;
}
.exhibit-card-img-wrap {
  position: relative;
  overflow: hidden;
  height: 220px;
}
.exhibit-card-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.3) brightness(0.6) sepia(0.15);
  transition: filter 0.5s, transform 0.5s;
  transform: scale(1.04);
}
.exhibit-card:hover .exhibit-card-img-wrap img {
  filter: saturate(0.5) brightness(0.7) sepia(0.1);
  transform: scale(1);
}
.exhibit-card-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(20,14,4,0.55) 0%, transparent 60%);
  pointer-events: none;
}
.exhibit-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #EDD98A;
  background: rgba(30,20,5,0.65);
  border: 1px solid rgba(212,168,67,0.35);
  padding: 4px 10px;
  backdrop-filter: blur(6px);
}
.exhibit-badge--gold {
  color: #1E2744;
  background: #D4A843;
  border-color: #D4A843;
}
.exhibit-card-body {
  padding: 28px 28px 32px;
}
.exhibit-tag {
  font-size: 9px;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: #b08830;
  font-weight: 700;
  display: block;
  margin-bottom: 10px;
}
.exhibit-title {
  font-family: 'Cinzel', serif;
  font-size: 20px;
  font-weight: 700;
  color: #1E2744;
  letter-spacing: 1px;
  line-height: 1.2;
  margin-bottom: 12px;
}
.exhibit-excerpt {
  font-size: 14px;
  color: #5a6a80;
  line-height: 1.75;
  font-weight: 300;
  margin-bottom: 20px;
}
.exhibit-readmore {
  display: inline-flex;
  align-items: center;
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #b08830;
  text-decoration: none;
  font-weight: 700;
  border-bottom: 1px solid rgba(176,136,48,0.35);
  padding-bottom: 3px;
  transition: color 0.2s, border-color 0.2s;
}
.exhibit-readmore:hover {
  color: #D4A843;
  border-color: #D4A843;
}

.ftj-cta-sec {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  display: flex;
  align-items: center;
  padding: 80px 0;
}
.ftj-cta-bg {
  position: absolute;
  inset: 0;
}
.ftj-cta-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.2) brightness(0.35) sepia(0.2);
}
.ftj-cta-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(15,10,3,0.82) 0%, rgba(30,39,68,0.78) 100%);
  z-index: 1;
}
.ftj-cta-bars {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: repeating-linear-gradient(
    90deg,
    transparent, transparent 44px,
    rgba(212,168,67,0.06) 44px,
    rgba(212,168,67,0.06) 49px
  );
}
.ftj-cta-inner {
  position: relative;
  z-index: 3;
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
  padding: 0 20px;
}
.ftj-cta-badge {
  display: inline-block;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #EDD98A;
  border: 1px solid rgba(237,217,138,0.4);
  padding: 6px 18px;
  margin-bottom: 28px;
  background: rgba(212,168,67,0.08);
  backdrop-filter: blur(8px);
}
.ftj-icon {
  font-size: 44px;
  display: block;
  margin-bottom: 16px;
}
.ftj-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(40px, 6vw, 72px);
  font-weight: 700;
  color: #FFF8EC;
  letter-spacing: 6px;
  line-height: 1;
  margin-bottom: 8px;
  text-shadow: 0 4px 30px rgba(0,0,0,0.5);
}
.ftj-subtitle {
  font-family: 'Crimson Text', serif;
  font-style: italic;
  font-size: 22px;
  color: #EDD98A;
  letter-spacing: 2px;
  margin-bottom: 24px;
}
.ftj-desc {
  font-size: 15px;
  color: #c8bda8;
  line-height: 1.85;
  font-weight: 300;
  max-width: 520px;
  margin: 0 auto 36px;
}
.ftj-desc strong {
  color: #EDD98A;
  font-weight: 600;
}
.ftj-stats-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 36px;
  flex-wrap: wrap;
  gap: 4px;
}
.ftj-stat {
  text-align: center;
  padding: 16px 32px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(212,168,67,0.18);
}
.ftj-stat-divider {
  width: 1px;
  height: 48px;
  background: rgba(212,168,67,0.2);
  display: none;
}
.ftj-stat-num {
  font-family: 'Cinzel', serif;
  font-size: 26px;
  font-weight: 700;
  color: #D4A843;
  line-height: 1;
  margin-bottom: 4px;
}
.ftj-stat-label {
  font-size: 9px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #9a8a6a;
}
.ftj-btn {
  margin: 0 auto;
}

/* ── FAQ SECTION ── */
.faq-sec {
  padding: 100px 0 110px;
  background: #FFFCF7;
  position: relative;
}
.faq-sec::before {
  content: 'FAQ';
  position: absolute;
  top: 20px;
  left: -10px;
  font-family: 'Cinzel', serif;
  font-size: 160px;
  color: rgba(212,168,67,0.05);
  letter-spacing: 10px;
  pointer-events: none;
  line-height: 1;
}
.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.faq-item {
  border: 1px solid #e8e0d0;
  background: #FFFCF7;
  overflow: hidden;
  transition: border-color 0.3s;
}
.faq-item:has(.faq-answer.show) {
  border-color: rgba(212,168,67,0.5);
  border-left: 3px solid #D4A843;
}
.faq-question {
  width: 100%;
  background: none;
  border: none;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
  text-align: left;
  font-family: 'Cinzel', serif;
  font-size: 13px;
  letter-spacing: 0.8px;
  color: #1E2744;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
}
.faq-question:hover {
  background: rgba(212,168,67,0.04);
}
.faq-icon {
  color: #b08830;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.faq-chevron {
  margin-left: auto;
  flex-shrink: 0;
  color: #b08830;
  transition: transform 0.3s ease;
  display: flex;
  align-items: center;
}
.faq-question:not(.collapsed) .faq-chevron {
  transform: rotate(180deg);
}
.faq-answer-inner {
  padding: 0 24px 22px 56px;
}
.faq-answer-inner p {
  font-size: 14px;
  color: #4a4030;
  line-height: 1.85;
  font-weight: 300;
  margin: 0;
}
.faq-answer-inner strong {
  color: #1E2744;
  font-weight: 600;
}

@media (max-width: 991.98px) {
  .featured-inner {
    grid-template-columns: 1fr;
  }
  .featured-img-wrap {
    height: 260px;
  }
  .featured-img-overlay {
    background: linear-gradient(to bottom, transparent 40%, #F2EDE4 100%);
  }
  .featured-text-wrap {
    padding: 36px 24px 48px;
  }
  .exhibit-grid {
    grid-template-columns: 1fr;
  }
  .ftj-stats-row {
    flex-direction: column;
    gap: 2px;
  }
  .ftj-stat {
    width: 100%;
    max-width: 260px;
  }
  .serviceCardSec:after { 
    outline-offset: -10px; 
}
}

@media (max-width: 767.98px) {
  .blog-inner-banner {
    min-height: 300px;
  }
  .blog-featured-hero .featured-text-wrap {
    padding: 28px 16px 40px;
  }
  .exhibit-grid-sec,
  .faq-sec {
    padding: 60px 0;
  }
  .faq-answer-inner {
    padding-left: 24px;
  }
  .ftj-cta-sec {
    min-height: 480px;
    padding: 60px 0;
  }
}

.about-page { background: #ffffff; color: #2a2a2a; }

/* ── SHARED TYPE ── */
.about-eyebrow {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  color: #b08830;
  margin-bottom: 12px;
  display: block;
}
.about-section-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.15;
  margin-bottom: 20px;
}
.about-title-accent {
  color: #b08830;
  font-style: italic;
  font-family: 'Crimson Text', serif;
}
.about-body-text {
  font-size: 15px;
  color: #4a4a4a;
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: 18px;
}

/* ── HERO CAROUSEL ── */
.about-hero-sec { margin-top: 82px; }
.about-carousel { position: relative; overflow: hidden; }
.about-carousel-img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  object-position: center;
  filter: none;
  display: block;
}
.about-carousel-overlay {
  background: transparent;
}
.about-carousel-caption {
  position: absolute;
  bottom: 72px;
  left: 0; right: 0;
  text-align: center;
  z-index: 2;
  padding: 0 20px;
}
.about-carousel-tag {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: #EDD98A;
  display: block;
  margin-bottom: 12px;
  font-weight: 600;
}
.about-carousel-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(30px, 5vw, 58px);
  font-weight: 700;
  color: #FFF8EC;
  letter-spacing: 4px;
  line-height: 1.05;
  text-shadow: 0 3px 30px rgba(0,0,0,0.5);
  margin: 0;
}
.about-carousel-title em {
  font-family: 'Crimson Text', serif;
  font-style: italic;
  color: #EDD98A;
  font-size: 0.8em;
  display: block;
  letter-spacing: 3px;
  margin-top: 6px;
}

/* Rectangle indicators */
.about-indicators { bottom: 24px; }
.about-indicators [data-bs-target] {
  width: 28px; height: 4px;
  border-radius: 0;
  background: rgba(255,255,255,0.35);
  border: none; opacity: 1;
  transition: background 0.3s, width 0.3s;
}
.about-indicators .active { background: #D4A843; width: 44px; }

/* Controls */
.about-ctrl {
  width: 44px; height: 44px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(212,168,67,0.3);
  border-radius: 0;
  top: 50%; transform: translateY(-50%);
  position: absolute;
  display: flex; align-items: center; justify-content: center;
  color: #EDD98A;
  backdrop-filter: blur(8px);
  transition: background 0.25s;
  z-index: 5;
}
.about-ctrl:hover { background: rgba(212,168,67,0.2); }
.carousel-control-prev.about-ctrl { left: 20px; }
.carousel-control-next.about-ctrl { right: 20px; }

/* ── ABOUT INTRO ── */
.about-intro-sec { padding: 100px 0; background: #ffffff; }

.about-img-mosaic {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 6px;
  height: 420px;
}
.mosaic-main { overflow: hidden; }
.mosaic-main img {
  width: 100%; height: 100%; object-fit: cover;
  filter: none;
  transition: filter 0.5s;
}
.mosaic-main:hover img { filter: saturate(0.5) brightness(0.75); }
.mosaic-side { display: flex; flex-direction: column; gap: 6px; }
.mosaic-side img {
  width: 100%; flex: 1; object-fit: cover;
  filter: none;
  transition: filter 0.5s;
  display: block;
}
.mosaic-side img:hover { filter: saturate(0.45) brightness(0.72); }

/* ── CONTRIBUTION ── */
.about-contribution-sec {
  background: #F8F5F0;
  padding: 90px 0;
  position: relative;
}
.about-contribution-sec::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, #D4A843 30%, #EDD98A 50%, #D4A843 70%, transparent);
}
.about-contribution-inner {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
  padding: 0 20px;
}
.contribution-label {
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: #b08830;
  margin-bottom: 18px;
}
.contribution-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(22px, 3.5vw, 36px);
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.15;
  margin-bottom: 24px;
}
.contribution-text {
  font-size: 15px;
  color: #4a4040;
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: 16px;
}
.contribution-text strong { color: #1a1a1a; font-weight: 600; }
.contribution-highlight-row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 36px;
}
.contribution-highlight {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #ffffff;
  border: 1px solid #e0d8c8;
  padding: 10px 18px;
  font-size: 13px;
  color: #3a3020;
  font-weight: 500;
}
.ch-icon { font-size: 18px; }

/* ── ARTIFACTS SECTION ── */
.artifacts-sec {
  padding: 100px 0;
  background: #ffffff;
}
.artifacts-intro {
  font-size: 15px;
  color: #5a5a5a;
  line-height: 1.85;
  font-weight: 300;
  max-width: 680px;
  margin: 0 auto 56px;
  text-align: center;
}
.artifacts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}
.artifact-card {
  background: #FAFAF8;
  border: 1px solid #ece6db;
  border-top: 3px solid transparent;
  padding: 36px 28px;
  transition: border-top-color 0.3s, box-shadow 0.3s, background 0.3s;
}
.artifact-card:hover {
  border-top-color: #D4A843;
  background: #ffffff;
  box-shadow: 0 4px 20px rgba(60,50,20,0.07);
}
.artifact-icon-wrap {
  margin-bottom: 18px;
}
.artifact-icon {
  font-size: 32px;
  line-height: 1;
}
.artifact-name {
  font-family: 'Cinzel', serif;
  font-size: 16px;
  font-weight: 700;
  color: #1a1a1a;
  letter-spacing: 0.5px;
  line-height: 1.25;
  margin-bottom: 14px;
}
.artifact-desc {
  font-size: 14px;
  color: #5a6070;
  line-height: 1.8;
  font-weight: 300;
  margin: 0;
}

/* ── GALLERY ── */
.about-gallery-sec { padding: 100px 0; background: #F8F5F0; }

.about-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: 6px;
}
.gallery-frame {
  position: relative;
  overflow: hidden;
  height: 220px;
  background: #f0ece4;
}
.gallery-frame--tall { grid-row: span 2; height: 100%; min-height: 446px; }
.gallery-frame--wide { grid-column: span 2; }
.gallery-frame img {
  width: 100%; height: 100%; object-fit: cover;
  filter: none;
  transition: filter 0.5s, transform 0.5s;
  transform: scale(1.03);
  display: block;
}
.gallery-frame:hover img {
  filter: saturate(0.45) brightness(0.72);
  transform: scale(1);
}
.gallery-frame-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,8,2,0.6) 0%, transparent 55%);
  display: flex; align-items: flex-end;
  padding: 16px 18px;
  pointer-events: none;
}
.gallery-frame-label {
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #EDD98A;
  font-weight: 600;
}

















/* ── TWO EXPERIENCES ── */
.about-exp-sec { padding: 100px 0 110px; background: #ffffff; }

.exp-card {
  background: #FAFAF8;
  border: 1px solid #ece6db;
  border-top: 3px solid #D4A843;
  padding: 40px 36px;
  height: 100%;
}
.exp-card--dark {
  background: #1E2744;
  border-color: transparent;
  border-top: 3px solid #D4A843;
}
.exp-card-header {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(212,168,67,0.18);
}
.exp-card-icon { font-size: 32px; line-height: 1; flex-shrink: 0; margin-top: 2px; }
.exp-card-title {
  font-family: 'Cinzel', serif;
  font-size: 20px;
  font-weight: 700;
  color: #1a1a1a;
  letter-spacing: 1px;
  margin: 0 0 4px;
}
.exp-card--dark .exp-card-title { color: #FFF8EC; }
.exp-card-subtitle {
  font-size: 10px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #b08830;
  margin: 0;
  font-weight: 600;
}
.exp-card-body-text {
  font-size: 14px;
  color: #4a4a4a;
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 20px;
}
.exp-card-body-text--light { color: #a0b0c8; }

.exp-feature-list {
  list-style: none;
  padding: 0; margin: 0 0 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.exp-feature-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 14px;
  color: #444;
  line-height: 1.7;
}
.exp-card--dark .exp-feature-list li { color: #b0bcd4; }

.ef-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #D4A843;
  flex-shrink: 0;
  margin-top: 8px;
}
.ef-dot--gold { background: #EDD98A; }

/* Barrack theme tags */
.barrack-theme-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}
.barrack-theme-tag {
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #D4A843;
  border: 1px solid rgba(212,168,67,0.3);
  padding: 5px 12px;
  background: rgba(212,168,67,0.06);
  font-weight: 600;
}

/* ── RESPONSIVE ── */
@media (max-width: 991.98px) {
  .about-img-mosaic { height: 300px; }
  .artifacts-grid { grid-template-columns: 1fr 1fr; }
  .about-gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-frame--tall { grid-column: span 2; grid-row: span 1; min-height: 220px; }
  .gallery-frame--wide { grid-column: span 2; }
  #footer { 
    padding: 50px 30px 0px!important; 
}
}

@media (max-width: 767.98px) {
  .about-carousel-img { height: 340px; }
  .about-intro-sec,
  .about-contribution-sec,
  .artifacts-sec,
  .about-gallery-sec,
  .about-exp-sec { padding: 60px 0; }
  .about-img-mosaic { grid-template-columns: 1fr; height: auto; }
  .mosaic-main { height: 220px; }
  .mosaic-side { flex-direction: row; height: 120px; }
  .mosaic-side img { height: 100%; }
  .artifacts-grid { grid-template-columns: 1fr; }
  .about-gallery-grid { grid-template-columns: 1fr; }
  .gallery-frame,
  .gallery-frame--tall,
  .gallery-frame--wide {
    grid-column: span 1;
    grid-row: span 1;
    height: 200px; min-height: unset;
  }
  .exp-card { padding: 28px 20px; }
  .contribution-highlight-row { flex-direction: column; align-items: center; }
}











.hero-section {
            position: relative;
            height: 70vh;
            background: url('https://images.unsplash.com/photo-1563492065-5ffa60875206?ixlib=rb-4.0.3&auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
        }

        .hero-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.55);
        }

        .hero-content {
            position: relative;
            z-index: 2;
            text-align: center;
            max-width: 800px;
            padding: 0 20px;
        }

        .hero-content h1 {
            font-family: 'Cinzel', serif;
            font-size: 3rem;
            font-weight: 700;
            margin-bottom: 1rem;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
        }

        .hero-content p {
            font-family: 'Crimson Text', serif;
            font-size: 1.2rem;
            margin-bottom: 2rem;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8);
        }

        .breadcrumb {
            background: transparent;
            justify-content: center;
            margin-bottom: 2rem;
        }

        .breadcrumb-item a {
            color: #EDD98A;
            text-decoration: none;
        }

        .breadcrumb-item.active {
            color: white;
        }

        .section-title {
            font-family: 'Cinzel', serif;
            font-size: 2.5rem;
            font-weight: 600;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .section-subtitle {
            font-family: 'Source Sans 3', sans-serif;
            font-size: 1rem;
            color: #6b7a96;
            margin-bottom: 2rem;
        }

        .card-custom {
            background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
            border: 1px solid #dee2e6;
            border-radius: 10px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            overflow: hidden;
        }

        .card-custom:hover {
            transform: translateY(-5px);
            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
        }

        .card-custom .card-body {
            padding: 2rem;
        }

        .card-custom h5 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
            margin-bottom: 0.5rem;
        }

        .card-custom p {
            font-family: 'Source Sans 3', sans-serif;
            color: #6b7a96;
            margin: 0;
        }

        .attraction-card {
            background: white;
            border-left: 5px solid #b08830;
            border-radius: 8px;
            overflow: hidden;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
            transition: transform 0.3s ease;
        }

        .attraction-card:hover {
            transform: translateY(-5px);
        }

        .attraction-card-image {
            height: 250px;
            background-size: cover;
            background-position: center;
        }

        .attraction-card-content {
            padding: 2rem;
        }

        .attraction-card h4 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .attraction-card ul {
            list-style: none;
            padding: 0;
        }

        .attraction-card li {
            margin-bottom: 0.5rem;
            color: #6b7a96;
            padding-left: 20px;
            position: relative;
        }

        .attraction-card li::before {
            content: '▸';
            color: #b08830;
            position: absolute;
            left: 0;
        }

        .programme-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 1.5rem;
        }

        .programme-item {
            background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
            padding: 1.5rem;
            border-radius: 8px;
            text-align: center;
            border: 1px solid #dee2e6;
            transition: all 0.3s ease;
        }

        .programme-item:hover {
            background: linear-gradient(135deg, #e9ecef 0%, #f8f9fa 100%);
            transform: translateY(-3px);
        }

        .programme-item h6 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
        }

        .products-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
            gap: 1.5rem;
        }

        .product-item {
            background: white;
            padding: 1.5rem;
            border-radius: 8px;
            text-align: center;
            border: 1px solid #dee2e6;
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
            transition: all 0.3s ease;
        }

        .product-item:hover {
            transform: translateY(-5px);
            box-shadow: 0 5px 20px rgba(0, 0, 0, 0.12);
        }

        .product-item h6 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
        }

        .heritage-section {
            background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
            padding: 3rem 2rem;
            border-radius: 10px;
            margin-bottom: 2rem;
        }

        .heritage-section h4 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .heritage-section p {
            color: #6b7a96;
            margin-bottom: 1rem;
        }

        .dos-donts {
            display: flex;
            flex-wrap: wrap;
            gap: 2rem;
        }

        .dos-donts .col-md-6 {
            flex: 1;
        }

        .dos-donts-box {
            background: #f8f9fa;
            border: 1px solid #dee2e6;
            border-radius: 10px;
            padding: 2rem;
            height: 100%;
        }

        .dos-donts-box h4 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .dos-donts-box ul {
            list-style: none;
            padding: 0;
        }

        .dos-donts-box li {
            margin-bottom: 0.5rem;
            font-family: 'Source Sans 3', sans-serif;
            color: #6b7a96;
        }

        .dos-donts-box li::before {
            content: '•';
            color: #b08830;
            font-weight: bold;
            margin-right: 0.5rem;
        }

        .warning-box {
            background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%);
            border: 1px solid #ffc107;
            border-radius: 10px;
            padding: 2rem;
            margin: 2rem 0;
        }

        .warning-box h4 {
            color: #856404;
            font-family: 'Cinzel', serif;
        }

        .warning-box ul {
            list-style: none;
            padding: 0;
            margin: 0;
        }

        .warning-box li {
            margin-bottom: 0.5rem;
            color: #856404;
        }

        .warning-box li::before {
            content: '⚠️';
            margin-right: 0.5rem;
        }

        .cta-section {
            background: url('https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?ixlib=rb-4.0.3&auto=format&fit=crop&w=1000&q=80') center/cover no-repeat;
            padding: 5rem 0;
            color: white;
            text-align: center;
            position: relative;
        }

        .cta-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.8);
        }

        .cta-content {
            position: relative;
            z-index: 2;
        }

        .cta-content h2 {
            font-family: 'Cinzel', serif;
            font-size: 2.5rem;
            margin-bottom: 1rem;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
        }

        .cta-buttons {
            display: flex;
            justify-content: center;
            gap: 1rem;
            flex-wrap: wrap;
        }

        @media (max-width: 768px) {
            .hero-content h1 {
                font-size: 2rem;
            }

            .section-title {
                font-size: 2rem;
            }

            .dos-donts {
                flex-direction: column;
            }

            .cta-buttons {
                flex-direction: column;
                align-items: center;
            }

            .programme-grid {
                grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
            }

            .products-grid {
                grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
            }
        }



        .hero-section {
      position: relative;
      height: 70vh;
      background: url('https://images.unsplash.com/photo-1563492065-5ffa60875206?ixlib=rb-4.0.3&auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
    }
    .hero-overlay {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.55);
    }
    .hero-content {
      position: relative;
      z-index: 2;
      text-align: center;
      max-width: 800px;
      padding: 0 20px;
    }
    .hero-content h1 {
      font-family: 'Cinzel', serif;
      font-size: 3rem;
      font-weight: 700;
      margin-bottom: 1rem;
      text-shadow: 2px 2px 4px rgba(0,0,0,0.8);
    }
    .hero-content p {
      font-family: 'Crimson Text', serif;
      font-size: 1.2rem;
      margin-bottom: 2rem;
      text-shadow: 1px 1px 2px rgba(0,0,0,0.8);
    }
    .breadcrumb {
      background: transparent;
      justify-content: center;
      margin-bottom: 2rem;
    }
    .breadcrumb-item a {
      color: #EDD98A;
      text-decoration: none;
    }
    .breadcrumb-item.active {
      color: white;
    }
    .section-title {
      font-family: 'Cinzel', serif;
      font-size: 2.5rem;
      font-weight: 600;
      color: #1E2744;
      margin-bottom: 1rem;
    }
    .section-subtitle {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 1rem;
      color: #6b7a96;
      margin-bottom: 2rem;
    }
    .card-custom {
      background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
      border: 1px solid #dee2e6;
      border-radius: 10px;
      box-shadow: 0 4px 15px rgba(0,0,0,0.1);
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      overflow: hidden;
    }
    .card-custom:hover {
      transform: translateY(-5px);
      box-shadow: 0 8px 25px rgba(0,0,0,0.15);
    }
    .card-custom .card-body {
      padding: 2rem;
    }
    .card-custom h5 {
      font-family: 'Cinzel', serif;
      color: #1E2744;
      margin-bottom: 0.5rem;
    }
    .card-custom p {
      font-family: 'Source Sans 3', sans-serif;
      color: #6b7a96;
      margin: 0;
    }
    .attraction-card {
      background: white;
      border-left: 5px solid #b08830;
      border-radius: 8px;
      overflow: hidden;
      box-shadow: 0 4px 15px rgba(0,0,0,0.1);
      transition: transform 0.3s ease;
    }
    .attraction-card:hover {
      transform: translateY(-5px);
    }
    .attraction-card-image {
      height: 250px;
      background-size: cover;
      background-position: center;
    }
    .attraction-card-content {
      padding: 2rem;
    }
    .attraction-card h4 {
      font-family: 'Cinzel', serif;
      color: #1E2744;
      margin-bottom: 1rem;
    }
    .attraction-card ul {
      list-style: none;
      padding: 0;
    }
    .attraction-card li {
      margin-bottom: 0.5rem;
      color: #6b7a96;
      padding-left: 20px;
      position: relative;
    }
    .attraction-card li::before {
      content: '▸';
      color: #b08830;
      position: absolute;
      left: 0;
    }
    .programme-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
      gap: 1.5rem;
    }
    .programme-item {
      background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
      padding: 1.5rem;
      border-radius: 8px;
      text-align: center;
      border: 1px solid #dee2e6;
      transition: all 0.3s ease;
    }
    .programme-item:hover {
      background: linear-gradient(135deg, #e9ecef 0%, #f8f9fa 100%);
      transform: translateY(-3px);
    }
    .programme-item h6 {
      font-family: 'Cinzel', serif;
      color: #1E2744;
    }
    .products-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
      gap: 1.5rem;
    }
    .product-item {
      background: white;
      padding: 1.5rem;
      border-radius: 8px;
      text-align: center;
      border: 1px solid #dee2e6;
      box-shadow: 0 2px 10px rgba(0,0,0,0.08);
      transition: all 0.3s ease;
    }
    .product-item:hover {
      transform: translateY(-5px);
      box-shadow: 0 5px 20px rgba(0,0,0,0.12);
    }
    .product-item h6 {
      font-family: 'Cinzel', serif;
      color: #1E2744;
    }
    .heritage-section {
      background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
      padding: 3rem 2rem;
      border-radius: 10px;
      margin-bottom: 2rem;
    }
    .heritage-section h4 {
      font-family: 'Cinzel', serif;
      color: #1E2744;
      margin-bottom: 1rem;
    }
    .heritage-section p {
      color: #6b7a96;
      margin-bottom: 1rem;
    }
    .dos-donts {
      display: flex;
      flex-wrap: wrap;
      gap: 2rem;
    }
    .dos-donts .col-md-6 {
      flex: 1;
    }
    .dos-donts-box {
      background: #f8f9fa;
      border: 1px solid #dee2e6;
      border-radius: 10px;
      padding: 2rem;
      height: 100%;
    }
    .dos-donts-box h4 {
      font-family: 'Cinzel', serif;
      color: #1E2744;
      margin-bottom: 1rem;
    }
    .dos-donts-box ul {
      list-style: none;
      padding: 0;
    }
    .dos-donts-box li {
      margin-bottom: 0.5rem;
      font-family: 'Source Sans 3', sans-serif;
      color: #6b7a96;
    }
    .dos-donts-box li::before {
      content: '•';
      color: #b08830;
      font-weight: bold;
      margin-right: 0.5rem;
    }
    .warning-box {
      background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%);
      border: 1px solid #ffc107;
      border-radius: 10px;
      padding: 2rem;
      margin: 2rem 0;
    }
    .warning-box h4 {
      color: #856404;
      font-family: 'Cinzel', serif;
    }
    .warning-box ul {
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .warning-box li {
      margin-bottom: 0.5rem;
      color: #856404;
    }
    .warning-box li::before {
      content: '⚠️';
      margin-right: 0.5rem;
    }
    .cta-section {
      background: url('https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?ixlib=rb-4.0.3&auto=format&fit=crop&w=1000&q=80') center/cover no-repeat;
      padding: 5rem 0;
      color: white;
      text-align: center;
      position: relative;
    }
    .cta-overlay {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.8);
    }
    .cta-content {
      position: relative;
      z-index: 2;
    }
    .cta-content h2 {
      font-family: 'Cinzel', serif;
      font-size: 2.5rem;
      margin-bottom: 1rem;
      text-shadow: 2px 2px 4px rgba(0,0,0,0.8);
    }
    .cta-buttons {
      display: flex;
      justify-content: center;
      gap: 1rem;
      flex-wrap: wrap;
    }
    @media (max-width: 768px) {
      .hero-content h1 {
        font-size: 2rem;
      }
      .section-title {
        font-size: 2rem;
      }
      .dos-donts {
        flex-direction: column;
      }
      .cta-buttons {
        flex-direction: column;
        align-items: center;
      }
      .programme-grid {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
      }
      .products-grid {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
      }
    }

     .hero-section {
            position: relative;
            height: 70vh;
            background: url('https://images.unsplash.com/photo-1558618666-fcd25c85cd64?ixlib=rb-4.0.3&auto=format&fit=crop&w=1000&q=80') center/cover no-repeat;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
        }

        .hero-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.7);
        }

        .hero-content {
            position: relative;
            z-index: 2;
            text-align: center;
            max-width: 800px;
            padding: 0 20px;
        }

        .hero-content h1 {
            font-family: 'Cinzel', serif;
            font-size: 3rem;
            font-weight: 700;
            margin-bottom: 1rem;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
        }

        .hero-content p {
            font-family: 'Crimson Text', serif;
            font-size: 1.2rem;
            margin-bottom: 2rem;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8);
        }

        .breadcrumb {
            background: transparent;
            justify-content: center;
            margin-bottom: 2rem;
        }

        .breadcrumb-item a {
            color: #EDD98A;
            text-decoration: none;
        }

        .breadcrumb-item.active {
            color: white;
        }

        .section-title {
            font-family: 'Cinzel', serif;
            font-size: 2.5rem;
            font-weight: 600;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .section-subtitle {
            font-family: 'Source Sans 3', sans-serif;
            font-size: 1rem;
            color: #6b7a96;
            margin-bottom: 2rem;
        }

        .card-custom {
            background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
            border: 1px solid #dee2e6;
            border-radius: 10px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            overflow: hidden;
        }

        .card-custom:hover {
            transform: translateY(-5px);
            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
        }

        .card-custom .card-body {
            padding: 2rem;
        }

        .card-custom h5 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .timeline {
            position: relative;
            padding-left: 30px;
        }

        .timeline::before {
            content: '';
            position: absolute;
            left: 15px;
            top: 0;
            bottom: 0;
            width: 2px;
            background: #b08830;
        }

        .timeline-item {
            position: relative;
            margin-bottom: 2rem;
        }

        .timeline-item::before {
            content: '';
            position: absolute;
            left: -22px;
            top: 10px;
            width: 12px;
            height: 12px;
            background: #b08830;
            border-radius: 50%;
        }

        .timeline-item h5 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
        }

        .dos-donts {
            display: flex;
            flex-wrap: wrap;
            gap: 2rem;
        }

        .dos-donts .col-md-6 {
            flex: 1;
        }

        .dos-donts-box {
            background: #f8f9fa;
            border: 1px solid #dee2e6;
            border-radius: 10px;
            padding: 2rem;
            height: 100%;
        }

        .dos-donts-box h4 {
            font-family: 'Cinzel', serif;
            color: #1E2744;
            margin-bottom: 1rem;
        }

        .dos-donts-box ul {
            list-style: none;
            padding: 0;
        }

        .dos-donts-box li {
            margin-bottom: 0.5rem;
            font-family: 'Source Sans 3', sans-serif;
        }

        .dos-donts-box li::before {
            content: '•';
            color: #b08830;
            font-weight: bold;
            margin-right: 0.5rem;
        }

        .warning-box {
            background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%);
            border: 1px solid #ffc107;
            border-radius: 10px;
            padding: 2rem;
            margin: 2rem 0;
        }

        .warning-box h4 {
            color: #856404;
            font-family: 'Cinzel', serif;
        }

        .cta-section {
            background: url('https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?ixlib=rb-4.0.3&auto=format&fit=crop&w=1000&q=80') center/cover no-repeat;
            padding: 5rem 0;
            color: white;
            text-align: center;
            position: relative;
        }

        .cta-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.8);
        }

        .cta-content {
            position: relative;
            z-index: 2;
        }

        .cta-content h2 {
            font-family: 'Cinzel', serif;
            font-size: 2.5rem;
            margin-bottom: 1rem;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
        }

        .cta-buttons {
            display: flex;
            justify-content: center;
            gap: 1rem;
            flex-wrap: wrap;
        }

        @media (max-width: 768px) {
            .hero-content h1 {
                font-size: 2rem;
            }

            .section-title {
                font-size: 2rem;
            }

            .dos-donts {
                flex-direction: column;
            }

            .cta-buttons {
                flex-direction: column;
                align-items: center;
            }
        }


        .hero-section {
      position: relative;
      min-height: 75vh;
      background-image:
        linear-gradient(
          rgba(0,0,0,0.15),
          rgba(0,0,0,0.28)
        ),
        url('./banner1.jpg');
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #f8f4eb;
      text-align: center;
      padding: 120px 20px 80px;
    }

    .hero-content {
      position: relative;
      z-index: 1;
      max-width: 860px;
      width: 100%;
    }

    .hero-breadcrumb {
      display: inline-flex;
      gap: 0.5rem;
      align-items: center;
      font-family: 'Source Sans 3', sans-serif;
      font-size: 0.85rem;
      color: rgba(248,244,235,0.88);
      margin-bottom: 1.4rem;
      text-transform: uppercase;
      letter-spacing: 0.18em;
    }
    .hero-breadcrumb a {
      color: rgba(248,244,235,0.88);
      text-decoration: none;
      transition: color 0.3s;
    }
    .hero-breadcrumb a:hover { color: #eedc9e; }
    .hero-breadcrumb .sep { opacity: 0.5; }

    .hero-content h1 {
      font-family: 'Cinzel', serif;
      font-size: clamp(2.2rem, 5vw, 3.8rem);
      font-weight: 700;
      line-height: 1.1;
      letter-spacing: 0.02em;
      color: #ffffff;
      text-shadow: 0 2px 24px rgba(0,0,0,0.45), 0 1px 4px rgba(0,0,0,0.3);
      margin-bottom: 1.1rem;
    }

    .hero-content p {
      font-family: 'Crimson Text', serif;
      font-size: clamp(1rem, 2vw, 1.22rem);
      color: rgba(248,244,235,0.93);
      line-height: 1.78;
      max-width: 720px;
      margin: 0 auto;
      text-shadow: 0 1px 8px rgba(0,0,0,0.3);
    }

    /* ════════════════════════════════════════════
       SECTION TYPOGRAPHY
    ════════════════════════════════════════════ */
    .section-eyebrow {
      font-family: 'Cinzel', serif;
      font-size: 10px;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: #b08830;
      margin-bottom: 10px;
      display: block;
    }

    .section-title {
      font-family: 'Cinzel', serif;
      font-size: clamp(1.8rem, 3.5vw, 2.5rem);
      font-weight: 700;
      color: #1E2744;
      margin-bottom: 0.75rem;
      line-height: 1.2;
    }

    .section-title em {
      font-family: 'Crimson Text', serif;
      font-style: italic;
      color: #b08830;
    }

    .section-lead {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 1.02rem;
      color: #5a6a80;
      line-height: 1.75;
      max-width: 660px;
      margin: 0 auto;
    }

    /* ════════════════════════════════════════════
       VISITOR INFO CARDS
    ════════════════════════════════════════════ */
    .vinfo-card {
      background: #ffffff;
      border: 1px solid #e4ddd0;
      border-top: 3px solid #b08830;
      border-radius: 10px;
      padding: 2rem 1.6rem;
      height: 100%;
      transition: transform 0.28s ease, box-shadow 0.28s ease;
      position: relative;
    }
    .vinfo-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 12px 32px rgba(60,40,10,0.11);
    }
    .vinfo-icon {
      font-size: 26px;
      margin-bottom: 12px;
      display: block;
    }
    .vinfo-card h5 {
      font-family: 'Cinzel', serif;
      font-size: 14px;
      letter-spacing: 0.08em;
      color: #1E2744;
      margin-bottom: 8px;
    }
    .vinfo-card p {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 14px;
      color: #5a6a80;
      margin: 0;
      line-height: 1.65;
    }
    .vinfo-card .price {
      font-family: 'Cinzel', serif;
      font-size: 2rem;
      font-weight: 700;
      color: #b08830;
      display: block;
      margin-bottom: 4px;
    }

    /* ════════════════════════════════════════════
       ATTRACTION CARDS — LOCAL IMAGES, NO OVERLAY
    ════════════════════════════════════════════ */
    .attraction-card {
      background: #ffffff;
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 4px 20px rgba(30,20,5,0.1);
      border: 1px solid #e4ddd0;
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      height: 100%;
    }
    .attraction-card:hover {
      transform: translateY(-6px);
      box-shadow: 0 14px 40px rgba(30,20,5,0.15);
    }

    /* Image shown FULL — no dark filter, no overlay div */
    .attraction-card-image {
      height: 240px;
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      position: relative;
    }

    /* Only a very subtle bottom fade to separate from text — not hiding the image */
    .attraction-card-image::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 50px;
      background: linear-gradient(transparent, rgba(255,255,255,0.55));
      pointer-events: none;
    }

    .attraction-card-content {
      padding: 1.6rem 1.8rem 1.8rem;
    }

    .attraction-card-content h4 {
      font-family: 'Cinzel', serif;
      font-size: 15px;
      letter-spacing: 0.06em;
      color: #1E2744;
      margin-bottom: 14px;
      padding-bottom: 10px;
      border-bottom: 1px solid #e4ddd0;
    }

    .attraction-card-content ul {
      list-style: none;
      padding: 0;
      margin: 0;
    }

    .attraction-card-content li {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 13.5px;
      color: #5a6a80;
      line-height: 1.6;
      padding: 5px 0 5px 18px;
      position: relative;
      border-bottom: 1px solid #f2ede6;
    }
    .attraction-card-content li:last-child { border-bottom: none; }
    .attraction-card-content li::before {
      content: '▸';
      position: absolute;
      left: 0;
      color: #b08830;
      font-size: 10px;
      top: 8px;
    }

    /* ════════════════════════════════════════════
       PROGRAMMES GRID
    ════════════════════════════════════════════ */
    .programme-item {
      background: #ffffff;
      border: 1px solid #e4ddd0;
      border-top: 2px solid #b08830;
      padding: 1.4rem 1rem;
      border-radius: 8px;
      text-align: center;
      transition: transform 0.25s ease, box-shadow 0.25s ease;
    }
    .programme-item:hover {
      transform: translateY(-4px);
      box-shadow: 0 8px 22px rgba(30,20,5,0.1);
    }
    .programme-item .prog-icon { font-size: 26px; margin-bottom: 10px; display: block; }
    .programme-item h6 {
      font-family: 'Cinzel', serif;
      font-size: 12px;
      letter-spacing: 0.06em;
      color: #1E2744;
      margin: 0;
    }

    /* ════════════════════════════════════════════
       PRODUCTS TAGS
    ════════════════════════════════════════════ */
    .product-tag {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      border: 1px solid rgba(176,136,48,0.35);
      background: rgba(176,136,48,0.05);
      color: #8a6418;
      font-family: 'Cinzel', serif;
      font-size: 11px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      padding: 10px 18px;
      border-radius: 4px;
      margin: 5px;
      transition: background 0.25s, color 0.25s;
    }
    .product-tag:hover {
      background: rgba(176,136,48,0.12);
      color: #6a4a10;
    }
    .product-tag .dot {
      width: 5px;
      height: 5px;
      background: #b08830;
      border-radius: 50%;
      flex-shrink: 0;
    }

    /* ════════════════════════════════════════════
       HERITAGE TIMELINE
    ════════════════════════════════════════════ */
    .heritage-item {
      display: flex;
      gap: 24px;
      padding-bottom: 32px;
      position: relative;
    }
    .heritage-item:last-child { padding-bottom: 0; }

    .heritage-dot {
      flex-shrink: 0;
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: #f8f4eb;
      border: 2px solid #c8a84b;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 18px;
      margin-top: 4px;
    }

    .heritage-line {
      position: absolute;
      left: 21px;
      top: 50px;
      bottom: 0;
      width: 2px;
      background: linear-gradient(to bottom, rgba(200,168,75,0.4), transparent);
    }
    .heritage-item:last-child .heritage-line { display: none; }

    .heritage-text h4 {
      font-family: 'Cinzel', serif;
      font-size: 15px;
      letter-spacing: 0.06em;
      color: #1E2744;
      margin-bottom: 8px;
    }
    .heritage-text p {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 14px;
      color: #5a6a80;
      line-height: 1.75;
      margin: 0;
    }

    /* ════════════════════════════════════════════
       DO'S & DON'TS
    ════════════════════════════════════════════ */
    .dos-box {
      background: #ffffff;
      border: 1px solid #e4ddd0;
      border-top: 3px solid #b08830;
      border-radius: 10px;
      padding: 2rem 1.8rem;
      height: 100%;
    }
    .donts-box {
      background: #ffffff;
      border: 1px solid #e4ddd0;
      border-top: 3px solid #c87070;
      border-radius: 10px;
      padding: 2rem 1.8rem;
      height: 100%;
    }
    .dos-box .dd-title {
      font-family: 'Cinzel', serif;
      font-size: 16px;
      letter-spacing: 0.1em;
      color: #8a6418;
      margin-bottom: 1.2rem;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .donts-box .dd-title {
      font-family: 'Cinzel', serif;
      font-size: 16px;
      letter-spacing: 0.1em;
      color: #a04040;
      margin-bottom: 1.2rem;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .dd-list {
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .dd-list li {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 14px;
      color: #4a5a70;
      padding: 9px 0;
      border-bottom: 1px solid #f0ebe3;
      display: flex;
      align-items: flex-start;
      gap: 10px;
    }
    .dd-list li:last-child { border-bottom: none; }
    .dd-list .ic { font-size: 13px; flex-shrink: 0; margin-top: 2px; }
    .dos-box .dd-list .ic { color: #b08830; }
    .donts-box .dd-list .ic { color: #c07070; }

    /* ════════════════════════════════════════════
       SECURITY NOTICE
    ════════════════════════════════════════════ */
    .notice-box {
      background: #fffbf2;
      border: 1px solid rgba(176,136,48,0.3);
      border-left: 4px solid #b08830;
      border-radius: 0 10px 10px 0;
      padding: 2rem 2.2rem;
    }
    .notice-box .notice-head {
      font-family: 'Cinzel', serif;
      font-size: 14px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #8a6418;
      margin-bottom: 1.2rem;
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .notice-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 4px 24px;
    }
    .notice-list li {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 13.5px;
      color: #6a5020;
      padding: 7px 0 7px 18px;
      position: relative;
      border-bottom: 1px solid rgba(176,136,48,0.1);
    }
    .notice-list li:last-child { border-bottom: none; }
    .notice-list li::before {
      content: '■';
      position: absolute;
      left: 0;
      color: #b08830;
      font-size: 7px;
      top: 11px;
    }

    /* ════════════════════════════════════════════
       CTA SECTION — no overlay div, image via background
       Very light gradient so image stays visible
    ════════════════════════════════════════════ */
    .cta-section {
      position: relative;
      background-image:
        linear-gradient(
          rgba(10,10,10,0.60),
          rgba(10,10,10,0.68)
        ),
        url('./banner4.jpg');
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      padding: 100px 0;
      text-align: center;
      color: #fff;
    }

    .cta-section h2 {
      font-family: 'Cinzel', serif;
      font-size: clamp(1.8rem, 4vw, 2.8rem);
      font-weight: 700;
      color: #fff;
      text-shadow: 0 2px 20px rgba(0,0,0,0.4);
      margin-bottom: 0.5rem;
      line-height: 1.25;
    }

    .cta-section h2 em {
      font-family: 'Crimson Text', serif;
      font-style: italic;
      color: #e8c96a;
    }

    .cta-section p {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 15px;
      color: rgba(255,255,255,0.75);
      margin: 0 auto 40px;
      max-width: 480px;
    }

    .cta-buttons { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }

    /* ════════════════════════════════════════════
       ABOUT INTRO
    ════════════════════════════════════════════ */
    .about-feature {
      display: flex;
      gap: 16px;
      align-items: flex-start;
      padding: 16px 0;
      border-bottom: 1px solid #f0ebe3;
    }
    .about-feature:last-child { border-bottom: none; }
    .about-feature-icon {
      width: 40px;
      height: 40px;
      background: #f8f4eb;
      border: 1px solid rgba(176,136,48,0.3);
      border-radius: 6px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      font-size: 18px;
    }
    .about-feature-text strong {
      display: block;
      font-family: 'Cinzel', serif;
      font-size: 13px;
      letter-spacing: 0.05em;
      color: #1E2744;
      margin-bottom: 4px;
    }
    .about-feature-text p {
      font-family: 'Source Sans 3', sans-serif;
      font-size: 13.5px;
      color: #5a6a80;
      line-height: 1.65;
      margin: 0;
    }

    /* ════════════════════════════════════════════
       RESPONSIVE
    ════════════════════════════════════════════ */
    @media (max-width: 768px) {
      .hero-section { padding: 100px 20px 60px; min-height: 60vh; }
      .notice-list { grid-template-columns: 1fr; }
      .attraction-card-image { height: 200px; }
    }