:root {
  /* ── Palette GeoDahar ── */
  --sand:         #C8A96E;
  --sand-light:   #E8D4A8;
  --sand-dim:     rgba(200,169,110,0.15);
  --terracotta:   #B85C38;
  --terracotta-dim: rgba(184,92,56,0.25);
  --deep-brown:   #3D2B1F;
  --dark:         #1A120B;
  --dark2:        #0F0A06;
  --olive:        #6B7C45;
  --cream:        #F5EDD8;

  /* Compatibility aliases (used in existing code) */
  --blue:         var(--terracotta);
  --blue-dark:    #8B3A1F;
  --purple:       var(--sand);
  --purple-light: var(--sand-light);
  --gold:         var(--sand);
  --bg:           var(--dark);
  --panel:        rgba(26,18,11,0.97);
  --muted:        #A09070;
  --border:       rgba(200,169,110,0.18);
  --ok:           #7aba6a;
  --warn:         var(--sand);
  --bad:          #ef4444;

  --sidebar-w: 384px;
  --sidebar-w-collapsed: 72px;
}

* { box-sizing: border-box; }
html, body, #app { height: 100%; }
body {
  margin: 0;
  background: var(--dark);
  color: var(--cream);
  font-family: 'Barlow', 'Inter', system-ui, sans-serif;
  font-weight: 300;
}

    /* Topbar */
    .topbar{
      position:fixed;inset:0 0 auto 0;height:56px;display:flex;align-items:center;gap:16px;
      padding:0 16px;border-bottom:1px solid rgba(200,169,110,0.25);
      background:linear-gradient(180deg, rgba(26,18,11,.95) 0%, rgba(26,18,11,.85) 100%);
      backdrop-filter:saturate(130%) blur(10px);z-index:20
    }
    .brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.3px;text-decoration:none}
    .brand .logo{width:28px;height:28px;border-radius:8px;background:radial-gradient(circle at 30% 30%, var(--sand), var(--terracotta));box-shadow:0 0 0 2px rgba(200,169,110,.25), 0 10px 30px rgba(184,92,56,.35)}
    .brand .title{font-size:18px}
    .spacer{flex:1}
    .nav{display:flex;gap:8px}
    .nav button{
      appearance:none;border:1px solid rgba(200,169,110,.25);background:rgba(200,169,110,.08);color:var(--cream);cursor:pointer;
      padding:8px 12px;border-radius:10px;font-weight:600;letter-spacing:.2px;font-family:inherit
    }
    .nav button:hover{background:rgba(200,169,110,.2);border-color:var(--sand)}

    /* Layout */
    .layout{
      display:grid;
      grid-template-columns: var(--sidebar-w) 1fr;
      grid-template-rows:56px 1fr;
      grid-template-areas:"top top" "left main";
      height:100%;
    }
    .top{grid-area:top}
    .left{grid-area:left}
    .main{grid-area:main;position:relative}
