/* =========================================================================
   Dress Cafe — Design Tokens
   Palette:  --pink (brand) / --pink-deep / --plum (evening-gown accent)
             --gold (trim/CTA accent) / --blush (soft section bg)
             --ink (text) / --cream (page bg)
   Type:     "Chonburi" — display face for headings (Thai + Latin, condensed,
             a little theatrical — echoes the province the shop is named for)
             "Prompt" — body/UI face, clean and Thai-friendly
   Signature: scalloped "hem" divider between sections + arched eyebrow text,
              both borrowed from the logo's curved tagline motif
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Chonburi&family=Prompt:wght@300;400;500;600;700&display=swap');

:root{
  --pink: #EC1E79;
  --pink-deep: #C4106A;
  --plum: #4A1030;
  --plum-soft: #6B1E45;
  --gold: #C9A227;
  --blush: #FDEDF3;
  --cream: #FFFBF8;
  --ink: #241318;
  --ink-soft: #6b5560;
  --white: #ffffff;
  --line: rgba(74,16,48,0.12);
  --shadow: 0 12px 30px rgba(74,16,48,0.10);
  --radius: 18px;
  --max-width: 1180px;
}

*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family:'Prompt', sans-serif;
  color: var(--ink);
  background: var(--cream);
  line-height:1.7;
  font-size:16px;
}
h1,h2,h3,h4{
  font-family:'Chonburi', 'Prompt', sans-serif;
  font-weight:400;
  color: var(--plum);
  line-height:1.3;
  margin: 0 0 .5em;
}
h1{ font-size: clamp(2rem, 4vw, 3.2rem); }
h2{ font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3{ font-size: 1.3rem; }
p{ margin:0 0 1em; }
a{ color: var(--pink-deep); text-decoration:none; }
a:hover{ text-decoration:underline; }
img{ max-width:100%; display:block; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family:inherit; }

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

:focus-visible{
  outline: 3px solid var(--gold);
  outline-offset: 2px;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 13px 28px;
  border-radius: 999px;
  font-weight:600;
  font-size:.98rem;
  border: 2px solid transparent;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.btn-primary{ background: var(--pink); color:#fff; box-shadow: 0 8px 20px rgba(236,30,121,.35); }
.btn-primary:hover{ background: var(--pink-deep); transform: translateY(-2px); text-decoration:none; }
.btn-outline{ background:transparent; border-color: var(--plum); color: var(--plum); }
.btn-outline:hover{ background: var(--plum); color:#fff; text-decoration:none; }
.btn-gold{ background: var(--gold); color: var(--plum); }
.btn-gold:hover{ filter: brightness(1.08); text-decoration:none; }
.btn-block{ width:100%; }
.btn-sm{ padding:8px 18px; font-size:.85rem; }

/* ---------- Eyebrow (arched-tagline echo) ---------- */
.eyebrow{
  display:inline-block;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color: var(--pink-deep);
  font-weight:600;
  margin-bottom:10px;
  position:relative;
  padding-bottom:8px;
}
.eyebrow::after{
  content:"";
  position:absolute; left:0; bottom:0;
  width:46px; height:3px; border-radius:3px;
  background: var(--gold);
}
.center .eyebrow::after{ left:50%; transform:translateX(-50%); }

/* ---------- Scalloped hem divider (signature element) ---------- */
.hem-divider{
  width:100%; height:34px; display:block;
  margin-top:-1px;
}
.hem-blush-to-cream{ color: var(--blush); background: var(--cream); }
.hem-cream-to-blush{ color: var(--cream); background: var(--blush); }
.hem-plum-to-cream{ color: var(--plum); background: var(--cream); }

