*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
    --color-bg: #f5f0e8;
    --color-bg-alt: #ebe4d6;
    --color-bg-dark: #2c1810;
    --color-primary: #8b1a1a;
    --color-primary-light: #b02e2e;
    --color-accent: #c9a96e;
    --color-accent-light: #dfc48f;
    --color-text: #2d2018;
    --color-text-light: #6b5d4f;
    --color-text-inv: #f5f0e8;
    --color-border: #d4c9b8;
    --color-card: #faf7f2;
    --color-overlay: rgba(44,24,16,0.7);
    --font-heading: 'Playfair Display', 'Cormorant Garamond', serif;
    --font-body: 'Nunito Sans', sans-serif;
    --font-serif: 'Source Serif 4', 'Cormorant Garamond', serif;
    --font-decorative: 'Cormorant Garamond', serif;
    --max-width: 1200px;
    --header-height: 72px;
    --radius: 8px;
    --shadow: 0 4px 20px rgba(44,24,16,0.1);
    --shadow-lg: 0 8px 40px rgba(44,24,16,0.15);
    --transition: 0.3s ease;
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.7;min-height:100vh;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-primary-light)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.3;color:var(--color-bg-dark)}
h1{font-size:2.8rem;font-weight:800}
h2{font-size:2.2rem;font-weight:700}
h3{font-size:1.5rem;font-weight:600}

.page-loader{
    position:fixed;top:0;left:0;width:100%;height:100%;
    background:var(--color-bg);z-index:10000;
    display:flex;align-items:center;justify-content:center;
    transition:opacity 0.5s ease
}
.page-loader.loaded{opacity:0;pointer-events:none}
.loader-content{text-align:center}
.loader-spinner{
    width:48px;height:48px;margin:0 auto 16px;
    border:4px solid var(--color-border);
    border-top-color:var(--color-primary);
    border-radius:50%;animation:spin 0.8s linear infinite
}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{font-family:var(--font-decorative);font-size:1.1rem;color:var(--color-text-light)}

.site-header{
    position:fixed;top:0;left:0;width:100%;z-index:1000;
    background:var(--color-bg-dark);
    box-shadow:0 2px 16px rgba(0,0,0,0.2);
    height:var(--header-height)
}
.header-inner{
    max-width:var(--max-width);margin:0 auto;padding:0 24px;
    display:flex;align-items:center;justify-content:space-between;
    height:100%
}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{width:40px;height:40px;border-radius:50%}
.logo-text{font-family:var(--font-heading);font-size:1.4rem;color:var(--color-text-inv);font-weight:700}
.logo-accent{color:var(--color-accent)}
.main-nav .nav-list{display:flex;gap:4px}
.main-nav .nav-list a{
    color:var(--color-text-inv);padding:8px 16px;border-radius:var(--radius);
    font-size:0.95rem;font-weight:600;transition:all var(--transition)
}
.main-nav .nav-list a:hover,.main-nav .nav-list a.active{
    background:var(--color-primary);color:#fff
}

.burger-menu{
    display:none;background:none;border:none;cursor:pointer;
    width:32px;height:24px;position:relative;z-index:1001
}
.burger-menu span{
    display:block;width:100%;height:3px;background:var(--color-text-inv);
    border-radius:2px;position:absolute;left:0;transition:all var(--transition)
}
.burger-menu span:nth-child(1){top:0}
.burger-menu span:nth-child(2){top:50%;transform:translateY(-50%)}
.burger-menu span:nth-child(3){bottom:0}
.burger-menu.active span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.burger-menu.active span:nth-child(2){opacity:0}
.burger-menu.active span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

main{margin-top:var(--header-height);min-height:60vh}