#cesiumContainer { position: relative; }

    /* Outils panel */
    .panel{
      position:relative;
      top:56px;
      height:calc(100vh - 56px);
      background:linear-gradient(180deg, rgba(26,18,11,0.98), rgba(39,27,17,0.97));
      border-right:1px solid rgba(200,169,110,0.2);
      padding:14px 12px;
      overflow:auto;
      width:var(--sidebar-w);
    }
    .section-title{font-size:11px;text-transform:uppercase;letter-spacing:.22em;color:var(--sand);margin:10px 6px 14px;font-weight:600;font-family:'Barlow',sans-serif}
    .tool-grid{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:8px;margin:6px}
    .tool-btn{
      display:flex;flex-direction:column;align-items:flex-start;gap:8px;justify-content:center;
      padding:12px;border-radius:12px;border:1px solid rgba(200,169,110,.12);background:rgba(61,43,31,.5);cursor:pointer
    }
    .tool-btn:hover{background:rgba(61,43,31,.8);border-color:rgba(200,169,110,.35)}
    .tool-btn .label{font-weight:700;color:var(--cream)}
    .tool-btn .sublabel{font-size:12px;color:var(--muted)}

    .card{margin:12px;border:1px solid var(--border);border-radius:14px;background:#1E1208}
    .card .card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}
    .card .card-body{padding:12px}
    .inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
    .inline .grow{flex:1}
    .field{display:flex;flex-direction:column;gap:6px}
    .field label{font-size:12px;color:var(--muted)}
    .field input[type="number"], .field input[type="text"], .field select{
      appearance:none;background:#120D08;color:#F5EDD8;border:1px solid var(--border);border-radius:10px;padding:10px 12px;outline:none
    }
    .chip{font-size:12px;background:rgba(200,169,110,.15);border:1px solid rgba(200,169,110,.35);padding:4px 8px;border-radius:999px;color:#E8D4A8}
    .btn{
      appearance:none;border:1px solid var(--border);background:linear-gradient(180deg, var(--terracotta), var(--deep-brown));
      color:#fff;padding:10px 12px;border-radius:10px;font-weight:700;cursor:pointer
    }
    .btn.secondary{background:#120D08}
    .btn.ghost{background:transparent}
    .btn.block{width:100%}
    .danger{color:#ffd1d1;border-color:rgba(255,107,107,.4)}





    /* Cesium container */
    #cesiumContainer{position:absolute;inset:56px 0 0 0}





    /* Floating controls on map */
    .hud{
      position:absolute;right:14px;top:70px;display:flex;flex-direction:column;gap:10px;z-index:15
    }
    .hud .widget{background:rgba(26,18,11,.75);border:1px solid var(--border);backdrop-filter:blur(6px);padding:10px 12px;border-radius:12px}
    .hud .widget h4{margin:0 0 8px 0;font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
    .row{display:flex;align-items:center;gap:8px}

    /* Modal */
    .modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:40}
    .modal .dialog{width:min(900px,92vw);max-height:85vh;overflow:auto;background:#1A120B;border:1px solid var(--border);border-radius:16px}
    .modal .dialog header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
    .modal .dialog .content{padding:16px}
    .kbd{border:1px solid var(--border);border-bottom-width:2px;border-right-width:2px;border-radius:6px;padding:.1em .4em;background:#120D08;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

    .hidden{display:none}
    .fade-in{animation:fade .25s ease-out}
    @keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
  




    .panel{width:360px; background:linear-gradient(180deg, rgba(61,43,31,.08), rgba(184,92,56,.06)); border-right:1px solid var(--border);}
    .tool-gallery{display:grid;grid-template-columns:1fr;gap:10px;margin:10px}
    .tool-card{display:grid;grid-template-columns:88px 1fr;gap:12px;align-items:center;padding:10px;border-radius:14px;cursor:pointer;border:1px solid var(--border);background:#180E07;transition:transform .12s ease, background .2s ease}
    .tool-card:hover{transform:translateY(-1px);background:#251608}
    .tool-card .meta .label{font-weight:800}
    .tool-card .meta .sublabel{font-size:12px;color:var(--muted)}
    .thumb{width:88px;height:64px;border-radius:10px;border:1px solid var(--border);background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}

    /* Thumbs via data-URI SVG */
    .thumb-mines{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><defs><linearGradient id='g' x1='0' y1='0' x2='0' y2='1'><stop offset='0' stop-color='%230354c3'/><stop offset='1' stop-color='%23024aa6'/></linearGradient></defs><rect width='240' height='160' fill='url(%23g)'/><path d='M20 130 L60 70 L100 110 L140 60 L180 120 L220 90' fill='none' stroke='%23C8A96E' stroke-width='6'/><circle cx='60' cy='70' r='8' fill='%23C8A96E'/></svg>")}
    .thumb-affleurements{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' fill='%23024aa6'/><path d='M0 110 Q60 90 120 110 T240 110' fill='none' stroke='%23C8A96E' stroke-width='6'/><path d='M0 130 Q60 110 120 130 T240 130' fill='none' stroke='%23E8D4A8' stroke-width='4' stroke-dasharray='10 8'/></svg>")}
    .thumb-carrieres{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' fill='%230354c3'/><rect x='40' y='70' width='160' height='50' fill='rgba(200,169,110,0.25)' stroke='%23C8A96E' stroke-width='4'/><path d='M40 120 L80 90 L120 120 L160 85 L200 120' fill='none' stroke='%23E8D4A8' stroke-width='4'/></svg>")}
    .thumb-sondages{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' fill='%230b1426'/><circle cx='60' cy='40' r='10' fill='%23C8A96E'/><line x1='60' y1='40' x2='60' y2='140' stroke='%23C8A96E' stroke-width='6'/><line x1='60' y1='80' x2='170' y2='140' stroke='%23ffffff' stroke-width='3' stroke-dasharray='6 8'/></svg>")}
    .thumb-geotope{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><defs><radialGradient id='rg' cx='50%' cy='40%' r='60%'><stop offset='0' stop-color='%23C8A96E'/><stop offset='1' stop-color='%23024aa6'/></radialGradient></defs><rect width='240' height='160' fill='url(%23rg)'/><polygon points='120,30 150,80 120,130 90,80' fill='rgba(255,255,255,0.35)' stroke='white' stroke-width='3'/></svg>")}
  

    /* ——— Variante: vrais boutons simples (au lieu de cartes) ——— */
    .tool-buttons{display:flex;flex-direction:column;gap:10px;margin:10px}
    .tool-btn2{display:flex;align-items:center;gap:12px;width:100%;
      padding:12px 14px;border-radius:14px;border:1px solid var(--border);
      background:#120D08;color:#F5EDD8;cursor:pointer;font:inherit;text-align:left}
    .tool-btn2:hover{background:#221508;border-color:rgba(200,169,110,.4)}
    .tool-btn2:active{transform:translateY(1px)}
    .tool-btn2 .txt strong{display:block;font-weight:800}
    .tool-btn2 .txt small{display:block;font-size:12px;color:var(--muted)}
    .tool-btn2 .ico{width:42px;height:42px;border-radius:10px;border:1px solid var(--border);
      background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}

    /* icônes (SVG inline en data-URI) */
    .i-mines{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><defs><linearGradient id='g' x1='0' y1='0' x2='0' y2='1'><stop offset='0' stop-color='%230354c3'/><stop offset='1' stop-color='%23024aa6'/></linearGradient></defs><rect width='240' height='160' rx='16' ry='16' fill='url(%23g)'/><path d='M20 120 L60 70 L100 110 L140 60 L180 120 L220 95' fill='none' stroke='%23C8A96E' stroke-width='6'/></svg>")}
    .i-affleurements{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' rx='16' ry='16' fill='%23024aa6'/><path d='M0 100 Q60 85 120 100 T240 100' fill='none' stroke='%23C8A96E' stroke-width='6'/><path d='M0 125 Q60 108 120 125 T240 125' fill='none' stroke='%23E8D4A8' stroke-width='4' stroke-dasharray='10 8'/></svg>")}
    .i-carrieres{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' rx='16' ry='16' fill='%230354c3'/><rect x='40' y='70' width='160' height='50' rx='8' ry='8' fill='rgba(200,169,110,0.25)' stroke='%23C8A96E' stroke-width='4'/><path d='M40 120 L80 90 L120 120 L160 85 L200 120' fill='none' stroke='%23E8D4A8' stroke-width='4'/></svg>")}
    .i-sondages{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' rx='16' ry='16' fill='%230b1426'/><circle cx='60' cy='40' r='10' fill='%23C8A96E'/><line x1='60' y1='40' x2='60' y2='140' stroke='%23C8A96E' stroke-width='6'/><line x1='60' y1='80' x2='170' y2='140' stroke='%23ffffff' stroke-width='3' stroke-dasharray='6 8'/></svg>")}
    .i-geotope{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><defs><radialGradient id='rg' cx='50%' cy='40%' r='60%'><stop offset='0' stop-color='%23C8A96E'/><stop offset='1' stop-color='%23024aa6'/></radialGradient></defs><rect width='240' height='160' rx='16' ry='16' fill='url(%23rg)'/><polygon points='120,30 150,80 120,130 90,80' fill='rgba(255,255,255,0.35)' stroke='white' stroke-width='3'/></svg>")}
  

    /* —— Barre d’actions en bas de la carte —— */
    .bottom-dock{position:absolute;left:14px;right:14px;bottom:14px;z-index:16;
      display:flex;gap:10px;overflow:auto;padding:10px;border:1px solid var(--border);
      border-radius:14px;background:rgba(26,18,11,.78);backdrop-filter:blur(6px)}
    .bottom-dock .tool-btn2{width:auto;white-space:nowrap}
    .bottom-dock::-webkit-scrollbar{height:8px}




.brand{display:flex;align-items:center;gap:.6rem;}
.brand-badge{
  width:28px;height:28px;border-radius:9px;
  background:linear-gradient(145deg,var(--gold),#e9c83e);
  box-shadow:inset 0 0 0 2px rgba(0,0,0,.15);
}
.brand-text{font-weight:1000;font-size:1.85rem;letter-spacing:.2px}
.brand-geo{color:var(--sand)}
.brand-dahar{color:var(--terracotta)}
.beta-badge{
  padding:.15rem .6rem;border-radius:999px;font-weight:700;font-size:.8rem;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(184,92,56,.12); color:var(--gold)
}
:root{
  --sidebar-w: 384px;            /* largeur sidebar ouverte */
  --sidebar-w-collapsed: 72px;   /* largeur sidebar fermée (icônes seules) */
}

/* Panneaux outils (boreholes/forages, etc.) */
.tool-drawer{
  position:fixed;
  left:calc(var(--sidebar-w) + 16px);
  right:16px; bottom:16px;
  z-index:40;
  max-width:min(560px, calc(100vw - var(--sidebar-w) - 48px));
  background:rgba(26,18,11,.9); backdrop-filter:blur(5px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px; padding:16px; box-shadow:0 12px 36px rgba(0,0,0,.35);
}
body.sidebar-collapsed .tool-drawer{
  left:calc(var(--sidebar-w-collapsed) + 16px);
  max-width:min(640px, calc(100vw - var(--sidebar-w-collapsed) - 48px));
}
.tool-drawer h3{margin:0 0 10px 0;font-size:1.05rem}
.tool-drawer .form-row{display:flex;gap:12px;flex-wrap:wrap}
.tool-drawer input{height:42px}





.tool-btn2 .ico{display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(145deg,rgba(200,169,110,.15),rgba(184,92,56,.12));
  border:1px solid rgba(255,255,255,.06); flex-shrink:0;
}
.tool-btn2 .ico i{font-size:1.05rem;opacity:.95}
.tool-btn2{display:flex;gap:.8rem;align-items:center;width:100%;
  padding:.6rem .75rem;border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.06); color:#F5EDD8; text-align:left;
}
.tool-btn2:hover{border-color:rgba(184,92,56,.45);box-shadow:0 6px 18px rgba(184,92,56,.18)}
.tool-btn2 .txt strong{display:block;font-weight:700}
.tool-btn2 .txt small{display:block;opacity:.75;margin-top:2px}

.btn-geo{
  display:flex; align-items:center; gap:.75rem;
  padding:.55rem .75rem; border-radius:12px; 
  background:linear-gradient(180deg,#0f1b2d,#0b1422);
  border:1px solid rgba(255,255,255,.08); color:#F5EDD8;
}
.btn-geo:hover{border-color:rgba(184,92,56,.55); box-shadow:0 8px 22px rgba(184,92,56,.22)}
:root{ --sidebar-w:384px; --sidebar-w-collapsed:72px; }
.tool-drawer{
  position:fixed; left:calc(var(--sidebar-w) + 16px); right:16px; bottom:16px;
  z-index:40; max-width:min(560px, calc(100vw - var(--sidebar-w) - 48px));
  background:rgba(26,18,11,.9); border:1px solid rgba(255,255,255,.08);
  border-radius:16px; padding:16px; backdrop-filter:blur(5px);
}
body.sidebar-collapsed .tool-drawer{
  left:calc(var(--sidebar-w-collapsed) + 16px);
  max-width:min(640px, calc(100vw - var(--sidebar-w-collapsed) - 48px));
}
.hidden { display: none !important; }

.tool-tree { display: flex; flex-direction: column; gap: 12px; margin: 10px 0 0 0; }

.tree-level { display: grid; grid-template-columns: 1fr; gap: 10px; }

.card-btn {
  position: relative;
  display: grid;
  grid-template-columns: 56px 1fr;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(39,27,17,.9), rgba(26,18,11,.9));
  border-radius: 14px;
  color: #F5EDD8;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s;
}
.card-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.35); border-color: rgba(200,169,110,.35); }

.card-btn::before{
  content:"";
  width: 56px; height: 56px;
  border-radius: 12px;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(200,169,110,.25), transparent 60%),
    var(--thumb, linear-gradient(135deg,#223,#112));
  background-size: cover;
  background-position: center;
  outline: 1px solid rgba(255,255,255,.08);
}

.card-btn .title { font-weight: 700; letter-spacing:.2px; display:block; line-height:1.15; }
.card-btn .subtitle { display:block; font-size:12px; opacity:.7; margin-top:2px; }

.back-btn{
  all: unset;
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:10px;
  background: rgba(255,255,255,.06); color:#F5EDD8; cursor:pointer;
  width:max-content; border:1px solid rgba(255,255,255,.1);
}
.back-btn:hover{ background: rgba(255,255,255,.1); }

.tool-tree button {
  background: #120D08;
  border: 1px solid var(--border);
  color: #F5EDD8;
  padding: 8px 10px;
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
}
.tool-tree button:hover {
  background: #221508;
}
.theme-mines{
  --bg: #160D06;
  --panel: #1E1208;
  --card: #221508;
  --card2:#1A1007;
  --text: #F5EDD8;
  --muted:#A09070;
  --brand:#B85C38;    /* bleu */
  --brand2:#8B3A1F;   /* bleu foncé */
  --accent:#C8A96E;   /* jaune */
  --ring: rgba(200,169,110,.45);
}

.tool-tree.theme-mines{ gap:14px; margin:12px 0 0 0; }
.tree-level{ display:flex; flex-direction:column; gap:10px; }

.tile-btn{
  --r:14px;
  display:grid; grid-template-columns: 56px 1fr 18px; align-items:center; gap:12px;
  width:100%; padding:12px 14px;
  background: linear-gradient(180deg,var(--card),var(--card2));
  border:1px solid rgba(255,255,255,0.06);
  border-radius: var(--r);
  color:var(--text); text-align:left; cursor:pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.tile-btn:hover{
  transform: translateY(-2px);
  border-color: var(--ring);
  box-shadow: 0 10px 24px rgba(0,0,0,.35), 0 0 0 4px var(--ring);
}

.tile-icon{
  width:56px; height:56px; border-radius:12px;
  display:grid; place-items:center; font-size:22px;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(184,92,56,.35), transparent 60%),
    linear-gradient(135deg, var(--brand2), var(--brand));
  color:#fff; border:1px solid rgba(255,255,255,.08);
}

.tile-text .t-title{ display:block; font-weight:800; letter-spacing:.2px; line-height:1.1; }
.tile-text .t-sub{ display:block; font-size:12px; color:var(--muted); margin-top:2px; }

.tile-caret{ color:var(--accent); opacity:.9; }

.chip-back{
  all: unset; display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px; cursor:pointer;
  background: rgba(200,169,110,.12); color:var(--text);
  border:1px solid rgba(200,169,110,.35);
  width:max-content; transition: transform .12s ease, background .12s ease;
}
.chip-back:hover{ transform: translateY(-1px); background: rgba(200,169,110,.18); }

/* util */
.hidden{ display:none !important; }
body {
  margin:0;
  background:var(--bg);
  color:var(--cream); /* gris foncé lisible */
  font-family: Inter, system-ui, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

/* Topbar clair */
.topbar {
  position:fixed;inset:0 0 auto 0;height:56px;
  display:flex;align-items:center;gap:16px;
  padding:0 16px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg, rgba(184,92,56,.1) 0%, rgba(200,169,110,.1) 100%);
  backdrop-filter:saturate(130%) blur(8px);
  z-index:20;
}
.brand-text {
  font-weight:900;
  font-size:1.6rem;
}
.brand-geo { color: var(--sand); }
.brand-dahar { color: var(--terracotta); }
.beta-badge {
  padding:.15rem .6rem;
  border-radius:999px;
  font-weight:600;
  font-size:.8rem;
  border:1px solid var(--purple-light);
  background:rgba(184,92,56,.1);
  color:var(--sand);
}

/* Sidebar claire */
.panel {
  background:var(--panel);
  border-right:1px solid var(--border);
  color:var(--cream);
}
.section-title { color: var(--sand); font-weight:600; }

/* Boutons */
.tool-btn2 {
  display:flex;align-items:center;gap:.8rem;width:100%;
  padding:.75rem 1rem;border-radius:14px;
  background:linear-gradient(180deg, rgba(61,43,31,0.6), rgba(39,27,17,0.6));
  border:1px solid var(--border); color:#7c9dcb; text-align:left;
  transition:all .2s;
}
.tool-btn2:hover {
  border-color:#F5EDD8;
    box-shadow:0 4px 12px rgba(200,169,110, 0.2);

}
.tool-btn2 .ico {
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(145deg,var(--purple-light),var(--blue));
  color:white;
}
.tool-btn2 .ico i { font-size:1.1rem; }

/* Modals */
.modal .dialog {
  background:rgba(26,18,11,0.97); color:var(--cream);
  border:1px solid var(--border);
}
.modal .dialog header {
  border-bottom:1px solid var(--border);
}

/* ==== PATCH boutons-images dans .tool-buttons ==== */

/* 1) Supprimer le carré noir auto (pseudoelement) */
.tool-buttons .tool-btn2.card-btn::before {
  content: none !important;
}

/* 2) Layout "carte" propre */
.tool-buttons { display: grid; gap: 16px; }

.tool-buttons .tool-btn2.card-btn{
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  padding: 16px 14px 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(39,27,17,.9), rgba(26,18,11,.9));
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}

/* 3) La vignette image */
.tool-buttons .tool-btn2.card-btn .thumb{
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;             /* coupe l'image aux coins arrondis */
  background: #0e1730;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.tool-buttons .tool-btn2.card-btn .thumb img{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transform: translateZ(0);
  transition: transform .35s ease;
}

/* 4) Titre / sous-titre */
.tool-buttons .tool-btn2.card-btn .txt strong{
  font-size: 18px; font-weight: 800; color: #fff; letter-spacing:.2px;
}
.tool-buttons .tool-btn2.card-btn .txt small{
  font-size: 13px; color: #A09070; margin-top: 2px;
}

/* 5) Effet hover doux (carte + image) */
.tool-buttons .tool-btn2.card-btn:hover{
  transform: translateY(-2px);
  border-color: rgba(200,169,110,.35);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
.tool-buttons .tool-btn2.card-btn:hover .thumb img{
  transform: scale(1.03);
}

/* 6) Accessibilité focus */
.tool-buttons .tool-btn2.card-btn:focus-visible{
  outline: 3px solid rgba(200,169,110,.45);
  outline-offset: 2px;
}
/* === PATCH: boutons images propres + grille 2 colonnes === */

/* 0) Supprimer le petit carré sombre généré par ::before */
.tool-buttons .tool-btn2.card-btn::before { content: none !important; }

/* 1) Grille: 2 colonnes dès que la largeur le permet, sinon 1 colonne */
#panelOutils .tool-buttons{
  display:grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:14px;
  margin:12px;
}
@media (max-width: 420px){
  #panelOutils .tool-buttons{ grid-template-columns: 1fr; }
}

/* 2) Carte bouton: on passe en colonne (image au-dessus, texte en dessous) */
.tool-buttons .tool-btn2.card-btn{
  display:flex !important;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
  padding:12px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#f3f4f6,#e5e7eb);
  color:var(--cream);
  transition:transform .18s ease, box-shadow .25s ease, border-color .25s ease;
}

/* 3) Vignette image bien cadrée */
.tool-buttons .tool-btn2.card-btn .thumb{
  width:100%;
  aspect-ratio: 16 / 9;
  overflow:hidden;                /* coupe l'image dans les coins arrondis */
  background:rgba(26,18,11,0.97);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
}
.tool-buttons .tool-btn2.card-btn .thumb img{
  width:100%; height:100%;
  object-fit: cover;              /* 👈 image TOUJOURS bien cadrée */
  display:block;
  transition: transform .35s ease;
}

/* 4) Texte sous l'image */
.tool-buttons .tool-btn2.card-btn .txt strong{
  display:block; font-weight:800; font-size:16px; color:#1f2a44;
}
.tool-buttons .tool-btn2.card-btn .txt small{
  display:block; font-size:13px; color:#6b7280; margin-top:2px;
}

/* 5) Hover / focus doux et pro */
.tool-buttons .tool-btn2.card-btn:hover{
  transform: translateY(-3px);
  border-color: rgba(184,92,56,.35); /* violet doux */
  box-shadow: 0 10px 26px rgba(0,0,0,.12);
}
.tool-buttons .tool-btn2.card-btn:hover .thumb img{ transform: scale(1.04); }
.tool-buttons .tool-btn2.card-btn:focus-visible{
  outline: 3px solid rgba(184,92,56,.45);
  outline-offset: 2px;
}

/* 6) Nettoyage: l’ancienne icône .ico n’est plus utilisée dans cette variante */
.tool-buttons .tool-btn2.card-btn .ico{ display:none !important; }

#panelOutils .tool-buttons {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media(max-width: 480px){
  #panelOutils .tool-buttons {
    grid-template-columns: 1fr; /* une seule colonne sur mobile */
  }
}
.tool-btn2 .ico {
  overflow: hidden;
}
.tool-btn2 .ico img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}
.tool-btn2:hover {
  transform: translateY(-2px);
  border-color: var(--purple-light);
  box-shadow: 0 8px 20px rgba(184,92,56,.2);
}

.tool-btn2:focus-visible {
  outline: 2px solid var(--purple-light);
  outline-offset: 3px;
}
.tool-btn2 .ico::after {
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.25), rgba(0,0,0,0));
}
/* Séparation visuelle entre sidebar et viewer */
.panel {
  border-right: 1px solid rgba(0,0,0,.08);
  box-shadow: 4px 0 16px rgba(0,0,0,.08);
  z-index: 10;
}
.nav button {
  appearance: none;
  border: none;
  background: linear-gradient(135deg, var(--purple), var(--blue));
  color: #fff;
  cursor: pointer;
  padding: 8px 14px;
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: .2px;
  transition: transform .15s ease, box-shadow .2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}

.nav button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(184,92,56,.25);
}

.nav button:active {
  transform: translateY(0);
  box-shadow: 0 3px 8px rgba(184,92,56,.25);
}
.nav button {
  background: rgba(184,92,56,.15);
  border: 1px solid rgba(184,92,56,.35);
  backdrop-filter: blur(6px);
  color: var(--purple);
}
.nav button:hover {
  background: rgba(184,92,56,.25);
}
.map-attrib {
  gap: 12px;
  justify-content: center;
  align-items: center;
  
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.4));
  backdrop-filter: blur(6px);
  margin-bottom: 10px;
}

.attrib-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: #1f2937;
  text-decoration: none;
  transition: transform .15s ease;
}
.attrib-item:hover {
  transform: scale(1.05);
}
.attrib-item img {
  width: 32px;
  height: 22px;
  object-fit: contain;
}
/* ===== Topbar actions : Outils / Tutoriel ===== */
.topbar .nav { display:flex; gap:10px; }

.topbar .nav .tb-btn{
  --bg: rgba(184,92,56,.14);     /* violet clair */
  --bd: rgba(184,92,56,.35);
  --fg: #2b2d42;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .9rem; border-radius:999px;
  border:1px solid var(--bd); background:var(--bg);
  color:var(--fg); font-weight:700; letter-spacing:.2px;
  backdrop-filter: blur(6px) saturate(120%);
  transition: transform .15s ease, box-shadow .25s ease, background .2s ease, border-color .2s ease;
}
.topbar .nav .tb-btn i{ font-size:1rem; opacity:.9; }
.topbar .nav .tb-btn:hover{
  transform: translateY(-1px);
  background: rgba(184,92,56,.22);
  box-shadow: 0 8px 22px rgba(184,92,56,.22);
  border-color: rgba(184,92,56,.5);
}
.topbar .nav .tb-btn:active{ transform: translateY(0); box-shadow: 0 4px 12px rgba(184,92,56,.2); }
.topbar .nav .tb-btn:focus-visible{ outline:3px solid rgba(184,92,56,.45); outline-offset:3px; }

/* Variante “ghost-bleu” (ex: Tutoriel) */
.topbar .nav .tb-btn.ghost{
  --bg: rgba(200,169,110,.12);
  --bd: rgba(200,169,110,.35);
}
.topbar .nav .tb-btn.ghost:hover{
  background: rgba(200,169,110,.2);
  box-shadow: 0 8px 22px rgba(200,169,110,.22);
  border-color: rgba(200,169,110,.5);
}
/* ===== Modal tutoriel (look pro) ===== */
.modal{background:rgba(26,18,11,.45); backdrop-filter: blur(4px); }
.modal .dialog{
  width:min(900px,92vw); max-height:86vh; overflow:auto;
  border-radius:18px; background:rgba(26,18,11,0.97); color:#0f172a;
  box-shadow: 0 20px 60px rgba(3, 20, 46, .35);
  animation: tscale .18s ease-out;
}
@keyframes tscale{ from{ opacity:0; transform:translateY(8px) scale(.98);} to{ opacity:1; transform:none;} }

.modal .dialog header{
  position:sticky; top:0;
  background:rgba(26,18,11,0.97); z-index:1;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid rgba(0,0,0,.06);
}
.modal .dialog header h3{ margin:0; font-size:1.1rem; font-weight:800; letter-spacing:.2px; }

.modal .dialog .content{ padding:18px; }
.modal .dialog ol{ margin:0; padding-left:1.2rem; }
.modal .dialog li{ margin:.4rem 0; line-height:1.4; }

.kbd, .modal .dialog kbd{
  font: 600 12px ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  background:#f1f5f9; color:#0f172a;
  border:1px solid #e2e8f0; border-bottom-width:2px; border-right-width:2px;
  padding:.15rem .45rem; border-radius:6px;
}

/* Bouton Fermer */
.modal .dialog .close-btn{
  appearance:none; border:1px solid rgba(0,0,0,.08);
  background:#0f172a; color:#fff; border-radius:10px;
  padding:.45rem .7rem; font-weight:700; cursor:pointer;
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.modal .dialog .close-btn:hover{ transform: translateY(-1px); box-shadow: 0 8px 18px rgba(26,18,11,.2); background:#111827; }
.modal .dialog .close-btn:focus-visible{ outline:3px solid rgba(200,169,110,.45); outline-offset:3px; }
.panel{
  border-right:1px solid rgba(0,0,0,.08);
  box-shadow: 6px 0 18px rgba(2,12,32,.06);
  z-index:10;
}
.modal .dialog header {
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 2;
}
.modal .dialog header button {
  border-radius: 8px;
  background: var(--purple);
  color: #fff;
  font-size: .9rem;
}
/* ==== Modals Transparence & Noyau – style pro ==== */
#modalTransparence .dialog,
#modalNoyau .dialog {
  width: min(480px, 92vw);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(10px) saturate(140%);
  color: #1f2937;
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  animation: upscale .2s ease-out;
}

#modalTransparence .dialog header,
#modalNoyau .dialog header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--purple);
}

#modalTransparence .dialog .content,
#modalNoyau .dialog .content {
  padding: 18px;
  font-size: .95rem;
  line-height: 1.4;
}

#modalTransparence label,
#modalNoyau label {
  font-weight: 600;
  color: #374151;
}

#modalTransparence input[type="range"] {
  width: 100%;
  accent-color: var(--purple);
}

#modalTransparence .sublabel {
  font-size: 0.85rem;
  color: var(--muted);
  margin-left: 6px;
}

#modalTransparence .row,
#modalNoyau .row {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

#modalTransparence button.btn.secondary,
#modalNoyau button.btn.secondary {
  border-radius: 8px;
  background: var(--purple);
  color: #fff;
  font-weight: 700;
  padding: .5rem .9rem;
  border: none;
  transition: transform .12s ease, box-shadow .2s ease;
}
#modalTransparence button.btn.secondary:hover,
#modalNoyau button.btn.secondary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(184,92,56,.25);
}

/* petite anim d’apparition */
@keyframes upscale {
  from { opacity: 0; transform: translateY(8px) scale(.96); }
  to { opacity: 1; transform: none; }
}
:root{
  --ms-sidebar-offset: 320px;   /* largeur approx. de ta colonne gauche */
  --ms-radius: 18px;
  --ms-bg: rgba(17,24,39,.94);  /* fond sombre lisible */
}

/* Panneau flottant dans la carte */
.map-submenu{
  position: absolute;
  z-index: 50;                
  left: calc(var(--ms-sidebar-offset) + 500px);
  bottom: 16px;
  width: 600px;
  max-height: min(62vh, 560px);
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 10px;
  padding: 12px;
  border-radius: var(--ms-radius);
  background: var(--ms-bg);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  backdrop-filter: saturate(1.05);
  overflow: hidden;
  transform: translateY(12px);
  opacity: 0;
  pointer-events: none;
  transition: transform .22s cubic-bezier(.2,.8,.2,1), opacity .18s ease;
}
.map-submenu.open{
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.ms-head{
  display:flex; align-items:center; justify-content:space-between;
  gap: 8px; padding: 2px 4px 6px;
}
.ms-head h4{ font-size: .98rem; font-weight: 600; }
.ms-close{
  background: transparent; border: 0; color: #e5e7eb; cursor: pointer;
  width: 36px; height: 36px; border-radius: 10px;
}
.ms-close:hover{ background: rgba(255,255,255,.08); }

/* Grille d’items */
.ms-grid{
  display: grid; gap: 10px;
  grid-template-columns: repeat(3, minmax(0,1fr));
  overflow: auto; padding-right: 4px;
}
@media (max-width: 1200px){
  .ms-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 760px){
  .ms-grid{ grid-template-columns: 1fr 1fr; }
}

.ms-item{
  display:flex; gap:10px; align-items:center;
  padding: 12px; border-radius: 14px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  color:#fff; text-decoration: none;
  transform: translateY(8px); opacity: 0;
  animation: msIn .28s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay: calc(var(--stagger, 0) * .035s);
  will-change: transform, opacity;
}
.ms-item:hover{
  border-color: rgba(16,185,129,.45);
  box-shadow: 0 10px 24px rgba(16,185,129,.18) inset;
}
.ms-item .ic{
  width:40px; height:40px; border-radius: 12px;
  display:grid; place-items:center;
  background: linear-gradient(160deg, #6D4DE6, #4F46E5);
}
.ms-item .ic svg{ width:22px; height:22px; color:#fff; }
.ms-item .tx b{ display:block; font-size:.96rem; color:#EAF2FF; }
.ms-item .tx small{ color: rgba(226,232,240,.85); }

@keyframes msIn{
  from{ transform: translateY(10px); opacity:0; }
  to  { transform: translateY(0);    opacity:1; }
}

/* Mobile = bottom-sheet centré dans la carte */
@media (max-width: 720px){
  .map-submenu{
    left: 50%; bottom: 0;
    width: min(720px, 96vw);
    border-radius: 16px 16px 0 0;
    transform: translate(-50%, 12px);
  }
  .map-submenu.open{ transform: translate(-50%, 0); }
}

/* Si la largeur du sidebar change, ajuste cette valeur */
@media (max-width: 1100px){
  :root{ --ms-sidebar-offset: 280px; }
}
@media (max-width: 980px){
  :root{ --ms-sidebar-offset: 0px; } /* quand la colonne passe en haut */
}
/* === Boutons flottants dans la carte === */
.map-fabs{
  position:absolute; right:16px; bottom:16px; z-index:60;
  display:flex; flex-direction:column; gap:10px;
}

.fab{
  width:58px; height:58px; padding:1px ; border:0; cursor:pointer;
  border-radius:14px; overflow:hidden;
  background: rgba(17,24,39,.75);
  box-shadow: 0 10px 26px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.08);
  transition: transform .12s ease, box-shadow .2s ease, outline-color .2s ease;
}
.fab img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter: saturate(1.05) contrast(1.02);
}
.fab:hover{ transform: translateY(-2px); box-shadow: 0 14px 32px rgba(0,0,0,.45); }
.fab:active{ transform: translateY(-1px); }
.fab[aria-pressed="true"]{
  outline: 3px solid rgba(184,92,56,.45);  /* anneau violet actif */
  outline-offset: 2px;
}
:root{
  --header-h: 56px;     /* hauteur compacte du header */
  --sidebar-w: 384px;   /* largeur menu gauche */
}

/* Header compact collé en haut */
.app-header{
  position:fixed; inset:0 0 auto 0;
  height:var(--header-h);
  display:flex; align-items:center; gap:12px;
  padding:0 16px;
  backdrop-filter:saturate(120%) blur(6px);
  background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.6));
  border-bottom:1px solid rgba(26,18,11,.06);
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  z-index:50;
}

.app-main{
  padding-top:var(--header-h);           /* << enlève l’espace */
}

.sidebar{
  position:fixed; top:var(--header-h); left:0;
  width:var(--sidebar-w); height:calc(100vh - var(--header-h));
  overflow:auto; padding:14px 14px 18px;
  background:rgba(255,255,255,.85);
  border-right:1px solid rgba(26,18,11,.06);
  z-index:30;
}

#cesiumContainer{
  position:fixed;
  top:var(--header-h);
  left:var(--sidebar-w);
  right:0; bottom:0;
}
.brand{display:flex; align-items:center; gap:8px; font-size:18px; color:#0f172a;}
.logo-dot{width:12px; height:12px; border-radius:999px; background:#B85C38; box-shadow:0 0 0 4px rgba(184,92,56,.15);}

.top-search{flex:1; display:flex;}
.top-search input{
  width:100%; height:36px; border-radius:999px; border:1px solid rgba(2,6,23,.08);
  padding:0 14px; outline:none; background:rgba(26,18,11,0.97);
}

.top-actions{display:flex; align-items:center; gap:8px;}
.chip{
  display:flex; align-items:center; gap:8px;
  height:36px; padding:0 12px; border-radius:999px;
  border:1px solid rgba(2,6,23,.08); background:rgba(26,18,11,0.97); cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}
.chip:hover{border-color:rgba(2,6,23,.18); transform:translateY(-1px);}
.chip svg{width:18px; height:18px; fill:none; stroke:#0f172a; stroke-width:2;}

.icon-btn{
  width:36px; height:36px; display:grid; place-items:center; border-radius:12px;
  border:1px solid rgba(2,6,23,.08); background:rgba(26,18,11,0.97); cursor:pointer;
}
.icon-btn:hover{border-color:rgba(2,6,23,.18); transform:translateY(-1px);}
.icon-btn svg{width:18px; height:18px; fill:#0f172a;}
.menu-title{letter-spacing:.08em; margin:4px 8px 10px; font-weight:700;}
.card-btn{margin-bottom:10px;}
.card-btn .thumb img{border-radius:14px;}
.card-btn .txt strong{font-size:14px;}
.card-btn .txt small{opacity:.7;}
/* ====== LAYOUT COMPACT (final) ====== */
:root{
  --header-h: 56px;        /* hauteur du header */
  --sidebar-w: 384px;      /* largeur de la colonne gauche */
}

/* Header collé en haut, look clair et plein */
.topbar{
  position:fixed; inset:0 0 auto 0; height:var(--header-h);
  display:flex; align-items:center; gap:12px; padding:0 16px;
  border-bottom:1px solid rgba(0,0,0,.08);
  background:linear-gradient(180deg, rgba(184,92,56,.10) 0%, rgba(200,169,110,.10) 100%);
  backdrop-filter:saturate(130%) blur(8px);
  z-index:50;
}
.brand-text{font-weight:900; font-size:1.6rem;}
.brand-vaud{color:#B85C38;} .brand-geol{color:#8B3A1F;}

.topbar .nav{display:flex; gap:10px;}
.topbar .nav .tb-btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .9rem; border-radius:999px; font-weight:700; letter-spacing:.2px;
  border:1px solid rgba(184,92,56,.35);
  background:rgba(184,92,56,.14); color:#2b2d42;
  backdrop-filter: blur(6px) saturate(120%);
  transition: transform .15s, box-shadow .25s, background .2s, border-color .2s;
}
.topbar .nav .tb-btn:hover{
  transform: translateY(-1px);
  background: rgba(184,92,56,.22);
  box-shadow: 0 8px 22px rgba(184,92,56,.22);
  border-color: rgba(184,92,56,.5);
}
.topbar .nav .tb-btn.ghost{
  border-color: rgba(200,169,110,.35);
  background: rgba(200,169,110,.12);
}
.topbar .nav .tb-btn.ghost:hover{
  background: rgba(200,169,110,.20);
  box-shadow: 0 8px 22px rgba(200,169,110,.22);
}

/* Sidebar collée sous le header */
.panel{
  position:fixed; top:var(--header-h); left:0;
  width:var(--sidebar-w); height:calc(100vh - var(--header-h));
  overflow:auto; padding:14px 12px 18px;
  background:rgba(26,18,11,0.97); color:var(--cream);
  border-right:1px solid rgba(0,0,0,.08);
  box-shadow: 6px 0 18px rgba(2,12,32,.06);
  z-index:30;
}

/* La carte occupe tout le reste sans GAP */
#cesiumContainer{
  position:fixed;
  top:var(--header-h); left:var(--sidebar-w);
  right:0; bottom:0;
}

/* Barre d’attribution (optionnel, plus dense) */
.map-attrib{
   left:calc(var(--sidebar-w) + 12px); right:12px; bottom:10px;
  display:flex; gap:12px; justify-content:center; align-items:center;
  padding:8px 10px; border-radius:10px;
  background:linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.4));
  backdrop-filter: blur(6px);
  z-index:40;
}
body.dark {
  --bg: #0b1320;
  --panel: #101828;
  --muted: #9ca3af;
  color: #f3f4f6;
  background: var(--bg);
}
body.dark .panel { background: var(--panel); color: #f3f4f6; }
body.dark .topbar { background: rgba(17,24,39,.9); color: #fff; }
body.dark .chip,
body.dark .icon-btn { background: #1f2937; color:#f3f4f6; border-color: rgba(255,255,255,.1); }

.highlight {
  outline: 3px solid var(--purple);
  outline-offset: 3px;
  border-radius: 12px;
}
.chip {
  display:flex; align-items:center; gap:8px;
  height:38px; padding:0 16px;
  border-radius:999px;
  font-family: "Poppins", sans-serif;   /* 👉 font */
  font-size:15px;                       /* 👉 taille texte */
  font-weight:600;
  color:#fff;
  background: linear-gradient(135deg, #B85C38, #C8A96E); /* 👉 violet → bleu */
  border: none;
  cursor:pointer;
  transition: transform .15s, box-shadow .2s, background .2s;
}
.chip:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,.25);
  background: linear-gradient(135deg, #8b5cf6, #2563eb); /* plus clair au hover */
}

.icon-btn {
  width:38px; height:38px;
  display:grid; place-items:center;
  border-radius:12px;
  border:none;
  background: linear-gradient(135deg, #C8A96E, #8B3A1F);
  color:#fff;
  cursor:pointer;
  transition: transform .15s, box-shadow .2s;
}
.icon-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,.25);
}
.icon-btn svg { width:18px; height:18px; fill:#fff; }
.map-fabs .fab {
  width: 40px;
  height: 40px;
  border-radius: 10px;
}


.map-left-fabs {
  position: absolute;
  top: 10px;   
  left: 16px;
  z-index: 60;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.map-left-fabs .fab img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.map-fabs{
  position:absolute;
  right:0px;
  bottom: 35px;                /* valeur par défaut = au-dessus du Fullscreen */
  z-index:60;
  display:flex; flex-direction:column; gap:10px;
}
.map-fabs .fab{ width:40px; height:40px; border-radius:15px; }
.map-fabs .fab img{ width:100%; height:100%; object-fit:cover; }
body.sidebar-collapsed #cesiumContainer { left: 0; }

body.sidebar-collapsed .panel { display: none; }

body.sidebar-collapsed .map-attrib { left: 12px; }

body.sidebar-collapsed { --ms-sidebar-offset: 0px; }
#tools-sidebar.panel{
  padding:14px 12px 18px;
  background: var(--panel);
}

#tools-sidebar h2{
  margin: 6px 6px 10px;
  font-size: 1.6rem;
  font-weight: 800;
  color: #1f2937;             
}

#tools-sidebar ul{
  list-style: none;             
  margin: 10px 8px 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

#tools-sidebar .sidebar-link{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 700;
  letter-spacing: .2px;
  color: #1f2937;               /* évite le violet des liens par défaut */
  background: linear-gradient(180deg, #f3f4f6, #e5e7eb);
  border: 1px solid var(--border);
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
#tools-sidebar .sidebar-link:hover{
  transform: translateY(-2px);
  border-color: var(--purple-light);
  box-shadow: 0 8px 20px rgba(184,92,56,.18);
}

#tools-sidebar .sidebar-link i{
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: 10px;
  color: #fff;
  background: linear-gradient(135deg, var(--purple), var(--blue));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.15);
}

body.dark #tools-sidebar h2{ color: #e5e7eb; }
body.dark #tools-sidebar .sidebar-link{
  color: #F5EDD8;
  background: linear-gradient(180deg, rgba(39,27,17,.9), rgba(26,18,11,.9));
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
body.dark #tools-sidebar .sidebar-link:hover{
  border-color: rgba(184,92,56,.45);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
.map-fabs{
  position:absolute;
  top:10px;            
  right:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:30;
  pointer-events:auto;
}

.fab{
  width:46px; height:46px;
  border:0; padding:0;
  border-radius:12px;
  overflow:hidden;
  background:rgba(26,27,34,.9);
  box-shadow:0 6px 16px rgba(0,0,0,.25);
  cursor:pointer;
  transition:transform .12s ease, opacity .12s ease, box-shadow .12s ease;
}
.fab:hover{ transform:translateY(-1px); }
.fab:active{ transform:translateY(0); }
.fab[aria-pressed="true"]{ outline:2px solid #6d28d9; }

.fab img{ width:100%; height:100%; object-fit:cover; display:block; }

@media (max-width:640px){
  .map-fabs{ top:0px; right:8px; gap:2px; }
  .fab{ width:40px; height:40px; border-radius:10px; }
}
#cesiumContainer::after{
  content:"";
  position:absolute; inset:0;
  background: rgba(0,0,0,.72);  
  opacity:0;                     
  pointer-events:none;          
  transition: opacity .18s ease;
  z-index:25;                  
}
#cesiumContainer.night::after{ opacity:1; }

@media (max-width: 1280px){
  :root{ --sidebar-w: 300px; }
}
@media (max-width: 1100px){
  :root{ --sidebar-w: 280px; }
}

@media (max-width: 900px){

  .layout{
    grid-template-columns: 1fr;
    grid-template-areas:
      "top"
      "main";
  }

  

  #panelOutils .tool-buttons{ grid-template-columns: 1fr; }

  .map-fabs{ top: 72px; right: 8px; gap: 8px; }
  .fab{ width: 40px; height: 40px; border-radius: 10px; }

  .top-actions .chip{ padding: 6px 10px; }
  .search .input{ font-size: 14px; }
}

:root{ --topbar-h:56px; --sidebar-w:384px; }

/* Thèmes : fixe à GAUCHE, pleine hauteur sous la topbar */
#panelThemes.left.panel{
  position: fixed !important;
  top: var(--topbar-h) !important;
  left: 0 !important;
  width: var(--sidebar-w) !important;
  height: calc(100vh - var(--topbar-h)) !important;
  transform: none !important;
  border-radius: 0 !important;
  box-shadow: 6px 0 18px rgba(2,12,32,.06);
  z-index: 30;
}


/* Outils : même place que Thèmes (à gauche), caché par défaut */
#tools-sidebar.outils{
  position: fixed !important;
  top: var(--topbar-h) !important;
  left: 0 !important;
  width: var(--sidebar-w) !important;
  height: calc(100vh - var(--topbar-h)) !important;
  border-radius: 0 !important;
  transform: none !important;
  display: none;                     /* masqué tant qu’on n’ouvre pas */
  z-index: 31;                       /* au-dessus pour remplacer */
}
#tools-sidebar.outils.open{ display:block; }
#panelThemes.left.panel.open{ display:block; }

@media (max-width:900px){
  :root{ --topbar-h: 56px; }       

  #panelThemes.left.panel{
    position:fixed; top:var(--topbar-h); left:0;
    width:min(92vw, 360px);
    height:calc(100vh - var(--topbar-h));
    max-height:none;
    border-radius:0 14px 14px 0;
    transform:translateX(-100%);
  }
  #panelThemes.left.panel.open{ transform:translateX(0); }

  #tools-sidebar.outils{
    position:fixed; top:var(--topbar-h); right:0;
    width:min(92vw, 360px);
    height:calc(100vh - var(--topbar-h));
    max-height:none;
    border-radius:14px 0 0 14px;
    transform:translateX(100%);
  }
  #tools-sidebar.outils.open{ transform:translateX(0); }

  .backdrop{
    position:fixed; inset:var(--topbar-h) 0 0 0;
    background:rgba(0,0,0,.3);
    opacity:0; pointer-events:none;
    transition:opacity .18s ease;
    z-index:27;
  }
  .backdrop.show{ opacity:1; pointer-events:auto; }
}
  #panelThemes.left.panel{
  background: rgba(250, 250, 250, 0.882) !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

