/* ============================================
   VINTAGEGIRL — Bridal Boutique
   Minimal, elegant, monochrome + warm accent
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Open+Sans:wght@300;400;600;700;800&display=swap');

:root {
  --color-bg: #ffffff;
  --color-bg-alt: #f8f7f5;
  --color-bg-dark: #1a1a1a;
  --color-text: #222222;
  --color-text-light: #777777;
  --color-text-muted: #999999;
  --color-white: #ffffff;
  --color-black: #000000;
  --color-border: #e8e8e8;
  --color-accent: #c9a96e;
  --color-accent-dark: #b08d52;
  --color-accent-light: #f5f0e6;

  --font-heading: 'Cormorant Garamond', 'Palatino', Georgia, serif;
  --font-body: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;

  --container: 1100px;
  --header-h: 80px;

  --radius-sm: 2px;
  --radius-md: 4px;

  --shadow-sm: 0 1px 4px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.08);
  --shadow-lg: 0 10px 40px rgba(0,0,0,0.1);

  --sp-xs: 4px; --sp-sm: 8px; --sp-md: 16px; --sp-lg: 24px; --sp-xl: 48px; --sp-2xl: 80px;
  --transition: 0.3s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-body); font-weight:400; font-size:14px; color:var(--color-text); background:var(--color-bg); line-height:1.7; overflow-x:hidden; }
body.menu-open { overflow:hidden; }
a { text-decoration:none; color:inherit; transition:color var(--transition); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
button { border:none; background:none; cursor:pointer; font-family:inherit; }
:focus-visible { outline:2px solid var(--color-accent); outline-offset:2px; }

.container { max-width:var(--container); margin:0 auto; padding:0 var(--sp-lg); }

/* ── Buttons ── */
.btn { display:inline-block; padding:13px 32px; font-family:var(--font-body); font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; transition:all var(--transition); cursor:pointer; }
.btn--dark { background:var(--color-black); color:var(--color-white); }
.btn--dark:hover { background:var(--color-accent-dark); }
.btn--outline { border:1px solid var(--color-black); color:var(--color-black); background:transparent; }
.btn--outline:hover { background:var(--color-black); color:var(--color-white); }
.btn--accent { background:var(--color-accent); color:var(--color-white); }
.btn--accent:hover { background:var(--color-accent-dark); }

/* ── Typography ── */
.heading-serif { font-family:var(--font-heading); font-weight:400; line-height:1.2; }
.text-center { text-align:center; }
.text-upper { text-transform:uppercase; letter-spacing:3px; }

/* ── Sections ── */
.section { padding:var(--sp-2xl) 0; }
.section--alt { background:var(--color-bg-alt); }
.section--dark { background:var(--color-bg-dark); color:var(--color-white); }
.section__header { text-align:center; margin-bottom:var(--sp-xl); }
.section__label { font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--color-accent); margin-bottom:var(--sp-sm); display:block; }
.section__title { font-family:var(--font-heading); font-weight:400; font-size:clamp(1.8rem,4vw,2.8rem); color:var(--color-text); }
.section--dark .section__title { color:var(--color-white); }
.section__subtitle { font-size:15px; color:var(--color-text-light); margin-top:var(--sp-sm); max-width:600px; margin-left:auto; margin-right:auto; }

/* ── Animations ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.6s ease,transform 0.6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1{transition-delay:.1s} .reveal-d2{transition-delay:.2s} .reveal-d3{transition-delay:.3s}

/* ============================================
   HEADER
   ============================================ */
.header { height:var(--header-h); border-bottom:1px solid var(--color-border); position:sticky; top:0; z-index:50; background:rgba(255,255,255,0.98); backdrop-filter:blur(6px); }
.header__inner { display:flex; align-items:center; height:100%; }
.logo { margin-right:auto; }
.logo__text { font-family:var(--font-heading); font-size:1.6rem; font-weight:400; letter-spacing:2px; color:var(--color-text); }
.logo__sub { display:block; font-family:var(--font-body); font-size:9px; font-weight:400; letter-spacing:2px; text-transform:uppercase; color:var(--color-text-muted); margin-top:-2px; }

.nav { display:flex; gap:0; align-items:center; }
.nav__item { position:relative; }
.nav__link { display:flex; align-items:center; gap:4px; padding:0 14px; height:var(--header-h); font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--color-text); transition:color var(--transition); }
.nav__link:hover { color:var(--color-accent); }
.nav__arrow { width:8px; height:5px; opacity:0.4; }
/* Dropdown */
.nav__drop { position:absolute; top:100%; left:0; min-width:200px; background:var(--color-white); box-shadow:var(--shadow-md); border-top:2px solid var(--color-accent); opacity:0; visibility:hidden; transform:translateY(-6px); transition:all 0.25s ease; z-index:60; padding:var(--sp-sm) 0; }
.nav__item:hover .nav__drop, .nav__item:focus-within .nav__drop { opacity:1; visibility:visible; transform:translateY(0); }
.nav__drop a { display:block; padding:8px 20px; font-size:12px; font-weight:400; letter-spacing:1px; color:var(--color-text); transition:all var(--transition); }
.nav__drop a:hover { color:var(--color-accent); padding-left:24px; }

