/* Innovative Bridal Studio — Global Styles */
:root{
  /* Light theme inspired by style guide */
  --bg:#faf9f7;           /* light neutral background */
  --surface:#ffffff;      /* surfaces/cards */
  --text:#333333;         /* primary text */
  --muted:#666666;        /* secondary text */
  --primary:#d4af37;      /* gold */
  --primary-2:#e6c55c;    /* lighter gold */
  --secondary:#2c1810;    /* deep brown */
  --accent:#d4af37;       /* use gold for links */
  --border:#eae7e2;       /* soft border */
  --card:#ffffff;         /* card background */
  --radius:14px;--radius-sm:10px;
  --shadow:0 10px 24px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;background:#000;color:#fff;padding:.5rem .75rem;border-radius:8px}

.container{width:min(1160px,92%);margin-inline:auto}
.tiny{font-size:.9rem;color:var(--muted);padding:1.25rem 0}
.muted{color:var(--muted)}

/* Header */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--border);z-index:10}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0}
.brand{display:flex;align-items:center;gap:.75rem}
.brand-logo{width:40px;height:40px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text strong{font-family:"Playfair Display",serif;font-weight:700;letter-spacing:.2px}
.brand-text span{font-size:.85rem;color:var(--muted)}
.nav ul{display:flex;list-style:none;gap:.75rem;padding:0;margin:0;flex-wrap:nowrap}
.nav a{padding:.5rem .8rem;border-radius:999px;transition:background .2s,color .2s;white-space:nowrap}
.nav a:hover,.nav a.active{background:rgba(212,175,55,.14);color:#000}
.nav-toggle{display:none;background:#1b1b1b;color:#fff;border:1px solid var(--border);padding:.5rem .75rem;border-radius:10px}
@media(max-width:920px){
  .nav-toggle{display:block}
  .nav{position:absolute;right:4%;top:64px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);display:none}
  .nav.open{display:block}
  .nav ul{flex-direction:column;padding:.5rem}
}
@media(max-width:1060px){
  .nav a{padding:.45rem .7rem;font-size:.95rem}
}

/* Hero */
.hero{position:relative}
.hero .hero-slider{position:relative;overflow:hidden;height:78vh;min-height:520px}
.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity .6s ease}
.hero .slide.is-active{opacity:1;z-index:1}
.hero figure img{object-fit:cover;width:100%;height:100%}
.hero figcaption{position:absolute;inset:auto 0 10% 0;color:#fff;text-align:center;padding:0 1rem}
.hero h1,.hero h2{font-family:"Playfair Display",serif;font-size:clamp(1.8rem,3.5vw,3.2rem);text-shadow:0 6px 22px rgba(0,0,0,.45)}
.hero p{color:#e7e7e7;max-width:720px;margin:.25rem auto 1.25rem}
.cta-row{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* Sections */
.section-head{margin:3rem 0 1rem;text-align:center}
.section-head h2{font-family:"Playfair Display",serif;font-size:clamp(1.6rem,2.4vw,2.2rem)}

/* Cards */
.cards{display:grid;grid-template-columns:1fr;gap:1.25rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.card-body{padding:1rem 1rem 1.25rem}
.card h3{font-family:"Playfair Display",serif;margin:.25rem 0 .5rem}
.link{color:var(--accent)}
@media(min-width:700px){.cards{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.cards{grid-template-columns:repeat(3,1fr)}}

/* Generic: make first tile in a card edge-to-edge with no padding */
.card > .tile{margin:0;border:none;box-shadow:none;border-radius:0}
.card > .tile:hover{transform:none;box-shadow:none}
.card > .tile img{display:block;width:100%;height:auto;border-radius:0}

/* Highlights: images should be full-width with no extra frame or hover lift */
#home-highlights .card .tile{border:none;box-shadow:none;border-radius:0}
#home-highlights .card .tile:hover{transform:none;box-shadow:none}
#home-highlights .card .tile{margin:0 0 .75rem 0;width:100%}
#home-highlights .card .tile img{height:auto;aspect-ratio:auto;border-radius:0;display:block;width:100%}

/* Mosaic */
.mosaic{padding:2rem 0}
.mosaic-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;align-items:start}
.mosaic-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;box-shadow:var(--shadow)}
@media(min-width:760px){.mosaic-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1120px){.mosaic-grid{grid-template-columns:repeat(4,1fr)}}

/* Force 4 columns for home mosaic on desktop widths */
@media(min-width:900px){
  #home-mosaic .mosaic-grid{grid-template-columns:repeat(4,1fr)}
}

/* CTA */
.cta{padding:2.5rem 0}
.cta.booking{background:linear-gradient(180deg,rgba(212,175,55,.08),transparent)}
.cta-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}

/* Insta strip */
.insta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}
.insta-item img{border-radius:10px;height:140px;object-fit:cover}
@media(min-width:600px){.insta-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.insta-grid{grid-template-columns:repeat(6,1fr)}}
@media(max-width:860px){.insta-item img{height:110px}}

/* Buttons */
.btn{--bg:#f6f5f2;--fg:#2b2b2b;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);padding:.7rem 1rem;border-radius:12px;cursor:pointer;transition:transform .06s ease,background .2s,box-shadow .2s}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(0,0,0,.06)}
.btn-primary{--bg:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border:none}
.btn-ghost{background:transparent;border:1px solid var(--primary);color:var(--primary)}
.btn-ghost:hover{background:rgba(212,175,55,.08)}
.icon-btn{background:#fff;border:1px solid var(--border);border-radius:10px;padding:.35rem .5rem;color:#444}

/* Floating WhatsApp button */
.whatsapp-float{position:fixed;right:18px;bottom:18px;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 10px 22px rgba(0,0,0,.18);z-index:900;border:none}
.whatsapp-float:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(0,0,0,.22)}
.whatsapp-float svg{width:28px;height:28px;fill:currentColor;display:block}
@media(max-width:560px){.whatsapp-float{right:14px;bottom:14px;width:52px;height:52px}.whatsapp-float svg{width:26px;height:26px}}

/* Footer */
.site-footer{border-top:1px solid transparent;margin-top:2rem;padding:1.25rem 0;background:var(--secondary);color:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem;align-items:start}
.footer-nav{display:grid;gap:.4rem}
.footer-nav a{color:#fff;opacity:.9}
.footer-nav a:hover{opacity:1;color:var(--primary)}
/* Prevent nav flicker: hide while JS hydrates menu */
.nav.is-hydrating,
.footer-nav.is-hydrating { display: none; }
.social{display:flex;gap:.75rem}
.brand--footer{display:flex;gap:.6rem;align-items:center}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr}}

/* Page hero */
.page-hero{position:relative;height:44vh;min-height:320px}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.05)}
.page-hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.6));display:flex;flex-direction:column;align-items:center;justify-content:end;padding:2rem 1rem;text-align:center}
.page-hero h1{font-family:"Playfair Display",serif;margin:0}