#panelThemes .section-title{
  background: rgba(250, 250, 250, 0.882) !important;
  padding: 4px 6px;
  box-shadow: none !important;
  backdrop-filter: none !important;
  border: 0;
}
body.sidebar-collapsed #cesiumContainer { left: 0; }
#cesiumContainer{ left: 0 !important; }

.map-attrib{ left: 12px !important; }

:root{ --ms-sidebar-offset: 0px; }
.ms-group{
  grid-column: 1 / -1;
  font-weight: 800;
  font-size: .92rem;
  letter-spacing: .2px;
  color: #EAF2FF;
  opacity: .9;
  margin: 6px 2px 2px;
}

@media (min-width: 900px) and (max-width: 1200px){
  .map-submenu{
    left: calc(var(--ms-sidebar-offset) + 200px) !important;
    right: 16px !important;
    width: 700px;             
    max-width: none !important;
    bottom: 16px !important;
    padding: 12px !important;
  }
  .ms-head h4{ font-size: .95rem; }
}

@media (min-width: 720px) and (max-width: 900px){
  .map-submenu{
    left: 60px !important;
    right: auto!important;
    width: 650px !important;
    max-width: none !important;
    bottom: 12px !important;
    border-radius: 14px !important;
    padding: 10px !important;
  }
  .ms-grid{ grid-template-columns: 1fr 1fr !important; }
}

@media (max-width: 700px){
  .map-submenu{
    width: min(96vw, 520px) !important;  
    padding: 10px !important;
  }
  .ms-grid{ grid-template-columns: 1fr !important; }
}

#panelThemes.left.panel,
#tools-sidebar.outils{
  width: clamp(260px, 28vw, 360px);
}

@media (min-width: 900px) and (max-width: 1200px){
  #panelThemes.left.panel,
  #tools-sidebar.outils{
    width: clamp(240px, 30vw, 320px);
  }
}

@media (min-width: 720px) and (max-width: 900px){
  #panelThemes.left.panel,
  #tools-sidebar.outils{
    width: clamp(220px, 46vw, 300px);
  }
}

@media (max-width: 700px){
  #panelThemes.left.panel,
  #tools-sidebar.outils{
    width: min(92vw, 360px) !important;
  }
}

/* La carte occupe le reste (décalée par la sidebar) */
body #cesiumContainer{
  position: fixed !important;
  top: var(--topbar-h) !important;
  left: var(--sidebar-w) !important;   /* décalage de la sidebar */
  right: 0 !important;
  bottom: 0 !important;
}

/* Option : quand la sidebar est “cachée” (si tu ajoutes .sidebar-collapsed au body) */
body.sidebar-collapsed #cesiumContainer{ left:0 !important; }
body.sidebar-collapsed #panelThemes.left.panel,
body.sidebar-collapsed #tools-sidebar.outils{ display:none !important; }

/* === “Cartes” (boutons images) en 2 colonnes dans la sidebar === */
#panelThemes .tool-buttons{
  display:grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap:14px !important;
}
@media (max-width:900px){
  #panelThemes .tool-buttons{ grid-template-columns: 1fr !important; }
}

/* Petites cartes plus propres dans la grille */
#panelThemes .tool-buttons .tool-btn2.card-btn{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:10px; padding:12px; border-radius:16px;
}
#panelThemes .tool-buttons .tool-btn2.card-btn .thumb{
  width:100%; aspect-ratio:16/9; border-radius:12px; overflow:hidden;
}
#panelThemes.left.panel:not(.open){ display:none; }
#tools-sidebar.outils:not(.open){ display:none; }

#panelThemes.left.panel,
#tools-sidebar.outils { z-index:30; }
/* =========================================================
   PALETTE VERT & BLANC — OVERRIDES MINIMAUX, LOOK PRO
   (GeoDahar — overrides)
========================================================= */

/* 2.1 — Remap des variables "bleu/violet" → verts */
:root{
  --blue:        #10b981;   /* vert moyen */
  --blue-dark:   #065f46;   /* vert très foncé */
  --purple:      #059669;   /* vert soutenu (ex-violet) */
  --purple-light:#34d399;   /* vert clair pour hovers/badges */
  --panel:#ffffff;
  --bg:#f7f9fb;
  --border:rgba(0,0,0,.08);
  --muted:#6b7280;
  --ok:#10b981; 
  --warn:#f59e0b; 
  --bad:#ef4444;
}

/* 2.2 — Header / topbar en dégradé vert translucide */
.app-header,
.topbar{
  background: linear-gradient(180deg, rgba(16,185,129,.10), rgba(6,95,70,.10)) !important;
  border-bottom:1px solid var(--border);
}

