
:root{
  --bg:#070a12;
  --card:#0c1224;
  --card2:#0b1020;
  --text:#eaf0ff;
  --muted:#b8c2e0;
  --line:rgba(255,255,255,.10);
  --accent:#7dd3fc;
  --accent2:#a78bfa;
  --good:#34d399;
  --warn:#fbbf24;
  --shadow: 0 14px 36px rgba(0,0,0,.45);
  --radius: 18px;
  --radius2: 24px;
  --max: 1120px;
  --gold:#fbbf24;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(1200px 700px at 10% -10%, rgba(125,211,252,.18), transparent 55%),
    radial-gradient(900px 650px at 90% 0%, rgba(167,139,250,.16), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.55;
  text-rendering:optimizeLegibility;
}

a{color:inherit; text-decoration:none}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{outline:2px solid var(--accent); outline-offset:2px}

.wrap{max-width:var(--max); margin:0 auto; padding:0 16px}
.skip{position:absolute; left:-999px; top:0; background:#fff; color:#000; padding:10px 12px; border-radius:10px; z-index:999}
.skip:focus{left:16px; top:16px}

.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border:1px solid var(--line);
  border-radius:999px; background:rgba(255,255,255,.04);
  color:var(--muted);
  font-size:14px;
}
.dot{width:8px;height:8px;border-radius:999px;background:var(--good); box-shadow:0 0 0 3px rgba(52,211,153,.18)}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px; border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(135deg, rgba(125,211,252,.20), rgba(167,139,250,.18));
  color:var(--text);
  font-weight:800;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition:transform .12s ease, background .12s ease;
  max-width:100%;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn2{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px; border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
  font-weight:800;
  transition:background .12s ease;
  max-width:100%;
}
.btn2:hover{background:rgba(255,255,255,.08)}

.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(130%) blur(10px);
  background:rgba(7,10,18,.65);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0;
  gap:12px;
}
.brand{display:flex; align-items:center; gap:10px}
.logo{
  width:40px; height:40px; border-radius:14px;
  display:grid; place-items:center;
  background: radial-gradient(circle at 30% 30%, rgba(125,211,252,.7), rgba(167,139,250,.65));
  box-shadow: 0 14px 30px rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  flex:0 0 auto;
}
.brand strong{display:block; font-size:14px; letter-spacing:.4px}
.brand span{display:block; font-size:12px; color:var(--muted)}

.menu{display:flex; align-items:center; gap:14px; flex-wrap:wrap}
.menu a{color:var(--muted); font-weight:700; font-size:14px; padding:8px 10px; border-radius:12px}
.menu a:hover{background:rgba(255,255,255,.06); color:var(--text)}
.nav-cta{display:flex; gap:10px; align-items:center}
.burger{display:none}

@media (max-width: 860px){
  .menu{display:none}
  .burger{display:inline-flex}
  .nav-cta .btn2{display:none} /* hide Réserver CTA only on mobile */
}

/* Mobile drawer */
.drawer{display:none; position:fixed; inset:0; z-index:80; background:rgba(0,0,0,.55)}
.drawer[aria-hidden="false"]{display:block}
.drawer-panel{
  position:absolute; right:0; top:0; bottom:0; width:min(92vw, 380px);
  background:linear-gradient(180deg, rgba(12,18,36,.98), rgba(11,16,32,.98));
  border-left:1px solid var(--line);
  padding:16px;
  box-shadow: var(--shadow);
}
.drawer-head{display:flex; align-items:center; justify-content:space-between; gap:10px}
.drawer-links{display:grid; gap:8px; margin-top:14px}
.drawer-links a{
  padding:12px 12px; border:1px solid var(--line); border-radius:14px;
  color:var(--text); background:rgba(255,255,255,.04);
  font-weight:700;
}
.drawer-links a small{display:block; color:var(--muted); font-weight:550; margin-top:2px}
.xbtn{
  width:42px; height:42px; border-radius:14px;
  border:1px solid var(--line); background:rgba(255,255,255,.06);
  color:var(--text); font-weight:900;
}

/* Layout sections */
.hero{padding:34px 0 20px}
.hero-grid{display:grid; grid-template-columns: 1.05fr .95fr; gap:16px; align-items:stretch}
@media (max-width: 980px){ .hero-grid{grid-template-columns:1fr} }