.header__cta { margin-left:var(--sp-md); }

/* Burger */
.burger { display:none; width:44px; height:44px; flex-direction:column; justify-content:center; gap:6px; padding:10px; margin-left:auto; z-index:60; }
.burger__line { width:100%; height:1.5px; background:var(--color-text); transition:all 0.3s ease; }
.burger.active .burger__line:nth-child(1){transform:rotate(45deg) translate(5px,5.5px)} .burger.active .burger__line:nth-child(2){opacity:0} .burger.active .burger__line:nth-child(3){transform:rotate(-45deg) translate(5px,-5.5px)}

/* Mobile */
.mobile-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.4); z-index:70; opacity:0; visibility:hidden; transition:all var(--transition); }
.mobile-overlay.active { opacity:1; visibility:visible; }
.mobile-menu { position:fixed; top:0; right:-320px; width:300px; max-width:85vw; height:100vh; background:var(--color-white); z-index:80; overflow-y:auto; transition:right var(--transition); display:flex; flex-direction:column; }
.mobile-menu.active { right:0; }
.mobile-menu__head { display:flex; align-items:center; justify-content:space-between; padding:var(--sp-lg); border-bottom:1px solid var(--color-border); }
.mobile-menu__title { font-family:var(--font-heading); font-size:1.3rem; }
.mobile-menu__close { width:36px; height:36px; display:flex; align-items:center; justify-content:center; color:var(--color-text-light); }
.mobile-menu__close svg { width:18px; height:18px; }
.mobile-menu__list { flex:1; padding:var(--sp-md) 0; }
.mobile-menu__link { display:block; padding:12px var(--sp-lg); font-size:12px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--color-text); border-bottom:1px solid var(--color-border); transition:color var(--transition); }
.mobile-menu__link:hover { color:var(--color-accent); }

/* ============================================
   HERO
   ============================================ */
.hero { padding:var(--sp-2xl) 0; text-align:center; background:var(--color-bg-alt); }
.hero__title { font-family:var(--font-heading); font-weight:300; font-size:clamp(2.2rem,5vw,3.8rem); color:var(--color-text); line-height:1.15; margin-bottom:var(--sp-md); letter-spacing:1px; animation:fadeUp 0.7s ease both; }
.hero__subtitle { font-size:15px; color:var(--color-text-light); max-width:520px; margin:0 auto var(--sp-lg); line-height:1.8; animation:fadeUp 0.7s 0.15s ease both; }
.hero__actions { display:flex; gap:var(--sp-md); justify-content:center; flex-wrap:wrap; animation:fadeUp 0.7s 0.25s ease both; }

/* ============================================
   SIZE GRID (dress categories)
   ============================================ */
.sizes-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-md); }
.size-card { background:var(--color-white); border:1px solid var(--color-border); text-align:center; padding:var(--sp-xl) var(--sp-lg); transition:all var(--transition); }
.size-card:hover { box-shadow:var(--shadow-md); border-color:var(--color-accent); transform:translateY(-4px); }
.size-card__title { font-family:var(--font-heading); font-size:1.5rem; color:var(--color-text); margin-bottom:var(--sp-xs); }
.size-card__sub { font-size:11px; color:var(--color-text-muted); letter-spacing:2px; text-transform:uppercase; }

/* ============================================
   FEATURES / BENEFITS
   ============================================ */
.features-list { max-width:700px; margin:0 auto; }
.features-list li { padding:var(--sp-md) 0; border-bottom:1px solid var(--color-border); font-size:14px; color:var(--color-text-light); display:flex; align-items:baseline; gap:var(--sp-sm); line-height:1.6; }
.features-list li::before { content:'✓'; color:var(--color-accent); font-weight:700; flex-shrink:0; }

/* ============================================
   ACCESSORIES GRID
   ============================================ */
.acc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-md); }
.acc-card { position:relative; aspect-ratio:1; background:var(--color-bg-alt); border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; overflow:hidden; transition:all var(--transition); }
.acc-card:hover { border-color:var(--color-accent); }
.acc-card__label { font-family:var(--font-heading); font-size:1.3rem; color:var(--color-text); z-index:2; text-align:center; padding:var(--sp-md); }

/* ============================================
   BRANDS
   ============================================ */