/* ---------- Top utility bar ---------- */
.topbar{
  background: var(--plum);
  color:#f3e3ea;
  font-size:.82rem;
}
.topbar .container{
  display:flex; flex-wrap:wrap; gap:6px 22px;
  justify-content:space-between; align-items:center;
  padding-top:8px; padding-bottom:8px;
}
.topbar a{ color:#f3e3ea; }
.topbar .topbar-links{ display:flex; gap:18px; flex-wrap:wrap; }
.topbar .topbar-links span, .topbar .topbar-links a{ display:inline-flex; align-items:center; gap:6px; }

/* ---------- Header / Nav ---------- */
.site-header{
  background: var(--white);
  position: sticky; top:0; z-index: 50;
  box-shadow: 0 2px 14px rgba(74,16,48,.06);
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:12px; padding-bottom:12px; gap:18px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:56px; width:auto; }
.brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.brand-text strong{ font-family:'Chonburi'; color: var(--pink-deep); font-size:1.3rem; }
.brand-text span{ font-size:.72rem; color: var(--ink-soft); letter-spacing:.05em; }

.main-nav ul{ display:flex; gap:26px; align-items:center; }
.main-nav a{
  color: var(--ink); font-weight:500; font-size:.96rem;
  padding:6px 2px; border-bottom:2px solid transparent;
}
.main-nav a:hover, .main-nav a.active{ color: var(--pink-deep); border-color: var(--gold); text-decoration:none; }

.header-actions{ display:flex; align-items:center; gap:14px; }
.header-actions .cart-link{ position:relative; font-size:1.3rem; color:var(--plum); }
.cart-badge{
  position:absolute; top:-8px; right:-10px;
  background: var(--pink); color:#fff; font-size:.68rem; font-weight:700;
  border-radius:999px; min-width:18px; height:18px;
  display:flex; align-items:center; justify-content:center; padding:0 4px;
}
.nav-toggle{ display:none; background:none; border:none; font-size:1.6rem; color:var(--plum); cursor:pointer; }

@media (max-width: 900px){
  .main-nav{
    position:fixed; inset:0 0 0 auto; width:78%; max-width:320px;
    background:var(--white); box-shadow:-8px 0 30px rgba(0,0,0,.15);
    transform: translateX(100%); transition: transform .25s ease;
    padding: 90px 26px 26px; z-index:60;
  }
  .main-nav.open{ transform: translateX(0); }
  .main-nav ul{ flex-direction:column; align-items:flex-start; gap:20px; }
  .nav-toggle{ display:block; }
  .nav-overlay{ display:none; position:fixed; inset:0; background:rgba(36,19,24,.4); z-index:55; }
  .nav-overlay.open{ display:block; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  background: linear-gradient(160deg, var(--blush) 0%, #fff 55%);
  overflow:hidden;
  padding: 56px 0 80px;
}
.hero .container{
  display:grid; grid-template-columns: 1.05fr .95fr; gap:40px; align-items:center;
}
.hero-copy .eyebrow{ }
.hero-copy h1{ margin-bottom:.35em; }
.hero-copy h1 em{ font-style:normal; color: var(--pink); }
.hero-copy p{ font-size:1.08rem; color: var(--ink-soft); max-width:46ch; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:22px; }
.hero-stats{ display:flex; gap:28px; margin-top:34px; flex-wrap:wrap; }
.hero-stats div strong{ display:block; font-family:'Chonburi'; font-size:1.6rem; color:var(--plum); }
.hero-stats div span{ font-size:.82rem; color:var(--ink-soft); }

.hero-art{ position:relative; display:flex; justify-content:center; }
.hero-art svg{ width:100%; max-width:380px; }
.hero-art .arch-text{ position:absolute; top:-18px; left:50%; transform:translateX(-50%); width:120%; max-width:460px; }

/* ---------- Section shells ---------- */
.section{ padding: 70px 0; }
.section.bg-blush{ background: var(--blush); }
.section.bg-plum{ background: var(--plum); color:#f3e3ea; }
.section.bg-plum h2, .section.bg-plum h3{ color:#fff; }
.section-head{ max-width:640px; margin: 0 0 40px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head p{ color: var(--ink-soft); }
.section.bg-plum .section-head p{ color:#e6c7d6; }

/* ---------- Category chips ---------- */
.chip-row{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom:34px; }
.chip{
  padding:9px 20px; border-radius:999px; border:1.5px solid var(--line);
  font-size:.88rem; font-weight:500; color:var(--plum); background:#fff;
  transition:.15s;
}
.chip:hover, .chip.active{ background:var(--pink); border-color:var(--pink); color:#fff; text-decoration:none; }

/* ---------- Product grid / card ---------- */
.grid{ display:grid; gap:26px; }
.grid-3{ grid-template-columns: repeat(3, 1fr); }
.grid-4{ grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px){ .grid-3, .grid-4{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .grid-3, .grid-4{ grid-template-columns: 1fr; } }

.card{
  background:#fff; border-radius: var(--radius); overflow:hidden;
  box-shadow: var(--shadow); transition: transform .2s ease, box-shadow .2s ease;
  display:flex; flex-direction:column;
}
.card:hover{ transform: translateY(-6px); box-shadow: 0 18px 38px rgba(74,16,48,.16); }
.card-media{ position:relative; aspect-ratio: 3/4; overflow:hidden; background:var(--blush); }
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.card:hover .card-media img{ transform: scale(1.06); }
.card-badge{
  position:absolute; top:12px; left:12px;
  background: var(--gold); color:var(--plum); font-size:.72rem; font-weight:700;
  padding:4px 12px; border-radius:999px;
}
.card-body{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:8px; flex:1; }
.card-cat{ font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; color:var(--pink-deep); font-weight:600; }
.card-body h3{ font-size:1.08rem; margin:0; font-family:'Prompt'; font-weight:600; color:var(--ink); }
.card-price{ margin-top:auto; display:flex; align-items:baseline; justify-content:space-between; }
.card-price strong{ color:var(--pink-deep); font-size:1.15rem; }
.card-price span{ font-size:.78rem; color:var(--ink-soft); }

/* ---------- Blog cards ---------- */
.blog-card{ background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; transition:transform .2s ease; }
.blog-card:hover{ transform:translateY(-6px); text-decoration:none; }
.blog-card .card-media{ aspect-ratio:4/3; }
.blog-cat-pill{
  position:absolute; top:12px; left:12px; background:rgba(36,19,24,.72); color:#fff;
  font-size:.7rem; padding:5px 12px; border-radius:999px; letter-spacing:.03em;
}
.blog-card .card-body h3{ font-size:1.15rem; color:var(--plum); }
.blog-card .card-body p{ color:var(--ink-soft); font-size:.92rem; margin-bottom:0; }
.blog-meta{ display:flex; gap:14px; font-size:.78rem; color:var(--ink-soft); margin-top:6px; flex-wrap:wrap; }

.blog-hero-featured{ display:grid; grid-template-columns: 1.3fr 1fr; gap:26px; margin-bottom:40px; }
@media (max-width: 860px){ .blog-hero-featured{ grid-template-columns:1fr; } }
.blog-hero-featured .card-media{ aspect-ratio:16/10; border-radius:var(--radius); }
.blog-side-list{ display:flex; flex-direction:column; gap:16px; }
.blog-side-item{ display:flex; gap:14px; align-items:center; background:#fff; border-radius:14px; padding:10px; box-shadow:var(--shadow); }
.blog-side-item img{ width:84px; height:84px; object-fit:cover; border-radius:10px; flex-shrink:0; }
.blog-side-item h4{ font-family:'Prompt'; font-size:.95rem; margin:0 0 4px; color:var(--plum); font-weight:600; }
.blog-side-item span{ font-size:.75rem; color:var(--ink-soft); }

/* ---------- Product detail ---------- */
.pd-wrap{ display:grid; grid-template-columns: 1fr 1fr; gap:50px; align-items:flex-start; }
@media (max-width: 900px){ .pd-wrap{ grid-template-columns:1fr; gap:30px; } }

.pd-gallery-main{ border-radius: var(--radius); overflow:hidden; aspect-ratio:3/4; background:var(--blush); box-shadow:var(--shadow); }
.pd-gallery-main img{ width:100%; height:100%; object-fit:cover; }
.pd-thumbs{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pd-thumbs img{
  width:74px; height:74px; object-fit:cover; border-radius:10px; cursor:pointer;
  border:2px solid transparent; opacity:.75;
}
.pd-thumbs img:hover, .pd-thumbs img.active{ border-color: var(--pink); opacity:1; }

.pd-info .eyebrow{ margin-bottom:4px; }
.pd-info h1{ font-size:1.9rem; margin-bottom:6px; }
.pd-price-row{ display:flex; align-items:baseline; gap:12px; margin:14px 0 22px; }
.pd-price-row .price{ font-size:1.7rem; color:var(--pink-deep); font-weight:700; font-family:'Chonburi'; }
.pd-price-row .unit{ color:var(--ink-soft); font-size:.9rem; }

.field-group{ margin-bottom:20px; }
.field-group label{ display:block; font-weight:600; font-size:.9rem; margin-bottom:8px; color:var(--plum); }
.swatches{ display:flex; gap:10px; flex-wrap:wrap; }
.swatch{
  width:38px; height:38px; border-radius:50%; border:2px solid var(--line); cursor:pointer;
  position:relative;
}
.swatch input{ position:absolute; inset:0; opacity:0; cursor:pointer; margin:0; }
.swatch.selected{ outline:3px solid var(--gold); outline-offset:2px; }
.size-row{ display:flex; gap:10px; flex-wrap:wrap; }
.size-pill{ position:relative; }
.size-pill input{ position:absolute; inset:0; opacity:0; cursor:pointer; margin:0; }
.size-pill span{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:48px; height:44px; padding:0 14px; border-radius:10px;
  border:1.5px solid var(--line); font-weight:600; color:var(--plum); background:#fff;
}
.size-pill input:checked + span{ background:var(--plum); border-color:var(--plum); color:#fff; }

.date-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:480px){ .date-row{ grid-template-columns:1fr; } }
input[type=date], input[type=text], input[type=tel], input[type=email], textarea, select{
  width:100%; padding:12px 14px; border-radius:10px; border:1.5px solid var(--line);
  font-family:'Prompt'; font-size:.96rem; background:#fff; color:var(--ink);
}
textarea{ resize:vertical; min-height:110px; }
input:focus, textarea:focus, select:focus{ outline:none; border-color: var(--pink); box-shadow:0 0 0 3px rgba(236,30,121,.14); }

.price-breakdown{
  background: var(--blush); border-radius:14px; padding:16px 18px; margin: 22px 0;
  font-size:.92rem;
}
.price-breakdown .row{ display:flex; justify-content:space-between; padding:5px 0; }
.price-breakdown .row.total{ border-top:1.5px dashed var(--line); margin-top:8px; padding-top:10px; font-weight:700; color:var(--pink-deep); font-size:1.05rem; }
.rental-note{ font-size:.82rem; color:var(--ink-soft); background:#fff; border:1px dashed var(--line); border-radius:10px; padding:10px 14px; margin-top:10px;}

.pd-tabs-nav{ display:flex; gap:6px; border-bottom:1.5px solid var(--line); margin: 50px 0 20px; }
.pd-tabs-nav button{
  background:none; border:none; padding:12px 20px; font-weight:600; color:var(--ink-soft);
  border-bottom:3px solid transparent; cursor:pointer; font-size:.96rem;
}
.pd-tabs-nav button.active{ color:var(--pink-deep); border-color:var(--pink); }
.pd-tab-panel{ display:none; color:var(--ink-soft); }
.pd-tab-panel.active{ display:block; }

/* ---------- Cart ---------- */
.cart-table{ width:100%; border-collapse:collapse; }
.cart-table th{ text-align:left; font-size:.8rem; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); padding:10px 8px; border-bottom:2px solid var(--line); }
.cart-table td{ padding:14px 8px; border-bottom:1px solid var(--line); vertical-align:middle; }
.cart-item{ display:flex; gap:12px; align-items:center; }
.cart-item img{ width:64px; height:80px; object-fit:cover; border-radius:8px; }
.cart-item-meta{ font-size:.82rem; color:var(--ink-soft); }
.remove-link{ color:#b23a48; font-size:.85rem; }
.cart-summary{ background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); padding:24px; }

.empty-state{ text-align:center; padding:70px 20px; color:var(--ink-soft); }
.empty-state .icon{ font-size:3rem; margin-bottom:14px; }

/* ---------- Forms / contact ---------- */
.form-card{ background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); padding:34px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:640px){ .form-grid{ grid-template-columns:1fr; } }
.form-grid .full{ grid-column: 1 / -1; }

.info-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px; }
@media (max-width:780px){ .info-strip{ grid-template-columns:1fr; } }
.info-box{ background:#fff; border-radius:16px; padding:24px; box-shadow:var(--shadow); }
.info-box .ic{ font-size:1.6rem; color:var(--pink); margin-bottom:10px; }
.info-box h4{ font-family:'Prompt'; font-weight:600; color:var(--plum); margin-bottom:6px; }
.info-box p{ color:var(--ink-soft); font-size:.92rem; margin:0; }

.map-embed{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:0; width:100%; height:380px; }

/* ---------- Steps / process (about page) ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
@media (max-width:900px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } }
.step{ text-align:center; }
.step .num{
  width:56px; height:56px; border-radius:50%; background:var(--blush); color:var(--pink-deep);
  display:flex; align-items:center; justify-content:center; margin:0 auto 14px; font-family:'Chonburi'; font-size:1.2rem;
}
.step h4{ font-family:'Prompt'; font-weight:600; color:var(--plum); margin-bottom:6px; }
.step p{ font-size:.88rem; color:var(--ink-soft); }

/* ---------- Testimonials ---------- */
.testimonial{ background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); padding:26px; }
.testimonial .stars{ color:var(--gold); margin-bottom:10px; letter-spacing:2px; }
.testimonial p{ color:var(--ink-soft); font-style:italic; }
.testimonial .who{ font-weight:600; color:var(--plum); font-style:normal; margin-top:12px; }

/* ---------- Footer ---------- */
.site-footer{ background: var(--plum); color:#e6c7d6; padding: 56px 0 26px; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap:36px; }
@media (max-width:820px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.site-footer h4{ color:#fff; font-family:'Prompt'; font-weight:600; font-size:1rem; margin-bottom:16px; }
.site-footer a{ color:#e6c7d6; }
.site-footer a:hover{ color:#fff; }
.footer-brand img{ height:46px; margin-bottom:12px; }
.footer-brand p{ font-size:.88rem; color:#d9b3c4; }
.footer-links li{ margin-bottom:10px; font-size:.92rem; }
.social-row{ display:flex; gap:12px; margin-top:14px; }
.social-row a{ width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.15); margin-top:40px; padding-top:20px; text-align:center; font-size:.82rem; color:#c99cb2; }

/* ---------- Alerts ---------- */
.alert{ padding:14px 18px; border-radius:12px; margin-bottom:20px; font-size:.92rem; }
.alert-success{ background:#e5f6ea; color:#276b3a; }
.alert-error{ background:#fde6ea; color:#a12242; }

/* ---------- Breadcrumb ---------- */
.breadcrumb{ font-size:.85rem; color:var(--ink-soft); margin-bottom:20px; }
.breadcrumb a{ color:var(--ink-soft); }
.breadcrumb .sep{ margin:0 6px; }

/* ---------- Pagination ---------- */
.pagination{ display:flex; gap:8px; justify-content:center; margin-top:36px; }
.pagination a, .pagination span{ width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; background:#fff; box-shadow:var(--shadow); color:var(--plum); font-weight:600; }
.pagination .current{ background:var(--pink); color:#fff; }

/* ---------- Filter sidebar (blog + products) ---------- */
.layout-with-sidebar{ display:grid; grid-template-columns: 260px 1fr; gap:36px; align-items:flex-start; }
@media (max-width:860px){ .layout-with-sidebar{ grid-template-columns:1fr; } }
.filter-box{ background:#fff; border-radius:16px; box-shadow:var(--shadow); padding:22px; }
.filter-box h4{ font-family:'Prompt'; font-weight:600; color:var(--plum); margin-bottom:14px; font-size:.95rem; }
.filter-box ul li{ margin-bottom:10px; }
.filter-box ul a{ color:var(--ink-soft); font-size:.92rem; display:flex; justify-content:space-between; }
.filter-box ul a:hover, .filter-box ul a.active{ color:var(--pink-deep); text-decoration:none; }

/* ---------- Utility ---------- */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.flex-between{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.tag-row{ display:flex; gap:8px; flex-wrap:wrap; }
.tag{ font-size:.76rem; background:var(--blush); color:var(--pink-deep); padding:5px 12px; border-radius:999px; font-weight:600; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}
