:root {
    --red: #8a0000;
    --gold: #d4af37;
    --cream: #f9f5e8;
    --dark: #222;
    --muted: #666;
    --max: 1180px;
}

.skip-link {
    position: fixed;
    left: 12px;
    top: -80px;
    z-index: 100;
    padding: 10px 14px;
    background: #fff;
    color: var(--red);
    border-radius: 6px;
    box-shadow: 0 4px 18px rgba(0,0,0,.2);
}
.skip-link:focus { top: 12px; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--dark); background: #fff; font-family: Lato, Arial, sans-serif; line-height: 1.6; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.container { width: min(calc(100% - 32px), var(--max)); margin: 0 auto; }
.topbar { background: #050505; color: #fff; font-size: .78rem; padding: 9px 0; }
.topbar-inner, .header-inner, .footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.rating { color: #f5cf45; font-weight: 700; }
.site-header { position: sticky; top: 0; z-index: 20; background: #fff; border-bottom: 1px solid #eee; box-shadow: 0 2px 10px rgba(0,0,0,.05); }
.header-inner { min-height: 78px; }
.brand strong { display: block; color: var(--red); font: 700 1.65rem "Playfair Display", Georgia, serif; letter-spacing: .05em; }
.brand span { display: block; color: #777; font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; }
.nav { display: flex; gap: 26px; font-weight: 700; font-size: .92rem; }
.nav a:hover, .nav a.active { color: var(--red); }
.button { display: inline-flex; align-items: center; justify-content: center; border: 0; border-radius: 999px; padding: 13px 24px; background: var(--red); color: #fff; font-weight: 700; cursor: pointer; }
.button:hover { background: #650000; }
.button.dark { background: #252525; }
.button.green { background: #20a94b; }
.button.light { background: #fff; color: var(--red); }
.menu-button { display: none; background: transparent; border: 0; font-size: 1.6rem; }
.hero { min-height: 650px; display: grid; place-items: center; text-align: center; color: #fff; background: linear-gradient(rgba(0,0,0,.32), rgba(0,0,0,.78)), url("../images/sri-hari-wedding-fix.jpg") center/cover; }
.hero-content { max-width: 820px; padding: 70px 0; }
.eyebrow { color: var(--gold); font-size: .82rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; }
h1, h2, h3 { font-family: "Playfair Display", Georgia, serif; line-height: 1.2; }
.hero h1 { margin: 14px 0; font-size: clamp(2.6rem, 7vw, 5rem); }
.hero h1 span { display: block; color: var(--gold); font-size: .55em; font-style: italic; font-weight: 400; margin-top: 10px; }
.hero p { font-size: 1.15rem; color: #eee; }
.hero-actions { display: flex; justify-content: center; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.page-hero { padding: 100px 0; color: #fff; background: linear-gradient(135deg, #1c1c1c, #3a2222); }
.section { padding: 78px 0; }
.section.alt { background: #f7f7f7; }
.section.dark { background: #222; color: #fff; }
.section-heading { max-width: 720px; margin: 0 auto 42px; text-align: center; }
.section-heading h1, .section-heading h2 { font-size: clamp(2rem, 4vw, 3.2rem); margin: 8px 0 14px; }
.section-action { margin-top: 38px; text-align: center; }
.grid { display: grid; gap: 26px; }
.grid.three { grid-template-columns: repeat(3, 1fr); }
.grid.four { grid-template-columns: repeat(4, 1fr); }
.card { background: #fff; border: 1px solid #eee; border-radius: 14px; overflow: hidden; box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.card-body { padding: 24px; }
.product-image { width: 100%; height: 300px; object-fit: cover; background: #eee; }
.price { color: var(--red); font-weight: 700; }
.trust { background: var(--cream); padding: 24px 0; }
.trust-item { background: rgba(255,255,255,.7); padding: 16px; border-radius: 10px; text-align: center; }
.feature { padding: 28px; text-align: center; }
.feature-icon { width: 58px; height: 58px; display: grid; place-items: center; margin: 0 auto 15px; border-radius: 50%; background: var(--cream); color: var(--red); font-weight: 900; }
.dark-card { padding: 28px; border: 1px solid #444; border-radius: 14px; background: #2d2d2d; }
.story { max-width: 850px; margin: 0 auto; }
.story-item { display: grid; grid-template-columns: 150px 1fr; gap: 35px; margin-bottom: 55px; }
.story-year { color: rgba(138,0,0,.25); font: 700 3.4rem "Playfair Display", serif; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 35px; }
.contact-box { padding: 32px; background: #fff; border-radius: 12px; border-top: 4px solid var(--red); box-shadow: 0 8px 28px rgba(0,0,0,.08); }
.filter-links { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin: 0 0 40px; }
.filter-links a { padding: 9px 16px; border: 1px solid #ddd; border-radius: 999px; background: #fff; font-weight: 700; }
.filter-links a:hover { color: #fff; border-color: var(--red); background: var(--red); }
.gallery-card img { width: 100%; height: 320px; object-fit: cover; background: var(--cream); }
.gallery-card figcaption { display: grid; gap: 5px; padding: 18px 20px 22px; }
.gallery-card figcaption span { color: var(--red); font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.gallery-card figcaption strong { font-family: "Playfair Display", Georgia, serif; font-size: 1.25rem; }
.media-notice { margin-top: 30px; padding: 16px 20px; border-left: 4px solid var(--gold); background: #fff9df; color: #5c511e; }
.video-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.video-card { overflow: hidden; border: 1px solid #444; border-radius: 14px; background: #2d2d2d; }
.video-card video, .video-card iframe { display: block; width: 100%; aspect-ratio: 9/16; border: 0; object-fit: cover; background: #111; }
.video-card div { padding: 18px; }
.video-card h3 { margin: 0 0 8px; }
.video-card p { margin: 0; color: #ccc; }
.section-image { width: 100%; max-height: 560px; margin: 22px 0; border-radius: 12px; object-fit: cover; }
.honeypot { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.cta { padding: 70px 0; text-align: center; color: #fff; background: var(--red); }
.cta h2 { margin-top: 0; font-size: clamp(2rem, 4vw, 3rem); }
.field { margin-bottom: 17px; }
.field label { display: block; margin-bottom: 6px; font-weight: 700; }
.field input, .field textarea { width: 100%; padding: 12px 13px; border: 1px solid #ccc; border-radius: 8px; font: inherit; }
.field input:focus, .field textarea:focus { outline: 2px solid rgba(138,0,0,.18); border-color: var(--red); }
.alert { padding: 13px 16px; margin-bottom: 18px; border-radius: 8px; }
.alert.success { background: #e7f8eb; color: #17672d; }
.alert.error { background: #fff0f0; color: #8a0000; }
.site-footer { background: #171717; color: #bbb; padding: 60px 0 25px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.4fr; gap: 38px; }
.site-footer h3, .site-footer h4 { color: #fff; }
.site-footer ul { list-style: none; padding: 0; }
.site-footer li { margin: 8px 0; }
.footer-bottom { border-top: 1px solid #333; padding-top: 22px; margin-top: 42px; font-size: .8rem; }
.whatsapp-float { position: fixed; right: 22px; bottom: 22px; z-index: 30; width: 56px; height: 56px; display: grid; place-items: center; background: #20a94b; color: #fff; border-radius: 50%; font-weight: 900; box-shadow: 0 10px 30px rgba(0,0,0,.25); }
.empty { padding: 60px 20px; text-align: center; color: var(--muted); }

@media (max-width: 850px) {
    .topbar-inner { align-items: flex-start; flex-direction: column; gap: 3px; }
    .menu-button { display: block; }
    .nav { display: none; position: absolute; top: 78px; left: 0; right: 0; flex-direction: column; gap: 0; padding: 12px 20px 22px; background: #fff; border-top: 1px solid #eee; box-shadow: 0 10px 20px rgba(0,0,0,.08); }
    .nav.open { display: flex; }
    .nav a { padding: 10px 0; }
    .header-cta { display: none; }
    .grid.three, .grid.four, .footer-grid, .contact-grid, .video-grid { grid-template-columns: 1fr; }
    .story-item { grid-template-columns: 1fr; gap: 5px; }
    .hero { min-height: 580px; }
    .gallery-card img { height: 260px; }
}
