:root{
  --page-bg:#dbe9ff;
  --sky-1:#c9dcff;
  --sky-2:#edf5ff;
  --cream:#fffdf8;
  --cream-2:#fbf7ee;
  --gold:#b99b56;
  --gold-soft:#dfcfaa;
  --ink:#5b4d3b;
  --muted:#8a7b68;
  --line:#eadcc6;
  --shadow:0 18px 42px rgba(105,91,61,.16);
  --radius-xl:26px;
  --radius-lg:20px;
  --radius-md:16px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--page-bg)}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:linear-gradient(180deg,#c8dbff 0%,#eef6ff 56%,#f7fbff 100%);color:var(--ink);line-height:1.42;min-height:100vh}
button,input,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}
button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{outline:3px solid rgba(185,155,86,.42);outline-offset:3px}
.app-shell{width:min(100%,430px);min-height:100vh;margin:0 auto;padding-bottom:calc(88px + var(--safe-bottom));background:linear-gradient(180deg,var(--sky-1) 0%,var(--sky-2) 42%,#f8fbff 100%);box-shadow:0 0 0 1px rgba(255,255,255,.45),0 22px 80px rgba(75,96,132,.24);position:relative;overflow:hidden}
.app-shell:before{content:"";position:absolute;inset:98px 0 auto 0;height:340px;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.58),transparent 24%),radial-gradient(circle at 80% 8%,rgba(255,255,255,.48),transparent 19%),linear-gradient(180deg,rgba(255,255,255,.15),transparent);pointer-events:none}
.hero{position:relative;overflow:visible;min-height:0;color:var(--ink);border:0;background:transparent}.hero--compact{min-height:0}.hero__image,.hero__overlay{display:none}.hero__content{position:relative;z-index:1;padding:12px 16px 0;max-width:none;margin:0}.topbar{height:56px;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:10px;background:rgba(255,253,248,.70);backdrop-filter:blur(12px);border-bottom:1px solid rgba(234,220,198,.52);margin:0 -16px;padding:0 14px}.topbar__title{text-align:center;line-height:1.05}.topbar__title h1{margin:0;font-size:.88rem;font-weight:900;letter-spacing:-.01em;color:var(--ink)}.topbar__title p{margin:2px 0 0;font-size:.72rem;color:var(--muted);font-weight:650}.eyebrow,.lead{display:none}.icon-button{width:44px;height:44px;border-radius:14px;border:1px solid var(--line);color:var(--ink);background:rgba(255,253,248,.84);font-size:1.2rem;font-weight:900;display:grid;place-items:center;box-shadow:0 8px 20px rgba(100,82,46,.08)}.icon-button--ghost{opacity:.78}.brand-lockup{width:176px;height:76px;margin:34px auto 32px;display:grid;place-items:center;text-align:center;color:#d3b66a;position:relative;text-transform:uppercase;font-weight:950;letter-spacing:.11em}.brand-lockup:before,.brand-lockup:after{content:"";position:absolute;width:48px;height:48px;border-color:#d3b66a;opacity:.82}.brand-lockup:before{left:-14px;top:-6px;border-left:2px solid;border-top:2px solid}.brand-lockup:after{right:-14px;bottom:-6px;border-right:2px solid;border-bottom:2px solid}.brand-lockup span{font-size:1.44rem;line-height:1}.brand-lockup span:before{content:"☀";display:block;font-size:1.05rem;letter-spacing:0;margin-bottom:-1px;color:#e0c77d}.brand-lockup small{display:block;font-size:.58rem;letter-spacing:.08em;margin-top:4px;color:#c4a75f}.hero-card{margin:0 0 14px;background:rgba(255,253,248,.94);color:var(--ink);border:1px solid rgba(234,220,198,.86);border-radius:var(--radius-xl);padding:18px 18px 17px;display:grid;gap:12px;box-shadow:var(--shadow)}.hero-card--compact{margin-top:0}.hero-card h2{font-size:1.45rem;letter-spacing:-.03em;color:var(--ink)}.hero-card p{margin:5px 0 0;color:var(--muted);font-size:.92rem}.badge{display:inline-flex;align-items:center;width:max-content;padding:5px 9px;border-radius:999px;background:#b99b56;color:#fffdf8;font-size:.74rem;font-weight:900}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:12px 0 0}.quick-action,.card-link,.primary-button,.secondary-button{min-height:48px;border-radius:16px;font-weight:900}.quick-action{display:grid;place-items:center;border:1px solid var(--line);background:rgba(255,253,248,.94);color:var(--ink);box-shadow:0 10px 24px rgba(100,82,46,.10)}.quick-action--danger{color:#8b5d1e;background:#fff7ea}.main-content,.page-content{position:relative;z-index:1;max-width:none;margin:0;padding:0 16px 26px}.status-strip,.nav-grid,.grid-cards,.option-grid,.doc-grid{display:grid;grid-template-columns:1fr;gap:10px}.status-strip{grid-template-columns:repeat(2,1fr);background:rgba(255,253,248,.94);border:1px solid rgba(234,220,198,.78);border-radius:22px;padding:12px;margin:0 0 14px;box-shadow:var(--shadow)}.status-strip article,.card,.doc-card,.option-card,.message-card{background:rgba(255,253,248,.95);border:1px solid var(--line);border-radius:18px;padding:13px;box-shadow:0 10px 24px rgba(100,82,46,.08)}.status-strip article{box-shadow:none}.status-strip span,.muted,.card small,.option-card small{display:block;color:var(--muted);font-size:.78rem}.status-strip strong{display:block;margin-top:3px;font-size:1.08rem;color:var(--ink)}.section-title{margin:14px 0 12px}.section-title h2{font-size:1.18rem;letter-spacing:-.02em}.section-title p{margin:4px 0 0;color:var(--muted);font-size:.9rem}.nav-grid{background:rgba(255,253,248,.94);border:1px solid rgba(234,220,198,.78);border-radius:22px;padding:12px;box-shadow:var(--shadow)}.card-link{display:grid;grid-template-columns:1fr auto;align-items:center;text-align:left;background:linear-gradient(180deg,#fffdf8,#fffaf0);padding:14px 14px;border:1px solid var(--line);box-shadow:none}.card-link:after{content:attr(data-chip);min-width:44px;min-height:36px;border-radius:13px;background:#b99b56;color:#fffdf8;font-size:.76rem;font-weight:950;display:grid;place-items:center}.card-link span{display:block;font-size:1.04rem;font-weight:950}.card-link small{margin-top:4px;color:var(--muted);font-size:.82rem}.accordion{background:rgba(255,253,248,.95);border:1px solid var(--line);border-radius:18px;margin:10px 0;box-shadow:0 10px 24px rgba(100,82,46,.08);overflow:hidden}.accordion summary{min-height:58px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:950;list-style:none}.accordion summary::-webkit-details-marker{display:none}.accordion summary:after{content:"⌄";width:28px;height:28px;border-radius:10px;background:#f6eddc;color:#9c7e3b;display:grid;place-items:center;font-weight:950}.accordion[open] summary:after{content:"⌃"}.accordion summary small{color:var(--muted);font-weight:700}.accordion-body{padding:0 14px 14px}.pill-list{display:flex;flex-wrap:wrap;gap:8px}.pill{background:#f5ecd9;color:#806628;border-radius:999px;padding:7px 10px;font-weight:800;font-size:.82rem}.message-switch{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.secondary-button,.primary-button{padding:10px 12px;border:1px solid var(--line);display:grid;place-items:center;text-align:center}.secondary-button{background:#fffaf0;color:var(--ink)}.secondary-button.is-active,.primary-button{background:#b99b56;color:#fffdf8;border-color:#b99b56}textarea,input{width:100%;border:1px solid var(--line);border-radius:16px;padding:12px;background:#fffdf8;color:var(--ink)}textarea{min-height:110px;resize:vertical}.form-row{display:grid;gap:10px;margin-top:10px}.preview-img{max-width:100%;border-radius:16px;margin-top:10px;display:none}.preview-img.is-visible{display:block}.doc-actions,.option-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.link-button{border:0;background:transparent;color:#8c6f2e;font-weight:950;min-height:44px;padding:6px}.price{font-weight:950;color:#8c6f2e}.option-card.is-paid{border-color:#d9bc73}.money-grid{display:grid;grid-template-columns:1fr;gap:10px}.money-grid article{background:rgba(255,253,248,.95);border:1px solid var(--line);border-radius:16px;padding:12px}.money-grid strong{display:block;margin-top:5px;font-size:1.08rem}.bottom-nav{position:fixed;left:50%;right:auto;bottom:calc(10px + var(--safe-bottom));z-index:50;width:min(398px,calc(100% - 24px));transform:translateX(-50%);display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:rgba(255,253,248,.92);border:1px solid rgba(234,220,198,.88);border-radius:22px;padding:8px;box-shadow:0 12px 34px rgba(100,82,46,.18);backdrop-filter:blur(14px)}.bottom-nav a,.bottom-nav button{min-height:48px;border:0;border-radius:16px;background:#fff7e8;color:var(--ink);font-weight:950;text-align:center;display:grid;place-items:center}.bottom-nav .danger{background:#b99b56;color:#fffdf8}.modal{position:fixed;inset:0;z-index:80;display:none;align-items:flex-end;background:rgba(91,77,59,.45)}.modal.is-open{display:flex}.modal__box{width:100%;max-height:78vh;overflow:auto;background:#fffdf8;border-top-left-radius:24px;border-top-right-radius:24px;padding:18px;box-shadow:var(--shadow)}.modal__header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}.modal__close{width:44px;height:44px;border:0;border-radius:999px;background:#f6eddc;color:var(--ink);font-size:1.35rem}.toast{position:fixed;left:50%;right:auto;transform:translateX(-50%);width:min(398px,calc(100% - 24px));bottom:calc(92px + var(--safe-bottom));z-index:100;display:none;background:var(--ink);color:#fff;border-radius:16px;padding:12px;box-shadow:var(--shadow)}.toast.is-visible{display:block}.api-note{font-size:.82rem;color:var(--muted);margin-top:10px}.hidden{display:none!important}
@media (min-width:700px){body{background:linear-gradient(180deg,#c5d8fa 0%,#eef6ff 100%)}.app-shell{margin-top:0;margin-bottom:0}.hero-card{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(4,1fr)}.status-strip{grid-template-columns:repeat(2,1fr)}.doc-grid,.option-grid,.grid-cards{grid-template-columns:1fr}.modal{align-items:center;justify-content:center}.modal__box{max-width:390px;border-radius:24px}}
@media (max-width:380px){.app-shell{width:100%}.hero__content{padding-left:12px;padding-right:12px}.topbar{margin-left:-12px;margin-right:-12px}.brand-lockup{margin-top:24px;margin-bottom:24px}.hero-card{padding:16px}.quick-actions{grid-template-columns:1fr 1fr}.card-link{padding:13px}.bottom-nav{width:calc(100% - 18px)}}

.check-module{padding-bottom:30px}.check-mode-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}.check-progress{background:rgba(255,253,248,.94);border:1px solid rgba(234,220,198,.78);border-radius:22px;padding:12px;margin:0 0 14px;box-shadow:var(--shadow)}.check-progress__top{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.9rem}.check-progress__bar{height:8px;background:#f1e5cd;border-radius:999px;overflow:hidden;margin-top:9px}.check-progress__bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,#b99b56,#e0c77d);transition:width .25s}.check-steps{display:flex;gap:7px;overflow:auto;padding:10px 0 1px}.check-step{white-space:nowrap;min-height:40px;border:1px solid var(--line);border-radius:999px;background:#fffaf0;color:var(--muted);font-weight:850;padding:7px 10px}.check-step.current{background:#b99b56;color:#fffdf8;border-color:#b99b56}.check-step.done{background:#eef8ee;color:#2f7e3e;border-color:#bde2c1}.check-room-title{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.check-family{border:1px solid var(--line);border-radius:18px;background:#fffdf8;margin:10px 0;overflow:hidden}.check-family__head{width:100%;min-height:62px;border:0;background:transparent;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 14px;text-align:left;color:var(--ink)}.check-family__head strong{display:block;font-size:1rem}.check-family__head small{display:block;color:var(--muted);font-weight:700}.check-family__head em{font-style:normal;font-size:.78rem;font-weight:950;color:#8c6f2e;background:#f6eddc;border-radius:999px;padding:6px 9px}.check-family.is-done .check-family__head em{color:#2f7e3e;background:#eef8ee}.check-family__body{display:none;border-top:1px solid var(--line);padding:12px 14px}.check-family.open .check-family__body{display:block}.check-items p{display:flex;justify-content:space-between;gap:10px;margin:0;padding:8px 0;border-bottom:1px solid rgba(234,220,198,.6)}.check-items p:last-child{border-bottom:0}.check-items strong{font-size:1rem}.check-actions,.check-room-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}.check-problem{border:1px solid #ecd8aa;background:#fffaf0;border-radius:16px;padding:12px;margin-top:12px}.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.problem-choice{min-height:44px;border:1px solid var(--line);background:#fffdf8;border-radius:13px;font-weight:850;color:var(--ink)}.problem-choice.selected{background:#b99b56;color:#fffdf8;border-color:#b99b56}.summary-room{background:#fffdf8;border:1px solid var(--line);border-radius:18px;padding:13px;margin:10px 0}.summary-room h3{margin:0 0 4px}.summary-room ul{margin:8px 0 0;padding-left:18px;color:var(--ink)}
@media (min-width:700px){.check-actions,.check-room-actions,.check-mode-grid{grid-template-columns:1fr 1fr}}


/* V2.0 — Navigation par onglets, remplacement des cartes de navigation */
.tabs-nav{
  position:relative;
  z-index:2;
  display:flex;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:10px 14px 12px;
  margin:0 0 4px;
  background:rgba(255,253,248,.78);
  border-top:1px solid rgba(234,220,198,.55);
  border-bottom:1px solid rgba(234,220,198,.70);
  scrollbar-width:none;
}
.tabs-nav::-webkit-scrollbar{display:none}
.tab-link{
  flex:0 0 auto;
  min-height:44px;
  display:grid;
  place-items:center;
  padding:0 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,253,248,.95);
  color:var(--ink);
  font-size:.88rem;
  font-weight:900;
  box-shadow:0 8px 18px rgba(100,82,46,.08);
}
.tab-link.is-active{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--cream);
}
.nav-grid{display:none!important}
.card-link{display:none!important}
.main-content .section-title{margin-top:12px}
@media (min-width:700px){
  .tabs-nav{justify-content:center;overflow:visible;flex-wrap:wrap}
}

.photo-button{display:grid;place-items:center;min-height:48px;border:1px solid var(--line);border-radius:16px;background:#fffdf8;color:var(--ink);font-weight:950;margin-top:10px;text-align:center;cursor:pointer}.photo-button input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}.photo-button span:before{content:"📷 ";}

/* v2.2 — correction mobile : résumé séjour compact */
.stay-ribbon{
  margin:0 0 10px;
  min-height:64px;
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  background:rgba(255,253,248,.96);
  border:1px solid rgba(234,220,198,.86);
  border-radius:18px;
  box-shadow:0 8px 20px rgba(100,82,46,.08);
}
.stay-ribbon__main{min-width:0;display:grid;gap:3px}
.stay-ribbon__home{font-weight:950;font-size:1rem;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
.stay-ribbon__dates{font-weight:750;font-size:.82rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stay-ribbon__badge{white-space:nowrap;display:inline-grid;place-items:center;min-height:32px;padding:6px 10px;border-radius:999px;background:#b99b56;color:#fffdf8;font-size:.72rem;font-weight:950}
.quick-actions--top{margin-top:8px}
.hero-card{display:none}
@media (max-width:380px){.stay-ribbon{min-height:58px;padding:10px 12px;border-radius:16px}.stay-ribbon__home{font-size:.94rem}.stay-ribbon__dates{font-size:.78rem}.stay-ribbon__badge{font-size:.68rem;padding:5px 8px}}


/* V2.3 — correction mobile : résumé séjour ultra-compact */
.brand-lockup{width:142px!important;height:54px!important;margin:14px auto 12px!important;letter-spacing:.08em!important}
.brand-lockup:before,.brand-lockup:after{width:32px!important;height:32px!important}
.brand-lockup span{font-size:1.02rem!important}
.brand-lockup span:before{font-size:.78rem!important;margin-bottom:-2px!important}
.brand-lockup small{font-size:.44rem!important;margin-top:2px!important}
.hero-card{display:none!important}
.stay-ribbon{display:grid!important;grid-template-columns:1fr auto;align-items:center;gap:10px;min-height:54px!important;margin:0 0 8px!important;padding:9px 11px!important;border-radius:18px!important;background:rgba(255,253,248,.96);border:1px solid rgba(234,220,198,.86);box-shadow:0 8px 18px rgba(100,82,46,.08)}
.stay-ribbon__home{font-size:.95rem!important;line-height:1.05!important}
.stay-ribbon__dates{font-size:.76rem!important;line-height:1.1!important}
.stay-ribbon__badge{min-height:28px!important;padding:5px 8px!important;font-size:.66rem!important}
.quick-actions{margin-top:8px!important;gap:8px!important}
.quick-action{min-height:44px!important;border-radius:14px!important;font-size:.9rem!important}
.tabs-nav{margin-top:8px!important;padding:8px 12px!important}
.tab-link{min-height:42px!important;padding:0 16px!important}
.page-content,.main-content{padding-top:0!important}
.section-title{margin-top:10px!important}
@media (max-width:430px){
  .hero__content{padding:8px 14px 0!important}
  .topbar{height:48px!important;grid-template-columns:40px 1fr 40px!important}
  .icon-button{width:40px!important;height:40px!important;border-radius:13px!important}
  .brand-lockup{width:132px!important;height:48px!important;margin:12px auto 10px!important}
  .stay-ribbon{min-height:50px!important;padding:8px 10px!important;border-radius:16px!important}
  .stay-ribbon__home{font-size:.9rem!important}
  .stay-ribbon__dates{font-size:.73rem!important}
  .stay-ribbon__badge{font-size:.62rem!important;min-height:26px!important}
}


/* V2.4 — remplacement du grand logo par l’icône profil client */
.brand-lockup{display:none!important}
.profile-lockup{
  width:100%;
  margin:10px auto 8px!important;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:var(--ink);
  font-weight:950;
  letter-spacing:-.02em;
}
.profile-lockup img{
  width:56px;
  height:56px;
  border-radius:16px;
  object-fit:contain;
  background:transparent;
  flex:0 0 auto;
  filter:drop-shadow(0 8px 16px rgba(100,82,46,.16));
}
.profile-lockup span{
  font-size:.95rem;
  color:var(--ink);
}
@media (max-width:430px){
  .profile-lockup{margin:8px auto 6px!important;gap:8px}
  .profile-lockup img{width:52px;height:52px;border-radius:14px}
  .profile-lockup span{font-size:.88rem}
}
@media (max-width:360px){
  .profile-lockup img{width:48px;height:48px}
  .profile-lockup span{font-size:.84rem}
}


/* V2.7 — menu hamburger client en haut à gauche */
.hamburger-toggle{
  cursor:pointer;
  font-size:1.05rem!important;
  line-height:1;
}
.topbar__spacer{
  width:40px;
  height:40px;
  display:block;
}
.hamburger-menu{
  position:fixed;
  inset:0;
  z-index:120;
  display:none;
}
.hamburger-menu.is-open{display:block}
.hamburger-menu__backdrop{
  position:absolute;
  inset:0;
  background:rgba(91,77,59,.42);
}
.hamburger-menu__panel{
  position:absolute;
  top:0;
  left:0;
  width:min(310px,86vw);
  min-height:100%;
  padding:calc(14px + env(safe-area-inset-top,0px)) 14px 18px;
  background:#fffdf8;
  border-right:1px solid rgba(234,220,198,.9);
  box-shadow:18px 0 42px rgba(100,82,46,.22);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.hamburger-menu__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:48px;
  margin-bottom:8px;
  color:var(--ink);
}
.hamburger-menu__header strong{
  font-size:1.15rem;
  font-weight:950;
}
.hamburger-menu__close{
  width:44px;
  height:44px;
  border:0;
  border-radius:14px;
  background:#f6eddc;
  color:var(--ink);
  font-size:1.35rem;
  font-weight:900;
}
.hamburger-menu__link{
  min-height:52px;
  display:flex;
  align-items:center;
  padding:0 14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:linear-gradient(180deg,#fffdf8,#fff8ec);
  color:var(--ink);
  font-weight:950;
  box-shadow:0 8px 18px rgba(100,82,46,.08);
}
.hamburger-menu__link:active,
.hamburger-menu__link:hover{
  background:#b99b56;
  color:#fffdf8;
  border-color:#b99b56;
}

/* V2.8 — Accueil repensé : grand logo, actions principales, check-in/check-out dynamique */
body[data-page="portail"] .app-shell.home-shell{
  background:
    radial-gradient(circle at 50% 10%,rgba(255,255,255,.96),rgba(255,255,255,.56) 28%,transparent 58%),
    linear-gradient(180deg,#fdfbf5 0%,#eef6ff 46%,#dcecff 100%);
}
body[data-page="portail"] .app-shell.home-shell:before{display:none}
.home-header{position:relative;z-index:2;padding:18px 18px 6px}
.home-topbar{display:flex;align-items:center;justify-content:space-between;min-height:48px;margin-bottom:18px}
.home-menu-button,.home-more-button{width:48px;height:48px;border:0;border-radius:16px;background:rgba(255,253,248,.76);color:var(--ink);font-size:1.9rem;font-weight:950;display:grid;place-items:center;box-shadow:0 10px 22px rgba(100,82,46,.10)}
.home-more-button{font-size:2rem;line-height:0;letter-spacing:.04em;padding-bottom:8px}
.home-logo{display:block;width:min(82vw,360px);max-height:150px;object-fit:contain;margin:10px auto 28px;filter:drop-shadow(0 10px 20px rgba(100,82,46,.08))}
.home-welcome{margin:0 0 18px;text-align:left}.home-welcome h1{margin:0;font-size:2rem;line-height:1.04;font-weight:1000;letter-spacing:-.05em;color:#121829}.home-welcome p{margin:8px 0 0;font-size:1.08rem;font-weight:650;color:#516078}
.home-main{position:relative;z-index:2;padding:0 18px 30px}.home-actions{display:grid;gap:10px;margin-top:2px}.home-action{width:100%;min-height:86px;border:0;border-top:1px solid rgba(185,155,86,.34);border-bottom:1px solid rgba(185,155,86,.18);border-radius:0;background:rgba(255,253,248,.76);display:grid;grid-template-columns:56px 1fr 28px;align-items:center;gap:14px;text-align:left;padding:14px 0;color:var(--ink)}
.home-action:first-child{border-top-width:2px}.home-action__icon{width:54px;height:54px;border-radius:20px;background:#f5eddb;display:grid;place-items:center;font-size:1.6rem;font-weight:1000;color:#b99b56}.home-action--primary .home-action__icon{background:#eaf3ff;color:#1973de}.home-action--sos .home-action__icon{background:#ffe7e4;color:#d03225;font-size:1rem;letter-spacing:-.06em}.home-action__text{display:grid;gap:3px}.home-action__text strong{font-size:1.42rem;line-height:1.05;font-weight:1000;letter-spacing:-.04em;color:#151515}.home-action__text em{font-style:normal;font-size:.94rem;line-height:1.28;color:#56647c;font-weight:650}.home-action__arrow{font-size:2.1rem;font-weight:700;color:#181818;justify-self:end}.home-action--sos .home-action__text em{color:#7c4740}.home-action.is-disabled{opacity:.82}.home-action.is-disabled .home-action__arrow{opacity:.35}
body[data-page="portail"] .tabs-nav,body[data-page="portail"] .status-strip,body[data-page="portail"] .quick-actions,body[data-page="portail"] .stay-ribbon,body[data-page="portail"] .profile-lockup,body[data-page="portail"] .brand-lockup{display:none!important}
body[data-page="portail"] .bottom-nav{box-shadow:0 -10px 28px rgba(100,82,46,.12)}
@media (max-width:390px){.home-header{padding:14px 16px 4px}.home-logo{width:min(84vw,320px);max-height:126px;margin:4px auto 20px}.home-welcome h1{font-size:1.78rem}.home-welcome p{font-size:1rem}.home-action{min-height:78px;grid-template-columns:50px 1fr 24px;gap:12px;padding:12px 0}.home-action__icon{width:48px;height:48px;border-radius:17px}.home-action__text strong{font-size:1.22rem}.home-action__text em{font-size:.86rem}.home-action__arrow{font-size:1.85rem}.home-menu-button,.home-more-button{width:44px;height:44px;border-radius:15px}}


/* V2.9 — accueil : menu hamburger flottant, suppression barre haute */
body[data-page="portail"] .home-topbar{display:none!important}
body[data-page="portail"] .home-header{padding-top:calc(env(safe-area-inset-top, 0px) + 18px)!important}
body[data-page="portail"] .floating-home-menu,
body[data-page="portail"] .floating-home-more{
  position:fixed;
  top:calc(env(safe-area-inset-top, 0px) + 12px);
  z-index:70;
  width:48px;
  height:48px;
  border-radius:16px;
  background:rgba(255,253,248,.88);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
body[data-page="portail"] .floating-home-menu{left:14px}
body[data-page="portail"] .floating-home-more{right:14px}
body[data-page="portail"] .home-logo{margin-top:22px}
@media (max-width:390px){
  body[data-page="portail"] .floating-home-menu,
  body[data-page="portail"] .floating-home-more{width:44px;height:44px;top:calc(env(safe-area-inset-top, 0px) + 10px)}
  body[data-page="portail"] .floating-home-menu{left:12px}
  body[data-page="portail"] .floating-home-more{right:12px}
  body[data-page="portail"] .home-logo{margin-top:18px}
}


/* V3.0 — suppression du bouton options inutile et menu hamburger flottant seul */
body[data-page="portail"] .home-more-button,
body[data-page="portail"] .floating-home-more{display:none!important}
body[data-page="portail"] .home-header{padding-top:calc(env(safe-area-inset-top, 0px) + 8px)!important}
body[data-page="portail"] .floating-home-menu{
  position:fixed!important;
  top:calc(env(safe-area-inset-top, 0px) + 12px)!important;
  left:14px!important;
  z-index:90!important;
}
body[data-page="portail"] .home-logo{margin-top:44px!important}
@media (max-width:390px){
  body[data-page="portail"] .floating-home-menu{top:calc(env(safe-area-inset-top, 0px) + 10px)!important;left:12px!important}
  body[data-page="portail"] .home-logo{margin-top:42px!important}
}


/* V3.1 — Navigation unifiée : menu hamburger uniquement + SOS flottant */
.app-shell{padding-bottom:calc(22px + var(--safe-bottom))!important;}
.tabs-nav,.bottom-nav{display:none!important;}
.floating-sos{position:fixed;right:calc(14px + env(safe-area-inset-right,0px));bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:70;width:58px;height:58px;border:0;border-radius:999px;background:#b99b56;color:#fffdf8;font-weight:950;box-shadow:0 14px 34px rgba(100,82,46,.24);letter-spacing:.02em;}
body[data-page="portail"] .floating-sos{display:none;}
body:not([data-page="portail"]) .page-content{padding-bottom:88px;}
body:not([data-page="portail"]) .hero__content{padding-bottom:6px;}
body:not([data-page="portail"]) .topbar{position:sticky;top:0;z-index:40;}

/* V3.4 — Prévisualisation photo signalement check-in/out */
.photo-preview{margin-top:10px;border:1px solid var(--line);border-radius:16px;background:#fffdf8;padding:10px;display:grid;gap:10px;justify-items:start}.photo-preview__thumb{border:0;background:transparent;padding:0;width:128px;height:128px;border-radius:14px;overflow:hidden;display:block;box-shadow:0 8px 18px rgba(0,0,0,.08)}.photo-preview__thumb img{display:block;width:100%;height:100%;object-fit:cover;border-radius:14px}.photo-preview__actions{display:grid;grid-template-columns:1fr;gap:8px}.problem-summary-list{display:grid;gap:10px;margin-top:10px}.problem-summary-card{display:grid;grid-template-columns:1fr;gap:10px;border:1px solid var(--line);border-radius:16px;background:#fffaf0;padding:12px}.problem-summary-card__text strong{display:block;font-size:.96rem}.problem-summary-card__text .problem-type{display:inline-flex;margin-top:6px;border-radius:999px;background:#b99b56;color:#fffdf8;padding:5px 9px;font-size:.78rem;font-weight:950}.problem-summary-card__text p{margin:8px 0 0;color:var(--ink);line-height:1.35}.problem-photo-thumb{width:128px;height:128px;border:0;background:transparent;padding:0;border-radius:14px;overflow:hidden;box-shadow:0 8px 18px rgba(0,0,0,.08)}.problem-photo-thumb img{display:block;width:100%;height:100%;object-fit:cover;border-radius:14px}.photo-viewer{display:none;position:fixed;inset:0;z-index:120;background:rgba(31,26,18,.72);align-items:center;justify-content:center;padding:20px}.photo-viewer.is-open{display:flex}.photo-viewer__backdrop{position:absolute;inset:0}.photo-viewer__box{position:relative;z-index:1;width:min(100%,520px);max-height:88vh;display:grid;place-items:center}.photo-viewer__box img{max-width:100%;max-height:84vh;border-radius:18px;box-shadow:0 18px 44px rgba(0,0,0,.28);background:#fff}.photo-viewer__close{position:absolute;top:-14px;right:-8px;width:44px;height:44px;border-radius:999px;border:0;background:#fffdf8;color:var(--ink);font-size:1.6rem;font-weight:900;box-shadow:0 8px 22px rgba(0,0,0,.18)}
@media (min-width:520px){.problem-summary-card{grid-template-columns:1fr 160px;align-items:start}.problem-photo-thumb img{height:120px}}

/* V3.5 — photos de signalement limitées à l’affichage */
@media (max-width:420px){.photo-preview__thumb,.problem-photo-thumb{width:112px;height:112px}.problem-summary-card{grid-template-columns:1fr auto;align-items:start}}
