
/* Quercy Brocante - styles.css */
:root{
  --bg:#faf7f0;
  --paper:#efe7da;
  --ink:#3a2b1a;
  --ink-soft:#6d5a45;
  --accent:#8c6d4f;
  --accent-2:#b08860;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-serif, Georgia, 'Times New Roman', Times, serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.header{
  position:sticky;top:0;background:rgba(250,247,240,.9);
  backdrop-filter:saturate(120%) blur(6px);border-bottom:1px solid #e5dccd; z-index:10;
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand img{height:40px;width:auto;border-radius:6px;box-shadow:0 1px 0 rgba(0,0,0,.05)}
.brand span{font-weight:700;letter-spacing:.03em}
.menu{display:flex;gap:18px;flex-wrap:wrap}
.menu a{color:var(--ink);text-decoration:none;padding:8px 10px;border-radius:8px;border:1px solid transparent}
.menu a:hover{border-color:#e5dccd;background:var(--paper)}
.hero{
  display:grid;place-items:center;min-height:68vh;
  background:radial-gradient(1000px 400px at 50% 0%, #f5efe4, transparent), var(--bg);
  border-bottom:1px solid #e5dccd;
}
.hero .logo{
  width:min(560px,90vw);max-width:560px;display:block;margin:0 auto 24px;
  filter:sepia(.15) contrast(1.05);
}
.hero h1{
  margin:0 0 10px 0;font-size:clamp(26px,4vw,42px);text-align:center;
}
.hero p{margin:0 0 22px 0;text-align:center;color:var(--ink-soft)}
.cta-grid{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.btn{
  display:inline-block;padding:12px 18px;border-radius:999px;
  background:var(--accent);color:#fff;text-decoration:none;border:1px solid #7b5f45;
  box-shadow:0 2px 0 #7b5f45;
}
.btn.secondary{background:var(--accent-2);border-color:#9a744e;box-shadow:0 2px 0 #9a744e}
.btn:hover{transform:translateY(-1px)}
.section{padding:56px 0;background:linear-gradient(180deg, var(--bg), var(--paper) 120%)}
.card{
  background:#fff;border:1px solid #e5dccd;border-radius:16px;padding:22px;
  box-shadow:0 8px 20px rgba(0,0,0,.04);
}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.span-6{grid-column:span 6}
.span-12{grid-column:span 12}
@media (max-width:800px){.span-6{grid-column:span 12}}
.footer{padding:26px 0;border-top:1px solid #e5dccd;color:var(--ink-soft);background:var(--paper)}
.small{font-size:.92rem}
hr{border:0;border-top:1px dashed #e0d6c5;margin:24px 0}
figure{margin:0}
figcaption{font-size:.9rem;color:var(--ink-soft);margin-top:8px}
form{display:grid;gap:12px;max-width:640px}
input, textarea{
  padding:12px 14px;border-radius:12px;border:1px solid #d8cdbb;background:#fff;font:inherit
}
label{font-weight:600}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#f3ede4;border:1px solid #e5dccd}
ul.clean{padding-left:18px}


/* ===== Responsive Enhancements ===== */
:root{
  --maxw:1100px;
}
img, video{max-width:100%;height:auto;}

/* Fluid typography */
h1{font-size:clamp(24px, 4vw, 40px)}
h2{font-size:clamp(20px, 3vw, 28px)}
p, li{font-size:clamp(16px, 1.6vw, 18px)}

/* Container */
.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(14px, 3vw, 24px)}

/* Grid that collapses gracefully */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,2vw,18px)}
.span-6{grid-column:span 6}
.span-12{grid-column:span 12}
@media (max-width: 900px){
  .span-6{grid-column:span 12}
}

/* Header: mobile nav */
.header .menu-toggle{
  display:none;
  background:none;border:1px solid #e5dccd;border-radius:10px;padding:8px 10px;
}
.header .menu{display:flex;gap:14px;flex-wrap:wrap}
@media (max-width: 840px){
  .header .menu-toggle{display:block}
  .header .menu{
    display:none;flex-direction:column;gap:10px;
    background:#fff;border:1px solid #e5dccd;border-radius:14px;padding:12px; margin-top:10px;
  }
  .header .menu.open{display:flex}
  .nav{flex-direction:column;align-items:stretch}
  .brand{justify-content:space-between}
}

/* Hero spacing on mobile */
.hero{padding:clamp(20px,4vw,40px) 0}
.hero .logo{width:min(520px,90vw);margin:0 auto 18px}

/* Forms */
form{display:grid;gap:12px}
form label{display:grid;gap:6px}
input, textarea{width:100%}

/* Buttons wrap cleanly on small screens */
.cta-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.btn{white-space:nowrap}

/* Breadcrumbs */
.breadcrumb{font-size:.95rem;opacity:.85}
