/* =========================================================
   Brishti's Beauty Parlour — Brand CSS (Dark + Orange)
   Primary: #F05F40 | Secondary: #FF8A65 | WhatsApp: #25D366
   ========================================================= */

/* ========== Base / Tokens ========== */
:root{
  --bg:#0b0d10; --panel:#11151a; --muted:#9aa4b2; --text:#e9eef5;
  --brand:#F05F40; --brand-2:#FF8A65; --whatsapp:#25D366;
  --ring:rgba(240,95,64,.35); --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:16px; --radius-lg:22px; --maxw:1360px;
}
@media (min-width:1200px){ :root{ --maxw:1440px; } }
@media (min-width:1536px){ :root{ --maxw:1560px; } }

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:radial-gradient(1200px 600px at 100% -10%, rgba(240,95,64,.12), transparent 60%), #0a0c0f;
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3{ font-family:"Merriweather",Georgia,serif; line-height:1.2; margin:0 0 .6rem; }
p{ margin:0 0 1rem; }
a{ color:var(--text); text-decoration:none; transition:.18s ease; }
a:hover{ color:#fff; }
img{ max-width:100%; display:block; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding:0 20px; }
@media (min-width:1200px){ .container{ padding:0 28px; } }

.section{ padding:64px 0; }
.section.alt{ background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)); }

/* Accessibility */
.skip-link{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus{
  left:10px; top:10px; width:auto; height:auto; background:#000; color:#fff;
  padding:8px 12px; border-radius:8px;
}

/* ========== Header / Nav ========== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,12,15,.6);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-wrap{
  display:flex; gap:16px; align-items:center; justify-content:space-between;
  height:64px; max-width:var(--maxw); margin:0 auto; padding:0 20px;
}
@media (min-width:1200px){ .nav-wrap{ padding:0 28px; } }

.logo{ display:flex; align-items:center; gap:12px; font-weight:700; letter-spacing:.2px; color:var(--text); }
.logo-image{ display:block; height:clamp(32px,5vw,48px); width:auto; }
.logo-text{ white-space:nowrap; }

.nav{ display:flex; gap:18px; align-items:center; }
.nav a{ opacity:.9; }
.nav a:hover{ opacity:1; color:var(--brand); }

/* ========== Buttons ========== */
.btn{
  display:inline-block; border-radius:999px; padding:10px 18px; font-weight:600;
  background:linear-gradient(145deg, var(--brand), var(--brand-2));
  color:#fff; box-shadow:var(--shadow); border:1px solid rgba(255,255,255,.08);
  transition:transform .18s ease, filter .18s ease, box-shadow .18s ease;
}
.btn:hover{ transform:translateY(-1px); filter:brightness(1.02); }
.btn:focus{ outline:none; box-shadow:0 0 0 4px var(--ring); }
.btn-sm{ padding:8px 14px; font-size:.95rem; }

.btn-ghost{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,.18); box-shadow:none; }
.btn-ghost:hover{ background:rgba(255,255,255,.06); }

