@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,600;0,6..96,700;1,6..96,400&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');

:root {
    --c-primary:    #5D4037;
    --c-primary-dk: #3E2723;
    --c-primary-lt: #795548;
    --c-gold:       #C49A4A;
    --c-gold-lt:    #DDB76C;
    --c-gold-pale:  #F0DCA8;
    --c-accent:     #B85C38;
    --c-accent-dk:  #8E3F1F;
    --c-bg:         #F8F3EA;
    --c-bg-dk:      #EDE3CF;
    --c-bg-warm:    #E5D7B7;
    --c-dark:       #1D1B18;
    --c-dark-2:     #2C2823;
    --c-text:       #2C1F18;
    --c-muted:      #7D6B5C;
    --c-border:     rgba(93,64,55,0.12);
    --c-border-gold:rgba(196,154,74,0.30);
    --c-glass:      rgba(248,243,234,0.85);
    --c-success:    #6B8E23;
    --shadow-sm:    0 2px 8px rgba(93,64,55,0.08);
    --shadow-md:    0 10px 32px rgba(93,64,55,0.12);
    --shadow-lg:    0 20px 56px rgba(93,64,55,0.18);
    --shadow-xl:    0 30px 80px rgba(93,64,55,0.24);
    --font-logo:    'Cinzel Decorative', 'Playfair Display', serif;
    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-heading: 'Bodoni Moda', 'Cormorant Garamond', Georgia, serif;
    --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;
    --r-sm: 8px; --r-md: 14px; --r-lg: 22px; --r-xl: 32px;
    --ease: cubic-bezier(0.19, 1, 0.22, 1);
    --t: 0.5s var(--ease);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--c-bg);color:var(--c-text);line-height:1.7;overflow-x:hidden;font-weight:400;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--c-primary-dk);line-height:1.2;font-weight:600;}

/* === Batik Pattern === */
.batik-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;opacity:0.06;
    background-image:url("data:image/svg+xml,%3Csvg width='160' height='160' viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%235D4037' stroke-width='1'%3E%3Ccircle cx='80' cy='80' r='70'/%3E%3Ccircle cx='80' cy='80' r='55'/%3E%3Ccircle cx='80' cy='80' r='40'/%3E%3Ccircle cx='80' cy='80' r='25'/%3E%3Cpath d='M80 10 C120 50 120 110 80 150 C40 110 40 50 80 10Z'/%3E%3Cpath d='M10 80 C50 40 110 40 150 80 C110 120 50 120 10 80Z'/%3E%3Cpath d='M80 50 Q95 65 80 80 Q65 65 80 50Z' fill='%235D4037' fill-opacity='0.2'/%3E%3Cpath d='M80 80 Q95 95 80 110 Q65 95 80 80Z' fill='%235D4037' fill-opacity='0.2'/%3E%3Cpath d='M50 80 Q65 95 80 80 Q65 65 50 80Z' fill='%235D4037' fill-opacity='0.2'/%3E%3Cpath d='M80 80 Q95 65 110 80 Q95 95 80 80Z' fill='%235D4037' fill-opacity='0.2'/%3E%3C/g%3E%3C/svg%3E");
    background-size:160px 160px;
}

/* === Navbar === */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px 0;transition:var(--t);background:transparent;}
.navbar.scrolled{background:var(--c-glass);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);padding:14px 0;box-shadow:0 4px 28px rgba(93,64,55,0.10);border-bottom:1px solid var(--c-border);}
.nav-container{max-width:1320px;margin:0 auto;padding:0 36px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav-logo{display:flex;align-items:center;gap:14px;}
.logo-mark{width:50px;height:50px;background:linear-gradient(135deg,var(--c-primary-dk),var(--c-accent));border-radius:20px;display:flex;align-items:center;justify-content:center;color:var(--c-gold-lt);font-size:20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;}
.logo-mark img{width:100%;height:100%;object-fit:cover;border-radius:22px;display:block;}
.logo-text{display:flex;flex-direction:column;line-height:1;}
.logo-name{font-family:var(--font-logo);font-size:22px;color:var(--c-primary-dk);letter-spacing:1px;font-weight:700;}
.logo-tag{font-size:9.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--c-gold);font-weight:600;margin-top:4px;font-family:var(--font-body);}
.navbar:not(.scrolled) .logo-name{color:#fff;}
.navbar:not(.scrolled) .logo-tag{color:var(--c-gold-lt);}
.navbar:not(.scrolled) .nav-menu a{color:rgba(255,255,255,0.92);}
.navbar:not(.scrolled) .search-btn{color:#fff;background:rgba(255,255,255,0.12);}
.navbar:not(.scrolled) .nav-cta{background:var(--c-gold);color:var(--c-primary-dk);}
.nav-menu{display:flex;list-style:none;gap:6px;align-items:center;}
.nav-menu a{padding:9px 18px;font-size:13.5px;font-weight:500;color:var(--c-text);border-radius:50px;transition:var(--t);letter-spacing:0.3px;position:relative;}
.nav-menu a:hover,.nav-menu a.active{color:var(--c-gold);}
.nav-menu a.active::after{content:'';position:absolute;left:50%;bottom:2px;transform:translateX(-50%);width:6px;height:6px;background:var(--c-gold);border-radius:50%;}
.nav-actions{display:flex;align-items:center;gap:12px;}
.search-btn,.nav-toggle{width:42px;height:42px;border-radius:50%;background:rgba(93,64,55,0.08);border:none;cursor:pointer;color:var(--c-primary);display:flex;align-items:center;justify-content:center;transition:var(--t);font-size:15px;}
.search-btn:hover,.nav-toggle:hover{background:var(--c-gold);color:#fff;}
.nav-toggle{display:none;}
.nav-cta{padding:10px 22px;background:var(--c-primary-dk);color:#fff !important;border-radius:50px;font-size:13px;font-weight:600;transition:var(--t);letter-spacing:0.5px;}
.nav-cta:hover{background:var(--c-accent);transform:translateY(-2px);}
.search-overlay{position:absolute;top:100%;left:0;right:0;background:var(--c-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--c-border);padding:22px 32px;opacity:0;pointer-events:none;transform:translateY(-10px);transition:var(--t);}
.search-overlay.active{opacity:1;pointer-events:all;transform:translateY(0);}
.search-form{max-width:720px;margin:0 auto;display:flex;align-items:center;gap:12px;background:#fff;padding:6px 6px 6px 24px;border-radius:50px;box-shadow:var(--shadow-md);border:1px solid var(--c-border-gold);}
.search-form i{color:var(--c-gold);}
.search-form input{flex:1;border:none;outline:none;background:transparent;padding:14px 0;font-family:var(--font-body);font-size:15px;}
.search-close{width:40px;height:40px;border-radius:50%;border:none;background:var(--c-primary-dk);color:#fff;cursor:pointer;}

/* === HERO === */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--c-dark);}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.hero-bg{position:absolute;inset:0;z-index:-1;}
.hero:hover .hero-bg{transform:scale(1);}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(29,27,24,0.88) 0%,rgba(29,27,24,0.55) 50%,rgba(29,27,24,0.25) 100%);}
.hero-content{position:relative;z-index:2;max-width:1320px;margin:0 auto;padding:0 36px;width:100%;color:#fff;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:14px;margin-bottom:32px;color:var(--c-gold-lt);font-size:11px;letter-spacing:5px;text-transform:uppercase;font-weight:600;}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:50px;height:1px;background:var(--c-gold);}
.hero-title{font-family:var(--font-logo);font-size:clamp(64px,11vw,156px);line-height:0.95;color:#fff;font-weight:900;letter-spacing:2px;margin-bottom:22px;text-shadow:0 4px 30px rgba(0,0,0,0.4);}
.hero-tagline{font-family:var(--font-display);font-style:italic;font-size:clamp(20px,2.4vw,30px);color:var(--c-gold-lt);max-width:700px;margin-bottom:18px;font-weight:400;line-height:1.3;}
.hero-sub{font-size:16px;color:rgba(255,255,255,0.78);max-width:560px;margin-bottom:48px;line-height:1.8;font-weight:300;}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;}
.btn-hero-primary{padding:18px 36px;background:var(--c-gold);color:var(--c-primary-dk);border-radius:50px;font-size:13.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;display:inline-flex;align-items:center;gap:12px;transition:var(--t);border:none;cursor:pointer;box-shadow:0 10px 30px rgba(196,154,74,0.30);}
.btn-hero-primary:hover{background:var(--c-gold-lt);transform:translateY(-3px);box-shadow:0 16px 40px rgba(196,154,74,0.45);}
.btn-hero-secondary{padding:18px 36px;background:transparent;color:#fff;border-radius:50px;font-size:13.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;display:inline-flex;align-items:center;gap:12px;transition:var(--t);border:1px solid rgba(255,255,255,0.40);cursor:pointer;}
.btn-hero-secondary:hover{background:rgba(255,255,255,0.10);border-color:var(--c-gold-lt);}
.hero-title{
    opacity:0;
    transform:translateY(40px) scale(.96);
    animation:heroTitleReveal 1.4s ease forwards;
    animation-delay:.8s;
}

@keyframes heroTitleReveal{
    from{
        opacity:0;
        transform:translateY(40px) scale(.96);
    }
    to{
        opacity:1;
        transform:translateY(0) scale(1);
    }
}

/* === Section Common === */
section{padding:110px 0;position:relative;}
.container{max-width:1320px;margin:0 auto;padding:0 36px;position:relative;}
.sec-header{text-align:center;margin-bottom:64px;}
.sec-header.left{text-align:left;display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;}
.sec-header.left>div{flex:1;min-width:280px;}
.sec-eyebrow{display:inline-block;color:var(--c-gold);font-size:11px;letter-spacing:5px;text-transform:uppercase;font-weight:700;margin-bottom:14px;}
.sec-title{font-family:var(--font-display);font-size:clamp(38px,5vw,58px);color:var(--c-primary-dk);font-weight:600;line-height:1.12;margin-bottom:18px;}
.sec-title em{font-style:italic;color:var(--c-accent);}
.sec-desc{max-width:620px;margin:0 auto;color:var(--c-muted);font-family:var(--font-display);font-size:18px;font-weight:400;font-style:italic;}
.sec-header.left .sec-desc{margin:0;}
.sec-link{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--c-primary-dk);padding:14px 24px;border:1px solid var(--c-border);border-radius:50px;transition:var(--t);}
.sec-link:hover{background:var(--c-primary-dk);color:#fff;border-color:var(--c-primary-dk);}

/* === Featured Story === */
.featured-section{background:var(--c-bg);position:relative;}
.featured-wrap{display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center;position:relative;z-index:1;}
.featured-wrapper{background:#F8F4EE;border-radius:32px;padding:48px;box-shadow:0 20px 60px rgba(0,0,0,.06);border:1px solid rgba(194,163,96,.12);}
.featured-img{position:relative;border-radius:var(--r-xl);overflow:hidden;aspect-ratio:5/6;box-shadow:var(--shadow-xl);}
.featured-img img{width:100%;height:100%;object-fit:cover;}
.featured-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,0.4) 100%);pointer-events:none;}
.featured-frame-deco{position:absolute;width:140px;height:140px;border:2px solid var(--c-gold);border-radius:var(--r-xl);z-index:0;}
.featured-frame-deco.top-left{top:-28px;left:-28px;}
.featured-frame-deco.bottom-right{bottom:-28px;right:-28px;}
.featured-body .tag{display:inline-block;padding:8px 18px;background:rgba(184,92,56,0.10);border:1px solid rgba(184,92,56,0.30);border-radius:50px;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--c-accent);margin-bottom:22px;}
.featured-body h2{font-family:var(--font-display);font-size:clamp(36px,4.5vw,56px);color:var(--c-primary-dk);line-height:1.08;margin-bottom:22px;font-weight:600;}
.featured-body .lead{font-family:var(--font-display);font-style:italic;font-size:19px;color:var(--c-muted);line-height:1.7;margin-bottom:32px;}
.featured-meta{display:flex;flex-wrap:wrap;gap:28px;padding:24px 0;border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);margin-bottom:32px;}
.featured-meta-item{display:flex;flex-direction:column;gap:4px;}
.featured-meta-item .lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--c-muted);font-weight:600;}
.featured-meta-item .val{font-family:var(--font-heading);font-size:16px;color:var(--c-primary-dk);font-weight:500;}

