/* Google Fonts import is in each page's <head> */
:root{
  /* Alpine Light palette */
  --bg:#f7f4ef; /* off-white (snow) */
  --paper:#fffdf8; /* paper */
  --card:#fcfaf4; /* light card */
  --soft:#f1ece3; /* soft panel */
  --stone:#d7cbbd; /* rock border */
  --text:#1e1b16; /* dark pine bark */
  --muted:#6b6357; /* muted dune */
  --accent:#8a5a44; /* warm cedar (primary) */
  --accent-2:#3f6d57; /* pine green (secondary) */
  --danger:#b24a3a; /* alpine alert */
  --radius:18px;
  --shadow:0 14px 36px rgba(61,46,32,.08);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;color:var(--text);
  background:
    radial-gradient(1000px 420px at 80% -10%, rgba(63,109,87,.06), transparent 60%),
    radial-gradient(900px 420px at 10% 110%, rgba(138,90,68,.06), transparent 60%),
    linear-gradient(180deg,#fffefb 0%, var(--bg) 60%, #efe9de 100%);
  font:16px/1.5 'Inter',system-ui,Segoe UI,Roboto,Apple Color Emoji,Segoe UI Emoji,sans-serif;
  -webkit-font-smoothing:antialiased
}

.container{max-width:960px;margin:0 auto;padding:20px}
.header{display:flex;align-items:center;gap:12px}
.brand{font-weight:700;font-size:22px;letter-spacing:.2px;font-family:'Marcellus',serif;color:#2d261d}

/* === Cards === */
.card{background:var(--card);border:1px solid var(--stone);border-radius:18px;box-shadow:var(--shadow)}
.card.pad{padding:18px}
.row{display:flex;gap:12px;flex-wrap:wrap}

/* === Buttons === */
.btn{
  appearance:none;border:0;color:#fff;cursor:pointer;
  padding:14px 18px;border-radius:14px;font-weight:700;
  background:linear-gradient(135deg,#8a5a44,#6f4636);
  box-shadow:0 10px 24px rgba(138,90,68,.25), inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .08s ease, filter .2s ease, box-shadow .2s ease;
  text-decoration:none;
}
.btn:hover{filter:brightness(1.05);box-shadow:0 14px 28px rgba(138,90,68,.3), inset 0 1px 0 rgba(255,255,255,.25)}
.btn:active{transform:translateY(1px)}
.btn.soft{
  background:#fffdf8;color:#3a3026;border:1px solid var(--stone);
  box-shadow:0 6px 18px rgba(61,46,32,.08);
}
.btn.alt{background:linear-gradient(135deg,#3f6d57,#2d5342)}
.btn.danger{background:var(--danger);color:#fff}

.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#efe7db;color:var(--muted);font-size:12px;border:1px solid var(--stone)}

/* === Grid menu === */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (min-width:720px){.grid{grid-template-columns:repeat(3,1fr)}}

.tile{
  display:flex;
  flex-direction:column;
  justify-content:center;   /* centre vertical */
  align-items:center;       /* centre horizontal */
  text-align:center;
  min-height:180px;         /* hauteur */
  padding:24px;
  border-radius:18px;
  background:linear-gradient(160deg,#fffdf9,#f6f0e7);
  border:1px solid var(--stone);
  box-shadow:0 16px 36px rgba(61,46,32,.10);
  transition:transform .12s ease, box-shadow .2s ease;
  color:inherit;
  text-decoration:none;
}
.tile h3{
  font-size:20px;
  margin:0 0 8px 0;
  font-family:'Marcellus',serif;
}
.tile p{
  font-size:15px;
  margin:0;
  opacity:.85;
}
.tile:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 46px rgba(61,46,32,.14),0 0 0 1px rgba(138,90,68,.12) inset;
  text-decoration:none;
}

/* === Upload === */
.drop{border:1.5px dashed #cdbca8;border-radius:16px;padding:20px;text-align:center;background:#fffdf8}
.drop input[type=file]{display:none}
.drop label{display:block;padding:14px 16px;border-radius:12px;background:#faf5ec;border:1px solid var(--stone)}
.meta{font-size:13px;color:var(--muted)}

/* === Gallery masonry === */
.masonry{column-count:2;column-gap:10px}
@media(min-width:720px){.masonry{column-count:3}}
.item{break-inside:avoid;margin-bottom:12px;position:relative}
.item img{
  width:100%;height:auto;border-radius:16px;display:block;
  box-shadow:0 8px 24px rgba(61,46,32,.12);
  transition:transform .15s ease, box-shadow .2s ease, filter .2s ease;
}
.item a:hover img{transform:translateY(-2px);box-shadow:0 14px 34px rgba(61,46,32,.18);filter:contrast(1.03) saturate(1.03)}

/* === Lightbox === */
.lightbox{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(28,22,16,.75);backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:9999;
}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{
  max-width:92%;max-height:90vh;border-radius:18px;
  box-shadow:0 30px 80px rgba(20,16,12,.45);opacity:0;transform:scale(.98);
  transition:opacity .18s ease, transform .18s ease;
}
.lightbox.open img{opacity:1;transform:scale(1)}
.lb-btn{
  position:absolute;border:none;cursor:pointer;
  width:46px;height:46px;border-radius:999px;font-size:28px;line-height:1;
  color:#3a3026;background:rgba(255,255,255,.92);
  box-shadow:0 10px 26px rgba(61,46,32,.25);
  display:flex;align-items:center;justify-content:center;
}
.lb-prev{left:14px} .lb-next{right:14px}
.lb-close{top:14px;right:14px;font-size:24px;width:40px;height:40px;background:rgba(255,255,255,.95)}

/* === Footer & ridge === */
.fab{position:fixed;right:18px;bottom:18px}
.footer{opacity:.8;font-size:12px;margin-top:14px;color:#594f43}
.ridge{margin:10px -20px 0;}
.ridge svg{display:block;width:100%;height:60px}
.ridge path:first-child{fill:#efe7db}
.ridge path:last-child{fill:#a3765f}

/* === Timeline === */
.section-title{font-family:'Marcellus',serif;font-size:22px;margin:6px 0 12px;color:#2d261d}
.timeline{position:relative;list-style:none;margin:0;padding:0 0 0 24px}
.timeline:before{
  content:'';position:absolute;left:10px;top:0;bottom:0;width:3px;
  background:linear-gradient(#d7cbbd,#bfae9b);border-radius:2px
}
.tl-item{position:relative;margin:0 0 16px}
.tl-dot{
  position:absolute;left:0;top:10px;width:22px;height:22px;border-radius:999px;
  background:#fff;border:2px solid #bfae9b;display:flex;align-items:center;justify-content:center;
  font-size:13px;box-shadow:0 6px 16px rgba(61,46,32,.12)
}
details.tl-card{
  background:linear-gradient(160deg,#fffdf9,#f6f0e7);
  border:1px solid var(--stone);border-radius:16px;box-shadow:0 12px 28px rgba(61,46,32,.10);
  overflow:hidden
}
details.tl-card summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;
  padding:16px 16px
}
details.tl-card[open] summary{border-bottom:1px solid var(--stone)}
.tl-time{
  font-weight:800;color:#8a5a44;background:#f3ebe2;border:1px solid #e3d6c7;
  padding:6px 10px;border-radius:10px;min-width:74px;text-align:center
}
details.tl-card h3{margin:0;font-family:'Marcellus',serif;font-size:18px;color:#3a3026}
.tl-chevron{margin-left:auto;opacity:.6;transition:transform .18s ease}
details[open] .tl-chevron{transform:rotate(180deg)}

.tl-body{padding:12px 16px 16px}
.tl-place{color:#6b6357;margin:.25rem 0 .5rem}
.tl-note{color:#3a3026;margin:.25rem 0}
.tl-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}

/* Ergonomie tactile */
details.tl-card summary:focus-visible{outline:2px solid #8a5a44;outline-offset:2px;border-radius:14px}
.btn.soft{min-height:42px;padding:10px 14px}

/* Desktop */
@media(min-width:720px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .timeline{padding-left:28px}
  .timeline:before{left:12px}
  .tl-dot{left:-1px}
  details.tl-card h3{font-size:19px}
}
																		/* Boutons plus petits dans admin */
.actions {
  display: flex;
  gap: 6px;          /* espace entre boutons */
  flex-wrap: wrap;   /* si trop petit écran, ils passent à la ligne */
  margin-top: 6px;
}

.actions .btn.small {
  padding: 4px 8px;       /* réduit la taille */
  font-size: 13px;        /* police plus petite */
  border-radius: 8px;     /* arrondis cohérents */
  flex: none;             /* pas d'élargissement forcé */
}