.hero{
    position:relative;min-height:70vh;display:flex;align-items:center;
    justify-content:center;overflow:hidden;
    background-size:cover;background-position:center;background-repeat:no-repeat
}
.hero::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg, rgba(44,24,16,0.75) 0%, rgba(139,26,26,0.5) 100%)
}
.hero-content{
    position:relative;z-index:2;text-align:center;
    max-width:800px;padding:60px 24px
}
.hero-content h1{
    color:#fff;font-size:3.2rem;margin-bottom:16px;
    text-shadow:0 2px 8px rgba(0,0,0,0.3)
}
.hero-subtitle{
    color:var(--color-accent-light);font-family:var(--font-serif);
    font-size:1.3rem;font-style:italic;margin-bottom:32px
}
.hero-cta{
    display:inline-block;padding:14px 36px;
    background:var(--color-primary);color:#fff;
    font-weight:700;border-radius:var(--radius);
    font-size:1rem;transition:all var(--transition);
    border:2px solid transparent
}
.hero-cta:hover{background:transparent;border-color:var(--color-accent);color:var(--color-accent)}

.section{padding:80px 24px}
.section-inner{max-width:var(--max-width);margin:0 auto}
.section-title{text-align:center;margin-bottom:48px}
.section-title h2{margin-bottom:12px}
.section-title p{
    font-family:var(--font-serif);color:var(--color-text-light);
    font-size:1.1rem;max-width:600px;margin:0 auto
}
.section-title::after{
    content:'';display:block;width:60px;height:3px;
    background:var(--color-accent);margin:20px auto 0;border-radius:2px
}

.section-alt{background:var(--color-bg-alt)}

.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.card{
    background:var(--color-card);border-radius:var(--radius);
    overflow:hidden;box-shadow:var(--shadow);
    transition:transform var(--transition),box-shadow var(--transition)
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-image{position:relative;overflow:hidden;aspect-ratio:16/10}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.card:hover .card-image img{transform:scale(1.05)}
.card-body{padding:24px}
.card-body h3{margin-bottom:12px;font-size:1.3rem}
.card-body p{color:var(--color-text-light);font-size:0.95rem;margin-bottom:16px}
.card-link{
    display:inline-flex;align-items:center;gap:6px;
    color:var(--color-primary);font-weight:600;font-size:0.9rem
}
.card-link::after{content:'\2192';transition:transform var(--transition)}
.card-link:hover::after{transform:translateX(4px)}

.article-hero{
    position:relative;min-height:50vh;display:flex;align-items:flex-end;
    background-size:cover;background-position:center;overflow:hidden
}
.article-hero::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(to top, rgba(44,24,16,0.9) 0%, transparent 60%)
}
.article-hero-content{
    position:relative;z-index:2;max-width:var(--max-width);
    margin:0 auto;padding:40px 24px 60px;width:100%
}
.article-hero-content h1{color:#fff;font-size:2.8rem;margin-bottom:12px}
.article-meta{
    display:flex;gap:24px;flex-wrap:wrap;
    color:var(--color-accent-light);font-size:0.9rem;font-family:var(--font-serif)
}

.article-content{
    max-width:800px;margin:0 auto;padding:60px 24px
}
.article-content h2{
    margin:40px 0 16px;padding-bottom:8px;
    border-bottom:2px solid var(--color-accent)
}
.article-content h3{margin:32px 0 12px;font-size:1.3rem}
.article-content p{margin-bottom:20px;font-family:var(--font-serif);font-size:1.05rem}
.article-content ul,.article-content ol{
    margin:0 0 20px 24px;font-family:var(--font-serif);font-size:1.05rem
}
.article-content li{margin-bottom:8px}
.article-content ul li{list-style:disc}
.article-content ol li{list-style:decimal}
.article-content blockquote{
    margin:24px 0;padding:20px 24px;
    border-left:4px solid var(--color-accent);
    background:var(--color-bg-alt);border-radius:0 var(--radius) var(--radius) 0;
    font-family:var(--font-decorative);font-size:1.15rem;font-style:italic;
    color:var(--color-text-light)
}
.article-content img{
    width:100%;border-radius:var(--radius);margin:24px 0;
    box-shadow:var(--shadow)
}
.article-content .img-caption{
    text-align:center;font-size:0.85rem;color:var(--color-text-light);
    margin-top:-16px;margin-bottom:24px;font-style:italic
}

.article-sidebar{
    max-width:800px;margin:0 auto;padding:0 24px 60px
}
.sidebar-box{
    background:var(--color-bg-alt);padding:32px;border-radius:var(--radius);
    border-left:4px solid var(--color-primary)
}
.sidebar-box h3{margin-bottom:16px}
.sidebar-box ul{margin-left:20px}
.sidebar-box ul li{margin-bottom:8px;list-style:disc;font-family:var(--font-serif)}
.sidebar-box ul li a{font-weight:600}

.two-col-layout{
    display:grid;grid-template-columns:2fr 1fr;gap:48px;
    max-width:var(--max-width);margin:0 auto;padding:60px 24px
}
.two-col-layout .main-col h2{margin:32px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--color-accent)}
.two-col-layout .main-col p{margin-bottom:20px;font-family:var(--font-serif);font-size:1.05rem}
.two-col-layout .side-col .sidebar-box{margin-bottom:24px}