/* === Timeline === */
.sejarah-section{background:linear-gradient(180deg,var(--c-bg-dk) 0%,var(--c-bg) 100%);}
.timeline{position:relative;max-width:920px;margin:0 auto;padding:30px 0;}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent,var(--c-gold) 10%,var(--c-gold) 90%,transparent);transform:translateX(-50%);}
.tl-item{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:60px;}
.tl-item:last-child{margin-bottom:0;}
.tl-item:nth-child(even) .tl-content{grid-column:2;text-align:left;}
.tl-item:nth-child(even) .tl-spacer{grid-column:1;}
.tl-content{background:#fff;padding:32px 36px;border-radius:var(--r-lg);box-shadow:var(--shadow-md);border:1px solid var(--c-border);text-align:right;position:relative;}
.tl-item:nth-child(even) .tl-content{text-align:left;}
.tl-content::before{content:'';position:absolute;top:50%;width:16px;height:2px;background:var(--c-gold);}
.tl-item:nth-child(odd) .tl-content::before{right:-16px;}
.tl-item:nth-child(even) .tl-content::before{left:-16px;}
.tl-marker{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:var(--c-bg);border:3px solid var(--c-gold);border-radius:50%;z-index:2;}
.tl-marker::before{content:'';position:absolute;inset:4px;background:var(--c-gold);border-radius:50%;}
.tl-era{font-family:var(--font-display);font-style:italic;color:var(--c-accent);font-size:14px;font-weight:600;letter-spacing:1px;margin-bottom:8px;}
.tl-title{font-family:var(--font-display);font-size:26px;color:var(--c-primary-dk);margin-bottom:12px;line-height:1.2;font-weight:600;}
.tl-desc{color:var(--c-muted);font-size:14px;line-height:1.75;}
.tl-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--c-accent);}

/* === Berita Grid === */
.berita-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;}
.berita-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;transition:var(--t);cursor:pointer;display:flex;flex-direction:column;border:1px solid transparent;box-shadow:var(--shadow-sm);}
.berita-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--c-border-gold);}
.bc-image{position:relative;aspect-ratio:16/11;overflow:hidden;}
.bc-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.berita-card:hover .bc-image img{transform:scale(1.08);}
.bc-cat{position:absolute;top:16px;left:16px;padding:6px 14px;background:rgba(248,243,234,0.94);backdrop-filter:blur(8px);border-radius:50px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--c-primary-dk);}
.bc-body{padding:26px 28px 24px;flex:1;display:flex;flex-direction:column;}
.bc-body h3{font-family:var(--font-display);font-size:22px;color:var(--c-primary-dk);margin-bottom:12px;line-height:1.3;flex:1;font-weight:600;transition:color 0.3s;}
.berita-card:hover .bc-body h3{color:var(--c-accent);}
.bc-excerpt{font-size:14px;color:var(--c-muted);line-height:1.7;margin-bottom:18px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.bc-meta{display:flex;align-items:center;justify-content:space-between;padding-top:18px;border-top:1px solid var(--c-border);gap:10px;}
.bc-author{display:flex;align-items:center;gap:10px;}
.bc-author img{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1px solid var(--c-border-gold);}
.bc-author .name{font-size:12px;font-weight:600;color:var(--c-primary-dk);}
.bc-author .date{font-size:11px;color:var(--c-muted);}
.bc-read{font-size:11px;color:var(--c-muted);display:flex;align-items:center;gap:4px;white-space:nowrap;}

/* === Resep === */
.resep-section{background:var(--c-bg-dk);}
.resep-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.resep-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;transition:var(--t);border:1px solid transparent;box-shadow:var(--shadow-sm);cursor:pointer;}
.resep-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--c-border-gold);}
.resep-img{aspect-ratio:4/3;position:relative;overflow:hidden;}
.resep-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.resep-card:hover .resep-img img{transform:scale(1.07);}
.resep-difficulty{position:absolute;top:14px;right:14px;padding:5px 12px;background:var(--c-success);border-radius:50px;font-size:10px;font-weight:700;letter-spacing:1.5px;color:#fff;text-transform:uppercase;}
.resep-difficulty.medium{background:var(--c-gold);color:var(--c-primary-dk);}
.resep-difficulty.hard{background:var(--c-accent);}
.resep-body{padding:24px 26px;}
.resep-body h3{font-family:var(--font-display);font-size:22px;color:var(--c-primary-dk);margin-bottom:10px;line-height:1.3;font-weight:600;}
.resep-stats{display:flex;align-items:center;gap:18px;padding-top:14px;border-top:1px solid var(--c-border);flex-wrap:wrap;}
.resep-stat{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--c-muted);font-weight:500;}
.resep-stat i{color:var(--c-gold);font-size:13px;}
.resep-stat strong{color:var(--c-primary-dk);font-weight:600;}

/* === Restoran === */
.restoran-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;}
.resto-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;transition:var(--t);border:1px solid transparent;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:220px 1fr;cursor:pointer;}
.resto-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--c-border-gold);}
.resto-img{position:relative;overflow:hidden;}
.resto-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.resto-card:hover .resto-img img{transform:scale(1.08);}
.resto-body{padding:24px 28px;}
.resto-loc{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--c-accent);font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.resto-body h3{font-family:var(--font-display);font-size:24px;color:var(--c-primary-dk);margin-bottom:10px;font-weight:600;line-height:1.2;}
.resto-desc{font-size:13px;color:var(--c-muted);line-height:1.65;margin-bottom:16px;}
.resto-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--c-border);gap:10px;flex-wrap:wrap;}
.resto-rating{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--c-primary-dk);}
.resto-rating .stars{color:var(--c-gold);letter-spacing:1.5px;font-size:13px;}
.resto-rating strong{font-weight:700;}
.resto-hours{font-size:12px;color:var(--c-muted);display:flex;align-items:center;gap:6px;}

/* === Map === */
.map-section{background:var(--c-dark);color:#fff;position:relative;}
.map-section .batik-bg{opacity:0.04;filter:invert(1);}
.map-section .sec-title{color:#fff;}
.map-section .sec-eyebrow{color:var(--c-gold-lt);}
.map-section .sec-desc{color:rgba(255,255,255,0.7);}
.map-wrap{background:rgba(255,255,255,0.04);border:1px solid rgba(196,154,74,0.20);border-radius:var(--r-xl);padding:32px;backdrop-filter:blur(10px);position:relative;z-index:1;}
.map-frame{aspect-ratio:16/8;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(255,255,255,0.10);background:var(--c-dark-2);}
.map-frame iframe{width:100%;height:100%;border:0;filter:saturate(0.85) brightness(0.95);}
.map-cities{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;}
.city-chip{padding:10px 22px;background:rgba(196,154,74,0.10);border:1px solid rgba(196,154,74,0.30);border-radius:50px;font-size:12px;color:var(--c-gold-lt);font-weight:600;letter-spacing:1px;transition:var(--t);cursor:pointer;}
.city-chip:hover,.city-chip.active{background:var(--c-gold);color:var(--c-primary-dk);border-color:var(--c-gold);}

/* === Event === */
.event-section{background:var(--c-bg);}
.event-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;}
.event-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;transition:var(--t);border:1px solid transparent;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:180px 1fr;cursor:pointer;}
.event-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--c-border-gold);}
.event-img{position:relative;overflow:hidden;}
.event-img img{width:100%;height:100%;object-fit:cover;}
.event-date-badge{position:absolute;top:16px;left:16px;background:rgba(29,27,24,0.92);backdrop-filter:blur(8px);border-radius:var(--r-sm);padding:10px 14px;text-align:center;color:#fff;}
.event-date-badge .day{font-family:var(--font-display);font-size:24px;font-weight:700;line-height:1;}
.event-date-badge .month{font-size:10px;letter-spacing:2px;color:var(--c-gold-lt);margin-top:3px;text-transform:uppercase;}
.event-body{padding:22px 26px;}
.event-body h3{font-family:var(--font-display);font-size:22px;color:var(--c-primary-dk);margin-bottom:8px;line-height:1.3;font-weight:600;}
.event-body p{font-size:13px;color:var(--c-muted);line-height:1.6;margin-bottom:14px;}
.event-loc{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--c-accent);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;}