.btn-call{ background:linear-gradient(145deg, var(--brand), #e44927); border-color:transparent; color:#fff; }
.btn-call .fa{ margin-right:8px; }

.btn-whatsapp{ background:var(--whatsapp); border-color:var(--whatsapp); color:#fff; }
.btn-whatsapp:hover{ filter:brightness(1.05); }

/* Mobile menu */
#nav-toggle{ display:none; }
.hamburger{ display:none; cursor:pointer; width:32px; height:22px; position:relative; }
.hamburger span{
  position:absolute; left:0; right:0; height:3px; background:#fff; border-radius:3px; transition:.2s;
}
.hamburger span:nth-child(1){ top:0; }
.hamburger span:nth-child(2){ top:9px; }
.hamburger span:nth-child(3){ bottom:0; }

@media (max-width:860px){
  .hamburger{ display:block; }
  .nav{
    position:absolute; right:20px; top:64px; padding:14px; border-radius:12px;
    background:rgba(14,16,20,.98); border:1px solid rgba(255,255,255,.08);
    box-shadow:var(--shadow); display:none; flex-direction:column; min-width:200px;
  }
  #nav-toggle:checked ~ .hamburger span:nth-child(1){ transform:translateY(9px) rotate(45deg); }
  #nav-toggle:checked ~ .hamburger span:nth-child(2){ opacity:0; }
  #nav-toggle:checked ~ .hamburger span:nth-child(3){ transform:translateY(-9px) rotate(-45deg); }
  #nav-toggle:checked ~ .nav{ display:flex; }
}

/* ========== Hero ========== */
.hero{ padding:88px 0 56px; }
.hero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:32px; align-items:center; }
.hero-text .lead{ color:var(--muted); font-size:1.1rem; }
.actions{ display:flex; gap:12px; margin:16px 0 12px; flex-wrap:wrap; }
.trust{ list-style:none; padding:0; margin:8px 0 0; display:flex; gap:16px; flex-wrap:wrap; color:#cdd6e0; }
.accent{ color:var(--brand-2); }
.hero-card{
  border-radius:var(--radius-lg);
  padding:10px; background:linear-gradient(145deg, rgba(240,95,64,.22), rgba(255,255,255,.06));
  box-shadow:var(--shadow); min-height:300px;
}
.hero-art{
  height:100%; border-radius:calc(var(--radius-lg) - 8px);
  background:
    radial-gradient(200px 200px at 20% 20%, rgba(240,95,64,.35), transparent 60%),
    radial-gradient(300px 300px at 80% 80%, rgba(255,138,101,.25), transparent 60%),
    linear-gradient(160deg, #10141a, #0c1015 70%);
}
@media (max-width:920px){ .hero-grid{ grid-template-columns:1fr; } }

/* ========== Cards / Grids ========== */
.grid{ display:grid; gap:18px; }
.cards{ grid-template-columns:repeat(4,1fr); }
.card{
  background:var(--panel); border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius); padding:18px;
}
.card h3{ margin-bottom:6px; }
.card p{ color:var(--muted); }
.card img{ width:100%; height:200px; object-fit:cover; border-radius:var(--radius); margin-bottom:12px; }
@media (max-width:1000px){ .cards{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:720px){ .cards{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .cards{ grid-template-columns:1fr; } }

/* ========== Pricing ========== */
.price-grid{ display:grid; gap:18px; grid-template-columns:repeat(3,1fr); }
.price-card{ background:var(--panel); border:1px solid rgba(255,255,255,.06); border-radius:var(--radius); padding:18px; }
.price-card h3{ margin-bottom:8px; }
.price-card ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.price-card li{ display:flex; justify-content:space-between; gap:10px; color:#d7dfeb; }
.price-card li span{ color:var(--muted); }
.note{ color:var(--muted); margin-top:10px; }
@media (max-width:900px){ .price-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .price-grid{ grid-template-columns:1fr; } }

/* ========== About ========== */
.about-grid{ display:grid; grid-template-columns:1fr .9fr; gap:22px; align-items:center; }
.list-check{ list-style:none; padding:0; display:grid; gap:8px; }
.list-check li::before{ content:"✔"; color:var(--brand-2); margin-right:8px; }
.about-art{
  min-height:220px; border-radius:var(--radius);
  background:
    radial-gradient(180px 180px at 80% 20%, rgba(255,138,101,.25), transparent 60%),
    linear-gradient(160deg, #0d1116, #0a0d12 70%);
  border:1px solid rgba(255,255,255,.06);
}
@media (max-width:900px){ .about-grid{ grid-template-columns:1fr; } }

/* ========== Reviews ========== */
.reviews{ display:grid; gap:16px; grid-template-columns:1fr 1fr; }
blockquote{
  margin:0; padding:16px 18px; border-left:3px solid var(--brand);
  background:var(--panel); border-radius:var(--radius);
}
cite{ display:block; margin-top:8px; color:var(--muted); font-style:normal; }
@media (max-width:720px){ .reviews{ grid-template-columns:1fr; } }

/* ========== Contact (Buttons + Address) ========== */
.contact-wrap{
  background:linear-gradient(145deg, rgba(240,95,64,.12), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius); padding:24px;
}
.contact-actions{ display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin:6px 0 12px; }
.address{ text-align:center; color:#d7dfeb; margin-top:10px; }
.address .fa{ color:var(--brand); margin-right:6px; }
.map-wrap{ margin-top:14px; border-radius:16px; overflow:hidden; border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow); }
.map-wrap iframe{ width:100%; height:260px; display:block; }

/* ========== Footer ========== */
.site-footer{ border-top:1px solid rgba(255,255,255,.06); padding:20px 0; margin-top:40px; background:rgba(10,12,15,.6); }
.foot-grid{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.hours{ color:var(--muted); }

/* ========== Utilities ========== */
.section-title{ font-size:clamp(1.6rem, 1.1rem + 1.8vw, 2.1rem); margin-bottom:18px; }
.lead{ font-size:1.08rem; }
::selection{ background:var(--brand); color:#fff; }
::-moz-selection{ background:var(--brand); color:#fff; }

/* ========== BLOG PAGE ========== */
.blog-hero{ padding:92px 0 56px; background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)); text-align:center; }
.blog-hero h1{ margin-bottom:10px; }
.blog-hero p{ color:var(--muted); max-width:720px; margin:0 auto; }

.year-archives{ margin:14px 0 22px; }
.year-archives .btn-ghost{
  padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.18);
  color:#fff; text-decoration:none; margin:0 8px 8px 0; display:inline-block; font-size:.9rem;
}
.year-archives .btn-ghost:hover{ background:rgba(255,255,255,.06); }

.list-wrap{ max-width:var(--maxw); margin-inline:auto; padding:0 20px; }
@media (min-width:1200px){ .list-wrap{ padding:0 28px; } }

.post{
  background:var(--panel); border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius); padding:18px; margin-bottom:18px;
}
.post h2{ margin:0 0 6px; font-size:1.35rem; }
.post h2 a{ color:#fff; text-decoration:none; }
.post h2 a:hover{ color:var(--brand); }
.meta{ color:#cfd7e3; font-size:.92rem; margin-bottom:8px; }
.post p{ color:var(--muted); margin:0 0 12px; }

/* "Read more" pill on cards */
.read-more{
  display:inline-block; padding:8px 14px; border-radius:999px; font-weight:600;
  background:linear-gradient(145deg, var(--brand), var(--brand-2));
  color:#fff; text-decoration:none; box-shadow:var(--shadow);
  transition:transform .18s ease, filter .18s ease, box-shadow .18s ease;
}
.read-more:hover{ filter:brightness(1.05); transform:translateY(-1px); }
.read-more:focus{ outline:none; box-shadow:0 0 0 4px var(--ring); }

/* Blog search */
.search-wrap{ max-width:var(--maxw); margin:0 auto 16px; padding:0 20px; }
@media (min-width:1200px){ .search-wrap{ padding:0 28px; } }
.search{
  display:flex; gap:8px; align-items:center; justify-content:center; flex-wrap:wrap;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:10px;
}
.search input{
  width:100%; max-width:560px; padding:10px 12px; border-radius:10px; border:1px solid rgba(255,255,255,.14);
  background:#0c1015; color:#fff; outline:none;
}
.search input:focus{ border-color:var(--brand-2); box-shadow:0 0 0 4px rgba(240,95,64,.25); }
.search .btn-clear{
  background:transparent; border:1px solid rgba(255,255,255,.18); color:#fff; border-radius:999px; padding:8px 12px; cursor:pointer;
}
.tip{ color:#9aa4b2; font-size:.85rem; margin-top:6px; text-align:center; }

/* No results */
.no-results{
  display:none; padding:16px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:12px; margin:16px auto 0; max-width:var(--maxw);
}
.no-results button{ background:none; border:none; color:var(--brand); font-weight:700; cursor:pointer; }

/* CTA footer (blog) */
.cta{
  background:linear-gradient(145deg, rgba(240,95,64,.12), rgba(255,255,255,.03));
  border-top:1px solid rgba(255,255,255,.08); padding:36px 0; text-align:center; margin-top:36px;
}
.btn-xl{ padding:12px 22px; border-radius:999px; font-weight:700; text-decoration:none; }
.btn-brand{ background:linear-gradient(145deg, var(--brand), var(--brand-2)); color:#fff; }
.btn-brand:hover{ filter:brightness(1.05); }

/* Post figure (centered + spacing) */
.post-figure{ margin:16px 0 22px; text-align:center; }
.post-figure img{ display:block; max-width:100%; height:auto; margin:0 auto; }

/* Post CTA buttons (centered) */
.post-cta{ text-align:center; }
.post-cta .btn{ margin:4px 6px; }

/* CTA footer section (center align) */
#contact-footer-post .contact-wrap{ text-align:center; }
#contact-footer-post .contact-wrap h2{ margin-bottom:18px; }
#contact-footer-post .contact-wrap a.btn{ display:inline-block; margin:0 auto; }

/* FAQ boxed styling */
.faq details{
  border:1px solid rgba(255,255,255,.1); border-radius:8px;
  padding:12px 14px; margin:10px 0;
}
.faq details summary{ cursor:pointer; font-weight:600; outline:none; }

/* Section tweak */
.section--no-top{ padding-top:0; }

/* ===== Breadcrumbs (explicit <li class="breadcrumb-sep">) ===== */
.breadcrumb-nav{ margin:24px 0; } /* adjust if sticky header overlaps */
.breadcrumb-clean{
  list-style:none; padding:0; margin:0;
  display:flex; flex-wrap:wrap; align-items:center;
}
.breadcrumb-clean li{ display:inline; }
.breadcrumb-sep{ display:inline; margin:0 6px; color:#aaa; line-height:1; }

/* 404 hero background */
.hero-404{
  background: url('/img/brishti-beauty-parlour-scarborough-header.jpg') center/cover no-repeat;
}