.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.feature-item{
    text-align:center;padding:40px 24px;
    background:var(--color-card);border-radius:var(--radius);
    box-shadow:var(--shadow);transition:transform var(--transition)
}
.feature-item:hover{transform:translateY(-4px)}
.feature-icon{
    width:64px;height:64px;margin:0 auto 20px;
    background:var(--color-primary);border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:1.8rem;font-family:var(--font-decorative)
}
.feature-item h3{margin-bottom:12px;font-size:1.2rem}
.feature-item p{color:var(--color-text-light);font-size:0.95rem}

.timeline{position:relative;max-width:700px;margin:0 auto}
.timeline::before{
    content:'';position:absolute;left:50%;top:0;bottom:0;
    width:3px;background:var(--color-accent);transform:translateX(-50%)
}
.timeline-item{
    position:relative;padding:24px 0;display:flex;
    align-items:flex-start
}
.timeline-item:nth-child(odd){flex-direction:row-reverse}
.timeline-dot{
    width:16px;height:16px;background:var(--color-primary);
    border:3px solid var(--color-accent);border-radius:50%;
    position:absolute;left:50%;top:32px;transform:translateX(-50%);z-index:1
}
.timeline-content{
    width:calc(50% - 40px);background:var(--color-card);
    padding:24px;border-radius:var(--radius);box-shadow:var(--shadow)
}
.timeline-content h3{font-size:1.1rem;margin-bottom:8px;color:var(--color-primary)}
.timeline-content p{font-size:0.95rem;color:var(--color-text-light);font-family:var(--font-serif)}

.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-item{
    position:relative;border-radius:var(--radius);overflow:hidden;
    aspect-ratio:1;cursor:pointer
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(to top, rgba(44,24,16,0.4) 0%, transparent 50%);
    opacity:0;transition:opacity var(--transition)
}
.gallery-item:hover::after{opacity:1}

.page-hero{
    padding:120px 24px 60px;text-align:center;
    background:linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-primary) 100%)
}
.page-hero h1{color:#fff;margin-bottom:12px}
.page-hero p{color:var(--color-accent-light);font-family:var(--font-serif);font-size:1.1rem;max-width:600px;margin:0 auto}

.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;max-width:var(--max-width);margin:0 auto;padding:60px 24px}
.contact-item{background:var(--color-card);padding:32px;border-radius:var(--radius);box-shadow:var(--shadow)}
.contact-item h3{margin-bottom:16px;color:var(--color-primary)}
.contact-item p{color:var(--color-text-light);font-family:var(--font-serif);margin-bottom:8px}
.contact-item a{font-weight:600}

.breadcrumb{
    padding:12px 24px;background:var(--color-bg-alt);font-size:0.85rem
}
.breadcrumb-inner{max-width:var(--max-width);margin:0 auto;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--color-text-light)}
.breadcrumb span{color:var(--color-text-light)}

.site-footer{
    background:var(--color-bg-dark);color:var(--color-text-inv);padding:60px 24px 24px
}
.footer-inner{max-width:var(--max-width);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-bottom:40px}
.footer-col h3{font-size:1.1rem;margin-bottom:16px;color:var(--color-accent);font-family:var(--font-heading)}
.footer-col p{font-size:0.9rem;color:rgba(245,240,232,0.7);line-height:1.6}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{color:rgba(245,240,232,0.7);font-size:0.9rem;transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--color-accent)}
.footer-bottom{
    border-top:1px solid rgba(245,240,232,0.15);padding-top:24px;
    text-align:center;font-size:0.85rem;color:rgba(245,240,232,0.5)
}
.footer-bottom a{color:var(--color-accent)}
.footer-update{margin-top:8px}