/* === Footer === */
.footer{background:var(--c-dark);color:rgba(255,255,255,0.65);position:relative;}
.footer .batik-bg{opacity:0.04;filter:invert(1);}
.footer-top{padding:90px 0 56px;position:relative;z-index:1;}
.footer-grid{max-width:1320px;margin:0 auto;padding:0 36px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:56px;}
.footer-brand p{font-family:var(--font-display);font-style:italic;font-size:15px;margin:22px 0 28px;line-height:1.8;max-width:360px;color:rgba(255,255,255,0.65);}
.footer-brand .logo-name{color:#fff;}
.footer-brand .logo-tag{color:var(--c-gold);}
.social-links{display:flex;gap:10px;}
.social-links a{width:40px;height:40px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:var(--t);font-size:14px;}
.social-links a:hover{background:var(--c-gold);color:var(--c-primary-dk);border-color:var(--c-gold);transform:translateY(-3px);}
.footer-col h4{font-family:var(--font-display);color:#fff;font-size:22px;margin-bottom:22px;font-weight:600;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col a{font-size:14px;transition:var(--t);color:rgba(255,255,255,0.65);}
.footer-col a:hover{color:var(--c-gold-lt);padding-left:6px;}
.nl-desc{font-size:14px;margin-bottom:18px;line-height:1.7;color:rgba(255,255,255,0.65);}
.nl-form{display:flex;background:rgba(255,255,255,0.06);border-radius:50px;padding:6px;border:1px solid rgba(255,255,255,0.10);}
.nl-form input{flex:1;background:transparent;border:none;outline:none;padding:10px 18px;color:#fff;font-size:13px;font-family:var(--font-body);}
.nl-form input::placeholder{color:rgba(255,255,255,0.35);}
.nl-form button{width:40px;height:40px;border-radius:50%;border:none;background:var(--c-gold);color:var(--c-primary-dk);cursor:pointer;transition:var(--t);}
.nl-form button:hover{background:var(--c-gold-lt);transform:rotate(45deg);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding:24px 36px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;max-width:1320px;margin:0 auto;position:relative;z-index:1;}
.footer-links{display:flex;gap:24px;}
.footer-links a:hover{color:var(--c-gold-lt);}

/* === Detail === */
.detail-hero{position:relative;height:78vh;min-height:540px;display:flex;align-items:flex-end;overflow:hidden;}
.detail-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.detail-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.10) 0%,rgba(29,27,24,0.90) 100%);}
.detail-hero-content{position:relative;z-index:2;max-width:1080px;margin:0 auto;padding:0 36px 84px;width:100%;color:#fff;}
.detail-hero-content .badge{display:inline-block;padding:8px 18px;background:var(--c-accent);border-radius:50px;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;margin-bottom:26px;}
.detail-hero-content h1{font-family:var(--font-display);font-size:clamp(38px,5.5vw,72px);line-height:1.08;color:#fff;margin-bottom:30px;font-weight:600;max-width:920px;}
.detail-meta{display:flex;align-items:center;gap:32px;flex-wrap:wrap;font-size:14px;}
.detail-meta img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--c-gold);}
.detail-meta .meta-item{display:flex;align-items:center;gap:12px;}
.detail-meta .author-name{font-weight:600;font-size:15px;line-height:1.2;}
.detail-meta .author-role{font-size:12px;color:rgba(255,255,255,0.65);}
.detail-meta i{color:var(--c-gold-lt);}
.detail-body{padding:90px 0;background:var(--c-bg);}
.detail-layout{max-width:1180px;margin:0 auto;padding:0 36px;display:grid;grid-template-columns:1fr 320px;gap:70px;}
.detail-content{font-family:var(--font-display);font-size:19px;line-height:1.95;color:var(--c-text);}
.detail-content p{margin-bottom:26px;}
.detail-content p:first-of-type::first-letter{font-family:var(--font-display);font-size:84px;float:left;line-height:0.85;padding:8px 16px 0 0;color:var(--c-accent);font-weight:600;}
.detail-content h2,.detail-content h3{font-family:var(--font-display);margin:44px 0 22px;font-weight:600;}
.detail-content blockquote{margin:40px 0;padding:0 0 0 28px;border-left:3px solid var(--c-gold);font-style:italic;color:#6b5b4f;font-size:21px;line-height:2;}
.detail-content blockquote p{margin:0;}
.detail-content ul{margin:24px 0 32px 24px;padding-left:20px;}
.detail-content li{margin-bottom:14px;line-height:1.9;}
.detail-content li::marker{color:var(--c-accent);}
.share-bar{display:flex;align-items:center;gap:12px;margin:44px 0;padding:26px 0;border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);}
.share-bar .lbl{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--c-muted);font-weight:700;margin-right:6px;font-family:var(--font-body);}
.share-bar a{width:40px;height:40px;border-radius:50%;background:var(--c-bg-dk);color:var(--c-primary-dk);display:flex;align-items:center;justify-content:center;transition:var(--t);}
.share-bar a:hover{background:var(--c-primary-dk);color:#fff;transform:translateY(-3px);}
.detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0;}
.detail-tags .tag{padding:6px 14px;background:var(--c-bg-dk);border-radius:50px;font-size:12px;color:var(--c-primary-dk);font-weight:600;font-family:var(--font-body);}
.detail-sidebar{display:flex;flex-direction:column;gap:28px;position:sticky;top:100px;align-self:start;}
.info-card{background:#fff;border-radius:var(--r-lg);padding:28px;border:1px solid var(--c-border);box-shadow:var(--shadow-sm);}
.info-card h3{font-family:var(--font-display);font-size:22px;margin-bottom:22px;padding-bottom:16px;border-bottom:2px solid var(--c-gold);color:var(--c-primary-dk);font-weight:600;}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--c-border);}
.info-row:last-child{border:none;}
.info-row .lbl{font-size:13px;color:var(--c-muted);display:flex;align-items:center;gap:8px;}
.info-row .lbl i{color:var(--c-gold);}
.info-row .val{font-size:14px;font-weight:600;color:var(--c-primary-dk);}
.rating-card{background:linear-gradient(135deg,var(--c-primary-dk),var(--c-primary));color:#fff;border-radius:var(--r-lg);padding:28px;text-align:center;position:relative;overflow:hidden;}
.rating-card::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23C49A4A' stroke-width='0.8' opacity='0.15'%3E%3Ccircle cx='40' cy='40' r='30'/%3E%3Ccircle cx='40' cy='40' r='18'/%3E%3Cpath d='M40 10 Q60 30 40 50 Q20 30 40 10Z'/%3E%3C/g%3E%3C/svg%3E");background-size:80px;pointer-events:none;}
.rating-card>*{position:relative;z-index:1;}
.rating-card .label{font-size:11px;color:var(--c-gold-lt);letter-spacing:3px;text-transform:uppercase;font-weight:700;margin-bottom:12px;font-family:var(--font-body);}
.rating-card .num{font-family:var(--font-display);font-size:64px;color:var(--c-gold-lt);line-height:1;font-weight:700;}
.rating-card .stars{color:var(--c-gold);font-size:18px;margin-top:10px;letter-spacing:4px;}
.rating-card .count{font-size:12px;color:rgba(255,255,255,0.6);margin-top:6px;}
.rating-breakdown{padding:8px 0;}
.rb-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.rb-row:last-child{margin-bottom:0;}
.rb-aspect{font-size:13px;color:var(--c-muted);font-weight:500;flex:0 0 auto;}
.rb-bar-wrap{flex:1;margin:0 14px;height:6px;background:var(--c-bg-dk);border-radius:3px;overflow:hidden;}
.rb-bar{height:100%;background:linear-gradient(90deg,var(--c-gold),var(--c-accent));border-radius:3px;}
.rb-val{font-size:13px;font-weight:700;color:var(--c-primary-dk);min-width:28px;text-align:right;}

/* === Listing === */
.page-header-sec{padding:170px 0 90px;background:linear-gradient(135deg,var(--c-dark) 0%,var(--c-primary-dk) 100%);color:#fff;text-align:center;position:relative;overflow:hidden;}
.page-header-sec .batik-bg{opacity:0.06;filter:invert(1);}
.page-header-sec>.container{position:relative;z-index:2;}
.page-header-sec h1{font-family:var(--font-display);font-size:clamp(46px,6vw,80px);color:#fff;margin-bottom:18px;font-weight:600;line-height:1.05;}
.page-header-sec h1 em{color:var(--c-gold-lt);font-style:italic;}
.page-header-sec p{font-family:var(--font-display);font-style:italic;font-size:19px;max-width:620px;margin:0 auto;color:rgba(255,255,255,0.78);}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;padding:72px 0 32px;}
.pagination-wrapper{display:flex;justify-content:center;padding:32px 0 90px;}
.pagination-wrapper nav{display:flex;gap:6px;}
.pagination-wrapper a,.pagination-wrapper span{padding:11px 18px;background:#fff;border-radius:50px;font-size:13px;font-weight:600;color:var(--c-primary-dk);transition:var(--t);border:1px solid var(--c-border);}
.pagination-wrapper a:hover,.pagination-wrapper .active span{background:var(--c-primary-dk);color:#fff;border-color:var(--c-primary-dk);}

/* === Filter Pills (kategori) === */
.filter-pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:44px 0 8px;}
.filter-pill{padding:10px 22px;border-radius:50px;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;transition:var(--t);background:#fff;color:var(--c-primary-dk);border:1px solid var(--c-border);}
.filter-pill.active,.filter-pill:hover{background:var(--c-primary-dk);color:#fff;border-color:var(--c-primary-dk);}

/* === Responsive === */
@media(max-width:1100px){
    .featured-wrap,.restoran-grid,.event-grid{grid-template-columns:1fr;gap:50px;}
    .berita-grid,.resep-grid{grid-template-columns:repeat(2,1fr);}
    .footer-grid{grid-template-columns:repeat(2,1fr);}
    .detail-layout{grid-template-columns:1fr;}
    .detail-sidebar{position:static;}
    .timeline::before{left:24px;transform:none;}
    .tl-item{grid-template-columns:1fr !important;padding-left:60px;}
    .tl-item:nth-child(even) .tl-content{grid-column:1;text-align:left;}
    .tl-spacer{display:none;}
    .tl-content{text-align:left !important;}
    .tl-content::before{left:-36px !important;right:auto !important;width:24px;}
    .tl-marker{left:24px;transform:translateY(-50%);}
}
@media(max-width:768px){
    .nav-menu{position:fixed;top:80px;left:0;right:0;background:var(--c-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-direction:column;padding:28px;transform:translateY(-130%);transition:transform 0.4s ease;border-bottom:1px solid var(--c-border);}
    .nav-menu.mobile-active{transform:translateY(0);}
    .nav-toggle{display:flex;}
    .navbar:not(.scrolled) .nav-menu a{color:var(--c-text);}
    .berita-grid,.resep-grid,.archive-grid{grid-template-columns:1fr;}
    .resto-card,.event-card{grid-template-columns:1fr;}
    .resto-img,.event-img{aspect-ratio:16/10;}
    section{padding:72px 0;}
    .container{padding:0 22px;}
    .footer-grid{grid-template-columns:1fr;gap:38px;}
}

/* ============================================================
   REVISI: Pattern Jawa, Modal, Snackbar, Pagination, dll
   ============================================================ */

/* === Pattern Kawung (4 lingkaran) === */
.pattern-kawung{position:absolute;inset:0;pointer-events:none;opacity:0.05;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%235D4037' stroke-width='1'%3E%3Ccircle cx='20' cy='20' r='14'/%3E%3Ccircle cx='60' cy='20' r='14'/%3E%3Ccircle cx='20' cy='60' r='14'/%3E%3Ccircle cx='60' cy='60' r='14'/%3E%3Ccircle cx='40' cy='40' r='6' fill='%235D4037' fill-opacity='0.3'/%3E%3C/g%3E%3C/svg%3E");
    background-size:80px;}

/* === Pattern Parang (diagonal) === */
.pattern-parang{position:absolute;inset:0;pointer-events:none;opacity:0.03;
    background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%235D4037' stroke-width='1.2'%3E%3Cpath d='M0 60 Q15 45 30 30 Q45 15 60 0'/%3E%3Cpath d='M-15 45 Q0 30 15 15 Q30 0 45 -15'/%3E%3Cpath d='M15 75 Q30 60 45 45 Q60 30 75 15'/%3E%3C/g%3E%3C/svg%3E");
    background-size:60px;}

/* === Divider Batik (between sections) === */
.batik-divider{position:relative;height:80px;display:flex;align-items:center;justify-content:center;background:var(--c-bg);overflow:hidden;}
.batik-divider::before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:linear-gradient(90deg,transparent 10%,var(--c-gold) 50%,transparent 90%);}
.batik-divider .ornament{position:relative;background:var(--c-bg);padding:0 30px;z-index:1;display:flex;align-items:center;gap:18px;color:var(--c-gold);}
.batik-divider .ornament svg{width:34px;height:34px;}
.batik-divider .ornament .dot{width:6px;height:6px;border-radius:50%;background:var(--c-gold);}

/* === Wave Separator === */
.wave-separator{height:80px;background:var(--c-bg);position:relative;overflow:hidden;}
.wave-separator svg{position:absolute;bottom:0;left:0;width:100%;height:100%;}

/* === Modal Konfirmasi === */
.modal-backdrop{position:fixed;inset:0;background:rgba(29,27,24,0.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px;animation:fadeIn 0.25s ease;}
.modal-backdrop.active{display:flex;}
.modal-card{background:#fff;border-radius:var(--r-xl);max-width:440px;width:100%;overflow:hidden;position:relative;animation:scaleIn 0.3s var(--ease);box-shadow:var(--shadow-xl);}
.modal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--c-primary-dk),var(--c-gold),var(--c-accent));}
.modal-icon{width:74px;height:74px;border-radius:50%;background:linear-gradient(135deg,var(--c-accent),var(--c-primary-dk));margin:32px auto 14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px;box-shadow:0 12px 28px rgba(184,92,56,0.30);}
.modal-card h3{text-align:center;font-family:var(--font-display);font-size:26px;color:var(--c-primary-dk);margin:0 32px 10px;font-weight:600;}
.modal-card p{text-align:center;color:var(--c-muted);font-family:var(--font-display);font-style:italic;font-size:16px;line-height:1.7;padding:0 32px 28px;}
.modal-actions{display:flex;gap:0;border-top:1px solid var(--c-border);}
.modal-actions button,.modal-actions a{flex:1;padding:18px;font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:none;cursor:pointer;background:#fff;color:var(--c-muted);transition:0.3s;text-align:center;}
.modal-actions button:first-child:hover,.modal-actions a:first-child:hover{background:var(--c-bg-dk);color:var(--c-primary-dk);}
.modal-actions .danger{color:var(--c-accent);border-left:1px solid var(--c-border);font-weight:700;}
.modal-actions .danger:hover{background:var(--c-accent);color:#fff;}

main {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{transform:scale(0.92);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes fadeUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}

/* === Snackbar === */
.snackbar{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--c-primary-dk);color:#fff;padding:16px 28px;border-radius:14px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-xl);z-index:9998;font-family:var(--font-body);font-size:14px;font-weight:500;transition:transform 0.4s var(--ease);min-width:280px;border-left:4px solid var(--c-gold);}
.snackbar.show{transform:translateX(-50%) translateY(0);}
.snackbar i{color:var(--c-gold);font-size:18px;}
.snackbar.success{border-left-color:var(--c-success);}
.snackbar.success i{color:var(--c-success);}
.snackbar.error{border-left-color:#DC2626;}
.snackbar.error i{color:#DC2626;}

/* === HERO VIDEO === */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.hero .hero-overlay{z-index:1;}
.hero-content{z-index:2;}

.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:54px;max-width:760px;}
.hero-stat{padding:20px 18px;background:rgba(255,255,255,0.08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(196,154,74,0.30);border-radius:14px;text-align:center;transition:var(--t);}
.hero-stat:hover{background:rgba(196,154,74,0.18);border-color:var(--c-gold);transform:translateY(-3px);}
.hero-stat-num{font-family:var(--font-display);font-size:32px;color:var(--c-gold-lt);font-weight:700;line-height:1;}
.hero-stat-lbl{font-size:11px;color:rgba(255,255,255,0.75);letter-spacing:1.5px;text-transform:uppercase;font-weight:600;margin-top:6px;}

.scroll-indicator{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,0.8);font-size:11px;letter-spacing:3px;text-transform:uppercase;font-weight:600;animation:bounce 2.2s infinite;}
.scroll-indicator i{font-size:18px;color:var(--c-gold-lt);}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* === Timeline Modern Jejak Warisan === */
.timeline-modern{display:grid;grid-template-columns:1fr 1fr;gap:36px;max-width:1080px;margin:0 auto;}
.tlm-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--c-border);transition:var(--t);}
.tlm-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--c-border-gold);}
.tlm-img{aspect-ratio:16/10;position:relative;overflow:hidden;}
.tlm-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.tlm-card:hover .tlm-img img{transform:scale(1.08);}
.tlm-city{position:absolute;top:18px;left:18px;background:rgba(29,27,24,0.85);backdrop-filter:blur(8px);color:var(--c-gold-lt);padding:8px 16px;border-radius:50px;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700;display:flex;align-items:center;gap:8px;}
.tlm-year{position:absolute;bottom:18px;right:18px;background:var(--c-gold);color:var(--c-primary-dk);padding:6px 14px;border-radius:50px;font-size:11px;font-weight:700;letter-spacing:1.5px;font-family:var(--font-display);font-style:italic;}
.tlm-body{padding:28px 30px 30px;}
.tlm-body h3{font-family:var(--font-display);font-size:28px;color:var(--c-primary-dk);margin-bottom:12px;line-height:1.2;font-weight:600;}
.tlm-body p{font-size:14px;color:var(--c-muted);line-height:1.75;margin-bottom:18px;}
.tlm-link{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--c-accent);transition:0.3s;}
.tlm-link:hover{gap:14px;color:var(--c-primary-dk);}

/* === Budaya Section (2 kolom) === */
.budaya-section{background:linear-gradient(180deg,var(--c-bg) 0%,var(--c-bg-dk) 100%);position:relative;}
.budaya-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:36px;margin-top:50px;}
.budaya-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--c-border);box-shadow:var(--shadow-sm);transition:var(--t);}
.budaya-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--c-border-gold);}
.budaya-card-img{overflow:hidden;}
.budaya-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.budaya-card:hover .budaya-card-img img{transform:scale(1.08);}
.budaya-card-body{padding:28px 30px;display:flex;flex-direction:column;justify-content:center;}
.budaya-card-body .eyebrow{font-size:10px;color:var(--c-accent);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;}
.budaya-card-body h3{font-family:var(--font-display);font-size:24px;color:var(--c-primary-dk);font-weight:600;margin-bottom:12px;line-height:1.2;}
.budaya-card-body p{font-size:14px;color:var(--c-muted);line-height:1.7;font-family:var(--font-display);font-style:italic;font-size:15px;margin-bottom:16px;}