.hero-card{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.hero-left{padding:22px}
h1{margin:10px 0 10px; font-size: clamp(28px, 4vw, 44px); line-height:1.1; letter-spacing:-.6px}
.lead{color:var(--muted); font-size:16px; margin:0 0 16px}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}

.trust{display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:16px}
@media (max-width: 560px){ .trust{grid-template-columns:1fr} }
.tcard{border:1px solid var(--line); border-radius:16px; padding:12px; background:rgba(255,255,255,.04)}
.tcard b{display:block; font-size:14px}
.tcard span{color:var(--muted); font-size:12px}

.kpi{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:12px}
@media (max-width: 900px){ .kpi{grid-template-columns:1fr 1fr} }
.kpi .card{padding:14px}
.kpi b{font-size:18px}

.hero-right{display:grid; grid-template-rows: 1fr auto}
.hero-media{position:relative; min-height: 320px; background:rgba(255,255,255,.02); border-bottom:1px solid var(--line)}
.hero-media img{width:100%; height:100%; object-fit:cover; display:block}
.hero-badge{
  position:absolute; left:14px; bottom:14px;
  padding:10px 12px; border-radius:16px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(7,10,18,.55);
  backdrop-filter: blur(10px);
  max-width: 85%;
}
.hero-badge b{display:block; font-size:13px}
.hero-badge span{display:block; color:var(--muted); font-size:12px}

.hero-form{padding:16px; display:grid; gap:10px}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media (max-width: 520px){ .form-grid{grid-template-columns:1fr} }

label{display:block; font-size:12px; color:var(--muted); margin:0 0 6px}
input, textarea{
  width:100%;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  color:var(--text);
  padding:12px 12px;
  font-size:14px;
}
textarea{min-height:86px; resize:vertical}
.fine{font-size:12px; color:var(--muted)}

/* ✅ Mobile responsiveness fix for the hero form */
.hero-grid, .hero-right, .hero-form, .form-grid, .form-grid > div{min-width:0}
.hero-form{overflow:hidden}
.hero-form input, .hero-form textarea, .hero-form button{max-width:100%}
@media (max-width: 560px){
  .hero-form{padding:12px; gap:10px}
  .form-grid{grid-template-columns:1fr !important; gap:10px}
  .hero-form input, .hero-form textarea{font-size:16px}
  .hero-form textarea{min-height:120px}
  .hero-form .btn{width:100%; display:flex; justify-content:center; padding:12px 14px; font-size:16px; white-space:normal; text-align:center}
  .hero-card{overflow:hidden}
}

.section{padding:18px 0}
.section h2{margin:0 0 8px; font-size: clamp(22px, 2.5vw, 30px); letter-spacing:-.4px}
.section p{margin:0; color:var(--muted)}

.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:12px}
@media (max-width: 900px){ .grid-3{grid-template-columns:1fr} }

.card{border:1px solid var(--line); border-radius:var(--radius); background:rgba(255,255,255,.04); padding:16px}
.card h3{margin:0 0 6px; font-size:16px}
.card p{margin:0; color:var(--muted); font-size:14px}

.chiprow{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.chip{font-size:12px; color:var(--muted); padding:7px 10px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.03)}

.split{display:grid; grid-template-columns: 1.05fr .95fr; gap:12px; align-items:start; margin-top:12px}
@media (max-width: 980px){ .split{grid-template-columns:1fr} }

.list{margin:10px 0 0; padding:0; list-style:none; display:grid; gap:10px}
.list li{border:1px solid var(--line); border-radius:16px; padding:12px 12px; background:rgba(255,255,255,.03); color:var(--muted)}
.list li b{color:var(--text)}

.cta-band{
  margin-top:16px;
  border:1px solid var(--line);
  border-radius:var(--radius2);
  background:linear-gradient(135deg, rgba(125,211,252,.12), rgba(167,139,250,.10));
  padding:16px;
  display:flex; justify-content:space-between; gap:12px; align-items:center; flex-wrap:wrap;
}