.cookie-banner{
    position:fixed;bottom:0;left:0;width:100%;z-index:9999;
    background:var(--color-bg-dark);box-shadow:0 -4px 20px rgba(0,0,0,0.3)
}
.cookie-inner{
    max-width:var(--max-width);margin:0 auto;padding:20px 24px;
    display:flex;align-items:center;gap:24px;flex-wrap:wrap
}
.cookie-inner p{flex:1;color:var(--color-text-inv);font-size:0.9rem;min-width:200px}
.cookie-inner p a{color:var(--color-accent);text-decoration:underline}
.cookie-buttons{display:flex;gap:12px}
.cookie-btn{
    padding:10px 24px;border:none;border-radius:var(--radius);
    font-weight:700;cursor:pointer;font-size:0.9rem;transition:all var(--transition)
}
.cookie-btn.accept{background:var(--color-accent);color:var(--color-bg-dark)}
.cookie-btn.accept:hover{background:var(--color-accent-light)}
.cookie-btn.reject{background:transparent;color:var(--color-text-inv);border:1px solid rgba(245,240,232,0.3)}
.cookie-btn.reject:hover{border-color:var(--color-accent);color:var(--color-accent)}

.policy-content{max-width:800px;margin:0 auto;padding:60px 24px}
.policy-content h2{margin:32px 0 16px;font-size:1.6rem}
.policy-content p{margin-bottom:16px;font-family:var(--font-serif);font-size:1.02rem;color:var(--color-text-light)}
.policy-content ul{margin:0 0 20px 24px}
.policy-content ul li{margin-bottom:8px;list-style:disc;font-family:var(--font-serif);color:var(--color-text-light)}

.about-intro{
    display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
    max-width:var(--max-width);margin:0 auto;padding:60px 24px
}
.about-intro img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.about-intro-text h2{margin-bottom:16px}
.about-intro-text p{font-family:var(--font-serif);font-size:1.05rem;color:var(--color-text-light);margin-bottom:16px}

@media(max-width:1024px){
    .card-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:repeat(2,1fr)}
    .features-grid{grid-template-columns:repeat(2,1fr)}
    .gallery-grid{grid-template-columns:repeat(3,1fr)}
    .two-col-layout{grid-template-columns:1fr}
    .about-intro{grid-template-columns:1fr}
    h1{font-size:2.2rem}
    .hero-content h1{font-size:2.6rem}
}

@media(max-width:768px){
    .burger-menu{display:block}
    .main-nav{
        position:fixed;top:0;right:-100%;width:280px;height:100vh;
        background:var(--color-bg-dark);padding:80px 24px 24px;
        transition:right var(--transition);z-index:1000;
        box-shadow:-4px 0 20px rgba(0,0,0,0.3)
    }
    .main-nav.open{right:0}
    .main-nav .nav-list{flex-direction:column;gap:0}
    .main-nav .nav-list a{display:block;padding:14px 16px;border-radius:0;border-bottom:1px solid rgba(245,240,232,0.1)}
    .card-grid{grid-template-columns:1fr}
    .features-grid{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:repeat(2,1fr)}
    .contact-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr}
    .hero{min-height:60vh}
    .hero-content h1{font-size:2rem}
    .hero-subtitle{font-size:1.1rem}
    h1{font-size:1.8rem}
    h2{font-size:1.6rem}
    .section{padding:48px 16px}
    .article-content{padding:40px 16px}
    .article-hero-content h1{font-size:2rem}
    .timeline::before{left:20px}
    .timeline-item,.timeline-item:nth-child(odd){flex-direction:row}
    .timeline-dot{left:20px}
    .timeline-content{width:calc(100% - 60px);margin-left:40px}
    .cookie-inner{flex-direction:column;text-align:center}
}

@media(max-width:480px){
    .gallery-grid{grid-template-columns:1fr}
    .hero-content h1{font-size:1.6rem}
    h1{font-size:1.5rem}
    .header-inner{padding:0 16px}
    .logo-text{font-size:1.2rem}
}