/* === Pagination Horizontal (override) === */
.pagination-wrapper nav,.pagination-wrapper>div{display:flex !important;flex-direction:row !important;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;}
.pagination-wrapper ul{display:flex !important;flex-direction:row !important;list-style:none;gap:6px;padding:0;margin:0;flex-wrap:wrap;}
.pagination-wrapper li{display:inline-flex;}

/* === Lokasi Clickable === */
.loc-link{color:inherit;display:inline-flex;align-items:center;gap:6px;border-bottom:1px dashed transparent;transition:0.3s;cursor:pointer;}
.loc-link:hover{color:var(--c-accent);border-bottom-color:var(--c-accent);}
.loc-link i{color:var(--c-gold);}

/* === Restoran Card improved (with Google Maps link) === */
.resto-card{position:relative;}
.resto-actions{display:flex;gap:8px;margin-top:14px;}
.btn-maps{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;background:var(--c-primary-dk);color:#fff !important;border-radius:50px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:var(--t);text-decoration:none;border:none;cursor:pointer;}
.btn-maps:hover{background:var(--c-accent);transform:translateY(-2px);}
.btn-maps i{color:var(--c-gold-lt);}

/* === Footer simplified === */
.footer-simple{background:var(--c-dark);color:rgba(255,255,255,0.65);padding:60px 36px 32px;text-align:center;position:relative;overflow:hidden;}
.footer-simple .pattern-kawung{opacity:0.04;filter:invert(1);}
.footer-simple-inner{position:relative;z-index:1;max-width:680px;margin:0 auto;}
.footer-simple .nav-logo{justify-content:center;margin-bottom:26px;}
.footer-simple .logo-name{color:#fff;}
.footer-simple .logo-tag{color:var(--c-gold);}
.footer-quote{font-family:var(--font-display);font-style:italic;font-size:20px;color:rgba(255,255,255,0.78);line-height:1.6;margin:28px auto 36px;max-width:560px;position:relative;padding:0 24px;}
.footer-quote::before,.footer-quote::after{font-family:var(--font-display);color:var(--c-gold);font-size:36px;line-height:0;position:absolute;top:50%;}
.footer-quote::before{content:'"';left:0;}
.footer-quote::after{content:'"';right:0;}
.footer-social{display:flex;justify-content:center;gap:10px;margin-bottom:36px;}
.footer-social a{width:42px;height:42px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:var(--t);font-size:14px;}
.footer-social a:hover{background:var(--c-gold);color:var(--c-primary-dk);border-color:var(--c-gold);transform:translateY(-3px);}
.footer-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.10) 30%,rgba(255,255,255,0.10) 70%,transparent);margin-bottom:24px;}
.footer-copyright{font-size:12px;color:rgba(255,255,255,0.45);letter-spacing:1px;}

/* === Animation utilities === */
.fade-up{opacity:0;animation:fadeUp 0.8s var(--ease) forwards;}
.fade-up-d2{animation-delay:0.15s;}
.fade-up-d3{animation-delay:0.30s;}
.fade-up-d4{animation-delay:0.45s;}

/* === Recipe steps (untuk detail resep) === */
.recipe-split{display:grid;grid-template-columns:1fr 2fr;gap:36px;margin:48px 0;}
.recipe-side{position:sticky;top:100px;align-self:start;}
.recipe-card-block{background:#fff;border-radius:var(--r-lg);padding:28px;border:1px solid var(--c-border);box-shadow:var(--shadow-sm);margin-bottom:24px;}
.recipe-card-block h3{font-family:var(--font-display);font-size:24px;color:var(--c-primary-dk);font-weight:600;padding-bottom:14px;border-bottom:2px solid var(--c-gold);margin-bottom:18px;}
.recipe-card-block ul{list-style:none;padding:0;margin:0;}
.recipe-card-block li{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--c-border);font-size:14px;}
.recipe-card-block li:last-child{border:none;}
.recipe-card-block li .item{color:var(--c-primary-dk);font-weight:500;}
.recipe-card-block li .qty{color:var(--c-muted);font-style:italic;font-family:var(--font-display);font-size:15px;}
.recipe-steps{display:flex;flex-direction:column;gap:20px;}
.recipe-step{display:grid;grid-template-columns:60px 1fr;gap:20px;background:#fff;padding:24px;border-radius:var(--r-lg);border:1px solid var(--c-border);box-shadow:var(--shadow-sm);transition:var(--t);}
.recipe-step:hover{border-color:var(--c-border-gold);box-shadow:var(--shadow-md);}
.recipe-step-num{width:48px;height:48px;background:linear-gradient(135deg,var(--c-gold),var(--c-accent));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:700;flex-shrink:0;}
.recipe-step-body h4{font-family:var(--font-display);font-size:20px;color:var(--c-primary-dk);font-weight:600;margin-bottom:8px;}
.recipe-step-body p{color:var(--c-muted);line-height:1.7;font-size:15px;font-family:var(--font-display);}

@media(max-width:1100px){
    .timeline-modern,.budaya-grid{grid-template-columns:1fr;}
    .budaya-card{grid-template-columns:1fr;}
    .recipe-split{grid-template-columns:1fr;}
    .recipe-side{position:static;}
    .hero-stats{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:680px){
    .modal-card{margin:0 16px;}
    .hero-stats{margin-top:36px;}
}

/* ============================================================
   FITUR BARU: Destinasi, Resep Cookpad, Galeri, Lightbox
   ============================================================ */

/* === Destinasi Cards === */
.destinasi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.destinasi-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;transition:var(--t);border:1px solid var(--c-border);box-shadow:var(--shadow-sm);position:relative;}
.destinasi-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--c-border-gold);}
.destinasi-card-img{position:relative;aspect-ratio:16/11;overflow:hidden;}
.destinasi-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.destinasi-card:hover .destinasi-card-img img{transform:scale(1.08);}
.destinasi-rating-badge{position:absolute;top:16px;right:16px;background:rgba(29,27,24,0.88);backdrop-filter:blur(8px);color:var(--c-gold-lt);padding:7px 14px;border-radius:50px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px;}
.destinasi-rating-badge i{color:var(--c-gold);}
.destinasi-kota-badge{position:absolute;bottom:16px;left:16px;background:var(--c-gold);color:var(--c-primary-dk);padding:6px 14px;border-radius:50px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;display:flex;align-items:center;gap:6px;}
.destinasi-card-body{padding:24px 26px;}
.destinasi-card-body h3{font-family:var(--font-display);font-size:24px;color:var(--c-primary-dk);font-weight:600;margin-bottom:8px;line-height:1.2;}
.destinasi-alamat{font-size:13px;color:var(--c-muted);line-height:1.6;margin-bottom:14px;display:flex;align-items:start;gap:8px;}
.destinasi-alamat i{color:var(--c-accent);margin-top:3px;}
.destinasi-info-row{display:flex;justify-content:space-between;padding-top:14px;border-top:1px solid var(--c-border);font-size:12px;}
.destinasi-info-row .item{display:flex;align-items:center;gap:6px;color:var(--c-muted);}
.destinasi-info-row .item i{color:var(--c-gold);}
.destinasi-actions{display:flex;gap:8px;margin-top:16px;}
.destinasi-actions a{flex:1;padding:10px;text-align:center;border-radius:50px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:var(--t);display:inline-flex;align-items:center;justify-content:center;gap:6px;}
.btn-detail{background:var(--c-bg-dk);color:var(--c-primary-dk);}
.btn-detail:hover{background:var(--c-primary-dk);color:#fff;}
.btn-mapsd{background:var(--c-primary-dk);color:#fff;}
.btn-mapsd:hover{background:var(--c-accent);}

/* === Destinasi Featured Slot === */
.destinasi-featured{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px;}
.dest-feat{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-md);cursor:pointer;transition:var(--t);}
.dest-feat:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);}
.dest-feat img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.dest-feat:hover img{transform:scale(1.08);}
.dest-feat::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.85));}
.dest-feat .info{position:absolute;left:24px;right:24px;bottom:24px;color:#fff;z-index:1;}
.dest-feat .badge-feat{display:inline-block;padding:5px 12px;background:var(--c-gold);color:var(--c-primary-dk);border-radius:50px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;}
.dest-feat h3{font-family:var(--font-display);font-size:26px;color:#fff;font-weight:600;margin-bottom:6px;line-height:1.15;}
.dest-feat .kota{font-size:12px;color:var(--c-gold-lt);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;}

/* === Destinasi Detail === */
.dest-hero{position:relative;height:75vh;min-height:480px;overflow:hidden;}
.dest-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.dest-hero-content{position:absolute;left:0;right:0;bottom:0;padding:0 36px 80px;color:#fff;max-width:1180px;margin:0 auto;width:100%;z-index:2;}
.dest-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.05) 0%,rgba(0,0,0,0.25) 45%,rgba(0,0,0,0.80) 100%);z-index:1;}
.dest-hero-content .kota-tag{display:inline-block;padding:6px 16px;background:var(--c-gold);color:var(--c-primary-dk);border-radius:50px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px;}
.dest-hero-content h1{font-family:var(--font-display);font-size:clamp(36px,5.5vw,68px);line-height:1.1;color:#fff;margin-bottom:18px;font-weight:600;text-shadow:0 2px 20px rgba(0,0,0,0.55),0 1px 4px rgba(0,0,0,0.4);}
.dest-hero-meta{display:flex;flex-wrap:wrap;gap:28px;align-items:center;font-size:14px;}
.dest-hero-meta .item{display:flex;align-items:center;gap:8px;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,0.7),0 1px 3px rgba(0,0,0,0.5);}
.dest-hero-meta .item i{color:var(--c-gold-lt);filter:drop-shadow(0 1px 4px rgba(0,0,0,0.5));}
.dest-rating-big{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:700;color:var(--c-gold-lt);font-family:var(--font-display);text-shadow:0 1px 10px rgba(0,0,0,0.7),0 1px 3px rgba(0,0,0,0.5);}

.dest-body{padding:80px 0;background:var(--c-bg);}
.dest-layout{max-width:1180px;margin:0 auto;padding:0 36px;display:grid;grid-template-columns:1fr 340px;gap:60px;}
.dest-content{font-family:var(--font-display);font-size:18px;line-height:1.9;color:var(--c-text);}
.dest-content p{margin-bottom:24px;}
.dest-content h2,.dest-content h3{font-family:var(--font-display);font-weight:600;margin:40px 0 18px;}
.dest-sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:100px;align-self:start;}

/* === Resep Cookpad Style === */
.resep-hero{position:relative;padding:140px 36px 60px;background:linear-gradient(180deg,var(--c-bg-dk) 0%,var(--c-bg) 100%);}
.resep-hero-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;}
.resep-hero-img{aspect-ratio:5/4;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-xl);}
.resep-hero-img img{width:100%;height:100%;object-fit:cover;}
.resep-hero-info .kategori{display:inline-block;padding:6px 16px;background:rgba(196,154,74,0.15);color:var(--c-gold);border:1px solid rgba(196,154,74,0.40);border-radius:50px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px;}
.resep-hero-info h1{font-family:var(--font-display);font-size:clamp(34px,4.5vw,56px);color:var(--c-primary-dk);line-height:1.1;font-weight:600;margin-bottom:20px;}
.resep-hero-info .lead{font-family:var(--font-display);font-style:italic;font-size:19px;color:var(--c-muted);line-height:1.7;margin-bottom:28px;}
.resep-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.resep-stat-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--r-md);padding:16px 12px;text-align:center;}
.resep-stat-card i{color:var(--c-gold);font-size:18px;margin-bottom:8px;}
.resep-stat-card .lbl{font-size:10px;color:var(--c-muted);letter-spacing:1.5px;text-transform:uppercase;font-weight:600;}
.resep-stat-card .val{font-family:var(--font-display);font-size:22px;color:var(--c-primary-dk);font-weight:600;line-height:1;margin-top:4px;}
.resep-stat-card .val small{font-size:13px;font-weight:500;color:var(--c-muted);}

