/* Luxe off-white theme — Le Refuge de la Traye (pré‑arrivée) */
:root{
  --bg:#f7f2e8;         /* blanc cassé */
  --paper:#fcfaf6;      /* surface */
  --paper2:#f3ede2;     /* subtle alt */
  --ink:#141414;        /* texte */
  --muted:#6f6a63;      /* secondaire */
  --gold:#b19852;       /* doré logo */
  --line:#d8d1c3;       /* traits */
  --danger:#b42318;
  --ok:#1a7f37;

  --shadow: 0 18px 60px rgba(20,20,20,.10);
  --shadow2: 0 10px 28px rgba(20,20,20,.10);

  --max: 1140px;
  --serif: "Cormorant Garamond", ui-serif, "Baskerville", "Garamond", "Times New Roman", serif;
  --sans: "Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:var(--bg);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  letter-spacing:.01em;
}
a{color:inherit}
button,input,textarea,select{font:inherit}
img{max-width:100%;display:block}

/* absolutely no rounded corners */
*{border-radius:0 !important}

::selection{background:rgba(177,152,82,.25)}

/* Subtle luxury atmosphere */
body::before{
  content:"";
  position:fixed;
  inset:-2px;
  pointer-events:none;
  z-index:-2;
  background:
    radial-gradient(1000px 700px at 10% -10%, rgba(177,152,82,.12), transparent 60%),
    radial-gradient(900px 700px at 110% 15%, rgba(20,20,20,.06), transparent 55%),
    radial-gradient(900px 700px at 50% 120%, rgba(177,152,82,.08), transparent 60%);
}

/* Layout */
.shell{
  max-width:var(--max);
  margin:0 auto;
  padding:28px 18px 70px;
}

.topnav{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(247,242,232,.80);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(216,209,195,.80);
}
body.scrolled .topnav{box-shadow:var(--shadow2)}
.topnav-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.brandlink{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}
.brand-logo{
  width:150px;
  height:auto;
}
.brand-mini{
  display:flex;
  flex-direction:column;
  gap:2px;
  line-height:1.05;
}
.brand-mini .kicker{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}
.brand-mini .title{
  font-family:var(--serif);
  font-weight:500;
  font-size:22px;
  letter-spacing:.02em;
}

.nav{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav a{
  text-decoration:none;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  padding:8px 0;
  position:relative;
  transition: transform .25s ease, color .25s ease;
}
.nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:2px;
  height:1px;
  width:0;
  background:var(--gold);
  transition: width .30s ease;
}
.nav a:hover{
  color:var(--ink);
  transform:translateY(-1px);
}
.nav a:hover::after{width:100%}
.nav form{margin:0}
.navform{display:inline}
.navbtn{
  appearance:none;
  border:0;
  background:transparent;
  font:inherit;
  cursor:pointer;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  padding:8px 0;
  position:relative;
  transition: transform .25s ease, color .25s ease;
}
.navbtn::after{
  content:"";
  position:absolute;
  left:0;
  bottom:2px;
  height:1px;
  width:0;
  background:var(--gold);
  transition: width .30s ease;
}
.navbtn:hover{
  color:var(--ink);
  transform:translateY(-1px);
}
.navbtn:hover::after{width:100%}


/* Brand blocks */
.brand{
  margin:26px 0 18px;
  padding:26px 0 10px;
  border-bottom:1px solid var(--line);
}
.brand.center{text-align:center}
.brand .brand-emblem{
  display:flex;
  justify-content:center;
  margin-bottom:14px;
}
.brand .brand-emblem img{width:180px}
.brand .mark{
  font-family:var(--serif);
  font-weight:500;
  font-size:44px;
  letter-spacing:.02em;
  margin:0 0 6px;
}
.brand .tag{
  color:var(--muted);
  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.topbar{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin:24px 0 18px;
  padding:0 0 14px;
  border-bottom:1px solid var(--line);
}
.brandline{
  display:flex;
  align-items:center;
  gap:14px;
}
.brandline img{width:120px}
.brandline .mark{
  font-family:var(--serif);
  font-weight:500;
  font-size:28px;
  margin:0;
}
.brandline .tag{
  color:var(--muted);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-top:3px;
}
.topbar-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

/* Cards */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  padding:22px;
  transition: transform .25s ease, box-shadow .25s ease;
}
.card:hover{transform:translateY(-2px); box-shadow:var(--shadow2)}
.card.narrow{max-width:520px; margin:0 auto}
.panel{
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(252,250,246,.85), rgba(243,237,226,.75));
  padding:18px;
}