/* Puppy cards */
.puppy-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:12px}
@media (max-width: 980px){ .puppy-grid{grid-template-columns:1fr} }
.pcard{border:1px solid var(--line); border-radius:var(--radius2); overflow:hidden; background:rgba(255,255,255,.04)}
.pmedia{aspect-ratio: 16/10; background:rgba(255,255,255,.03)}
.pmedia img{width:100%; height:100%; object-fit:cover; display:block}
.pbody{padding:14px}
.phead{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.phead h3{margin:0; font-size:16px}
.status{
  font-size:12px; font-weight:800;
  padding:6px 10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
  white-space:nowrap;
}
.status.available{border-color:rgba(52,211,153,.35); background:rgba(52,211,153,.10)}
.status.reserved{border-color:rgba(251,191,36,.35); background:rgba(251,191,36,.10)}
.pmeta{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.tag{font-size:12px; padding:6px 10px; border-radius:999px; border:1px solid var(--line); color:var(--muted); background:rgba(255,255,255,.03)}
.pinfo{margin-top:10px; display:grid; grid-template-columns: 1fr 1fr; gap:8px}
.pinfo div{border:1px solid var(--line); border-radius:14px; padding:10px; background:rgba(255,255,255,.03); color:var(--muted); font-size:13px}
.pinfo b{color:var(--text)}
@media (max-width: 520px){ .pinfo{grid-template-columns:1fr} }

/* Reviews */
.reviews{margin-top:12px; display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
@media (max-width: 980px){ .reviews{grid-template-columns:1fr} }
.g-review{border:1px solid var(--line); border-radius:var(--radius2); background:rgba(255,255,255,.04); padding:14px; box-shadow: 0 10px 26px rgba(0,0,0,.22)}
.g-top{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.g-user{display:flex; gap:10px; align-items:center}
.avatar{width:40px; height:40px; border-radius:999px; background:linear-gradient(135deg, rgba(125,211,252,.35), rgba(167,139,250,.35)); border:1px solid rgba(255,255,255,.16); flex:0 0 auto}
.g-user b{display:block; font-size:14px}
.g-user span{display:block; font-size:12px; color:var(--muted)}
.g-tag{font-size:12px; font-weight:900; padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:var(--text); white-space:nowrap}
.stars{display:flex; gap:3px; margin-top:6px}
.stars svg{width:16px; height:16px; fill:var(--gold)}
.g-body{margin-top:10px; color:var(--muted); font-size:14px}
.g-foot{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:12px}
.g-date{font-size:12px; color:var(--muted)}
.g-like{display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border-radius:12px; border:1px solid var(--line); background:rgba(255,255,255,.03); font-size:12px; color:var(--muted)}
.g-like svg{width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:2}

/* Blog */
.blog-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:12px}
@media (max-width: 980px){ .blog-grid{grid-template-columns:1fr} }
.post{border:1px solid var(--line); border-radius:var(--radius2); overflow:hidden; background:rgba(255,255,255,.04); box-shadow: 0 10px 26px rgba(0,0,0,.22)}
.post-media{aspect-ratio: 16/10; background:rgba(255,255,255,.03)}
.post-media img{width:100%; height:100%; object-fit:cover; display:block}
.post-body{padding:14px}
.post-body h3{margin:0 0 6px; font-size:16px}
.post-meta{display:flex; flex-wrap:wrap; gap:10px; align-items:center; color:var(--muted); font-size:12px}
.ico-row{display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:10px}
.metric{display:inline-flex; align-items:center; gap:6px; padding:7px 10px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.03); font-size:12px; color:var(--muted)}
.metric svg{width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:2}
.readmore{margin-top:12px; display:inline-flex}

/* Footer */
footer{margin-top:22px; border-top:1px solid var(--line); padding:22px 0 26px; color:var(--muted)}
.footgrid{display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap:14px; align-items:start}
@media (max-width: 980px){ .footgrid{grid-template-columns:1fr} }
.foot-title{color:var(--text); font-weight:900; margin-bottom:10px}
.footlinks{display:grid; gap:8px}
.footlinks a{color:var(--muted); padding:8px 10px; border-radius:12px; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.02)}
.footlinks a:hover{background:rgba(255,255,255,.05); color:var(--text)}
.small{font-size:12px}
.muted{color:var(--muted)}

/* Simple content page helpers */
.page-head{padding:22px 0 6px}
.breadcrumbs{color:var(--muted); font-size:12px}
.breadcrumbs a{color:var(--muted); text-decoration:underline; text-decoration-color:rgba(255,255,255,.25)}
.prose{border:1px solid var(--line); border-radius:var(--radius2); background:rgba(255,255,255,.04); padding:16px}
.prose h2{margin-top:0}
.prose p{color:var(--muted)}