/* === Resep 2-Column === */
.cookpad-section{padding:80px 0;}
.cookpad-layout{max-width:1180px;margin:0 auto;padding:0 36px;display:grid;grid-template-columns:380px 1fr;gap:50px;align-items:start;}
.bahan-side{position:sticky;top:100px;}
.bahan-card{background:#fff;border-radius:var(--r-lg);padding:32px 30px;border:1px solid var(--c-border);box-shadow:var(--shadow-sm);}
.bahan-card>h2{font-family:var(--font-display);font-size:30px;color:var(--c-primary-dk);font-weight:600;padding-bottom:16px;border-bottom:2px solid var(--c-gold);margin-bottom:24px;}
.bahan-group{margin-bottom:28px;}
.bahan-group:last-child{margin-bottom:0;}
.bahan-group .group-title{font-family:var(--font-display);font-style:italic;font-size:17px;color:var(--c-accent);font-weight:600;margin-bottom:12px;}
.bahan-list{list-style:none;padding:0;}
.bahan-item{display:flex;align-items:start;gap:12px;padding:10px 0;border-bottom:1px solid var(--c-border);cursor:pointer;transition:0.2s;}
.bahan-item:last-child{border:none;}
.bahan-check{flex-shrink:0;width:20px;height:20px;border:2px solid var(--c-border);border-radius:6px;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:0.2s;}
.bahan-item.checked .bahan-check{background:var(--c-gold);border-color:var(--c-gold);}
.bahan-item.checked .bahan-check::after{content:'';width:6px;height:10px;border:solid var(--c-primary-dk);border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px;}
.bahan-item.checked .bahan-info .nama,.bahan-item.checked .bahan-info .takaran{text-decoration:line-through;color:var(--c-muted);opacity:0.7;}
.bahan-info{flex:1;display:flex;justify-content:space-between;gap:10px;font-size:14px;line-height:1.4;}
.bahan-info .nama{color:var(--c-primary-dk);font-weight:500;}
.bahan-info .takaran{color:var(--c-muted);font-style:italic;font-family:var(--font-display);font-size:15px;white-space:nowrap;}

.langkah-side h2{font-family:var(--font-display);font-size:34px;color:var(--c-primary-dk);font-weight:600;margin-bottom:6px;}
.langkah-side .sub{font-family:var(--font-display);font-style:italic;font-size:17px;color:var(--c-muted);margin-bottom:28px;}
.langkah-list{display:flex;flex-direction:column;gap:24px;}
.langkah-step{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-border);box-shadow:var(--shadow-sm);transition:var(--t);}
.langkah-step:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-gold);}
.langkah-head{display:flex;align-items:center;gap:18px;padding:22px 72px 22px 28px;}
.langkah-num{width:46px;height:46px;background:linear-gradient(135deg,var(--c-gold),var(--c-accent));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:700;flex-shrink:0;}
.langkah-title{flex:1;font-family:var(--font-display);font-size:20px;color:var(--c-primary-dk);font-weight:600;}
.langkah-time{font-size:12px;color:var(--c-muted);display:flex;align-items:center;gap:5px;}
.langkah-time i{color:var(--c-gold);}
.langkah-img{position:relative;overflow:hidden;}
.langkah-img img{width:100%;max-height:420px;object-fit:cover;}
.langkah-body{padding:22px 28px 28px;font-family:var(--font-display);font-size:17px;line-height:1.85;color:var(--c-text);}

.resep-tips{margin-top:48px;padding:28px 36px;background:linear-gradient(135deg,rgba(196,154,74,0.10),rgba(184,92,56,0.06));border-radius:var(--r-lg);border-left:4px solid var(--c-gold);}
.resep-tips h3{font-family:var(--font-display);font-size:22px;color:var(--c-primary-dk);font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:10px;}
.resep-tips h3 i{color:var(--c-gold);}
.resep-tips p{font-family:var(--font-display);font-style:italic;font-size:16px;line-height:1.8;color:var(--c-text);}

/* === Galeri Masonry === */
.galeri-section{padding:80px 0;background:var(--c-bg-dk);position:relative;}
.galeri-section .pattern-kawung{opacity:0.04;}
.galeri-masonry{column-count:3;column-gap:18px;max-width:1180px;margin:0 auto;padding:0 36px;}
.galeri-item{break-inside:avoid;margin-bottom:18px;border-radius:var(--r-md);overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--shadow-sm);transition:var(--t);}
.galeri-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.galeri-item img{width:100%;display:block;transition:transform 0.6s var(--ease);}
.galeri-item:hover img{transform:scale(1.06);}
.galeri-item .overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,0.7));opacity:0;transition:0.3s;display:flex;align-items:flex-end;padding:18px;}
.galeri-item:hover .overlay{opacity:1;}
.galeri-item .overlay i{color:#fff;font-size:22px;}

/* === Lightbox === */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:10000;display:none;align-items:center;justify-content:center;padding:40px 20px;animation:fadeIn 0.3s ease;}
.lightbox.active{display:flex;}
.lightbox-img{max-width:90vw;max-height:85vh;border-radius:var(--r-md);box-shadow:0 20px 80px rgba(0,0,0,0.5);}
.lightbox-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.10);border:1px solid rgba(255,255,255,0.20);color:#fff;cursor:pointer;font-size:18px;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;transition:0.3s;}
.lightbox-close:hover{background:var(--c-accent);transform:rotate(90deg);}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:#fff;cursor:pointer;font-size:20px;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;transition:0.3s;}
.lightbox-prev{left:30px;}
.lightbox-next{right:30px;}
.lightbox-prev:hover,.lightbox-next:hover{background:var(--c-gold);color:var(--c-primary-dk);}
.lightbox-caption{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.85);font-family:var(--font-display);font-style:italic;font-size:15px;text-align:center;max-width:600px;padding:0 20px;}
.lightbox-counter{position:absolute;top:24px;left:24px;color:rgba(255,255,255,0.6);font-size:13px;letter-spacing:2px;font-weight:600;}

@media(max-width:900px){
    .destinasi-grid,.destinasi-featured{grid-template-columns:1fr;}
    .resep-hero-grid{grid-template-columns:1fr;gap:32px;}
    .resep-stats-row{grid-template-columns:repeat(2,1fr);}
    .cookpad-layout{grid-template-columns:1fr;gap:36px;}
    .bahan-side{position:static;}
    .dest-layout{grid-template-columns:1fr;}
    .dest-sidebar{position:static;}
    .galeri-masonry{column-count:2;}
}
@media(max-width:560px){
    .galeri-masonry{column-count:1;}
    .lightbox-prev,.lightbox-next{width:44px;height:44px;}
    .lightbox-prev{left:14px;}
    .lightbox-next{right:14px;}
}

/* ============================================================
   ENHANCEMENT 2026: PREMIUM ANIMATIONS & MICRO-INTERACTIONS
   Identitas visual (warna, font) TIDAK diubah.
   ============================================================ */