/* 2.3 — Marque */
.brand-vaud{ color:#065f46 !important; }   /* “Vaud” vert profond */
.brand-geol{ color:#10b981 !important; }   /* “Geol” vert moyen */

/* 2.4 — Boutons “chip” (Thèmes, Outils…) → verts */
.chip{
  color:#fff !important;
  background: linear-gradient(135deg, #10b981, #059669) !important;
  border:none !important;
}
.chip:hover{
  background: linear-gradient(135deg, #34d399, #0ea5a0) !important;
}

.icon-btn{
  background: linear-gradient(135deg, #10b981, #065f46) !important;
  color:#fff !important; border:none !important;
}

.section-title{ color:#065f46 !important; }

.tool-buttons .tool-btn2.card-btn{
  background: linear-gradient(180deg, #f5f7f8, #eceff1) !important;
  color:var(--cream) !important;
  border:1px solid var(--border) !important;
}
.tool-buttons .tool-btn2.card-btn:hover{
  border-color: rgba(16,185,129,.35) !important;
  box-shadow: 0 10px 24px rgba(16,185,129,.12) !important;
}
.tool-buttons .tool-btn2.card-btn .txt strong{ color:#0f172a !important; }
.tool-buttons .tool-btn2.card-btn .txt small{ color:#6b7280 !important; }

#tools-sidebar .sidebar-link{
  background: linear-gradient(180deg, #f5f7f8, #eceff1) !important;
  color:#0f172a !important;
  border:1px solid var(--border) !important;
}
#tools-sidebar .sidebar-link:hover{
  border-color: rgba(16,185,129,.35) !important;
  box-shadow: 0 8px 20px rgba(16,185,129,.12) !important;
}
#tools-sidebar .sidebar-link i{
  background: linear-gradient(135deg, #10b981, #059669) !important;
}

.ms-item .ic{
  background: linear-gradient(160deg, #10b981, #059669) !important;
}
.ms-item:hover{
  border-color: rgba(16,185,129,.45) !important;
  box-shadow: 0 10px 24px rgba(16,185,129,.18) inset !important;
}

body.dark{
  --bg:#0b1320;
  --panel:#0f1a24;
  --muted:#a3a3a3;
}
body.dark .panel{ background:var(--panel); }
body.dark .chip,
body.dark .icon-btn{
  filter: saturate(110%);
}

.fab[aria-pressed="true"]{
  outline: 3px solid rgba(16,185,129,.45) !important;
  outline-offset: 2px;
}

.beta-badge{
  border-color: rgba(16,185,129,.35) !important;
  background: rgba(16,185,129,.12) !important;
  color:#065f46 !important;
}

/* ===== POLYLINE 3D — Styles ===== */

.polyline-panel{
  position:absolute;
  right:68px;
  bottom:16px;
  z-index:70;
  width:340px;
  max-width:90vw;
  padding:12px;
  border-radius:14px;
  background:rgba(26,18,11,0.95);
  color:var(--cream);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 14px 36px rgba(0,0,0,.18);
  backdrop-filter:blur(6px) saturate(120%);
  font-family:'Barlow','Inter',system-ui,sans-serif;
}

.polyline-panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:6px;
}

.polyline-panel h4{
  margin:0;
  font-size:.95rem;
  font-weight:800;
  letter-spacing:.2px;
}

.polyline-close{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--cream);
  width:30px;
  height:30px;
  border-radius:8px;
  cursor:pointer;
}
.polyline-close:hover{
  background:rgba(0,0,0,.06);
}

.polyline-row{
  display:flex;
  align-items:center;
  gap:8px;
  margin:8px 0;
}
.polyline-row label{
  font-size:.85rem;
  min-width:110px;
}
.polyline-row input[type="color"]{
  width:40px;
  height:32px;
  padding:0;
  border:0;
  background:transparent;
}
.polyline-row input[type="range"]{
  flex:1;
}

.polyline-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;
}
.polyline-btn{
  appearance:none;
  border:1px solid rgba(200,169,110,.25);
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  font-weight:700;
  background:rgba(26,18,11,0.97);
  color:var(--cream);
  transition:transform .12s ease, box-shadow .18s ease, border-color .18s ease;
}
.polyline-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 18px rgba(0,0,0,.08);
}
.polyline-btn.primary{
  background:linear-gradient(180deg,#B85C3822,#C8A96E1a);
  border-color:#C8A96E;
}
.polyline-btn.danger{
  border-color:rgba(184,92,56,.5);
  color:#ef4444;
}

.hidden{ display:none !important; }

/* Thème sombre (si body.dark) */
body.dark .polyline-panel{
  background:rgba(26,18,11,.92);
  color:#e5e7eb;
  border-color:rgba(255,255,255,.08);
}
body.dark .polyline-btn{
  background:#1E1208;
  border-color:rgba(255,255,255,.12);
  color:#e5e7eb;
}
body.dark .polyline-btn.primary{ border-color:#B85C3888; }
body.dark .polyline-btn.danger{ border-color:rgba(184,92,56,.5); color:#fecaca; }


/* ==== Panneau générique (reutilisable poly/anno) ==== */
.tool-panel {
  position: fixed; right: 18px; top: 84px; z-index: 40;
  width: clamp(280px, 28vw, 420px);
  background: var(--panel-bg, rgba(39,27,17,.92)); color: #fff;
  border: 1px solid rgba(255,255,255,.12); border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35); padding: 12px; backdrop-filter: blur(8px);
}
.tool-panel.hidden { display: none; }
.tool-panel .tp-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.tool-panel .tp-close { background:transparent; border:0; color:#fff; font-size:18px; cursor:pointer; }
.tool-panel .tp-row { display:flex; gap:10px; align-items:center; margin:8px 0; flex-wrap:wrap; }
.tool-panel .field { display:flex; flex-direction:column; gap:6px; min-width:140px; }
.tool-panel input[type="text"]{ padding:.45rem .6rem; border-radius:8px; border:1px solid rgba(255,255,255,.15); background:rgba(0,0,0,.25); color:#fff; }
.tool-panel input[type="color"]{ width:44px; height:34px; border:0; background:transparent; }
.tool-panel input[type="range"]{ width:160px; }
.tool-panel .tp-foot{ font-size:.9rem; opacity:.9; margin-top:4px; }
.tool-panel .tp-actions{ display:flex; justify-content:flex-end; margin-top:8px; }
.switch { display:flex; gap:6px; align-items:center; user-select:none; }

/* FAB (reprend ton style existant) */
.fab[aria-pressed="true"] { outline: 2px solid rgba(255,255,255,.25); }

/* icône annotation blanc */
#fabAnno { color:#fff !important; }           /* FA suit currentColor */
#fabAnno .ico-anno{
  position:relative; display:inline-block; width:1.25em; height:1.25em;
}
#fabAnno .ico-anno .fa-comment{
  position:absolute; inset:0; font-size:1.35em; line-height:1;
}
#fabAnno .ico-anno .fa-pen{
  position:absolute; right:-0.05em; bottom:-0.05em; font-size:0.8em; line-height:1;
}
.sr-only{position:absolute;width:2px;height:2px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,1px,1px);white-space:nowrap;border:0;}

.info-bubble{
    position:absolute; left:0; top:0; transform:translate(-50%,-120%);
    padding:.45rem .6rem; border-radius:10px;
    background:rgba(39,27,17,.92); color:#fff; border:1px solid #ffffff22;
    box-shadow:0 6px 18px rgba(0,0,0,.35);
    font:14px/1.25 Segoe UI, system-ui, sans-serif; z-index:60; pointer-events:auto;
    white-space:nowrap;
  }
  .info-bubble b{font-weight:600}
  .info-bubble .x{margin-left:.6rem; opacity:.8; background:transparent; border:0; color:#fff; cursor:pointer}
  .info-bubble .x:hover{opacity:1}
/* ═══════════════════════════════════════
   GeoDahar — Overrides & Finitions
   ═══════════════════════════════════════ */

/* Brand */
.brand-geo  { color: var(--sand) !important; font-family: 'Playfair Display', serif; font-style: italic; }
.brand-dahar{ color: var(--terracotta) !important; font-family: 'Playfair Display', serif; }
.brand-text { font-size: 1.5rem !important; font-weight: 700 !important; letter-spacing: .5px; }

.logo-dot { display: block; }
.beta-badge {
  padding:.15rem .6rem; border-radius:999px; font-weight:600; font-size:.75rem;
  border:1px solid rgba(200,169,110,.35);
  background:rgba(200,169,110,.1); color:var(--sand);
  font-family:'Barlow',sans-serif;
}

/* Search bar */
.top-search input {
  background: rgba(61,43,31,.5) !important;
  border: 1px solid rgba(200,169,110,.25) !important;
  color: var(--cream) !important;
  border-radius: 10px;
  font-family: 'Barlow', sans-serif;
}
.top-search input::placeholder { color: rgba(200,169,110,.5); }
.top-search input:focus { outline: none; border-color: var(--sand) !important; }

/* HUD widgets */
.hud .widget {
  background: rgba(26,18,11,.85) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
}
.hud .widget h4 { color: var(--sand) !important; }

/* Chip / buttons in topbar */
.chip.tb-btn {
  background: rgba(200,169,110,.1) !important;
  border: 1px solid rgba(200,169,110,.3) !important;
  color: var(--cream) !important;
  font-family: 'Barlow', sans-serif;
  font-weight: 500;
}
.chip.tb-btn:hover { background: rgba(200,169,110,.22) !important; border-color: var(--sand) !important; }
.chip.tb-btn.ghost  { background: transparent !important; }

/* Icon btn (theme toggle) */
.icon-btn { color: var(--sand) !important; }
.icon-btn svg path { fill: var(--sand); }

/* FABs */
.fab {
  background: rgba(184,92,56,.85) !important;
  border: 1px solid rgba(200,169,110,.35) !important;
  box-shadow: 0 6px 20px rgba(184,92,56,.35) !important;
}
.fab:hover { background: rgba(184,92,56,1) !important; }

/* Btn primary */
.btn {
  background: linear-gradient(180deg, var(--terracotta), var(--deep-brown)) !important;
  border: 1px solid rgba(200,169,110,.25) !important;
  color: var(--cream) !important;
  font-family: 'Barlow', sans-serif;
  font-weight: 600;
}
.btn.secondary {
  background: rgba(61,43,31,.5) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
}
.btn.ghost { background: transparent !important; }
.btn:hover { filter: brightness(1.15); }

/* Tile icon gradient → Dahar */
.tile-icon {
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(184,92,56,.45), transparent 60%),
    linear-gradient(135deg, var(--deep-brown), var(--terracotta)) !important;
}

/* Back chip */
.chip-back {
  background: rgba(200,169,110,.12) !important;
  border: 1px solid rgba(200,169,110,.35) !important;
}
.chip-back:hover { background: rgba(200,169,110,.22) !important; }

/* Tile buttons */
.tile-btn {
  background: linear-gradient(180deg, rgba(39,27,17,.9), rgba(26,18,11,.9)) !important;
  border: 1px solid rgba(200,169,110,.1) !important;
  color: var(--cream) !important;
}
.tile-btn:hover {
  border-color: rgba(200,169,110,.45) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.35), 0 0 0 3px rgba(200,169,110,.2) !important;
}
.tile-caret { color: var(--sand) !important; }

/* Card buttons */
.card-btn {
  background: linear-gradient(180deg, rgba(39,27,17,.9), rgba(26,18,11,.9)) !important;
  border: 1px solid rgba(200,169,110,.1) !important;
  color: var(--cream) !important;
}
.card-btn:hover { border-color: rgba(200,169,110,.4) !important; }

/* tool-btn2 */
.tool-btn2 {
  background: linear-gradient(180deg, rgba(39,27,17,.6), rgba(26,18,11,.6)) !important;
  border: 1px solid rgba(200,169,110,.12) !important;
  color: var(--cream) !important;
}
.tool-btn2:hover {
  border-color: rgba(200,169,110,.4) !important;
  box-shadow: 0 6px 18px rgba(184,92,56,.18) !important;
}
.tool-btn2 .ico {
  background: linear-gradient(145deg, rgba(200,169,110,.2), rgba(184,92,56,.15)) !important;
  border: 1px solid rgba(200,169,110,.15) !important;
}
.tool-btn2 .txt strong { color: var(--cream); }
.tool-btn2 .txt small  { color: var(--muted); }

/* tool-drawer */
.tool-drawer {
  background: rgba(26,18,11,.92) !important;
  border: 1px solid rgba(200,169,110,.15) !important;
}
.card-header { border-bottom: 1px solid rgba(200,169,110,.15) !important; }

/* map-submenu */
#map-submenu { background: rgba(26,18,11,.96) !important; border-color: rgba(200,169,110,.2) !important; }
.ms-item { background: rgba(39,27,17,.7) !important; border-color: rgba(200,169,110,.12) !important; color: var(--cream) !important; }
.ms-item:hover { border-color: rgba(200,169,110,.4) !important; }

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(200,169,110,.3); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(200,169,110,.5); }

/* Tool panel (polyline/anno) */
.tool-panel {
  background: rgba(26,18,11,.94) !important;
  border: 1px solid rgba(200,169,110,.18) !important;
  color: var(--cream) !important;
}
.polyline-panel {
  background: rgba(26,18,11,.95) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
  color: var(--cream) !important;
}
.polyline-btn {
  background: rgba(39,27,17,.8) !important;
  border: 1px solid rgba(200,169,110,.25) !important;
  color: var(--cream) !important;
}
.polyline-btn.primary { border-color: var(--sand) !important; }
.polyline-btn.danger  { border-color: rgba(184,92,56,.6) !important; color: #fecaca !important; }
.polyline-close { color: var(--cream) !important; }

/* Modal */
.modal { background: rgba(0,0,0,.65) !important; }
.modal .dialog {
  background: #1A120B !important;
  border: 1px solid rgba(200,169,110,.2) !important;
}
.modal .dialog header { border-bottom: 1px solid rgba(200,169,110,.15) !important; }
.kbd {
  background: #120D08 !important;
  border-color: rgba(200,169,110,.25) !important;
  color: var(--sand) !important;
}

/* Card sondage */
#cardSondage .card-header .chip {
  background: rgba(200,169,110,.12) !important;
  border-color: rgba(200,169,110,.35) !important;
  color: var(--sand) !important;
}

/* Inputs */
input[type="number"], input[type="text"], select {
  background: rgba(26,18,11,.8) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
  color: var(--cream) !important;
  border-radius: 10px;
}
input:focus { outline: none !important; border-color: var(--sand) !important; }

/* Anno panel */
#annoPanel {
  background: rgba(26,18,11,.94) !important;
  border: 1px solid rgba(200,169,110,.18) !important;
}
.switch span { color: var(--sand-light); }

/* Info bubble */
.info-bubble {
  background: rgba(26,18,11,.94) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
}

/* Night mode label on cesium */
#cesiumContainer.night { filter: brightness(0.75) sepia(0.2); }

/* SVG thumb backgrounds → Dahar colors */
.thumb-mines { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><defs><linearGradient id='g' x1='0' y1='0' x2='0' y2='1'><stop offset='0' stop-color='%233D2B1F'/><stop offset='1' stop-color='%231A120B'/></linearGradient></defs><rect width='240' height='160' fill='url(%23g)'/><path d='M20 130 L60 70 L100 110 L140 60 L180 120 L220 90' fill='none' stroke='%23C8A96E' stroke-width='6'/><circle cx='60' cy='70' r='8' fill='%23B85C38'/></svg>") !important; }
.thumb-affleurements { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 160'><rect width='240' height='160' fill='%231A120B'/><path d='M0 110 Q60 90 120 110 T240 110' fill='none' stroke='%23C8A96E' stroke-width='6'/><path d='M0 130 Q60 110 120 130 T240 130' fill='none' stroke='%23E8D4A8' stroke-width='4' stroke-dasharray='10 8'/></svg>") !important; }

/* ============================================================
   GEODAHAR — PALETTE FINALE (écrase tout ce qui précède)
   ============================================================ */

/* Fond général */
body, html { background: #1A120B !important; color: #F5EDD8 !important; }

/* Topbar */
.topbar {
  background: linear-gradient(180deg, rgba(15,8,3,.97), rgba(26,14,6,.93)) !important;
  border-bottom: 1px solid rgba(200,169,110,.22) !important;
}

/* Boutons nav topbar */
.nav button,
.topbar .nav .tb-btn {
  background: rgba(200,169,110,.1) !important;
  border: 1px solid rgba(200,169,110,.28) !important;
  color: #E8D4A8 !important;
}
.nav button:hover,
.topbar .nav .tb-btn:hover {
  background: rgba(200,169,110,.22) !important;
  border-color: #C8A96E !important;
  box-shadow: 0 4px 14px rgba(200,169,110,.18) !important;
  color: #F5EDD8 !important;
}
/* texte fg sombre → clair */
.topbar .nav .tb-btn { --fg: #E8D4A8 !important; color: #E8D4A8 !important; }

/* Sidebar / Panel */
.panel, #panelOutils, #tools-sidebar {
  background: linear-gradient(180deg, #180E07, #1E1208) !important;
  border-right: 1px solid rgba(200,169,110,.18) !important;
  color: #F5EDD8 !important;
}
.section-title { color: #C8A96E !important; }

/* Cartes thèmes (les 6 boutons avec image) — c'était blanc ! */
.tool-buttons .tool-btn2.card-btn,
.tool-buttons .tool-btn2 {
  background: linear-gradient(160deg, #2A1A0E, #1A120B) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
  color: #F5EDD8 !important;
}
.tool-buttons .tool-btn2.card-btn:hover,
.tool-buttons .tool-btn2:hover {
  border-color: rgba(200,169,110,.55) !important;
  box-shadow: 0 8px 22px rgba(0,0,0,.4) !important;
  transform: translateY(-2px) !important;
}
.tool-buttons .tool-btn2.card-btn .txt strong { color: #F5EDD8 !important; }
.tool-buttons .tool-btn2.card-btn .txt small  { color: #A09070 !important; }
.tool-buttons .tool-btn2.card-btn .thumb { background: #120D08 !important; }

/* FABs (outils flottants droite) */
.fab {
  background: rgba(61,43,31,.88) !important;
  border: 1px solid rgba(200,169,110,.3) !important;
  color: #C8A96E !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.5) !important;
}
.fab:hover {
  background: rgba(184,92,56,.8) !important;
  border-color: #C8A96E !important;
  color: #F5EDD8 !important;
}

/* Tile-btn (sous-menus) */
.tile-btn {
  background: linear-gradient(180deg, #241508, #1A120B) !important;
  border: 1px solid rgba(200,169,110,.14) !important;
  color: #F5EDD8 !important;
}
.tile-btn:hover {
  border-color: rgba(200,169,110,.5) !important;
  box-shadow: 0 8px 22px rgba(0,0,0,.4), 0 0 0 3px rgba(200,169,110,.15) !important;
}
.tile-icon {
  background: linear-gradient(135deg, #3D2B1F, #B85C38) !important;
  color: #F5EDD8 !important;
}
.tile-caret { color: #C8A96E !important; }
.t-title { color: #F5EDD8 !important; }
.t-sub   { color: #A09070 !important; }

/* Chip-back */
.chip-back {
  background: rgba(200,169,110,.12) !important;
  border: 1px solid rgba(200,169,110,.3) !important;
  color: #E8D4A8 !important;
}

/* Map submenu */
#map-submenu {
  background: rgba(24,14,7,.96) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
  color: #F5EDD8 !important;
}
.ms-item {
  background: rgba(39,24,12,.8) !important;
  border: 1px solid rgba(200,169,110,.12) !important;
  color: #F5EDD8 !important;
}
.ms-item:hover { border-color: rgba(200,169,110,.4) !important; }
.ms-item b  { color: #E8D4A8 !important; }
.ms-item small { color: #A09070 !important; }

/* Attribution bar (Swisstopo / NASA) */
.map-attrib, #mapAttrib {
  background: rgba(26,18,11,.85) !important;
  border-top: 1px solid rgba(200,169,110,.15) !important;
  color: #A09070 !important;
}
.attrib-item { color: #A09070 !important; }

/* Boutons génériques */
.btn {
  background: linear-gradient(180deg, #B85C38, #3D2B1F) !important;
  border: 1px solid rgba(200,169,110,.25) !important;
  color: #F5EDD8 !important;
}
.btn.secondary {
  background: rgba(61,43,31,.5) !important;
  border: 1px solid rgba(200,169,110,.18) !important;
}
.btn.ghost { background: transparent !important; }
.btn.danger { border-color: rgba(184,92,56,.55) !important; color: #fecaca !important; }

/* HUD widgets */
.hud .widget {
  background: rgba(18,10,4,.85) !important;
  border: 1px solid rgba(200,169,110,.18) !important;
  color: #F5EDD8 !important;
}
.hud .widget h4 { color: #C8A96E !important; }

/* Tool drawer */
.tool-drawer {
  background: rgba(20,12,5,.92) !important;
  border: 1px solid rgba(200,169,110,.18) !important;
  color: #F5EDD8 !important;
}
.card-header { border-bottom: 1px solid rgba(200,169,110,.15) !important; }

/* Tool panel (polyline / anno) */
.tool-panel, .polyline-panel {
  background: rgba(20,12,5,.95) !important;
  border: 1px solid rgba(200,169,110,.2) !important;
  color: #F5EDD8 !important;
}
.polyline-btn {
  background: #1E1208 !important;
  border: 1px solid rgba(200,169,110,.25) !important;
  color: #E8D4A8 !important;
}
.polyline-btn.primary { border-color: #C8A96E !important; }
.polyline-btn.danger  { border-color: rgba(184,92,56,.5) !important; color: #fecaca !important; }
.polyline-close, .tp-close { color: #C8A96E !important; }

/* Modales */
.modal { background: rgba(0,0,0,.65) !important; }
.modal .dialog {
  background: #1A120B !important;
  border: 1px solid rgba(200,169,110,.2) !important;
  color: #F5EDD8 !important;
}
.modal .dialog header {
  background: #1A120B !important;
  border-bottom: 1px solid rgba(200,169,110,.15) !important;
  color: #F5EDD8 !important;
}
.modal .dialog .content { color: #E8D4A8 !important; }
.modal .dialog ol li { color: #E8D4A8 !important; }
.modal .dialog strong { color: #F5EDD8 !important; }

/* KBD */
.kbd, kbd {
  background: #120D08 !important;
  border-color: rgba(200,169,110,.3) !important;
  color: #C8A96E !important;
}

/* Inputs */
.field input, .field select,
input[type="number"], input[type="text"], input[type="search"], select {
  background: rgba(20,12,5,.85) !important;
  border: 1px solid rgba(200,169,110,.22) !important;
  color: #F5EDD8 !important;
}
input::placeholder { color: rgba(200,169,110,.4) !important; }
input:focus { border-color: #C8A96E !important; }

/* Labels, muted text */
.field label, .sublabel, .muted, small { color: #A09070 !important; }

/* Card sondage drawer */
#cardSondage { background: rgba(20,12,5,.92) !important; }
.card-body { color: #E8D4A8 !important; }

/* Info bubble */
.info-bubble {
  background: rgba(20,12,5,.94) !important;
  border: 1px solid rgba(200,169,110,.22) !important;
  color: #F5EDD8 !important;
}

/* Scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(200,169,110,.28); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(200,169,110,.5); }


/* ═══ Panneau Couches ═══ */
.couche-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(200,169,110,.15);
  background: rgba(39,24,12,.7);
  color: #F5EDD8;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  transition: border-color .2s, background .2s;
  text-align: left;
}
.couche-btn:hover {
  border-color: rgba(200,169,110,.45);
  background: rgba(61,43,31,.8);
}
.couche-btn.active {
  border-color: #C8A96E;
  background: rgba(200,169,110,.12);
}
.couche-preview {
  flex-shrink: 0;
  width: 48px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.1);
  display: block;
  position: relative;
}
.couche-info {
  flex: 1;
}
.couche-info strong {
  display: block;
  font-size: .9rem;
  font-weight: 600;
  color: #F5EDD8;
}
.couche-info small {
  display: block;
  font-size: .75rem;
  color: #A09070;
  margin-top: 2px;
}
.couche-check {
  color: #C8A96E;
  opacity: 0;
  transition: opacity .2s;
  font-size: .9rem;
}
.couche-btn.active .couche-check { opacity: 1; }

/* ═══ Infobulle géosite animée ═══ */
#geosite-popup {
  position: absolute;
  transform: translate(-50%, 0);
  pointer-events: none;
  z-index: 50;
  display: flex;
  flex-direction: column;
  align-items: center;
  opacity: 0;
  transition: opacity .35s ease;
}
#geosite-popup.gs-visible { opacity: 1; pointer-events: auto; }

/* Trait vertical qui monte */
.gs-stem {
  width: 2px;
  height: 0;
  background: linear-gradient(to top, #C8A96E, rgba(200,169,110,0));
  margin-bottom: 0;
  animation: stemGrow .5s .1s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes stemGrow {
  from { height: 0; opacity: 0; }
  to   { height: 52px; opacity: 1; }
}

/* Carte flottante */
.gs-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px 10px 10px;
  background: rgba(20,11,5,.92);
  border: 1px solid rgba(200,169,110,.45);
  border-radius: 10px;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 28px rgba(0,0,0,.55), 0 0 0 1px rgba(200,169,110,.1);
  white-space: nowrap;
  transform: translateY(8px) scale(.95);
  animation: cardPop .45s .4s cubic-bezier(.34,1.56,.64,1) forwards;
  opacity: 0;
}
@keyframes cardPop {
  from { opacity: 0; transform: translateY(8px) scale(.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Petite pastille colorée */
.gs-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #B85C38;
  border: 2px solid #C8A96E;
  flex-shrink: 0;
  box-shadow: 0 0 8px rgba(184,92,56,.6);
  animation: dotPulse 2s 1s ease-in-out infinite;
}
@keyframes dotPulse {
  0%, 100% { box-shadow: 0 0 8px rgba(184,92,56,.6); }
  50%       { box-shadow: 0 0 16px rgba(200,169,110,.9); }
}

.gs-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.gs-content strong {
  font-family: 'Playfair Display', serif;
  font-size: .95rem;
  color: #F5EDD8;
  letter-spacing: .3px;
}
.gs-content span {
  font-family: 'Barlow', sans-serif;
  font-size: .72rem;
  color: #A09070;
  letter-spacing: .5px;
}

/* Bouton fermer */
.gs-close {
  background: none;
  border: none;
  color: rgba(200,169,110,.5);
  cursor: pointer;
  font-size: .8rem;
  padding: 0 0 0 6px;
  line-height: 1;
  transition: color .2s;
  flex-shrink: 0;
}
.gs-close:hover { color: #C8A96E; }

/* ═══════════════════════════════════════════
   STORY MAP IMMERSIVE
   ═══════════════════════════════════════════ */

.sm-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: transparent; /* le globe est visible en arrière-plan */
  display: flex;
  flex-direction: column;
  font-family: 'Barlow', sans-serif;
  transition: opacity .4s ease;
}
.sm-overlay.hidden { display: none; }
.sm-overlay.sm-entering { animation: smFadeIn .5s ease forwards; }
@keyframes smFadeIn {
  from { opacity: 0; } to { opacity: 1; }
}

/* ── Topbar ── */
.sm-topbar {
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  background: rgba(15,8,3,.97);
  border-bottom: 1px solid rgba(200,169,110,.2);
  flex-shrink: 0;
  z-index: 10;
}
.sm-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .95rem;
  font-weight: 600;
  color: #C8A96E;
  white-space: nowrap;
}
.sm-brand em { color: #A09070; font-style: normal; font-weight: 300; }

.sm-chapter-title {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  color: #F5EDD8;
  text-align: center;
  flex: 1;
  padding: 0 20px;
  opacity: .85;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sm-close-btn {
  background: rgba(200,169,110,.1);
  border: 1px solid rgba(200,169,110,.3);
  color: #C8A96E;
  padding: 6px 16px;
  border-radius: 20px;
  font-family: 'Barlow', sans-serif;
  font-size: .8rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all .2s;
  white-space: nowrap;
}
.sm-close-btn:hover { background: rgba(200,169,110,.22); color: #F5EDD8; }

/* ── Body : globe + panneau ── */
.sm-body {
  flex: 1;
  display: flex;
  overflow: hidden;
  position: relative;
  /* Le globe Cesium est visible derrière l'overlay via transparence */
}

/* ── Panneau narratif ── */
.sm-panel {
  background: linear-gradient(180deg, rgba(20,11,5,.98), rgba(26,15,7,.96));
  border-right: 1px solid rgba(200,169,110,.18);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 5;
}

.sm-chapter-content {
  flex: 1;
  overflow-y: auto;
  padding: 32px 28px;
  scrollbar-width: thin;
  scrollbar-color: rgba(200,169,110,.3) transparent;
}

/* Era badge */
.sm-era {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #B85C38;
  border: 1px solid rgba(184,92,56,.4);
  padding: 3px 12px;
  border-radius: 20px;
  margin-bottom: 16px;
}

.sm-chapter-content h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.7rem;
  color: #F5EDD8;
  line-height: 1.2;
  margin: 0 0 6px;
}
.sm-chapter-content .sm-age {
  font-size: .8rem;
  color: #C8A96E;
  letter-spacing: 1px;
  margin-bottom: 20px;
  display: block;
}
.sm-chapter-content p {
  font-size: .9rem;
  line-height: 1.75;
  color: #C8B08A;
  margin: 0 0 16px;
  font-weight: 300;
}
.sm-chapter-content .sm-geosite-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(200,169,110,.1);
  border: 1px solid rgba(200,169,110,.3);
  color: #E8D4A8;
  font-size: .75rem;
  padding: 4px 12px;
  border-radius: 20px;
  margin: 4px 4px 4px 0;
  cursor: pointer;
  transition: all .2s;
}
.sm-chapter-content .sm-geosite-tag:hover {
  background: rgba(200,169,110,.22);
  border-color: #C8A96E;
}
.sm-chapter-content .sm-img {
  width: 100%;
  border-radius: 8px;
  margin: 16px 0;
  border: 1px solid rgba(200,169,110,.15);
  object-fit: cover;
  max-height: 180px;
}
.sm-chapter-content .sm-tags-label {
  font-size: .7rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #A09070;
  margin-bottom: 8px;
  margin-top: 12px;
  display: block;
}

/* ── Navigation ── */
.sm-nav {
  padding: 16px 24px;
  border-top: 1px solid rgba(200,169,110,.15);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-shrink: 0;
}
.sm-nav-btn {
  background: rgba(200,169,110,.1);
  border: 1px solid rgba(200,169,110,.25);
  color: #C8A96E;
  padding: 8px 18px;
  border-radius: 20px;
  font-family: 'Barlow', sans-serif;
  font-size: .8rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all .2s;
}
.sm-nav-btn:hover:not(:disabled) { background: rgba(200,169,110,.22); color: #F5EDD8; }
.sm-nav-btn:disabled { opacity: .3; cursor: default; }
.sm-dots { display: flex; gap: 6px; }
.sm-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(200,169,110,.25);
  border: 1px solid rgba(200,169,110,.3);
  cursor: pointer;
  transition: all .25s;
}
.sm-dot.active {
  background: #C8A96E;
  border-color: #C8A96E;
  transform: scale(1.3);
}

/* ── Timeline bar ── */
.sm-timeline-bar {
  position: absolute;
  bottom: 0;
  left: 420px;
  right: 0;
  height: 56px;
  background: rgba(10,5,2,.9);
  border-top: 1px solid rgba(200,169,110,.2);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 0;
  z-index: 5;
  backdrop-filter: blur(8px);
}
.sm-tl-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  cursor: pointer;
  padding: 6px 4px;
  border-radius: 6px;
  transition: background .2s;
  position: relative;
}
.sm-tl-item:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  width: 1px; height: 20px;
  background: rgba(200,169,110,.15);
}
.sm-tl-item:hover { background: rgba(200,169,110,.08); }
.sm-tl-item.active { background: rgba(200,169,110,.12); }
.sm-tl-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(200,169,110,.3);
  border: 1px solid rgba(200,169,110,.4);
  transition: all .2s;
}
.sm-tl-item.active .sm-tl-dot {
  background: #B85C38;
  border-color: #C8A96E;
  box-shadow: 0 0 8px rgba(184,92,56,.6);
}
.sm-tl-age {
  font-size: .6rem;
  color: #C8A96E;
  font-weight: 600;
  letter-spacing: .5px;
}
.sm-tl-label {
  font-size: .58rem;
  color: #A09070;
  text-align: center;
  max-width: 70px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Globe placeholder (dans l'overlay, Cesium y est téléporté) ── */
#smGlobeMount {
  position: relative;
  overflow: hidden;
  background: #0F0A06;
  padding-bottom: 56px; /* espace timeline */
}

/* ── Story Map : overlay par-dessus le globe existant ── */
.sm-overlay {
  background: transparent !important; /* globe visible derrière */
}
.sm-overlay.hidden { display: none !important; }

/* Le panel narratif a son propre fond */
.sm-panel {
  width: var(--sm-panel-w, 560px);
  min-width: 320px;
  max-width: 900px;
  background: linear-gradient(180deg, rgba(15,8,3,.97), rgba(20,11,5,.96)) !important;
  box-shadow: 4px 0 40px rgba(0,0,0,.6);
  position: relative;
}

/* Handle de resize pour le panel Story Map */
.sm-resize-handle {
  position: absolute;
  top: 0;
  right: -5px;
  width: 10px;
  height: 100%;
  cursor: ew-resize;
  z-index: 300;
  background: transparent;
  transition: background .2s;
}
.sm-resize-handle:hover,
.sm-resize-handle.dragging {
  background: rgba(200,169,110,0.2);
}
.sm-resize-handle::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  width: 2px;
  height: 50px;
  border-radius: 2px;
  background: rgba(200,169,110,0.5);
}

/* smGlobeMount ne sert pas — le globe est derrière en fixed */
#smGlobeMount { display: none; }

/* Timeline positionnée en bas mais pas sur le panel */
.sm-timeline-bar {
  left: var(--sm-panel-w, 560px) !important;
  transition: left .1s;
}

/* ═══════════════════════════════════════════════════════
   REFONTE PALETTE — Charte geotourisme-dahar.com
   Blanc / Orange #E8820C / Gris foncé #333
   ═══════════════════════════════════════════════════════ */

:root {
  --gd-orange:      #E8820C;
  --gd-orange-dark: #C56A00;
  --gd-orange-light:#F5A93A;
  --gd-orange-bg:   #FFF4E6;
  --gd-white:       #FFFFFF;
  --gd-light:       #F7F5F2;
  --gd-text:        #2C2C2C;
  --gd-text-muted:  #666666;
  --gd-border:      rgba(232,130,12,0.2);
  --gd-border-grey: #E0DDD8;
}

/* ── Body ── */
body, html {
  background: var(--gd-light) !important;
  color: var(--gd-text) !important;
}

/* ── Topbar ── */
.topbar {
  background: var(--gd-white) !important;
  border-bottom: 2px solid var(--gd-orange) !important;
  backdrop-filter: none !important;
}
.brand-geo  { color: var(--gd-orange) !important; }
.brand-dahar{ color: var(--gd-text) !important; }
.beta-badge {
  background: var(--gd-orange-bg) !important;
  border-color: var(--gd-orange) !important;
  color: var(--gd-orange) !important;
}

/* ── Nav buttons ── */
.nav button, .topbar .nav .tb-btn {
  background: var(--gd-orange-bg) !important;
  border: 1px solid var(--gd-orange) !important;
  color: var(--gd-orange-dark) !important;
}
.nav button:hover, .topbar .nav .tb-btn:hover {
  background: var(--gd-orange) !important;
  color: var(--gd-white) !important;
}
.topbar .nav .tb-btn { --fg: var(--gd-orange-dark) !important; color: var(--gd-orange-dark) !important; }

/* Search */
.top-search input {
  background: var(--gd-light) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.top-search input::placeholder { color: #AAA !important; }
.top-search input:focus { border-color: var(--gd-orange) !important; }

/* ── Sidebar / Panel ── */
.panel, #panelOutils, #tools-sidebar {
  background: var(--gd-white) !important;
  border-right: 2px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.section-title {
  color: var(--gd-orange) !important;
  font-size: 10px !important;
  letter-spacing: 3px !important;
}

/* ── Cartes thèmes ── */
.tool-buttons .tool-btn2.card-btn,
.tool-buttons .tool-btn2 {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.06) !important;
}
.tool-buttons .tool-btn2.card-btn:hover {
  border-color: var(--gd-orange) !important;
  box-shadow: 0 4px 16px rgba(232,130,12,.2) !important;
  transform: translateY(-2px) !important;
}
.tool-buttons .tool-btn2.card-btn .txt strong { color: var(--gd-text) !important; }
.tool-buttons .tool-btn2.card-btn .txt small  { color: var(--gd-text-muted) !important; }
.tool-buttons .tool-btn2.card-btn .thumb { background: var(--gd-light) !important; }

/* ── Tile buttons (sous-menus) ── */
.tile-btn {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.05) !important;
}
.tile-btn:hover {
  border-color: var(--gd-orange) !important;
  box-shadow: 0 6px 18px rgba(232,130,12,.18) !important;
}
.tile-icon {
  background: linear-gradient(135deg, var(--gd-orange-bg), #FFE8C4) !important;
  color: var(--gd-orange) !important;
  border: 1px solid rgba(232,130,12,.2) !important;
}
.tile-caret { color: var(--gd-orange) !important; }
.t-title { color: var(--gd-text) !important; font-weight: 700 !important; }
.t-sub   { color: var(--gd-text-muted) !important; }

/* ── chip-back ── */
.chip-back {
  background: var(--gd-orange-bg) !important;
  border: 1px solid var(--gd-orange) !important;
  color: var(--gd-orange-dark) !important;
}

/* ── Map submenu ── */
#map-submenu {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.12) !important;
  color: var(--gd-text) !important;
}
.ms-item {
  background: var(--gd-light) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.ms-item:hover { border-color: var(--gd-orange) !important; background: var(--gd-orange-bg) !important; }
.ms-item b     { color: var(--gd-text) !important; }
.ms-item small { color: var(--gd-text-muted) !important; }
.ms-head h4    { color: var(--gd-text) !important; }
.ms-close      { color: var(--gd-text-muted) !important; }
.ms-close:hover{ color: var(--gd-orange) !important; }

/* ── FABs ── */
.fab {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.15) !important;
  color: var(--gd-text-muted) !important;
}
.fab:hover {
  background: var(--gd-orange) !important;
  border-color: var(--gd-orange) !important;
  color: var(--gd-white) !important;
  box-shadow: 0 6px 20px rgba(232,130,12,.4) !important;
}
.fab svg path, .fab svg line, .fab svg circle, .fab svg polygon {
  stroke: var(--gd-text-muted);
}
.fab:hover svg path, .fab:hover svg line,
.fab:hover svg circle, .fab:hover svg polygon { stroke: #fff; }

/* ── Boutons génériques ── */
.btn {
  background: var(--gd-orange) !important;
  border: 1px solid var(--gd-orange-dark) !important;
  color: var(--gd-white) !important;
}
.btn.secondary {
  background: var(--gd-light) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.btn:hover { background: var(--gd-orange-dark) !important; }
.btn.danger { border-color: #E55 !important; color: #C00 !important; }

/* ── Panels flottants (polyline, anno, couches) ── */
.tool-panel, .polyline-panel, #couchesPanel, .tool-drawer, #cardSondage {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.12) !important;
}
.tp-head strong, .tool-panel .tp-head strong { color: var(--gd-text) !important; }
.tp-close { color: var(--gd-text-muted) !important; }
.tp-close:hover { color: var(--gd-orange) !important; }

/* ── HUD widgets ── */
.hud .widget {
  background: rgba(255,255,255,.92) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.1) !important;
}
.hud .widget h4 { color: var(--gd-orange) !important; }

/* ── Couches buttons ── */
.couche-btn {
  background: var(--gd-light) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.couche-btn:hover { border-color: var(--gd-orange) !important; background: var(--gd-orange-bg) !important; }
.couche-btn.active { border-color: var(--gd-orange) !important; background: var(--gd-orange-bg) !important; }
.couche-info strong { color: var(--gd-text) !important; }
.couche-info small  { color: var(--gd-text-muted) !important; }
.couche-check { color: var(--gd-orange) !important; }
#couchesPanel .tp-head strong { color: var(--gd-text) !important; }

/* ── Modales ── */
.modal { background: rgba(0,0,0,.5) !important; }
.modal .dialog {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.modal .dialog header {
  background: var(--gd-white) !important;
  border-bottom: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.modal .dialog .content { color: var(--gd-text) !important; }
.modal .dialog ol li { color: var(--gd-text) !important; }
.kbd { background: var(--gd-light) !important; border-color: var(--gd-border-grey) !important; color: var(--gd-orange) !important; }

/* ── Inputs ── */
input[type="number"], input[type="text"], input[type="search"], select {
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
input:focus { border-color: var(--gd-orange) !important; }
.field label, .sublabel { color: var(--gd-text-muted) !important; }

/* ── Attribution bar ── */
.map-attrib, #mapAttrib {
  background: rgba(255,255,255,.9) !important;
  border-top: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text-muted) !important;
}
.attrib-item { color: var(--gd-text-muted) !important; }

/* ── Polyline panel ── */
.polyline-btn {
  background: var(--gd-light) !important;
  border: 1px solid var(--gd-border-grey) !important;
  color: var(--gd-text) !important;
}
.polyline-btn.primary { border-color: var(--gd-orange) !important; color: var(--gd-orange) !important; }
.polyline-btn.danger  { border-color: #E55 !important; color: #C00 !important; }
.polyline-close { color: var(--gd-text-muted) !important; }

/* ── Scrollbar ── */
::-webkit-scrollbar-track { background: var(--gd-light); }
::-webkit-scrollbar-thumb { background: rgba(232,130,12,.3); }
::-webkit-scrollbar-thumb:hover { background: var(--gd-orange); }

/* ── Story Map palette orange/blanc ── */
.sm-topbar {
  background: var(--gd-white) !important;
  border-bottom: 2px solid var(--gd-orange) !important;
}
.sm-brand { color: var(--gd-orange) !important; }
.sm-brand em { color: var(--gd-text-muted) !important; }
.sm-chapter-title { color: var(--gd-text) !important; }
.sm-close-btn {
  background: var(--gd-orange-bg) !important;
  border-color: var(--gd-orange) !important;
  color: var(--gd-orange-dark) !important;
}
.sm-close-btn:hover { background: var(--gd-orange) !important; color: var(--gd-white) !important; }
.sm-panel {
  background: var(--gd-white) !important;
  border-right: 1px solid var(--gd-border-grey) !important;
  box-shadow: 4px 0 20px rgba(0,0,0,.08) !important;
}
.sm-era {
  color: var(--gd-orange) !important;
  border-color: rgba(232,130,12,.4) !important;
  background: var(--gd-orange-bg) !important;
}
.sm-chapter-content h2 { color: var(--gd-text) !important; }
.sm-chapter-content .sm-age { color: var(--gd-orange) !important; }
.sm-chapter-content p { color: var(--gd-text-muted) !important; }
.sm-chapter-content .sm-geosite-tag {
  background: var(--gd-orange-bg) !important;
  border-color: var(--gd-orange) !important;
  color: var(--gd-orange-dark) !important;
}
.sm-chapter-content .sm-geosite-tag:hover {
  background: var(--gd-orange) !important;
  color: var(--gd-white) !important;
}
.sm-chapter-content .sm-tags-label { color: var(--gd-text-muted) !important; }
.sm-nav { border-top: 1px solid var(--gd-border-grey) !important; }
.sm-nav-btn {
  background: var(--gd-orange-bg) !important;
  border-color: var(--gd-orange) !important;
  color: var(--gd-orange-dark) !important;
}
.sm-nav-btn:hover:not(:disabled) { background: var(--gd-orange) !important; color: var(--gd-white) !important; }
.sm-dot { background: rgba(232,130,12,.2) !important; border-color: rgba(232,130,12,.3) !important; }
.sm-dot.active { background: var(--gd-orange) !important; border-color: var(--gd-orange) !important; }
.sm-timeline-bar {
  background: rgba(255,255,255,.95) !important;
  border-top: 1px solid var(--gd-border-grey) !important;
}
.sm-tl-age   { color: var(--gd-orange) !important; }
.sm-tl-label { color: var(--gd-text-muted) !important; }
.sm-tl-dot   { background: rgba(232,130,12,.2) !important; border-color: rgba(232,130,12,.3) !important; }
.sm-tl-item.active .sm-tl-dot { background: var(--gd-orange) !important; border-color: var(--gd-orange-dark) !important; box-shadow: 0 0 8px rgba(232,130,12,.5) !important; }
.sm-tl-item:hover { background: var(--gd-orange-bg) !important; }
.sm-tl-item.active { background: var(--gd-orange-bg) !important; }

/* Geosite popup */
.gs-card {
  background: var(--gd-white) !important;
  border-color: var(--gd-orange) !important;
  box-shadow: 0 8px 28px rgba(232,130,12,.25) !important;
}
.gs-content strong { color: var(--gd-text) !important; font-family: 'Barlow', sans-serif !important; }
.gs-content span   { color: var(--gd-text-muted) !important; }
.gs-dot   { background: var(--gd-orange) !important; border-color: var(--gd-orange-dark) !important; }
.gs-close { color: rgba(232,130,12,.5) !important; }
.gs-close:hover { color: var(--gd-orange) !important; }
.gs-stem  { background: linear-gradient(to top, var(--gd-orange), rgba(232,130,12,0)) !important; }

/* Accès block dans story map touristique */
.vt-access {
  background: #FFF4E6;
  border: 1px solid rgba(232,130,12,.25);
  border-left: 3px solid #E8820C;
  border-radius: 6px;
  padding: 10px 14px;
  margin: 14px 0;
  font-size: .82rem;
  color: #555;
  line-height: 1.6;
}
.vt-access i { color: #E8820C; margin-right: 6px; }
.vt-access strong { color: #333; }

/* Bouton Visites dans topbar */
#btnVisites {
  background: #FFF4E6 !important;
  border-color: #E8820C !important;
  color: #C56A00 !important;
}
#btnVisites:hover {
  background: #E8820C !important;
  color: #fff !important;
}

/* ═══ FABs — 2 boutons uniquement : Couches + Impression ═══ */
.map-fabs {
  position: absolute;
  right: 14px;
  top: 70px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 15;
}

.fab {
  width: 44px !important;
  height: 44px !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--gd-white) !important;
  border: 1px solid var(--gd-border-grey) !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.12) !important;
  cursor: pointer !important;
  color: #666 !important;
  transition: all .2s ease !important;
  padding: 0 !important;
}

.fab:hover {
  background: var(--gd-orange) !important;
  border-color: var(--gd-orange-dark) !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(232,130,12,.35) !important;
  transform: translateY(-1px) !important;
}

.fab svg {
  display: block;
  color: inherit;
}

/* Supprimer les anciennes règles svg stroke hardcodées */
.fab:hover svg path,
.fab:hover svg rect,
.fab:hover svg circle { stroke: currentColor !important; }
.fab svg path,
.fab svg rect,
.fab svg circle { stroke: currentColor !important; }

/* ═══════════════════════════════════════════════
   PLANIFICATEUR DE VISITE
   ═══════════════════════════════════════════════ */

.planner-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: transparent;
  display: flex;
  flex-direction: column;
  font-family: 'Barlow', sans-serif;
}
.planner-overlay.hidden { display: none !important; }

/* Topbar */
.planner-topbar {
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  background: var(--gd-white);
  border-bottom: 2px solid var(--gd-orange);
  flex-shrink: 0;
  z-index: 10;
}
.planner-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .95rem;
  font-weight: 700;
  color: var(--gd-orange);
}

/* Body */
.planner-body {
  flex: 1;
  display: grid;
  grid-template-columns: 380px 1fr;
  overflow: hidden;
}

/* Panel gauche */
.planner-panel {
  background: var(--gd-white);
  border-right: 1px solid var(--gd-border-grey);
  padding: 24px 20px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
  box-shadow: 4px 0 20px rgba(0,0,0,.06);
}

.planner-step { display: flex; flex-direction: column; gap: 10px; }

.planner-step-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: .9rem;
  color: var(--gd-text);
}
.planner-step-label small {
  font-weight: 400;
  font-size: .75rem;
  color: var(--gd-text-muted);
}
.step-num {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--gd-orange);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Durée */
.planner-duration-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
}
.dur-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 10px 4px;
  border-radius: 10px;
  border: 1px solid var(--gd-border-grey);
  background: var(--gd-light);
  cursor: pointer;
  transition: all .2s;
  font-family: 'Barlow', sans-serif;
}
.dur-btn strong { font-size: 1.3rem; color: var(--gd-text); line-height: 1; }
.dur-btn small  { font-size: .65rem; color: var(--gd-text-muted); text-transform: uppercase; letter-spacing: 1px; }
.dur-btn:hover  { border-color: var(--gd-orange); background: var(--gd-orange-bg); }
.dur-btn.active {
  border-color: var(--gd-orange);
  background: var(--gd-orange);
}
.dur-btn.active strong,
.dur-btn.active small { color: #fff !important; }

/* Origine */
.planner-origin-btns {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.origin-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid var(--gd-border-grey);
  background: var(--gd-light);
  color: var(--gd-text);
  font-family: 'Barlow', sans-serif;
  font-size: .87rem;
  cursor: pointer;
  transition: all .2s;
  text-align: left;
}
.origin-btn i { color: var(--gd-orange); width: 16px; }
.origin-btn:hover  { border-color: var(--gd-orange); background: var(--gd-orange-bg); }
.origin-btn.active {
  border-color: var(--gd-orange);
  background: var(--gd-orange);
  color: #fff;
}
.origin-btn.active i { color: #fff; }

.origin-map-info {
  background: var(--gd-orange-bg);
  border: 1px solid rgba(232,130,12,.3);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .82rem;
  color: var(--gd-orange-dark);
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Intérêts */
.planner-interests {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.interest-tag {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 20px;
  border: 1px solid var(--gd-border-grey);
  background: var(--gd-light);
  cursor: pointer;
  font-size: .8rem;
  color: var(--gd-text);
  transition: all .2s;
  user-select: none;
}
.interest-tag input { display: none; }
.interest-tag span { pointer-events: none; }
.interest-tag:has(input:checked) {
  background: var(--gd-orange);
  border-color: var(--gd-orange);
  color: #fff;
}
.interest-tag:hover { border-color: var(--gd-orange); }

/* Bouton générer */
.planner-generate-btn {
  width: 100%;
  padding: 14px;
  border-radius: 10px;
  background: var(--gd-orange);
  border: none;
  color: #fff;
  font-family: 'Barlow', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all .2s;
  box-shadow: 0 4px 14px rgba(232,130,12,.35);
}
.planner-generate-btn:hover {
  background: var(--gd-orange-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(232,130,12,.45);
}
.planner-generate-btn:disabled {
  opacity: .5; cursor: default; transform: none;
}

.planner-credit {
  font-size: .72rem;
  color: var(--gd-text-muted);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* Panel droit — résultat */
.planner-result {
  overflow-y: auto;
  padding: 28px;
  background: var(--gd-light);
  display: flex;
  flex-direction: column;
}

.planner-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  color: var(--gd-text-muted);
  text-align: center;
}
.planner-empty i { font-size: 3rem; color: rgba(232,130,12,.3); }
.planner-empty p { font-size: .95rem; line-height: 1.6; }

/* Loading */
.planner-loading {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  color: var(--gd-text-muted);
}
.planner-spinner {
  width: 40px; height: 40px;
  border: 3px solid rgba(232,130,12,.2);
  border-top-color: var(--gd-orange);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Itinéraire */
.planner-itinerary { display: flex; flex-direction: column; gap: 20px; }

.plan-day {
  background: var(--gd-white);
  border-radius: 12px;
  border: 1px solid var(--gd-border-grey);
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.plan-day-header {
  background: var(--gd-orange);
  color: #fff;
  padding: 12px 18px;
  font-weight: 700;
  font-size: .95rem;
  display: flex;
  align-items: center;
  gap: 10px;
}
.plan-day-header i { opacity: .85; }
.plan-day-body { padding: 16px 18px; display: flex; flex-direction: column; gap: 12px; }

.plan-site {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 12px;
  border-radius: 8px;
  border: 1px solid var(--gd-border-grey);
  background: var(--gd-light);
  cursor: pointer;
  transition: all .2s;
}
.plan-site:hover {
  border-color: var(--gd-orange);
  background: var(--gd-orange-bg);
  transform: translateX(3px);
}
.plan-site-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--gd-orange);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.plan-site-info { flex: 1; }
.plan-site-name { font-weight: 700; color: var(--gd-text); font-size: .9rem; }
.plan-site-desc { font-size: .78rem; color: var(--gd-text-muted); margin-top: 3px; line-height: 1.5; }
.plan-site-access {
  font-size: .72rem;
  color: var(--gd-orange-dark);
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.plan-tip {
  background: var(--gd-orange-bg);
  border-left: 3px solid var(--gd-orange);
  border-radius: 0 8px 8px 0;
  padding: 10px 14px;
  font-size: .8rem;
  color: var(--gd-text-muted);
  line-height: 1.6;
}
.plan-tip strong { color: var(--gd-orange-dark); }

/* Bouton topbar planifier */
#btnPlanifier {
  background: var(--gd-orange-bg) !important;
  border-color: var(--gd-orange) !important;
  color: var(--gd-orange-dark) !important;
}
#btnPlanifier:hover {
  background: var(--gd-orange) !important;
  color: #fff !important;
}

/* ── Mode clic sur carte : panel se rétrécit, globe visible ── */
.planner-overlay.picking-mode .planner-body {
  grid-template-columns: 340px 1fr;
}
.planner-overlay.picking-mode .planner-result {
  display: none;
}

/* Hint flottant sur le globe pendant le clic */
#plannerPickHint {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(232,130,12,.92);
  color: #fff;
  padding: 14px 24px;
  border-radius: 30px;
  font-family: 'Barlow', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  box-shadow: 0 8px 32px rgba(232,130,12,.4);
  display: flex;
  align-items: center;
  gap: 10px;
  z-index: 300;
  pointer-events: none;
  animation: hintPulse 1.5s ease-in-out infinite;
}
@keyframes hintPulse {
  0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
  50%       { transform: translate(-50%, -50%) scale(1.04); opacity: .85; }
}

/* Quand on est en mode picking, le panel planif devient semi-transparent */
.planner-overlay.picking-mode .planner-panel {
  opacity: .92;
}
.planner-overlay.picking-mode {
  background: transparent !important;
  pointer-events: none;
}
.planner-overlay.picking-mode .planner-topbar,
.planner-overlay.picking-mode .planner-panel {
  pointer-events: auto;
}

/* ═══════════════════════════════════════════
   SIDEBAR OUTILS — Design orange/blanc
   ═══════════════════════════════════════════ */

.tools-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 4px 0;
}

.tool-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--gd-border-grey);
  background: var(--gd-light);
  cursor: pointer;
  transition: all .18s ease;
  font-family: 'Barlow', sans-serif;
  text-align: left;
  width: 100%;
}
.tool-card:hover {
  border-color: var(--gd-orange);
  background: var(--gd-orange-bg);
  transform: translateX(3px);
}
.tool-card.active {
  border-color: var(--gd-orange);
  background: var(--gd-orange);
  color: #fff;
}
.tool-card.active .tool-card-icon { background: rgba(255,255,255,.2); color: #fff; }
.tool-card.active strong { color: #fff; }
.tool-card.active small  { color: rgba(255,255,255,.75); }

.tool-card-danger:hover {
  border-color: #e55;
  background: #fff5f5;
}
.tool-card-danger .tool-card-icon { background: #fff0f0; color: #e55; }

.tool-card-icon {
  width: 38px;
  height: 38px;
  border-radius: 8px;
  background: var(--gd-orange-bg);
  color: var(--gd-orange);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  transition: all .18s;
}
.tool-card:hover .tool-card-icon {
  background: var(--gd-orange);
  color: #fff;
}
.tool-card.active .tool-card-icon {
  background: rgba(255,255,255,.25);
  color: #fff;
}

.tool-card-info { flex: 1; }
.tool-card-info strong {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: var(--gd-text);
  line-height: 1.2;
}
.tool-card-info small {
  display: block;
  font-size: .72rem;
  color: var(--gd-text-muted);
  margin-top: 2px;
}

/* Résultat */
.tool-result {
  margin-top: 16px;
  background: var(--gd-white);
  border: 1px solid var(--gd-border-grey);
  border-left: 3px solid var(--gd-orange);
  border-radius: 0 10px 10px 0;
  padding: 14px 16px;
}
.tool-result-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--gd-orange);
  font-weight: 700;
  margin-bottom: 6px;
}
.tool-result-value {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--gd-text);
  font-family: 'Playfair Display', serif;
}
.tool-result-hint {
  font-size: .75rem;
  color: var(--gd-text-muted);
  margin-top: 6px;
  line-height: 1.5;
}

/* Instruction */
.tool-instruction {
  margin-top: 12px;
  background: var(--gd-orange-bg);
  border: 1px solid rgba(232,130,12,.3);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .82rem;
  color: var(--gd-orange-dark);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.5;
}
.tool-instruction i { margin-top: 2px; flex-shrink: 0; }

/* ── Label de groupe dans les sous-arbres ── */
.tree-group-label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--gd-orange);
  padding: 8px 4px 4px;
  border-bottom: 1px solid rgba(232,130,12,.2);
  margin-bottom: 4px;
}

/* ── Cartes thèmes : grille 2 colonnes bien propre ── */
#panelOutils .tool-buttons {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 12px !important;
  margin: 8px 0 !important;
}

/* Thumb arrondi propre */
.tool-buttons .tool-btn2.card-btn .thumb {
  border-radius: 8px !important;
  overflow: hidden !important;
}

/* ── FABs remontés sur la carte ── */
.map-fabs {
  top: 68px !important;
  right: 14px !important;
  gap: 8px !important;
}

/* ── GEOREVO badge ── */
.georevo-badge {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  color: #999;
  white-space: nowrap;
  margin-left: 4px;
}
.georevo-badge span { color: #bbb; }
.georevo-badge a {
  color: var(--gd-orange);
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .3px;
}
.georevo-badge a:hover { text-decoration: underline; }

/* Thèmes : grille 2 cols propre */
#panelOutils .tool-buttons {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 10px !important;
  margin: 8px 0 !important;
}

/* ── Watermark MapRevo / GeoRevo ── */
.maprevo-watermark {
  position: absolute;
  bottom: 8px;
  right: 8px;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(232,130,12,.2);
  border-radius: 6px;
  padding: 4px 10px;
  font-family: 'Barlow', sans-serif;
  font-size: .7rem;
  color: #999;
  pointer-events: auto;
}
.maprevo-watermark a {
  color: var(--gd-orange);
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .2px;
  transition: color .2s;
}
.maprevo-watermark a:hover { color: var(--gd-orange-dark); text-decoration: underline; }
.maprevo-watermark span { color: #bbb; }

/* ── GEOREVO badge sidebar ── */
.sidebar-georevo {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  color: #bbb;
  margin: -4px 0 10px;
}
.sidebar-georevo a {
  color: var(--gd-orange);
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .3px;
}
.sidebar-georevo a:hover { text-decoration: underline; }

/* ═══════════════════════════════════════════════════════════
   TOOLS TOOLBAR — barre horizontale style BIMrevo
   ═══════════════════════════════════════════════════════════ */

.tools-toolbar {
  position: fixed;
  top: 56px;
  left: var(--sidebar-w);
  right: 0;
  height: 46px;
  z-index: 18;
  background: #FFFAF4;
  border-bottom: 1.5px solid rgba(184,92,56,0.18);
  box-shadow: 0 2px 12px rgba(26,18,11,0.08);
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 0;
}
.tools-toolbar.hidden { display: none; }

/* Quand la toolbar est visible, le cesium descend */
body.tools-open #cesiumContainer { top: 102px !important; }

.tools-toolbar-inner {
  display: flex;
  align-items: center;
  gap: 2px;
}

.tb-tool-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 6px 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: transparent;
  color: #3D2B1F;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
}
.tb-tool-btn svg {
  flex-shrink: 0;
  color: #B85C38;
  opacity: .8;
  transition: opacity .15s;
}
.tb-tool-btn:hover {
  background: rgba(184,92,56,0.08);
  color: #B85C38;
  border-color: rgba(184,92,56,0.2);
}
.tb-tool-btn:hover svg { opacity: 1; }

.tb-tool-btn.active {
  background: #B85C38;
  color: #fff;
  border-color: #B85C38;
  font-weight: 700;
}
.tb-tool-btn.active svg { opacity: 1; color: #fff; }

.tb-tool-danger { color: #c0392b !important; }
.tb-tool-danger svg { color: #c0392b !important; }
.tb-tool-danger:hover {
  background: rgba(192,57,43,0.1) !important;
  color: #c0392b !important;
  border-color: rgba(192,57,43,0.3) !important;
}

.tb-tool-sep {
  width: 1px;
  height: 22px;
  background: rgba(184,92,56,0.15);
  margin: 0 8px;
  flex-shrink: 0;
}

/* Résultat dans la toolbar */
.tb-result {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: 16px;
  padding: 4px 14px;
  border-radius: 8px;
  background: rgba(184,92,56,0.08);
  border: 1px solid rgba(184,92,56,0.2);
}
.tb-result.hidden { display: none; }
.tb-result-label {
  font-size: 11px;
  color: #6B5040;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.tb-result-value {
  font-size: 15px;
  font-weight: 800;
  color: #B85C38;
  font-family: 'Barlow', sans-serif;
}

/* Instruction dans la toolbar */
.tb-instruction {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: 12px;
  font-size: 12px;
  color: #6B5040;
  font-style: italic;
}
.tb-instruction.hidden { display: none; }

/* Bouton Outils dans la topbar quand actif */
#btnOutils.active {
  background: rgba(184,92,56,0.3) !important;
  border-color: var(--sand) !important;
  color: var(--sand) !important;
}

/* Décaler le cesium vers le bas quand toolbar visible */
.tools-toolbar:not(.hidden) ~ .main #cesiumContainer,
body.tools-open #cesiumContainer {
  top: 102px !important;
}

/* FAB Outils actif */
#btnOutils[aria-pressed="true"] {
  background: var(--terracotta) !important;
  outline: 2px solid rgba(200,169,110,0.5);
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════
   POI INLINE PANEL — charte GeoDahar
   ═══════════════════════════════════════════════════════════ */

.poi-panel {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.poi-panel.hidden { display: none; }

.poi-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 4px 10px;
  border-bottom: 1px solid rgba(200,169,110,0.18);
  margin-bottom: 4px;
  flex-shrink: 0;
}
.poi-back {
  display: flex;
  align-items: center;
  gap: 7px;
  background: none;
  border: none;
  color: #B85C38;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  padding: 5px 8px;
  border-radius: 8px;
  font-family: inherit;
  transition: background .15s;
}
.poi-back:hover { background: rgba(200,169,110,0.1); }
.poi-back i { font-size: 11px; }

.poi-toggle-all {
  width: 28px; height: 28px;
  border-radius: 7px;
  border: 1px solid rgba(200,169,110,0.2);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: background .15s, color .15s;
}
.poi-toggle-all:hover { background: rgba(200,169,110,0.12); color: var(--sand); }
.poi-toggle-all--on {
  background: rgba(184,92,56,0.25) !important;
  color: var(--sand) !important;
  border-color: rgba(184,92,56,0.5) !important;
}

.poi-list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding-bottom: 10px;
}
.poi-list::-webkit-scrollbar { width: 3px; }
.poi-list::-webkit-scrollbar-thumb { background: rgba(200,169,110,0.2); border-radius: 3px; }

.poi-group-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: #B85C38;
  opacity: 1;
  padding: 10px 4px 3px;
  font-weight: 800;
}

.poi-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 8px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background .14s, border-color .14s;
}
.poi-row:hover {
  background: rgba(200,169,110,0.07);
  border-color: rgba(200,169,110,0.12);
}
.poi-row--on {
  background: rgba(184,92,56,0.12);
  border-color: rgba(184,92,56,0.25);
}

/* Checkbox custom */
.poi-cb-wrap {
  position: relative;
  width: 16px; height: 16px;
  flex-shrink: 0;
}
.poi-cb-wrap input { position: absolute; opacity: 0; width: 0; height: 0; }
.poi-cb-box {
  position: absolute;
  inset: 0;
  border-radius: 4px;
  border: 1.5px solid var(--c, var(--terracotta));
  background: transparent;
  transition: background .13s;
}
.poi-cb-wrap input:checked ~ .poi-cb-box {
  background: var(--c, var(--terracotta));
}
.poi-cb-wrap input:checked ~ .poi-cb-box::after {
  content: '';
  position: absolute;
  left: 3px; top: 1px;
  width: 5px; height: 8px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

.poi-row-txt {
  flex: 1;
  min-width: 0;
}
.poi-row-txt strong {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: #1A120B;
  line-height: 1.2;
}
.poi-row-txt small {
  display: block;
  font-size: 11px;
  color: #5C3D2E;
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Boutons icônes (centrer + info) */
.poi-fly, .poi-info {
  flex-shrink: 0;
  width: 24px; height: 24px;
  border-radius: 6px;
  border: 1px solid rgba(200,169,110,0.15);
  background: transparent;
  color: var(--sand);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  opacity: 0;
  transition: opacity .13s, background .13s;
}
.poi-row:hover .poi-fly,
.poi-row:hover .poi-info { opacity: 1; }
.poi-fly:hover, .poi-info:hover {
  background: rgba(184,92,56,0.2);
  border-color: rgba(184,92,56,0.4);
  color: var(--cream);
}



/* Popup flottante draggable — charte GeoDahar blanc/terracotta */
.poi-popup {
  position: absolute;
  width: 300px;
  background: #FFFAF4;
  border: 1.5px solid rgba(184,92,56,0.25);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(26,18,11,0.35), 0 4px 16px rgba(184,92,56,0.15);
  z-index: 100;
  overflow: hidden;
  opacity: 0;
  transition: opacity .2s;
  pointer-events: all;
  user-select: none;
}

.poi-popup-drag-handle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 10px 6px;
  background: #FFF5EB;
  border-bottom: 1px solid rgba(184,92,56,0.15);
  cursor: grab;
}
.poi-popup-drag-handle:active { cursor: grabbing; }
.poi-popup-drag-icon {
  color: rgba(184,92,56,0.35);
  font-size: 12px;
}

.poi-popup-close {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1px solid rgba(184,92,56,0.2);
  background: transparent;
  color: #B85C38;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  transition: background .15s, color .15s;
}
.poi-popup-close:hover {
  background: #B85C38;
  color: #fff;
}

.poi-popup-img {
  width: 100%;
  height: 145px;
  overflow: hidden;
}
.poi-popup-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s;
}
.poi-popup:hover .poi-popup-img img { transform: scale(1.03); }

.poi-popup-body {
  padding: 11px 13px 13px;
  background: #FFFAF4;
}
.poi-popup-title {
  font-size: 14px;
  font-weight: 800;
  color: #1A120B;
  line-height: 1.3;
  margin-bottom: 5px;
  font-family: 'Barlow', sans-serif;
}
.poi-popup-desc {
  font-size: 11.5px;
  color: #6B5040;
  line-height: 1.5;
  margin-bottom: 10px;
}
.poi-popup-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(184,92,56,0.12);
}
.poi-popup-source {
  font-size: 10px;
  color: rgba(184,92,56,0.45);
  display: flex;
  align-items: center;
  gap: 4px;
}
.poi-popup-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  padding: 5px 11px;
  border-radius: 7px;
  background: #B85C38;
  border: none;
  transition: background .15s;
  white-space: nowrap;
}
.poi-popup-link:hover { background: #8B3A1F; }

/* ═══════════════════════════════════════════════════════════
   SIDEBAR RESIZE HANDLE
   ═══════════════════════════════════════════════════════════ */
#panelOutils {
  position: relative;
  min-width: 280px;
  max-width: 700px;
}
.sidebar-resize-handle {
  position: absolute;
  top: 0;
  right: -4px;
  width: 8px;
  height: 100%;
  cursor: ew-resize;
  z-index: 100;
  background: transparent;
  transition: background .2s;
}
.sidebar-resize-handle:hover,
.sidebar-resize-handle.dragging {
  background: rgba(184,92,56,0.25);
}
.sidebar-resize-handle::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 2px;
  height: 40px;
  border-radius: 2px;
  background: rgba(184,92,56,0.4);
}

/* Badge couches panel */
.ms-georevo-badge {
  padding: 10px 14px 6px;
  font-size: 10px;
  color: rgba(200,169,110,0.5);
  text-align: center;
  border-top: 1px solid rgba(200,169,110,0.1);
  margin-top: 8px;
}
.ms-georevo-badge a {
  color: var(--sand);
  text-decoration: none;
  font-weight: 700;
}
.ms-georevo-badge a:hover { text-decoration: underline; }


/* ── Sidebar resize handle ── */
.sidebar-resize-handle {
  position: absolute;
  top: 0; right: -4px;
  width: 8px; height: 100%;
  cursor: ew-resize;
  z-index: 100;
}
.sidebar-resize-handle:hover { background: rgba(184,92,56,0.15); }
.sidebar-resize-handle.dragging { background: rgba(184,92,56,0.25); }

/* Badge couches panel */
.ms-georevo-badge {
  padding: 10px 14px 6px;
  font-size: 10px;
  color: rgba(200,169,110,0.5);
  text-align: center;
  border-top: 1px solid rgba(200,169,110,0.1);
  margin-top: 8px;
}
.ms-georevo-badge a { color: var(--sand); text-decoration: none; font-weight: 700; }

/* Logo AGEOS dans le topbar */
.ageos-logo-link {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  opacity: .85;
  transition: opacity .2s;
}
.ageos-logo-link:hover { opacity: 1; }
.ageos-logo {
  height: 32px;
  width: auto;
  display: block;
  border-radius: 4px;
}

/* ═══════════════════════════════════════════════════════════
   OUTIL PARCOURS 3D — Panel + styles
   ═══════════════════════════════════════════════════════════ */

/* Bouton parcours dans toolbar */
.tb-tool-parcours { color: #E8820C !important; font-weight: 600 !important; }
.tb-tool-parcours.active {
  background: #E8820C !important;
  color: #fff !important;
  border-color: #E8820C !important;
}
.tb-tool-parcours svg { color: #E8820C; }
.tb-tool-parcours.active svg { color: #fff; }

/* Panel flottant */
.parcours-panel {
  position: fixed;
  top: 110px;
  right: 70px;
  width: 300px;
  background: #FFFAF4;
  border: 1.5px solid rgba(184,92,56,0.25);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(26,18,11,0.2), 0 4px 16px rgba(184,92,56,0.1);
  z-index: 50;
  overflow: hidden;
  font-family: 'Barlow', sans-serif;
}
.parcours-panel.hidden { display: none; }

/* Header */
.parcours-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px 10px;
  background: #E8820C;
  color: #fff;
}
.parcours-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.parcours-close {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.3);
  background: transparent;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}
.parcours-close:hover { background: rgba(255,255,255,0.2); }

/* Nom parcours */
.parcours-name-wrap { padding: 10px 14px 6px; }
.parcours-name-input {
  width: 100%;
  border: 1.5px solid rgba(184,92,56,0.2);
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 13px;
  font-weight: 600;
  color: #1A120B;
  background: #fff;
  font-family: 'Barlow', sans-serif;
  outline: none;
  transition: border-color .15s;
  box-sizing: border-box;
}
.parcours-name-input:focus { border-color: #B85C38; }

/* Stats */
.parcours-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 8px 10px;
  background: rgba(184,92,56,0.05);
  border-top: 1px solid rgba(184,92,56,0.1);
  border-bottom: 1px solid rgba(184,92,56,0.1);
}
.parcours-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 6px 4px;
}
.parcours-stat-val {
  font-size: 13px;
  font-weight: 800;
  color: #B85C38;
  line-height: 1;
}
.parcours-stat-lbl {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #6B5040;
}

/* Profil alti */
.parcours-profile-wrap {
  position: relative;
  padding: 8px 14px 4px;
  background: #fff;
}
.parcours-profile {
  width: 100%;
  height: 70px;
  display: block;
  border-radius: 6px;
}
.parcours-profile-empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: rgba(184,92,56,0.4);
  font-style: italic;
  pointer-events: none;
}

/* Waypoints liste */
.parcours-wpts {
  max-height: 140px;
  overflow-y: auto;
  padding: 4px 10px;
}
.parcours-wpts::-webkit-scrollbar { width: 3px; }
.parcours-wpts::-webkit-scrollbar-thumb { background: rgba(184,92,56,0.2); border-radius: 3px; }

.parcours-wpt {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 4px;
  border-radius: 6px;
  transition: background .12s;
}
.parcours-wpt:hover { background: rgba(184,92,56,0.06); }
.parcours-wpt-num {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: #B85C38;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.parcours-wpt-txt {
  flex: 1;
  font-size: 11px;
  color: #3D2B1F;
}
.parcours-wpt-txt strong { display: block; font-weight: 600; }
.parcours-wpt-txt small { color: #6B5040; }
.parcours-wpt-del {
  width: 20px; height: 20px;
  border: none; background: transparent;
  color: rgba(184,92,56,0.4);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
  border-radius: 4px;
  transition: background .12s, color .12s;
  opacity: 0;
}
.parcours-wpt:hover .parcours-wpt-del { opacity: 1; }
.parcours-wpt-del:hover { background: rgba(184,92,56,0.1); color: #B85C38; }

/* Actions */
.parcours-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 10px 14px 12px;
  border-top: 1px solid rgba(184,92,56,0.1);
}
.parcours-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  transition: all .15s;
  border: 1.5px solid transparent;
}
.parcours-btn:disabled { opacity: .4; cursor: not-allowed; }

.parcours-btn-fly {
  background: #E8820C;
  color: #fff;
  border-color: #C8A96E;
  grid-column: 1 / -1;
}
.parcours-btn-fly:hover:not(:disabled) { background: #B8966A; }

.parcours-btn-gpx {
  background: transparent;
  color: #B85C38;
  border-color: rgba(184,92,56,0.3);
}
.parcours-btn-gpx:hover:not(:disabled) { background: rgba(184,92,56,0.08); }

.parcours-btn-print {
  background: transparent;
  color: #B85C38;
  border-color: rgba(184,92,56,0.3);
}
.parcours-btn-print:hover:not(:disabled) { background: rgba(184,92,56,0.08); }

.parcours-btn-clear {
  grid-column: 1 / -1;
  background: transparent;
  color: #c0392b;
  border-color: rgba(192,57,43,0.2);
  font-size: 11px;
}
.parcours-btn-clear:hover { background: rgba(192,57,43,0.07); }

/* Curseur actif sur la carte */
body.parcours-drawing #cesiumContainer { cursor: crosshair !important; }

/* Bouton export planificateur → parcours */
.planner-export-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 16px;
  padding: 12px;
  background: #E8820C;
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 700;
  font-family: 'Barlow', sans-serif;
  cursor: pointer;
  transition: background .15s;
}
.planner-export-btn:hover { background: #C56A00; }

/* Bouton restaurer parcours (flottant sur la carte) */
.parcours-restore-btn {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  display: none;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  background: #E8820C;
  color: #fff;
  border: none;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 700;
  font-family: 'Barlow', sans-serif;
  cursor: pointer;
  z-index: 50;
  box-shadow: 0 4px 20px rgba(232,130,12,0.4);
  transition: background .15s, transform .15s;
  white-space: nowrap;
}
.parcours-restore-btn:hover {
  background: #C56A00;
  transform: translateX(-50%) translateY(-2px);
}

/* ── Style ligne parcours ── */
.parcours-style-wrap {
  padding: 6px 14px 8px;
  border-bottom: 1px solid rgba(232,130,12,0.1);
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.parcours-style-colors {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}
.pcolor-btn {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .12s, border-color .12s;
  flex-shrink: 0;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pcolor-btn:hover { transform: scale(1.15); }
.pcolor-btn.active {
  border-color: #1A120B;
  transform: scale(1.15);
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px currentColor;
}
.pcolor-custom {
  background: conic-gradient(red, yellow, lime, cyan, blue, magenta, red) !important;
  overflow: hidden;
}
.pcolor-custom input[type="color"] {
  position: absolute;
  opacity: 0;
  width: 100%; height: 100%;
  cursor: pointer;
}

.parcours-style-width {
  display: flex;
  align-items: center;
  gap: 8px;
}
.parcours-style-lbl {
  font-size: 11px;
  color: #6B5040;
  font-weight: 600;
  flex-shrink: 0;
}
.parcours-width-slider {
  flex: 1;
  -webkit-appearance: none;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(to right, #E8820C var(--val, 25%), rgba(232,130,12,0.2) var(--val, 25%));
  outline: none;
  cursor: pointer;
}
.parcours-width-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: #E8820C;
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
  cursor: pointer;
}
.parcours-width-val {
  font-size: 11px;
  font-weight: 700;
  color: #E8820C;
  min-width: 28px;
  text-align: right;
}

/* ── Contrôles site dans planificateur ── */
.plan-site {
  position: relative;
}
.plan-site-controls {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-left: 8px;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity .15s;
}
.plan-site:hover .plan-site-controls { opacity: 1; }

.psc-btn {
  width: 22px; height: 22px;
  border-radius: 5px;
  border: 1px solid rgba(232,130,12,0.2);
  background: rgba(232,130,12,0.06);
  color: #E8820C;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
  transition: background .12s;
  padding: 0;
}
.psc-btn:hover { background: rgba(232,130,12,0.18); }
.psc-del { color: #c0392b !important; border-color: rgba(192,57,43,0.2) !important; }
.psc-del:hover { background: rgba(192,57,43,0.12) !important; }

/* Bouton mettre à jour carte 3D */
.planner-update-3d-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 14px;
  padding: 11px;
  background: #E8820C;
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 700;
  font-family: 'Barlow', sans-serif;
  cursor: pointer;
  transition: background .15s;
}
.planner-update-3d-btn:hover { background: #C56A00; }

.planner-3d-fixed {
  padding: 10px 14px 4px;
}
.planner-3d-fixed.hidden { display: none; }

/* ═══════════════════════════════════════════════════════════
   SPLASH SCREEN
   ═══════════════════════════════════════════════════════════ */
#splash-screen {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: linear-gradient(160deg, #FFF8F0 0%, #FFFAF4 50%, #FFF5E8 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: opacity .6s ease, visibility .6s;
}
#splash-screen.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.splash-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

/* Icône animée */
.splash-icon {
  width: 100px;
  height: 100px;
  animation: splash-float 3s ease-in-out infinite;
}
.splash-icon svg {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 8px 24px rgba(184,92,56,0.4));
}
@keyframes splash-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

/* Logo */
.splash-logo {
  font-family: 'Barlow', sans-serif;
  font-size: 42px;
  font-weight: 900;
  letter-spacing: -.5px;
  display: flex;
  align-items: baseline;
  gap: 0;
  animation: splash-fadein .8s ease forwards;
}
.splash-geo   { color: #C8A96E; }
.splash-dahar { color: #B85C38; }
.splash-beta  {
  font-size: 14px;
  background: rgba(200,169,110,0.15);
  border: 1px solid rgba(200,169,110,0.3);
  color: #C8A96E;
  border-radius: 6px;
  padding: 2px 6px;
  margin-left: 8px;
  font-weight: 700;
  vertical-align: super;
}

.splash-tagline {
  font-size: 13px;
  color: rgba(184,92,56,0.6);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-family: 'Barlow', sans-serif;
  animation: splash-fadein 1s ease .2s both;
}

/* Barre de progression */
.splash-progress-wrap {
  width: 220px;
  height: 3px;
  background: rgba(184,92,56,0.15);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 8px;
}
.splash-progress-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #C8A96E, #E8820C);
  border-radius: 2px;
  transition: width .4s ease;
}

/* Hint rotatif */
.splash-hint {
  font-size: 12px;
  color: rgba(184,92,56,0.5);
  font-family: 'Barlow', sans-serif;
  font-style: italic;
  min-height: 18px;
  animation: splash-fadein .5s ease;
}

/* Footer */
.splash-footer {
  position: absolute;
  bottom: 24px;
  font-size: 11px;
  color: rgba(107,80,64,0.5);
  display: flex;
  gap: 5px;
  align-items: center;
}
.splash-footer a { color: #B85C38; text-decoration: none; font-weight: 700; }
.splash-footer a:hover { color: #E8820C; }

@keyframes splash-fadein {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Logos partenaires splash */
.splash-partners {
  position: absolute;
  bottom: 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.splash-partners-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(107,80,64,0.45);
  font-family: 'Barlow', sans-serif;
}
.splash-partners-logos {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
}
.splash-partners-logos a {
  display: flex;
  align-items: center;
  opacity: .7;
  transition: opacity .2s;
}
.splash-partners-logos a:hover { opacity: 1; }
.splash-partners-logos img {
  height: 28px;
  width: auto;
  max-width: 100px;
  object-fit: contain;
  filter: grayscale(20%);
}

.splash-partners-sep {
  width: 1px;
  height: 28px;
  background: rgba(184,92,56,0.15);
}

/* Couches panel position adjust when tools toolbar visible */
body.tools-open .tool-panel { top: 130px; }

/* Animation chameau */
.splash-camel-wrap {
  position: absolute;
  bottom: 115px;
  left: 0; right: 0;
  pointer-events: none;
  overflow: hidden;
  height: 210px;
}
.splash-camel {
  width: 100%;
  max-width: 680px;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* FAB GPS actif */
#fabGPS[aria-pressed="true"] {
  background: #3B82F6 !important;
  color: #fff !important;
  outline: 2px solid rgba(59,130,246,0.4);
}

/* Widget météo topbar */
.weather-widget {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 10px;
  border: 1px solid rgba(200,169,110,0.2);
  background: rgba(200,169,110,0.06);
  cursor: default;
  flex-shrink: 0;
  transition: background .15s;
}
.weather-widget:hover { background: rgba(200,169,110,0.12); }
.weather-icon { font-size: 18px; line-height: 1; }
.weather-info {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.weather-temp {
  font-size: 14px;
  font-weight: 800;
  color: var(--sand);
  line-height: 1.1;
  font-family: 'Barlow', sans-serif;
}
.weather-desc {
  font-size: 10px;
  color: var(--muted);
  white-space: nowrap;
  max-width: 90px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ═══════════════════════════════════════════════════════════
   MODAL PARTAGE
   ═══════════════════════════════════════════════════════════ */
.share-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(26,18,11,0.6);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.share-modal.hidden { display: none; }

.share-modal-box {
  background: #FFFAF4;
  border: 1.5px solid rgba(184,92,56,0.2);
  border-radius: 16px;
  width: 460px;
  max-width: 90vw;
  box-shadow: 0 24px 64px rgba(26,18,11,0.3);
  overflow: hidden;
}
.share-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  background: #E8820C;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  font-family: 'Barlow', sans-serif;
}
.share-modal-close {
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.3);
  background: transparent;
  color: #fff;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
}
.share-modal-close:hover { background: rgba(255,255,255,0.2); }

.share-modal-body { padding: 16px 18px 18px; }

.share-section { margin-bottom: 16px; }
.share-section.hidden { display: none; }
.share-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: #6B5040;
  font-weight: 700;
  margin-bottom: 6px;
}
.share-url-row {
  display: flex;
  gap: 6px;
}
.share-url-input {
  flex: 1;
  padding: 8px 10px;
  border: 1.5px solid rgba(184,92,56,0.2);
  border-radius: 8px;
  font-size: 12px;
  color: #3D2B1F;
  background: #fff;
  font-family: monospace;
  outline: none;
}
.share-copy-btn {
  width: 36px; height: 36px;
  border-radius: 8px;
  border: 1.5px solid rgba(184,92,56,0.25);
  background: rgba(232,130,12,0.08);
  color: #E8820C;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  transition: background .15s;
  flex-shrink: 0;
}
.share-copy-btn:hover { background: #E8820C; color: #fff; }
.share-copied {
  font-size: 12px;
  color: #2E7D32;
  font-weight: 600;
  margin-top: 4px;
}
.share-copied.hidden { display: none; }

.share-socials {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.share-social-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: opacity .15s;
  font-family: 'Barlow', sans-serif;
}
.share-social-btn:hover { opacity: .85; }
.share-wa { background: #25D366; color: #fff; }
.share-tw { background: #000; color: #fff; }
.share-fb { background: #1877F2; color: #fff; }
.share-li { background: #0A66C2; color: #fff; }

/* ── Sélecteur de langue ── */
.lang-selector {
  display: flex;
  align-items: center;
  gap: 2px;
  background: rgba(200,169,110,0.08);
  border: 1px solid rgba(200,169,110,0.18);
  border-radius: 8px;
  padding: 2px;
  flex-shrink: 0;
}
.lang-btn {
  padding: 4px 8px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  transition: background .15s, color .15s;
  min-width: 26px;
}
.lang-btn:hover { color: var(--sand); }
.lang-btn.active {
  background: #E8820C;
  color: #fff;
}

/* RTL support arabe */
[dir="rtl"] .topbar { flex-direction: row-reverse; }
[dir="rtl"] .left.panel { left: auto; right: 0; border-right: none; border-left: 1px solid var(--border); }
[dir="rtl"] #cesiumContainer { left: 0; right: var(--sidebar-w); }
[dir="rtl"] .map-fabs { left: 16px; right: auto; }
[dir="rtl"] .parcours-panel { right: auto; left: 70px; }
[dir="rtl"] .poi-back i { transform: scaleX(-1); }

/* ═══════════════════════════════════════════════════════════
   TUTORIEL GEODAHAR
   ═══════════════════════════════════════════════════════════ */
.tuto-overlay {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(26,18,11,0.65);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.tuto-overlay.hidden { display: none; }

.tuto-modal {
  background: #FFFAF4;
  border: 1.5px solid rgba(232,130,12,0.2);
  border-radius: 20px;
  width: 580px;
  max-width: 95vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 32px 80px rgba(26,18,11,0.35);
  overflow: hidden;
  font-family: 'Barlow', sans-serif;
}

/* Header */
.tuto-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  background: linear-gradient(135deg, #E8820C, #B85C38);
  color: #fff;
}
.tuto-header-left { display: flex; align-items: center; gap: 12px; }
.tuto-title { font-size: 15px; font-weight: 800; }
.tuto-subtitle { font-size: 11px; opacity: .8; margin-top: 2px; }
.tuto-close {
  width: 30px; height: 30px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.3);
  background: transparent;
  color: #fff;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  transition: background .15s;
}
.tuto-close:hover { background: rgba(255,255,255,0.2); }

/* Steps nav dots */
.tuto-steps-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px 0;
  background: #fff;
}
.tuto-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  border: none;
  background: rgba(232,130,12,0.2);
  cursor: pointer;
  transition: background .15s, transform .15s;
  padding: 0;
}
.tuto-dot:hover { background: rgba(232,130,12,0.4); }
.tuto-dot.active { background: #E8820C; transform: scale(1.3); }

/* Content */
.tuto-content {
  flex: 1;
  overflow-y: auto;
  padding: 16px 24px;
  background: #fff;
}
.tuto-content::-webkit-scrollbar { width: 4px; }
.tuto-content::-webkit-scrollbar-thumb { background: rgba(232,130,12,0.2); border-radius: 4px; }

.tuto-step-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(232,130,12,0.1);
}
.tuto-step-icon { font-size: 28px; line-height: 1; }
.tuto-step-title {
  font-size: 18px;
  font-weight: 800;
  color: #1A120B;
  margin: 0;
}
.tuto-step-body p {
  font-size: 14px;
  color: #3D2B1F;
  line-height: 1.6;
  margin-bottom: 10px;
}
.tuto-step-body strong { color: #E8820C; }

/* Step image */
.tuto-step-img {
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 14px;
  border: 1px solid rgba(232,130,12,0.15);
}

/* Controls grid */
.tuto-controls-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}
.tuto-control {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: rgba(232,130,12,0.05);
  border: 1px solid rgba(232,130,12,0.12);
  border-radius: 10px;
}
.tuto-control-icon { font-size: 20px; flex-shrink: 0; }
.tuto-control-desc { font-size: 12px; color: #3D2B1F; line-height: 1.4; }
.tuto-control-desc strong { color: #1A120B; display: block; }

/* Feature steps */
.tuto-feature {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
  font-size: 13px;
  color: #3D2B1F;
  line-height: 1.5;
}
.tuto-feature-step span {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #E8820C;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

/* Tools grid */
.tuto-tools-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}
.tuto-tool-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: rgba(232,130,12,0.04);
  border: 1px solid rgba(232,130,12,0.1);
  border-radius: 10px;
  font-size: 12px;
  color: #3D2B1F;
  line-height: 1.4;
}
.tuto-tool-item i { font-size: 16px; color: #E8820C; margin-top: 2px; flex-shrink: 0; }
.tuto-tool-item strong { display: block; color: #1A120B; margin-bottom: 2px; }
.tuto-tool-item small { color: #6B5040; }

/* Tip */
.tuto-tip {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: rgba(200,169,110,0.1);
  border: 1px solid rgba(200,169,110,0.25);
  border-radius: 8px;
  font-size: 12px;
  color: #5C3820;
  line-height: 1.5;
  margin-top: 10px;
}
.tuto-tip i { color: #E8820C; flex-shrink: 0; margin-top: 2px; }

/* Footer */
.tuto-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: #FFFAF4;
  border-top: 1px solid rgba(232,130,12,0.1);
}
.tuto-counter { font-size: 12px; color: #6B5040; font-weight: 600; }
.tuto-btn-prev, .tuto-btn-next {
  padding: 8px 18px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  transition: all .15s;
  border: 1.5px solid;
}
.tuto-btn-prev {
  background: transparent;
  color: #E8820C;
  border-color: rgba(232,130,12,0.3);
}
.tuto-btn-prev:hover:not(:disabled) { background: rgba(232,130,12,0.08); }
.tuto-btn-prev:disabled { opacity: .35; cursor: not-allowed; }
.tuto-btn-next {
  background: #E8820C;
  color: #fff;
  border-color: #E8820C;
}
.tuto-btn-next:hover { background: #C56A00; }

/* ── FAB OSM actif ── */
#fabOSM[aria-pressed="true"] {
  background: #4A90D9 !important;
  color: #fff !important;
  outline: 2px solid rgba(74,144,217,0.4);
}

/* ── Status OSM ── */
.osm-status {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(26,18,11,0.88);
  color: #C8A96E;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 20px;
  font-family: 'Barlow', sans-serif;
  display: none;
  z-index: 50;
  pointer-events: none;
  white-space: nowrap;
}

/* ── Popup POI OSM ── */
.osm-popup {
  position: absolute;
  width: 260px;
  background: #FFFAF4;
  border: 1.5px solid rgba(74,144,217,0.25);
  border-radius: 14px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.25);
  z-index: 100;
  overflow: hidden;
  font-family: 'Barlow', sans-serif;
}
.osm-popup-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  color: #fff;
}
.osm-popup-icon { font-size: 18px; }
.osm-popup-cat  { font-size: 12px; font-weight: 700; flex: 1; text-transform: uppercase; letter-spacing: .1em; }
.osm-popup-close {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.3);
  background: transparent;
  color: #fff;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
}
.osm-popup-close:hover { background: rgba(255,255,255,0.2); }
.osm-popup-body { padding: 10px 12px 12px; }
.osm-popup-name {
  font-size: 14px;
  font-weight: 800;
  color: #1A120B;
  margin-bottom: 8px;
  line-height: 1.3;
}
.osm-popup-row {
  font-size: 11px;
  color: #6B5040;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.osm-popup-row a { color: #4A90D9; text-decoration: none; }
.osm-popup-row i { width: 14px; color: #C8A96E; }

.osm-popup-actions {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.osm-popup-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 7px;
  font-size: 11px;
  font-weight: 700;
  text-decoration: none;
  transition: opacity .15s;
}
.osm-popup-btn:hover { opacity: .85; }
.osm-btn-map  { background: #4A90D9; color: #fff; }
.osm-btn-book { background: #003580; color: #fff; }
.osm-btn-web  { background: #E8820C; color: #fff; }

/* ═══════════════════════════════════════════════════════════
   RECHERCHE — nouveau style GeoDahar
   ═══════════════════════════════════════════════════════════ */
.search-wrap {
  position: relative;
  flex: 1;
  max-width: 360px;
}
.search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(232,130,12,0.6);
  font-size: 13px;
  pointer-events: none;
}
.top-search input#searchInput {
  width: 100%;
  height: 36px;
  border-radius: 10px;
  border: 1.5px solid rgba(232,130,12,0.2);
  padding: 0 12px 0 34px;
  outline: none;
  background: #fff;
  color: #1A120B;
  font-size: 13px;
  font-family: 'Barlow', sans-serif;
  transition: border-color .15s, box-shadow .15s;
}
.top-search input#searchInput::placeholder { color: rgba(107,80,64,0.45); }
.top-search input#searchInput:focus {
  border-color: #E8820C;
  box-shadow: 0 0 0 3px rgba(232,130,12,0.12);
}

/* Dropdown résultats */
.search-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0; right: 0;
  background: #FFFAF4;
  border: 1.5px solid rgba(232,130,12,0.2);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(26,18,11,0.15);
  z-index: 200;
  overflow: hidden;
  max-height: 380px;
  overflow-y: auto;
}
.search-dropdown.hidden { display: none; }
.search-dropdown::-webkit-scrollbar { width: 4px; }
.search-dropdown::-webkit-scrollbar-thumb { background: rgba(232,130,12,0.2); border-radius: 4px; }

.search-group-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: #E8820C;
  font-weight: 800;
  padding: 8px 14px 4px;
  font-family: 'Barlow', sans-serif;
}
.search-result-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  cursor: pointer;
  transition: background .12s;
  border-bottom: 1px solid rgba(232,130,12,0.06);
}
.search-result-item:last-child { border-bottom: none; }
.search-result-item:hover { background: rgba(232,130,12,0.07); }
.search-result-icon {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: rgba(232,130,12,0.1);
  display: flex; align-items: center; justify-content: center;
  color: #E8820C;
  font-size: 13px;
  flex-shrink: 0;
}
.search-result-text { flex: 1; }
.search-result-name {
  font-size: 13px;
  font-weight: 700;
  color: #1A120B;
  line-height: 1.2;
}
.search-result-sub {
  font-size: 11px;
  color: #6B5040;
  margin-top: 1px;
}
.search-result-badge {
  font-size: 10px;
  background: rgba(232,130,12,0.1);
  color: #E8820C;
  border-radius: 5px;
  padding: 2px 6px;
  font-weight: 600;
  flex-shrink: 0;
}
.search-empty {
  padding: 16px 14px;
  font-size: 13px;
  color: #6B5040;
  text-align: center;
  font-style: italic;
}