.brands-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-lg); text-align:center; }
.brand-card { padding:var(--sp-lg); border:1px solid var(--color-border); transition:all var(--transition); }
.brand-card:hover { border-color:var(--color-accent); box-shadow:var(--shadow-sm); }
.brand-card__name { font-family:var(--font-heading); font-size:1.2rem; margin-bottom:var(--sp-xs); }
.brand-card__info { font-size:12px; color:var(--color-text-muted); }

/* ============================================
   ABOUT / TEXT SECTIONS
   ============================================ */
.text-block { max-width:700px; margin:0 auto; }
.text-block h2 { font-family:var(--font-heading); font-weight:400; font-size:clamp(1.5rem,3vw,2.2rem); margin-bottom:var(--sp-lg); }
.text-block p { font-size:14px; color:var(--color-text-light); line-height:1.8; margin-bottom:var(--sp-md); }
.text-block strong { color:var(--color-text); font-weight:700; }

/* ============================================
   CONTACT FORM
   ============================================ */
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:var(--sp-xl); }
.contact-info h3 { font-family:var(--font-heading); font-size:1.5rem; margin-bottom:var(--sp-lg); }
.contact-detail { margin-bottom:var(--sp-md); font-size:13px; color:var(--color-text-light); line-height:1.6; }
.contact-detail strong { color:var(--color-text); display:block; font-size:11px; letter-spacing:2px; text-transform:uppercase; margin-bottom:var(--sp-xs); }
.contact-form .form-group { margin-bottom:var(--sp-md); }
.contact-form label { display:block; font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--color-text-light); margin-bottom:var(--sp-xs); }
.contact-form input,.contact-form textarea { width:100%; padding:12px 14px; border:1px solid var(--color-border); font-family:var(--font-body); font-size:13px; color:var(--color-text); transition:border-color var(--transition); }
.contact-form input:focus,.contact-form textarea:focus { border-color:var(--color-accent); outline:none; }
.contact-form textarea { min-height:120px; resize:vertical; }

/* ============================================
   BLOG
   ============================================ */
.blog-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--sp-lg); }
.blog-card { border:1px solid var(--color-border); padding:var(--sp-lg); transition:all var(--transition); }
.blog-card:hover { box-shadow:var(--shadow-sm); border-color:var(--color-accent); }
.blog-card__date { font-size:11px; color:var(--color-text-muted); letter-spacing:1px; text-transform:uppercase; }
.blog-card__title { font-family:var(--font-heading); font-size:1.3rem; margin:var(--sp-sm) 0; }
.blog-card__excerpt { font-size:13px; color:var(--color-text-light); line-height:1.7; }

/* ============================================
   FOOTER
   ============================================ */
.footer { background:var(--color-bg-dark); color:rgba(255,255,255,0.6); padding:var(--sp-xl) 0; font-size:12px; }
.footer__inner { display:grid; grid-template-columns:1fr 1fr 1fr; gap:var(--sp-xl); }
.footer h4 { color:var(--color-white); font-family:var(--font-body); font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; margin-bottom:var(--sp-md); }
.footer p { line-height:1.8; }
.footer a { color:rgba(255,255,255,0.6); transition:color var(--transition); }
.footer a:hover { color:var(--color-accent); }
.footer__links a { display:block; padding:3px 0; }
.footer__bottom { margin-top:var(--sp-xl); padding-top:var(--sp-lg); border-top:1px solid rgba(255,255,255,0.08); display:flex; justify-content:space-between; align-items:center; font-size:11px; letter-spacing:1px; }
.footer__socials { display:flex; gap:var(--sp-sm); }
.footer__socials a { width:30px; height:30px; border:1px solid rgba(255,255,255,0.15); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.5); transition:all var(--transition); }
.footer__socials a:hover { border-color:var(--color-accent); color:var(--color-accent); }
.footer__socials svg { width:13px; height:13px; }

/* ── Page hero (subpages) ── */
.page-hero { padding:var(--sp-2xl) 0 var(--sp-xl); background:var(--color-bg-alt); text-align:center; border-bottom:1px solid var(--color-border); }
.page-hero h1 { font-family:var(--font-heading); font-weight:300; font-size:clamp(1.8rem,4vw,2.8rem); letter-spacing:1px; margin-bottom:var(--sp-sm); }
.page-hero p { font-size:14px; color:var(--color-text-light); }

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .sizes-grid,.acc-grid{grid-template-columns:repeat(2,1fr)}
  .brands-grid{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav,.header__cta{display:none}
  .burger{display:flex}
  .sizes-grid{grid-template-columns:1fr 1fr}
  .acc-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;gap:var(--sp-md);text-align:center}
}
@media(max-width:480px){
  .container{padding:0 var(--sp-md)}
  .sizes-grid,.acc-grid,.brands-grid{grid-template-columns:1fr}
  .hero__actions{flex-direction:column;align-items:center}
}