/* ──────────────────────────────────────────────────────────
   1. SCROLL REVEAL (IntersectionObserver)
   ────────────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.9s var(--ease,cubic-bezier(0.16,1,0.3,1)),transform 0.9s var(--ease,cubic-bezier(0.16,1,0.3,1));will-change:opacity,transform;}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-fade{opacity:0;transition:opacity 1s ease;}
.reveal-fade.in{opacity:1;}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity 0.9s var(--ease),transform 0.9s var(--ease);}
.reveal-left.in{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity 0.9s var(--ease),transform 0.9s var(--ease);}
.reveal-right.in{opacity:1;transform:translateX(0);}
.reveal-scale{opacity:0;transform:scale(0.94);transition:opacity 0.8s var(--ease),transform 0.8s var(--ease);}
.reveal-scale.in{opacity:1;transform:scale(1);}
/* Stagger children */
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity 0.7s var(--ease),transform 0.7s var(--ease);}
.reveal-stagger.in>*:nth-child(1){transition-delay:0.05s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(2){transition-delay:0.15s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(3){transition-delay:0.25s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(4){transition-delay:0.35s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(5){transition-delay:0.45s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(6){transition-delay:0.55s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(7){transition-delay:0.65s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(8){transition-delay:0.75s;opacity:1;transform:translateY(0);}
.reveal-stagger.in>*:nth-child(9){transition-delay:0.85s;opacity:1;transform:translateY(0);}

/* ──────────────────────────────────────────────────────────
   2. HERO PARALLAX & FLOATING ORNAMENTS
   ────────────────────────────────────────────────────────── */
.hero-parallax{position:relative;overflow:hidden;}
.hero-parallax .bg-layer{position:absolute;inset:-10%;will-change:transform;transition:transform 0.05s linear;}
.hero-parallax .bg-layer video,.hero-parallax .bg-layer img{width:100%;height:100%;object-fit:cover;}
.hero-content-wrap{position:relative;z-index:3;}

.floating-ornament{position:absolute;pointer-events:none;opacity:0.25;animation:floatSlow 18s ease-in-out infinite;}
.floating-ornament svg{width:100%;height:100%;}
.floating-ornament.o1{top:12%;left:6%;width:80px;height:80px;animation-duration:22s;}
.floating-ornament.o2{top:28%;right:8%;width:100px;height:100px;animation-duration:26s;animation-delay:-4s;}
.floating-ornament.o3{bottom:18%;left:12%;width:64px;height:64px;animation-duration:20s;animation-delay:-8s;}
.floating-ornament.o4{bottom:22%;right:14%;width:90px;height:90px;animation-duration:24s;animation-delay:-12s;}

@keyframes floatSlow{
    0%,100%{transform:translateY(0) translateX(0) rotate(0deg);}
    25%{transform:translateY(-18px) translateX(8px) rotate(4deg);}
    50%{transform:translateY(-8px) translateX(-10px) rotate(-3deg);}
    75%{transform:translateY(-22px) translateX(6px) rotate(5deg);}
}

/* Smooth hero title reveal */
.hero-title-reveal{opacity:0;transform:translateY(40px);animation:heroReveal 1.4s var(--ease,cubic-bezier(0.16,1,0.3,1)) 0.3s forwards;}
.hero-subtitle-reveal{opacity:0;transform:translateY(24px);animation:heroReveal 1.2s var(--ease,cubic-bezier(0.16,1,0.3,1)) 0.7s forwards;}
.hero-cta-reveal{opacity:0;transform:translateY(20px);animation:heroReveal 1s var(--ease,cubic-bezier(0.16,1,0.3,1)) 1.0s forwards;}
.hero-stats-reveal{opacity:0;transform:translateY(20px);animation:heroReveal 1s var(--ease,cubic-bezier(0.16,1,0.3,1)) 1.3s forwards;}
@keyframes heroReveal{to{opacity:1;transform:translateY(0);}}

/* ──────────────────────────────────────────────────────────
   3. AUTO CAROUSEL (Trending, Resep, Destinasi)
   ────────────────────────────────────────────────────────── */
.auto-carousel{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);}
.auto-carousel-track{display:flex;gap:24px;width:max-content;animation:scrollLoop 50s linear infinite;will-change:transform;}
.auto-carousel:hover .auto-carousel-track{animation-play-state:paused;}
.auto-carousel-track.fast{animation-duration:36s;}
.auto-carousel-track.slow{animation-duration:70s;}
@keyframes scrollLoop{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
}

/* Trending Card */
.trending-card{flex:0 0 320px;background:#fff;border-radius:var(--r-lg,16px);overflow:hidden;border:1px solid var(--c-border,#D5C3B8);box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,0.05));transition:transform 0.5s var(--ease),box-shadow 0.5s var(--ease),border-color 0.4s;position:relative;}
.trending-card:hover{transform:translateY(-10px);box-shadow:0 22px 50px -10px rgba(93,64,55,0.25);border-color:var(--c-gold,#C49A4A);}
.trending-card .num-badge{position:absolute;top:14px;left:14px;z-index:2;background:rgba(29,27,24,0.85);backdrop-filter:blur(8px);color:var(--c-gold-lt,#DDB76C);font-family:var(--font-display,'Cormorant Garamond',serif);font-size:18px;font-weight:700;padding:6px 14px;border-radius:50px;letter-spacing:2px;}
.trending-card .img-wrap{aspect-ratio:5/4;overflow:hidden;position:relative;}
.trending-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.9s var(--ease);}
.trending-card:hover .img-wrap img{transform:scale(1.10);}
.trending-card .preview{position:absolute;inset:auto 0 0 0;background:linear-gradient(180deg,transparent,rgba(29,27,24,0.92) 60%);color:#fff;padding:60px 18px 18px;transform:translateY(101%);transition:transform 0.5s var(--ease);}
.trending-card:hover .preview{transform:translateY(0);}
.trending-card .preview p{font-family:var(--font-display);font-style:italic;font-size:13px;line-height:1.55;color:rgba(255,255,255,0.92);margin:0;}
.trending-card .body{padding:18px 22px 22px;}
.trending-card .body h3{font-family:var(--font-display);font-size:22px;color:var(--c-primary-dk);font-weight:600;line-height:1.2;margin-bottom:6px;}
.trending-card .body .meta{font-size:11px;color:var(--c-muted);letter-spacing:1.8px;text-transform:uppercase;font-weight:600;}
.trending-card .body .meta .gold{color:var(--c-gold);}

/* Wrapper untuk section auto-carousel agar tidak terpotong */
.carousel-section{padding:80px 0;position:relative;}

/* ──────────────────────────────────────────────────────────
   4. ENHANCED CARD HOVER (Berita, Resep, Destinasi, Event)
   ────────────────────────────────────────────────────────── */
.berita-card,.resep-card,.destinasi-card,.event-card,.resto-card{transition:transform 0.55s var(--ease,cubic-bezier(0.16,1,0.3,1)),box-shadow 0.55s var(--ease),border-color 0.4s;}
.berita-card:hover,.resep-card:hover,.destinasi-card:hover,.event-card:hover,.resto-card:hover{transform:translateY(-10px);box-shadow:0 22px 55px -12px rgba(93,64,55,0.28);}
.berita-card img,.resep-card img,.destinasi-card img,.event-card img,.resto-card img{transition:transform 0.9s var(--ease) !important;}
.berita-card:hover img,.resep-card:hover img,.destinasi-card:hover img,.event-card:hover img,.resto-card:hover img{transform:scale(1.10) !important;}

/* Subtle shine sweep on cards */
.berita-card,.resep-card,.destinasi-card,.event-card{position:relative;overflow:hidden;}
.berita-card::after,.resep-card::after,.destinasi-card::after,.event-card::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);transition:left 0.9s ease;pointer-events:none;z-index:1;}
.berita-card:hover::after,.resep-card:hover::after,.destinasi-card:hover::after,.event-card:hover::after{left:130%;}

/* ──────────────────────────────────────────────────────────
   5. NAVBAR ENHANCED BLUR
   ────────────────────────────────────────────────────────── */
.navbar{transition:background 0.4s ease,backdrop-filter 0.4s ease,box-shadow 0.4s ease,padding 0.3s ease;}
.navbar.scrolled{background:rgba(248,243,234,0.88);backdrop-filter:saturate(150%) blur(18px);-webkit-backdrop-filter:saturate(150%) blur(18px);box-shadow:0 1px 0 rgba(93,64,55,0.10),0 4px 24px rgba(93,64,55,0.08);}

/* Underline animation pada menu */
.nav-menu li a{position:relative;}
.nav-menu li a::before{content:'';position:absolute;left:50%;bottom:-4px;width:0;height:2px;background:var(--c-gold);transition:width 0.4s var(--ease),left 0.4s var(--ease);}
.nav-menu li a:hover::before,.nav-menu li a.active::before{width:calc(100% - 8px);left:4px;}

/* ──────────────────────────────────────────────────────────
   6. BUTTON ENHANCEMENTS (Hover + Ripple)
   ────────────────────────────────────────────────────────── */
.btn-hero-primary,.btn-hero-outline,.btn-maps,.btn-detail,.btn-mapsd,.sec-link{position:relative;overflow:hidden;transition:transform 0.4s var(--ease),box-shadow 0.4s var(--ease),background 0.3s,color 0.3s;}
.btn-hero-primary:hover,.btn-maps:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(196,154,74,0.35);}
.btn-hero-outline:hover{transform:translateY(-3px);}

/* Ripple */
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,0.45);transform:scale(0);animation:rippleEffect 0.7s linear;pointer-events:none;}
@keyframes rippleEffect{
    to{transform:scale(4);opacity:0;}
}

/* ──────────────────────────────────────────────────────────
   7. BUDAYA TIMELINE (Scroll-triggered)
   ────────────────────────────────────────────────────────── */
.budaya-timeline{position:relative;max-width:880px;margin:80px auto;padding:40px 20px;}
.budaya-timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:3px;background:rgba(196,154,74,0.18);transform:translateX(-50%);border-radius:3px;}
.budaya-timeline-fill{position:absolute;left:50%;top:0;width:3px;background:linear-gradient(180deg,var(--c-gold),var(--c-accent));transform:translateX(-50%);border-radius:3px;height:0;transition:height 0.1s linear;box-shadow:0 0 20px rgba(196,154,74,0.4);}
.timeline-node{position:relative;width:calc(50% - 40px);padding:24px 28px;background:#fff;border-radius:var(--r-lg,16px);box-shadow:var(--shadow-sm);border:1px solid var(--c-border);margin-bottom:60px;opacity:0;transform:translateY(40px) scale(0.96);transition:opacity 0.8s var(--ease),transform 0.8s var(--ease),border-color 0.4s;}
.timeline-node.in{opacity:1;transform:translateY(0) scale(1);}
.timeline-node.in{border-color:var(--c-border-gold,rgba(196,154,74,0.4));}
.timeline-node:nth-child(odd){margin-right:auto;}
.timeline-node:nth-child(even){margin-left:auto;}
.timeline-node .dot{position:absolute;top:30px;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--c-gold);box-shadow:0 0 0 5px rgba(196,154,74,0.15);transition:background 0.4s,box-shadow 0.4s,transform 0.5s;}
.timeline-node:nth-child(odd) .dot{right:-52px;}
.timeline-node:nth-child(even) .dot{left:-52px;}
.timeline-node.in .dot{background:var(--c-gold);box-shadow:0 0 0 8px rgba(196,154,74,0.22),0 0 24px rgba(196,154,74,0.6);transform:scale(1.15);}
.timeline-node .era{font-size:11px;color:var(--c-gold);letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.timeline-node .era i{font-size:18px;}
.timeline-node h3{font-family:var(--font-display);font-size:26px;color:var(--c-primary-dk);font-weight:600;margin-bottom:10px;line-height:1.2;}
.timeline-node p{font-size:14px;line-height:1.7;color:var(--c-text);font-family:var(--font-display);font-style:italic;}

@media(max-width:760px){
    .budaya-timeline::before,.budaya-timeline-fill{left:20px;}
    .timeline-node{width:calc(100% - 50px);margin-left:50px !important;}
    .timeline-node .dot{left:-42px !important;right:auto !important;}
}

/* ──────────────────────────────────────────────────────────
   8. NUMBER COUNTER (Stats)
   ────────────────────────────────────────────────────────── */
.counter-value{display:inline-block;font-variant-numeric:tabular-nums;}

/* ──────────────────────────────────────────────────────────
   9. BACK-TO-TOP BUTTON
   ────────────────────────────────────────────────────────── */
.back-to-top{position:fixed;bottom:30px;right:30px;width:52px;height:52px;border-radius:50%;background:var(--c-primary-dk);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;opacity:0;visibility:hidden;transform:translateY(20px);transition:opacity 0.4s,visibility 0.4s,transform 0.4s,background 0.3s;box-shadow:0 10px 30px rgba(93,64,55,0.35);z-index:990;}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0);}
.back-to-top:hover{background:var(--c-gold);color:var(--c-primary-dk);transform:translateY(-4px);}
.back-to-top svg,.back-to-top i{transition:transform 0.3s;}
.back-to-top:hover i{transform:translateY(-3px);}

/* ──────────────────────────────────────────────────────────
   10. SKELETON LOADERS (untuk lazy-load gambar)
   ────────────────────────────────────────────────────────── */
.skeleton{background:linear-gradient(90deg,#EDE3CF 25%,#F8F3EA 50%,#EDE3CF 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;}
@keyframes skeletonShimmer{
    0%{background-position:200% 0;}
    100%{background-position:-200% 0;}
}
img.lazy-img{opacity:0;transition:opacity 0.6s ease;}
img.lazy-img.loaded{opacity:1;}

/* ──────────────────────────────────────────────────────────
   11. COOKING MODE (Resep Detail)
   ────────────────────────────────────────────────────────── */
.cooking-mode-trigger{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:linear-gradient(135deg,var(--c-primary-dk),var(--c-accent));color:#fff;border:none;border-radius:50px;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:transform 0.4s var(--ease),box-shadow 0.4s;margin-top:24px;}
.cooking-mode-trigger:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(184,92,56,0.35);}

.cooking-mode{position:fixed;inset:0;background:linear-gradient(180deg,var(--c-bg) 0%,#fff 100%);z-index:9000;display:none;flex-direction:column;animation:cookFadeIn 0.5s ease; height: 100dvh;height: 100vh;overflow: hidden;}
.cooking-mode.active{display:flex;}
@keyframes cookFadeIn{from{opacity:0;}to{opacity:1;}}

.cooking-head{display:flex;align-items:center;justify-content:space-between;padding:24px 40px;border-bottom:1px solid var(--c-border);background:rgba(248,243,234,0.85);backdrop-filter:blur(14px);}
.cooking-head h3{font-family:var(--font-display);font-size:24px;color:var(--c-primary-dk);font-weight:600;}
.cooking-head .close-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--c-border);background:#fff;color:var(--c-primary-dk);cursor:pointer;font-size:16px;transition:transform 0.3s,background 0.3s;display:flex;align-items:center;justify-content:center;}
.cooking-head .close-btn:hover{background:var(--c-accent);color:#fff;transform:rotate(90deg);}

.cooking-progress{padding:0 40px;background:rgba(248,243,234,0.85);padding-bottom:14px;}
.cooking-progress-bar{height:6px;background:rgba(196,154,74,0.18);border-radius:50px;overflow:hidden;}
.cooking-progress-bar .fill{height:100%;background:linear-gradient(90deg,var(--c-gold),var(--c-accent));width:0;transition:width 0.6s var(--ease);border-radius:50px;}
.cooking-progress-text{margin-top:8px;font-size:11px;color:var(--c-muted);letter-spacing:2px;text-transform:uppercase;font-weight:700;display:flex;justify-content:space-between;}

.cooking-body{
    flex:1;
    overflow-y:auto;
    min-height: 0;
    padding:40px;
    display:flex;
    align-items:flex-start;
    justify-content:center;
}
.cooking-step{
    max-width:920px;
    width:100%;
    text-align:center;
    padding-top:20px;
    animation:stepFade 0.6s var(--ease);
}
@keyframes stepFade{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.cooking-step .num-big{font-family:var(--font-display);font-size:60px;color:var(--c-gold);line-height:1;font-weight:700;margin-bottom:8px;}
.cooking-step .label{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--c-muted);font-weight:700;margin-bottom:30px;}
.cooking-step .step-img{
    max-width:640px;
    width:100%;
    min-height:0;
    max-height:260px;
    border-radius:var(--r-lg);
    overflow:hidden;
    margin:0 auto 36px;
}
.cooking-step .step-img img{width:100%;height:100%;object-fit:cover;}
.cooking-step .step-desc{font-family:var(--font-display);font-size:20px;line-height:1.6;color:var(--c-text);max-width:740px;margin:0 auto 20px;}
.cooking-step .step-time{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--c-accent);font-weight:700;}

.cooking-nav{display:flex;justify-content:space-between;align-items:center;padding:24px 40px;border-top:1px solid var(--c-border);background:rgba(248,243,234,0.85);backdrop-filter:blur(14px);}
.cooking-nav button{padding:14px 28px;border-radius:50px;border:none;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:transform 0.3s,background 0.3s,color 0.3s,opacity 0.3s;display:inline-flex;align-items:center;gap:10px;}
.cooking-nav .prev{background:#fff;border:1px solid var(--c-border);color:var(--c-primary-dk);}
.cooking-nav .prev:hover{background:var(--c-bg-dk);}
.cooking-nav .prev:disabled,.cooking-nav .next:disabled{opacity:0.4;cursor:not-allowed;}
.cooking-nav .next{background:var(--c-primary-dk);color:#fff;}
.cooking-nav .next:hover:not(:disabled){background:var(--c-accent);transform:translateX(4px);}
.cooking-nav .next.done{background:var(--c-success,#6B8E23);}

@media(max-width:760px){
    .cooking-head,.cooking-progress,.cooking-body,.cooking-nav{padding-left:20px;padding-right:20px;}
    .cooking-step .num-big{font-size:60px;}
    .cooking-step .step-desc{font-size:20px;}
}

/* ──────────────────────────────────────────────────────────
   12. KALKULATOR PORSI + PROGRESS LANGKAH
   ────────────────────────────────────────────────────────── */
.porsi-calculator{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,rgba(196,154,74,0.10),rgba(184,92,56,0.06));padding:14px 18px;border-radius:50px;margin-bottom:24px;border:1px solid rgba(196,154,74,0.25);}
.porsi-calculator .label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--c-primary-dk);font-weight:700;}
.porsi-calculator .controls{display:flex;align-items:center;gap:10px;margin-left:auto;}
.porsi-calculator button{width:34px;height:34px;border-radius:50%;border:1px solid var(--c-gold);background:#fff;color:var(--c-primary-dk);font-size:14px;cursor:pointer;transition:transform 0.2s,background 0.2s,color 0.2s;display:flex;align-items:center;justify-content:center;}
.porsi-calculator button:hover{background:var(--c-gold);color:var(--c-primary-dk);transform:scale(1.08);}
.porsi-calculator .value{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--c-primary-dk);min-width:40px;text-align:center;}

/* Visual progress di sidebar bahan */
.langkah-step.completed{opacity:0.6;}
.langkah-step.completed .langkah-num{background:var(--c-success,#6B8E23) !important;}
.langkah-checkbox{position:absolute;top:18px;right:20px;width:28px;height:28px;border-radius:50%;border:2px solid var(--c-border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.3s;z-index:2;}
.langkah-checkbox:hover{border-color:var(--c-gold);}
.langkah-step.completed .langkah-checkbox{background:var(--c-success,#6B8E23);border-color:var(--c-success,#6B8E23);}
.langkah-step.completed .langkah-checkbox::after{content:'';width:8px;height:14px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);margin-bottom:3px;}

.steps-progress{position:sticky;top:100px;background:#fff;padding:18px 22px;border-radius:12px;border:1px solid var(--c-border);margin-bottom:20px;}
.steps-progress .lbl{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--c-muted);font-weight:700;margin-bottom:10px;display:flex;justify-content:space-between;}
.steps-progress .lbl span:last-child{color:var(--c-gold);font-family:var(--font-display);font-size:14px;letter-spacing:0;text-transform:none;}
.steps-progress-bar{height:6px;background:var(--c-bg-dk);border-radius:50px;overflow:hidden;}
.steps-progress-bar .fill{height:100%;background:linear-gradient(90deg,var(--c-gold),var(--c-success,#6B8E23));width:0;transition:width 0.6s var(--ease);border-radius:50px;}

/* ──────────────────────────────────────────────────────────
   13. SMOOTH SCROLL & MISC
   ────────────────────────────────────────────────────────── */
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce) {
    *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important;}
    .reveal,.reveal-fade,.reveal-left,.reveal-right,.reveal-scale{opacity:1 !important;transform:none !important;}
    .reveal-stagger>*{opacity:1 !important;transform:none !important;}
    .auto-carousel-track{animation:none !important;}
    .floating-ornament{animation:none !important;}
}

/* ============================================================
   POLISH 2026: Button Contrast, Section Rhythm, Spacing, Card Fixes
   ============================================================ */

/* ──────────────────────────────────────────────────────────
   A. BUTTON CONTRAST UPGRADE
   ────────────────────────────────────────────────────────── */
/* Primary button — selalu dark brown background, white text, jelas */
.btn-hero-primary,
a.btn-hero-primary{
    background:var(--c-primary-dk,#3E2723) !important;
    color:#fff !important;
    padding:16px 36px;
    border-radius:50px;
    font-size:13px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    display:inline-flex;align-items:center;gap:10px;
    box-shadow:0 6px 18px rgba(62,39,35,0.25);
    border:1.5px solid var(--c-primary-dk);
    transition:all 0.4s var(--ease,cubic-bezier(0.16,1,0.3,1));
    position:relative;overflow:hidden;
}
.btn-hero-primary:hover{
    background:var(--c-gold,#C49A4A) !important;
    color:var(--c-primary-dk,#3E2723) !important;
    border-color:var(--c-gold);
    transform:translateY(-3px);
    box-shadow:0 14px 30px rgba(196,154,74,0.40);
}

/* Outline / secondary button — border emas tebal, hover terisi */
.btn-hero-outline,
.btn-hero-secondary,
a.btn-hero-outline,
a.btn-hero-secondary{
    background:transparent !important;
    color:#fff !important;
    padding:15px 34px;
    border-radius:50px;
    font-size:13px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    display:inline-flex;align-items:center;gap:10px;
    border:1.5px solid rgba(255,255,255,0.65) !important;
    transition:all 0.4s var(--ease);
    position:relative;overflow:hidden;
}
.btn-hero-outline:hover,
.btn-hero-secondary:hover{
    background:var(--c-gold,#C49A4A) !important;
    color:var(--c-primary-dk) !important;
    border-color:var(--c-gold) !important;
    transform:translateY(-3px);
    box-shadow:0 14px 30px rgba(196,154,74,0.35);
}

/* Detail button di card — kontras tinggi */
.btn-detail,
a.btn-detail{
    background:var(--c-primary-dk,#3E2723) !important;
    color:#fff !important;
    border:1px solid var(--c-primary-dk);
    font-weight:700;
    box-shadow:0 4px 10px rgba(62,39,35,0.15);
    transition:all 0.35s var(--ease);
}
.btn-detail:hover{
    background:var(--c-gold,#C49A4A) !important;
    color:var(--c-primary-dk) !important;
    border-color:var(--c-gold);
    box-shadow:0 8px 20px rgba(196,154,74,0.35);
    transform:translateY(-2px);
}

/* Maps button — emas dengan border lebih jelas */
.btn-maps,
.btn-mapsd,
a.btn-maps{
    background:var(--c-gold,#C49A4A) !important;
    color:var(--c-primary-dk,#3E2723) !important;
    border:1px solid var(--c-gold);
    font-weight:700;
    box-shadow:0 4px 12px rgba(196,154,74,0.30);
    transition:all 0.35s var(--ease);
}
.btn-maps:hover,
.btn-mapsd:hover{
    background:var(--c-primary-dk) !important;
    color:#fff !important;
    border-color:var(--c-primary-dk);
    box-shadow:0 8px 22px rgba(62,39,35,0.35);
    transform:translateY(-2px);
}

/* Section link (Lihat Semua) — pakai underline animated */
.sec-link{
    color:var(--c-primary-dk) !important;
    font-weight:700;
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
    padding:10px 18px;
    border-radius:50px;
    background:rgba(196,154,74,0.10);
    border:1px solid rgba(196,154,74,0.30);
    transition:all 0.35s var(--ease);
    display:inline-flex;align-items:center;gap:8px;
}
.sec-link:hover{
    background:var(--c-gold);
    color:var(--c-primary-dk) !important;
    border-color:var(--c-gold);
    transform:translateX(4px);
    box-shadow:0 8px 18px rgba(196,154,74,0.30);
}
.sec-link i{transition:transform 0.35s;}
.sec-link:hover i{transform:translateX(4px);}

/* Filter pill — lebih solid */
.filter-pill{
    padding:10px 22px;
    background:#fff;
    border:1.5px solid var(--c-border,#D5C3B8);
    color:var(--c-primary-dk);
    border-radius:50px;
    font-size:12px;
    font-weight:600;
    letter-spacing:1.5px;
    text-transform:uppercase;
    transition:all 0.35s var(--ease);
    cursor:pointer;
}
.filter-pill:hover{
    border-color:var(--c-gold);
    color:var(--c-gold);
    transform:translateY(-2px);
    box-shadow:0 6px 14px rgba(196,154,74,0.18);
}
.filter-pill.active{
    background:var(--c-primary-dk);
    color:#fff !important;
    border-color:var(--c-primary-dk);
    box-shadow:0 6px 14px rgba(62,39,35,0.22);
}

/* ──────────────────────────────────────────────────────────
   B. SECTION RHYTHM (Alternating Background + Spacing)
   ────────────────────────────────────────────────────────── */
section{
    padding:90px 0;
    position:relative;
}
.sec-header{margin-bottom:50px;}
.sec-header.left{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;}

/* Force background rhythm pada home — alternating */
body.home-page section.featured-section{background:var(--c-bg,#F8F3EA) !important;}
body.home-page section.sejarah-section{background:var(--c-bg-dk,#EDE3CF) !important;}
/* "Cerita Terkini" section — putih */
body.home-page section[style*="background:var(--c-bg);"]:not(.featured-section):not(.resep-section){background:#fff !important;}
/* Trending — cream lebih gelap */
body.home-page .carousel-section{background:var(--c-bg-dk,#EDE3CF) !important;}
/* Resep section sudah cream — biarkan */
body.home-page section.resep-section{background:var(--c-bg,#F8F3EA) !important;}
/* Destinasi section (yang plain) — putih */
body.home-page section.reveal:not(.featured-section):not(.sejarah-section):not(.resep-section):not(.map-section):not(.event-section):not(.budaya-section):not(.carousel-section){background:#fff !important;}
/* Map section — dark */
body.home-page section.map-section{background:var(--c-dark,#1D1B18) !important;color:#fff;}
/* Event — cream */
body.home-page section.event-section{background:var(--c-bg,#F8F3EA) !important;}
/* Budaya — putih */
body.home-page section.budaya-section{background:#fff !important;}

/* Soft ornament tipis pada beberapa section sebagai pembeda */
section:not(.hero)::before{
    content:'';
    position:absolute;
    inset:0;
    background-image:
        radial-gradient(circle at 8% 20%, rgba(196,154,74,0.04) 0%, transparent 25%),
        radial-gradient(circle at 92% 80%, rgba(184,92,56,0.03) 0%, transparent 30%);
    pointer-events:none;
    z-index:0;
}
section > *{position:relative;z-index:1;}

/* Section divider lembut: garis emas thin antar section bg yang sama */
section + section{
    border-top:1px solid rgba(196,154,74,0.08);
}

/* ──────────────────────────────────────────────────────────
   C. CARD CAROUSEL FIX: tidak terpotong, smooth
   ────────────────────────────────────────────────────────── */
.auto-carousel{
    overflow:hidden;
    padding:30px 0;          /* ruang untuk hover lift */
    mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);
    -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);
}
.auto-carousel-track{
    padding:0 5%;            /* offset start */
    align-items:stretch;
}
.auto-carousel-track > *{
    height:auto;
}

/* Destinasi card (resto-card) di dalam carousel — sizing konsisten */
.auto-carousel-track .resto-card{
    flex:0 0 360px !important;
    width:360px;
    display:flex;
    flex-direction:column;
    background:#fff;
    border-radius:var(--r-lg,16px);
    overflow:hidden;
    border:1px solid var(--c-border,#D5C3B8);
    box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,0.05));
}
.auto-carousel-track .resto-card .resto-img{
    aspect-ratio:16/11;
    overflow:hidden;
    display:block;
}
.auto-carousel-track .resto-card .resto-img img{
    width:100%;height:100%;object-fit:cover;
    transition:transform 0.9s var(--ease);
}
.auto-carousel-track .resto-card:hover .resto-img img{
    transform:scale(1.08);
}
.auto-carousel-track .resto-card .resto-body{
    padding:22px 24px;
    flex:1;
    display:flex;
    flex-direction:column;
}
.auto-carousel-track .resto-card .resto-actions{
    margin-top:auto;
    padding-top:16px;
}

/* Resep card dalam carousel */
.auto-carousel-track .resep-card{
    flex:0 0 320px !important;
    width:320px;
    background:#fff;
    border-radius:var(--r-lg);
    overflow:hidden;
    border:1px solid var(--c-border);
    box-shadow:var(--shadow-sm);
    display:flex;
    flex-direction:column;
    text-decoration:none;
    color:inherit;
}

/* ──────────────────────────────────────────────────────────
   D. ADAPTIVE GALERI (jika foto sedikit, tampil compact)
   ────────────────────────────────────────────────────────── */
.galeri-masonry[data-count="1"]{
    column-count:1 !important;
    max-width:680px;
    margin-left:auto;
    margin-right:auto;
}
.galeri-masonry[data-count="2"]{
    column-count:2 !important;
    max-width:920px;
    margin-left:auto;
    margin-right:auto;
}
.galeri-masonry[data-count="3"]{
    column-count:3 !important;
}
/* Hide galeri section sepenuhnya kalau tidak ada foto */
.galeri-section:has(.galeri-masonry:empty){display:none;}

/* ──────────────────────────────────────────────────────────
   E. SPACING & ALIGNMENT POLISH
   ────────────────────────────────────────────────────────── */
.container{
    max-width:1240px;
    margin:0 auto;
    padding:0 36px;
}

.sec-eyebrow{
    font-size:11px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--c-gold);
    font-weight:700;
    margin-bottom:12px;
}
.sec-title{
    font-family:var(--font-display,'Cormorant Garamond',serif);
    font-size:clamp(34px,4vw,52px);
    color:var(--c-primary-dk,#3E2723);
    font-weight:600;
    line-height:1.1;
    margin-bottom:14px;
}
.sec-title em{color:var(--c-accent,#B85C38);font-style:italic;}
.sec-desc{
    font-family:var(--font-display);
    font-style:italic;
    font-size:18px;
    color:var(--c-muted,#7D6B5C);
    line-height:1.7;
    max-width:640px;
}

/* Grid yang terlihat lebih seimbang */
.berita-grid,.resep-grid,.event-grid,.restoran-grid,.destinasi-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
}

/* Section dark (.map-section) text-color override */
section.map-section .sec-title{color:#fff;}
section.map-section .sec-eyebrow{color:var(--c-gold-lt,#DDB76C);}
section.map-section .sec-desc{color:rgba(255,255,255,0.75);}

@media(max-width:1000px){
    section{padding:70px 0;}
    .sec-header.left{flex-direction:column;align-items:flex-start;}
    .berita-grid,.resep-grid,.event-grid,.restoran-grid,.destinasi-grid{grid-template-columns:1fr 1fr;gap:24px;}
}
@media(max-width:680px){
    section{padding:60px 0;}
    .berita-grid,.resep-grid,.event-grid,.restoran-grid,.destinasi-grid{grid-template-columns:1fr;}
}

/* ============================================================
   HALAMAN EVENT — Kalender Interaktif + Modal + Timeline
   ============================================================ */

/* ── Kalender wrapper ── */
.event-calendar-wrap{
    max-width:760px;
    margin:0 auto;
    background:#fff;
    border-radius:var(--r-xl,20px);
    border:1px solid var(--c-border,#D5C3B8);
    box-shadow:0 8px 40px rgba(93,64,55,0.10);
    overflow:hidden;
}

/* Header bulan */
.cal-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:28px 36px;
    background:var(--c-primary-dk,#3E2723);
}
.cal-month-label{
    font-family:var(--font-display,'Cormorant Garamond',serif);
    font-size:26px;
    font-weight:600;
    color:#fff;
    display:flex;
    gap:10px;
    align-items:baseline;
}
.cal-month-label span:last-child{
    font-size:16px;
    color:rgba(255,255,255,0.55);
    font-weight:400;
}
.cal-nav{
    width:40px;height:40px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,0.20);
    background:rgba(255,255,255,0.08);
    color:#fff;
    cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    font-size:14px;
    transition:background 0.3s,transform 0.2s;
}
.cal-nav:hover{background:var(--c-gold,#C49A4A);color:var(--c-primary-dk);transform:scale(1.08);}

/* Nama hari */
.cal-days-header{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    background:rgba(93,64,55,0.06);
    border-bottom:1px solid var(--c-border);
}
.cal-day-name{
    text-align:center;
    padding:12px 0;
    font-size:11px;
    font-weight:700;
    letter-spacing:1.5px;
    text-transform:uppercase;
    color:var(--c-muted,#7D6B5C);
}

/* Grid tanggal */
.cal-grid{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    padding:16px;
    gap:6px;
    opacity:1;
    transform:translateY(0);
}
.cal-cell{
    aspect-ratio:1/1;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    cursor:default;
    position:relative;
    transition:background 0.25s,transform 0.25s;
}
.cal-cell.empty{background:transparent;}
.cal-num{
    font-family:var(--font-display);
    font-size:15px;
    color:var(--c-text,#3A2E28);
    font-weight:500;
    line-height:1;
}
.cal-cell.is-today{
    background:rgba(196,154,74,0.15);
    border:1.5px solid var(--c-gold,#C49A4A);
}
.cal-cell.is-today .cal-num{color:var(--c-primary-dk);font-weight:700;}

/* Tanggal yang punya event */
.cal-cell.has-event{
    cursor:pointer;
    background:var(--c-primary-dk,#3E2723);
}
.cal-cell.has-event .cal-num{color:#fff;}
.cal-cell.has-event:hover{
    background:var(--c-gold,#C49A4A);
    transform:scale(1.12);
    box-shadow:0 6px 18px rgba(196,154,74,0.35);
}
.cal-cell.has-event:hover .cal-num{color:var(--c-primary-dk);}
.cal-dot{
    width:5px;height:5px;
    border-radius:50%;
    background:var(--c-gold,#C49A4A);
    position:absolute;
    bottom:6px;
}
.cal-cell.has-event .cal-dot{background:rgba(255,255,255,0.6);}
.cal-cell.has-event:hover .cal-dot{background:var(--c-primary-dk);}

/* Legend */
.cal-legend{
    display:flex;
    align-items:center;
    gap:8px;
    padding:14px 28px;
    border-top:1px solid var(--c-border);
    font-size:12px;
    color:var(--c-muted);
    letter-spacing:0.5px;
}
.cal-legend-dot{
    width:12px;height:12px;
    border-radius:50%;
    background:var(--c-primary-dk);
    flex-shrink:0;
}

/* ── Modal Event ── */
.event-modal-overlay{
    position:fixed;inset:0;
    background:rgba(0,0,0,0.60);
    backdrop-filter:blur(6px);
    z-index:9500;
    display:flex;align-items:center;justify-content:center;
    padding:20px;
    opacity:0;visibility:hidden;
    transition:opacity 0.35s ease,visibility 0.35s;
}
.event-modal-overlay.active{opacity:1;visibility:visible;}
.event-modal{
    background:#fff;
    border-radius:var(--r-xl,20px);
    max-width:520px;
    width:100%;
    overflow:hidden;
    box-shadow:0 24px 80px rgba(0,0,0,0.25);
    position:relative;
    transform:translateY(30px) scale(0.97);
    transition:transform 0.4s var(--ease,cubic-bezier(0.16,1,0.3,1));
}
.event-modal-overlay.active .event-modal{transform:translateY(0) scale(1);}
.event-modal-close{
    position:absolute;top:14px;right:14px;
    width:36px;height:36px;
    border-radius:50%;
    border:none;
    background:rgba(0,0,0,0.35);
    color:#fff;
    cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    font-size:14px;
    transition:background 0.3s,transform 0.3s;
    z-index:2;
}
.event-modal-close:hover{background:var(--c-accent);transform:rotate(90deg);}
.event-modal-img{
    width:100%;
    aspect-ratio:16/9;
    overflow:hidden;
}
.event-modal-img img{width:100%;height:100%;object-fit:cover;}
.event-modal-body{padding:28px 30px 32px;}
.event-modal-tag{
    display:inline-block;
    padding:5px 14px;
    background:rgba(184,92,56,0.12);
    color:var(--c-accent,#B85C38);
    border-radius:50px;
    font-size:10px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    margin-bottom:12px;
}
.event-modal-body h3{
    font-family:var(--font-display,'Cormorant Garamond',serif);
    font-size:24px;
    color:var(--c-primary-dk,#3E2723);
    font-weight:600;
    line-height:1.2;
    margin-bottom:14px;
}
.event-modal-meta{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-bottom:14px;
    font-size:13px;
    color:var(--c-muted,#7D6B5C);
}
.event-modal-meta span{display:flex;align-items:center;gap:6px;}
.event-modal-meta i{color:var(--c-gold,#C49A4A);}
.event-modal-body p{
    font-family:var(--font-display);
    font-size:15px;
    line-height:1.7;
    color:var(--c-text,#3A2E28);
    margin-bottom:20px;
    font-style:italic;
}

/* ── Event Timeline (mendatang) ── */
.event-timeline{
    display:flex;
    flex-direction:column;
    gap:0;
    max-width:900px;
    margin:0 auto;
}
.evt-item{
    display:grid;
    grid-template-columns:100px 1fr;
    gap:0 30px;
    position:relative;
}
.evt-date-col{
    display:flex;
    flex-direction:column;
    align-items:center;
}
.evt-date-box{
    width:80px;
    background:var(--c-primary-dk,#3E2723);
    border-radius:var(--r-md,12px);
    padding:14px 10px;
    text-align:center;
    color:#fff;
    flex-shrink:0;
}
.evt-date-box .day{
    display:block;
    font-family:var(--font-display);
    font-size:34px;
    font-weight:700;
    line-height:1;
    color:var(--c-gold-lt,#DDB76C);
}
.evt-date-box .month{
    display:block;
    font-size:11px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    color:rgba(255,255,255,0.8);
    margin-top:4px;
}
.evt-date-box .year{
    display:block;
    font-size:11px;
    color:rgba(255,255,255,0.45);
    margin-top:2px;
}
.evt-line{
    width:2px;
    flex:1;
    background:linear-gradient(180deg,var(--c-gold,#C49A4A),rgba(196,154,74,0.10));
    margin:8px auto;
    min-height:30px;
}
.evt-card{
    display:grid;
    grid-template-columns:160px 1fr;
    gap:0;
    background:#fff;
    border-radius:var(--r-lg,16px);
    overflow:hidden;
    border:1px solid var(--c-border,#D5C3B8);
    box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,0.05));
    margin-bottom:28px;
    text-decoration:none;
    color:inherit;
    transition:transform 0.4s var(--ease),box-shadow 0.4s var(--ease),border-color 0.3s;
}
.evt-card:hover{
    transform:translateY(-5px);
    box-shadow:0 16px 40px rgba(93,64,55,0.15);
    border-color:rgba(196,154,74,0.40);
}
.evt-img{
    width:160px;
    overflow:hidden;
    flex-shrink:0;
}
.evt-img img{
    width:100%;height:100%;
    object-fit:cover;
    transition:transform 0.7s var(--ease);
}
.evt-card:hover .evt-img img{transform:scale(1.08);}
.evt-body{
    padding:20px 24px;
    display:flex;
    flex-direction:column;
    gap:6px;
}
.evt-tag{
    font-size:10px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    color:var(--c-accent,#B85C38);
}
.evt-body h3{
    font-family:var(--font-display,'Cormorant Garamond',serif);
    font-size:20px;
    color:var(--c-primary-dk,#3E2723);
    font-weight:600;
    line-height:1.25;
}
.evt-loc{
    font-size:12px;
    color:var(--c-muted,#7D6B5C);
    display:flex;
    align-items:center;
    gap:5px;
}
.evt-loc i{color:var(--c-gold,#C49A4A);}
.evt-body p{
    font-family:var(--font-display);
    font-size:14px;
    line-height:1.65;
    color:var(--c-text,#3A2E28);
    font-style:italic;
    flex:1;
}
.evt-cta{
    font-size:11px;
    font-weight:700;
    letter-spacing:1.5px;
    text-transform:uppercase;
    color:var(--c-gold,#C49A4A);
    display:flex;
    align-items:center;
    gap:6px;
    margin-top:4px;
    transition:gap 0.3s;
}
.evt-card:hover .evt-cta{gap:10px;}

@media(max-width:760px){
    .evt-item{grid-template-columns:70px 1fr;gap:0 16px;}
    .evt-date-box{width:62px;padding:10px 8px;}
    .evt-date-box .day{font-size:26px;}
    .evt-card{grid-template-columns:1fr;}
    .evt-img{width:100%;height:180px;}
    .event-calendar-wrap{border-radius:var(--r-lg);}
    .cal-header{padding:20px 20px;}
}

/* Gambar dalam konten artikel (dari CKEditor) */
.detail-body img,
.article-content img,
.detail-content img {
    display: block;
    width: 100%;
    max-width: 820px;
    height: auto;
    margin: 36px auto;
    border-radius: 14px;
    box-shadow: 0 14px 38px rgba(93, 64, 55, 0.15);
}

.detail-body figure,
.article-content figure {
    margin: 36px auto;
    max-width: 820px;
}
.detail-body figure img,
.article-content figure img {
    margin: 0;
}
.detail-body figure figcaption,
.article-content figure figcaption {
    text-align: center;
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-style: italic;
    font-size: 14px;
    color: var(--c-muted, #7D6B5C);
    margin-top: 10px;
}

.detail-body h2,
.article-content h2 {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: 34px;
    color: var(--c-primary-dk, #3E2723);
    margin: 40px 0 16px;
    font-weight: 600;
}
.detail-body h3,
.article-content h3 {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: 26px;
    color: var(--c-primary-dk, #3E2723);
    margin: 32px 0 14px;
    font-weight: 600;
}

.galeri-section {
    background: var(--c-bg-dk, #EDE3CF) !important;
}

section:has(> .container > .sec-header + .resep-grid) {
    background: #fff !important;
}
/* Homepage Manager */
.admin-homepage .card {
    padding: 28px 32px;
}