/* Au Flamboyant — lean static rebuild */
:root{
  --bg:#fffdfb; --panel:#fbf4ef; --ink:#2e2a28; --muted:#7c736d;
  --accent:#b23a48; --accent-dark:#8f2c39; --line:#ece2da;
  --maxw:1160px; --radius:10px;
  --serif:Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-dark)}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.2;margin:0 0 .4em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:64px 0}
.section.alt{background:var(--panel)}
.section-head{text-align:center;max-width:680px;margin:0 auto 38px}
.section-head h2{font-size:2rem;margin-bottom:.2em}
.section-head .sub{color:var(--muted);font-size:1.05rem}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--accent);font-family:var(--sans);font-weight:700;margin-bottom:.5em}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,253,251,.95);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 22px;max-width:var(--maxw);margin:0 auto;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:56px;width:auto}
.brand .name{font-family:var(--serif);font-size:1.35rem;color:var(--ink);letter-spacing:.02em}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.nav a{font-family:var(--sans);font-size:.95rem;color:var(--ink);padding:8px 14px;border-radius:999px;transition:background .15s,color .15s}
.nav a:hover{background:var(--panel)}
.nav a.active{background:var(--accent);color:#fff}

/* Hero */
.hero{position:relative;min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;
  background:linear-gradient(rgba(40,30,28,.42),rgba(40,30,28,.52)),var(--hero) center/cover no-repeat;padding:90px 22px}
.hero h1{font-size:clamp(2.4rem,6vw,4rem);color:#fff;margin-bottom:.15em;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.hero p{font-size:clamp(1.05rem,2.5vw,1.4rem);margin:0 0 1.4em;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.page-hero{background:var(--panel);text-align:center;padding:60px 22px 50px;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2rem,5vw,3rem)}
.page-hero p{color:var(--muted);font-size:1.15rem;margin:0}

/* Buttons */
.btn{display:inline-block;background:var(--accent);color:#fff;font-family:var(--sans);font-weight:600;
  padding:13px 28px;border-radius:999px;transition:background .15s,transform .15s}
.btn:hover{background:var(--accent-dark);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:transparent;border:2px solid #fff;color:#fff}
.btn.ghost:hover{background:#fff;color:var(--accent)}

/* Category cards (home) */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;box-shadow:0 6px 20px rgba(0,0,0,.08)}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover img{transform:scale(1.06)}
.card .cap{position:absolute;inset:auto 0 0 0;padding:18px;background:linear-gradient(transparent,rgba(30,20,18,.78));color:#fff}
.card .cap span{font-family:var(--serif);font-size:1.3rem}

/* Hours */
.hours{max-width:520px;margin:0 auto;border-collapse:collapse;width:100%;font-size:1.05rem}
.hours td{padding:12px 6px;border-bottom:1px solid var(--line)}
.hours td:last-child{text-align:right;color:var(--muted)}
.hours tr:last-child td{border-bottom:none}
.closed{color:var(--accent);font-style:italic}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.gallery a{display:block;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:var(--panel);box-shadow:0 4px 14px rgba(0,0,0,.07)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.gallery a:hover img{transform:scale(1.07)}

/* Lightbox */
#lightbox{position:fixed;inset:0;background:rgba(20,14,13,.92);display:none;align-items:center;justify-content:center;z-index:100;padding:30px;cursor:zoom-out}
#lightbox.open{display:flex}
#lightbox img{max-width:92vw;max-height:90vh;width:auto;height:auto;border-radius:8px;box-shadow:0 10px 50px rgba(0,0,0,.5)}
#lightbox .x{position:absolute;top:18px;right:26px;color:#fff;font-size:2.2rem;line-height:1;cursor:pointer;opacity:.85}

/* Contact form */
.contact-form{max-width:660px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.contact-form .cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form input,.contact-form textarea{
  width:100%;font:inherit;color:var(--ink);background:#fff;border:1px solid var(--line);
  border-radius:8px;padding:13px 15px;transition:border-color .15s,box-shadow .15s}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(178,58,72,.15)}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form .btn{align-self:flex-start;border:none;cursor:pointer;font-size:1rem}
.contact-form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{margin:.2em 0 0;min-height:1.2em;font-size:.95rem}
.form-status.ok{color:#2e7d4f}
.form-status.err{color:var(--accent)}
@media(max-width:560px){.contact-form .cf-row{grid-template-columns:1fr}}

/* Contact + footer */
.site-footer{background:#211b1a;color:#e9ded7;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1.4fr;gap:36px;max-width:var(--maxw);margin:0 auto;padding:54px 22px}
.site-footer h3{color:#fff;font-size:1.15rem;margin-bottom:.7em}
.site-footer a{color:#f0c9cf}
.site-footer a:hover{color:#fff}
.site-footer .muted{color:#b3a59d}
.footer-grid p{margin:.25em 0}
.footer-map iframe{width:100%;height:200px;border:0;border-radius:8px}
.copyright{border-top:1px solid #3a302e;text-align:center;padding:20px;color:#9c8f88;font-size:.86rem}

@media(max-width:860px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .brand .name{display:none}
}
@media(max-width:560px){
  .header-inner{justify-content:center}
  .nav{justify-content:center}
  .section{padding:46px 0}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important}
  .card:hover img,.gallery a:hover img{transform:none}
}