/* Typography */
.h1{
  font-family:var(--serif);
  font-weight:500;
  font-size:36px;
  margin:0 0 10px;
  letter-spacing:.02em;
}
.h2{
  font-family:var(--serif);
  font-weight:500;
  font-size:22px;
  margin:18px 0 10px;
  letter-spacing:.02em;
}
.lead{color:var(--muted); line-height:1.7; margin:0 0 14px}
.muted{color:var(--muted)}
.smallnote{font-size:12px}
.mono{font-family:var(--mono)}
.right{text-align:right}
.center{text-align:center}
.fine{color:var(--muted); font-size:12px; line-height:1.6; margin-top:14px}

/* Forms */
.form{display:flex; flex-direction:column; gap:14px}
.field label{
  display:block;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 6px;
}
input,textarea,select{
  width:100%;
  border:1px solid var(--line);
  background:rgba(252,250,246,.7);
  padding:12px 12px;
  outline:none;
  color:var(--ink);
  transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
textarea{min-height:110px; resize:vertical}
input:focus, textarea:focus, select:focus{
  border-color:rgba(177,152,82,.95);
  box-shadow: 0 0 0 3px rgba(177,152,82,.18);
}
.mini{
  width:100%;
  padding:10px 10px;
  font-size:13px;
}

.checkbox, .radio{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--line);
  background:rgba(252,250,246,.65);
}
.checkbox input, .radio input{width:auto; margin-top:2px}
.hr, .sep{border:0; border-top:1px solid var(--line); margin:18px 0}

/* Buttons */
.btn{
  appearance:none;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--paper);
  padding:10px 14px;
  cursor:pointer;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:12px;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.btn:hover{transform:translateY(-1px); box-shadow:0 10px 20px rgba(20,20,20,.12)}
.btn:disabled{opacity:.55; cursor:not-allowed; transform:none; box-shadow:none}
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--line);
}
.btn-ghost:hover{border-color:var(--ink); box-shadow:0 10px 20px rgba(20,20,20,.10)}
.inline{display:inline}

/* Grid helpers */
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.grid3{display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px}
@media (max-width:860px){
  .grid2,.grid3{grid-template-columns:1fr}
  .topnav-inner{flex-direction:column; align-items:flex-start}
  .nav{width:100%; justify-content:space-between}
  .brand .mark{font-size:36px}
}

/* Wizard */
.split{display:flex; justify-content:space-between; gap:18px; align-items:flex-start; margin-bottom:10px}
@media (max-width:860px){ .split{flex-direction:column; align-items:flex-start} .right{text-align:left} }
.pill{
  display:inline-block;
  padding:8px 12px;
  border:1px solid var(--line);
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:11px;
  color:var(--muted);
  background:rgba(252,250,246,.75);
}
.pill.ok{border-color:rgba(26,127,55,.25); color:var(--ok)}
.pill.warn{border-color:rgba(177,152,82,.35); color:var(--gold)}
.pill-ok{border-color:rgba(26,127,55,.25); color:var(--ok)}
.pill-warn{border-color:rgba(177,152,82,.35); color:var(--gold)}
.pill-ghost{border-color:rgba(216,209,195,.65); color:var(--muted); background:transparent}