/* Filters */
.filters{padding:1.25rem 0}
.chip-group{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{background:#ffffff;border:1px solid var(--border);color:#444;border-radius:999px;padding:.45rem .8rem;cursor:pointer}
.chip.is-active{background:rgba(212,175,55,.14);border-color:rgba(212,175,55,.4);color:#2b2b2b}

/* Grid portfolio */
.gallery{padding:1rem 0 2rem}
.grid-portfolio{display:grid;grid-template-columns:1fr;gap:1rem}
.tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.tile img{display:block;width:100%;height:280px;object-fit:cover;cursor:pointer}
.tile figcaption{padding:.6rem .8rem;color:#444}
.tile{transition:transform .18s ease, box-shadow .18s ease}
.tile:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.08)}
@media(min-width:720px){.grid-portfolio{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.grid-portfolio{grid-template-columns:repeat(3,1fr)}}
/* Force 4 columns in gallery page on desktop */
@media(min-width:1100px){#gallery .grid-portfolio{grid-template-columns:repeat(4,1fr)}}
@media(max-width:900px){.tile img{height:220px}}

/* Hover link icon on all .tile images (non-hero sections) */
.tile{position:relative}
.tile::after{content:'\1F517'; /* link symbol */ position:absolute;inset:auto 8px 8px auto;background:rgba(0,0,0,.6);color:#fff;border-radius:999px;padding:.25rem .4rem;font-size:.95rem;line-height:1;opacity:0;transform:translateY(4px);transition:opacity .18s ease, transform .18s ease}
.tile:hover::after{opacity:1;transform:none}

/* Preserve original sizing in mosaic and insta sections */
.mosaic-grid .tile img{height:auto}
.insta-grid .tile img{height:140px}
@media(max-width:860px){.insta-grid .tile img{height:110px}}

/* Forms & modal */
label{display:grid;gap:.3rem;font-size:.95rem}
input,select,textarea{background:#ffffff;border:1px solid #d9d6d1;color:#2b2b2b;border-radius:10px;padding:.65rem .75rem;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(212,175,55,.14)}
.grid{display:grid;gap:.75rem;grid-template-columns:1fr 1fr}
@media(max-width:680px){.grid{grid-template-columns:1fr}}
.form-status{margin-top:.6rem;color:var(--accent)}

.modal{border:none;border-radius:16px;padding:0;background:#0008}
.modal::backdrop{background:rgba(0,0,0,.55)}
.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;min-width:min(560px,92%);box-shadow:var(--shadow)}
.modal-card header,.modal-card footer{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border)}
.modal-card footer{border-top:1px solid var(--border);border-bottom:none}
.modal-card .modal-body{padding:1rem;display:grid;gap:1rem}

/* Layout helpers */
.page-intro{padding:1.25rem 0 1rem}
.two-col{display:grid;grid-template-columns:1fr;gap:1rem;align-items:center}
.two-col.contact{align-items:start}
@media(min-width:900px){.two-col{grid-template-columns:1.2fr .8fr}}

/* Contact page */
.contact-card{padding:1rem}
.contact-card h3{margin-top:0}
.map-embed{margin-top:.75rem}
.map-embed iframe{width:100%;height:420px;border:0;border-radius:10px}

/* About page */
.about-layout{align-items:start;gap:1.25rem;margin-top:2rem}
.about-left h1{margin-top:0}
.about-right{position:relative}
.about-slider{position:relative;overflow:hidden;border-radius:14px;box-shadow:var(--shadow);height:56vh;min-height:360px}
.about-slider .slide{position:absolute;inset:0;opacity:0;z-index:0;transition:opacity .7s ease;margin:0}
.about-slider .slide.is-active{opacity:1;z-index:1}
.about-slider img{width:100%;height:100%;object-fit:cover}
.about-slider .slide.fade{transition:opacity .8s ease}
.about-slider .slide.slide-left{transition:transform .7s ease, opacity .7s ease;transform:translateX(8%);opacity:0}
.about-slider .slide.slide-left.is-active{transform:none;opacity:1}
.about-slider .slide.slide-up{transition:transform .7s ease, opacity .7s ease;transform:translateY(8%);opacity:0}
.about-slider .slide.slide-up.is-active{transform:none;opacity:1}
.about-slider .slide.zoom{transition:transform 1s ease, opacity .8s ease;transform:scale(1.06);opacity:0}
.about-slider .slide.zoom.is-active{transform:scale(1);opacity:1}

/* Video grid */
.video-grid{display:grid;grid-template-columns:1fr;gap:1rem;padding:0 0 2rem}
.video-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.video-embed{position:relative;padding-bottom:56.25%;height:0}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:8px}
@media(min-width:900px){.video-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1200px){.video-grid{grid-template-columns:repeat(3,1fr)}}

/* Accessibility */
:focus-visible{outline:2px dashed var(--primary);outline-offset:3px}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.86);display:none;align-items:center;justify-content:center;padding:2rem;z-index:1000}
.lightbox.open{display:flex;animation:lb-fade .2s ease-out}
.lb-figure{max-width:92vw;max-height:92vh;display:flex;flex-direction:column;gap:.5rem;align-items:center}
.lb-img{max-width:100%;max-height:calc(92vh - 80px);border-radius:12px;box-shadow:0 24px 64px rgba(0,0,0,.4);transition:transform .2s ease}
.lb-img.zoomed{transform:scale(1.6);cursor:zoom-out}
.lb-caption{color:#eee;text-align:center;font-size:.95rem}
.lb-btn{position:absolute;top:1rem;background:rgba(255,255,255,.9);border:none;color:#111;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(0,0,0,.2);transition:transform .1s ease}
.lb-btn:hover{transform:translateY(-1px)}
.lb-close{right:1rem;width:40px;height:40px;font-size:22px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:46px;height:46px;font-size:22px;background:rgba(255,255,255,.85)}
.lb-prev{left:1rem}
.lb-next{right:1rem}
@media(max-width:560px){.lightbox{padding:1rem}.lb-prev,.lb-next{width:40px;height:40px}}
@keyframes lb-fade{from{opacity:0}to{opacity:1}}

/* Product/Collection detail layout */
.product-layout{align-items:start;gap:2rem;margin:2rem 0}
.product-left{position:relative}
.product-left{max-width:720px;width:100%}
.product-hero{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
#product-main-img{width:100%;height:auto;display:block;aspect-ratio:5/6;object-fit:cover;cursor:zoom-in}
.thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-top:.6rem}
.thumb{display:block;border:1px solid var(--border);background:#fff;border-radius:10px;overflow:hidden;cursor:pointer;padding:0;aspect-ratio:1/1}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb.is-active{outline:2px solid var(--primary);outline-offset:2px}
.product-right .section-head{margin-top:0;text-align:left}
.product-right h1{margin:.25rem 0}
.product-right #product-specs h3{margin:1rem 0 .4rem}
.product-right #product-specs ul{margin:.25rem 0 .75rem 1rem}
@media(min-width:900px){.product-layout{grid-template-columns:minmax(420px,1.05fr) .95fr}}
@media(max-width:1024px){.thumbs{grid-template-columns:repeat(4,1fr)}}
@media(max-width:640px){.thumbs{grid-template-columns:repeat(3,1fr)}}