.wizard{margin-top:10px}
.wiz-progress{margin:10px 0 14px}
.wiz-bar{
  height:2px;
  background:rgba(216,209,195,.95);
  position:relative;
  overflow:hidden;
}
.wiz-bar-fill{
  height:100%;
  width:0%;
  background:linear-gradient(90deg, var(--gold), rgba(177,152,82,.55));
  transition: width .45s ease;
}
.wiz-steps{
  display:flex;
  flex-wrap:wrap;
  gap:14px 18px;
  margin-top:10px;
}
.wiz-step{
  position:relative;
  cursor:pointer;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  padding:8px 0;
  user-select:none;
  transition: transform .25s ease, color .25s ease;
}
.wiz-step .dot{display:none}
.wiz-step::after{
  content:"";
  position:absolute;
  left:0; bottom:2px;
  height:1px;
  width:0;
  background:var(--gold);
  transition: width .30s ease;
}
.wiz-step:hover{color:var(--ink); transform:translateY(-1px)}
.wiz-step:hover::after{width:100%}
.wiz-step.on{color:var(--ink)}
.wiz-step.on::after{width:100%}

.wiz-stage{padding:6px 0}
.wiz-stage.anim{animation: riseIn .45s ease both}
@keyframes riseIn{
  from{opacity:0; transform:translateY(10px); filter:blur(0.6px)}
  to{opacity:1; transform:translateY(0); filter:blur(0)}
}

.wiz-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid var(--line);
}
.wiz-actions-right{display:flex; gap:10px; align-items:center}

/* Tables */
.tablewrap{overflow:auto; border:1px solid var(--line); background:rgba(252,250,246,.55)}
.table{width:100%; border-collapse:collapse; font-size:13px}
.table thead th{
  text-align:left;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  background:rgba(243,237,226,.80);
  border-bottom:1px solid var(--line);
  padding:12px 12px;
  white-space:nowrap;
}
.table td{
  border-top:1px solid rgba(216,209,195,.65);
  padding:12px 12px;
  vertical-align:top;
}
.table .right{text-align:right}
.table-wide{min-width:980px}

.notice{
  border:1px solid rgba(177,152,82,.35);
  background:rgba(177,152,82,.08);
  padding:12px 12px;
  margin:0 0 14px;
  color:var(--ink);
}
.danger{
  border:1px solid rgba(180,35,24,.35);
  background:rgba(180,35,24,.06);
  padding:12px 12px;
  margin:0 0 14px;
  color:var(--danger);
}

/* Small util margins (avoid inline styles due to CSP) */
.mt10{margin-top:10px}
.mt12{margin-top:12px}

/* Toast */
.toast{
  position:fixed;
  right:16px;
  bottom:16px;
  padding:12px 14px;
  border:1px solid var(--line);
  background:rgba(252,250,246,.92);
  box-shadow:var(--shadow2);
  z-index:1000;
  font-size:12px;
  letter-spacing:.08em;
}


/* Admin / misc components */
.filters{
  display:grid;
  grid-template-columns: 2fr 1fr 160px;
  gap:14px;
  align-items:end;
  margin:14px 0 18px;
}
.field-actions{display:flex; flex-direction:column}
.field-actions .btn{width:100%}
@media (max-width:860px){
  .filters{grid-template-columns:1fr}
  .field-actions .btn{width:auto}
}

.actions{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.btn-small{
  padding:8px 12px;
  font-size:11px;
  letter-spacing:.16em;
}

.subhead{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin:18px 0 8px;
}

.copyline{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:10px;
}
.copyline input{flex:1}
.copyline .btn{white-space:nowrap}

.pre{
  border:1px solid var(--line);
  background:rgba(243,237,226,.55);
  padding:14px;
  font-family:var(--mono);
  font-size:12px;
  line-height:1.6;
  overflow:auto;
}

.kv{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:10px 0;
  border-bottom:1px solid rgba(216,209,195,.55);
}
.k{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}
.v{color:var(--ink)}

.audit{
  border:1px solid var(--line);
  background:rgba(252,250,246,.55);
}
.audit-row{
  display:grid;
  grid-template-columns: 160px 1fr;
  gap:14px;
  padding:14px;
  border-top:1px solid rgba(216,209,195,.55);
}
.audit-row:first-child{border-top:0}
.audit-when{
  font-family:var(--mono);
  font-size:12px;
  color:var(--muted);
}
.audit-main{color:var(--ink); line-height:1.6}
.audit-meta{color:var(--muted); font-size:12px; margin-top:6px}
.audit-line{
  display:flex;
  justify-content:space-between;
  gap:14px;
}
@media (max-width:860px){
  .audit-row{grid-template-columns:1fr}
}
