:root {
  /* ── Palette officielle du Canton de Vaud (sans or) ── */
  --vaud-green:        #007A33;   /* Vert sinople (drapeau) */
  --vaud-green-dark:   #004D20;   /* Vert foncé hover/text/accents */
  --vaud-green-light:  #3FA862;   /* Vert clair highlight */
  --vaud-green-dim:    rgba(0,122,51,0.12);
  /* Anciens tokens "or" remappés en vert foncé pour rétrocompat */
  --vaud-gold:         var(--vaud-green-dark);
  --vaud-gold-light:   var(--vaud-green-light);
  --vaud-gold-dim:     var(--vaud-green-dim);
  --vaud-cream:        #F8F6EE;   /* Blanc cassé chaleureux */
  --vaud-bone:         #FFFFFF;   /* Blanc pur (drapeau) */
  --vaud-slate:        #1A2620;   /* Vert très foncé (mode sombre) */
  --vaud-ink:          #0F1A14;   /* Encre noire-verte */

  /* ── Alias de compatibilité (utilisés dans le code existant) ── */
  --blue:         var(--vaud-green);
  --blue-dark:    var(--vaud-green-dark);
  --purple:       var(--vaud-green-dark);
  --purple-light: var(--vaud-green-light);
  --gold:         var(--vaud-green-dark);
  --yellow:       var(--vaud-green-dark);
  --bg:           var(--vaud-cream);
  --panel:        var(--vaud-bone);
  --muted:        #5d6d62;
  --text:         var(--vaud-ink);
  --accent:       var(--vaud-green-dark);
  --brand:        var(--vaud-green);
  --brand2:       var(--vaud-green-dark);
  --ring:         rgba(0,122,51,0.35);
  --border:       rgba(0,77,32,0.14);
  --ok:#22c55e;
  --warn:         var(--vaud-green);
  --bad:#ef4444;

  --sidebar-w: 320px;
  --sidebar-w-collapsed: 72px;
}
    *{box-sizing:border-box}
    html,body,#app{height:100%}
    body{margin:0;background:var(--bg);color:#e9eefb;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif}

    /* 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 var(--border);
      background:linear-gradient(180deg, rgba(3,84,195,.25) 0%, rgba(2,74,166,.15) 100%);
      backdrop-filter:saturate(130%) blur(8px);z-index:20
    }
    .brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.3px}
    .brand .logo{width:28px;height:28px;border-radius:8px;background:radial-gradient(circle at 30% 30%, var(--yellow), #3FA862 40%, #004D20 75%);box-shadow:0 0 0 2px rgba(0,77,32,.22), 0 10px 30px rgba(0,77,32,.30)}
    .brand .title{font-size:18px}
    .spacer{flex:1}
    .nav{display:flex;gap:8px}
    .nav button{
      appearance:none;border:1px solid var(--border);background:rgba(2,74,166,.25);color:#fff;cursor:pointer;
      padding:8px 12px;border-radius:10px;font-weight:600;letter-spacing:.2px
    }
    .nav button:hover{background:rgba(3,84,195,.4)}

    /* 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:var(--panel);
      border-right:1px solid var(--border);
      padding:14px 12px;
      overflow:auto;
      width:var(--sidebar-w);
    }
    .section-title{font-size:25px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin:6px 6px 10px}
    .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 var(--border);background:#0c1527;cursor:pointer
    }
    .tool-btn:hover{background:#0e1930}
    .tool-btn .label{font-weight:700}
    .tool-btn .sublabel{font-size:12px;color:var(--muted)}

    .card{margin:12px;border:1px solid var(--border);border-radius:14px;background:#0c1527}
    .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:#0a1222;color:#e9eefb;border:1px solid var(--border);border-radius:10px;padding:10px 12px;outline:none
    }
    .chip{font-size:12px;background:rgba(0,77,32,.12);border:1px solid rgba(0,77,32,.30);padding:4px 8px;border-radius:999px;color:#FFFFFF}
    .btn{
      appearance:none;border:1px solid var(--border);background:linear-gradient(180deg, var(--blue-600), var(--blue-700));
      color:#fff;padding:10px 12px;border-radius:10px;font-weight:700;cursor:pointer
    }
    .btn.secondary{background:#0a1222}
    .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(10,18,34,.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:#0b1426;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:#0a1222;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(2,74,166,.08), rgba(3,84,195,.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:#0b1420;transition:transform .12s ease, background .2s ease}
    .tool-card:hover{transform:translateY(-1px);background:#0e1930}
    .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='%23007A33'/><stop offset='1' stop-color='%23004D20'/></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='%2300A040' stroke-width='6'/><circle cx='60' cy='70' r='8' fill='%2300A040'/></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='%23004D20'/><path d='M0 110 Q60 90 120 110 T240 110' fill='none' stroke='%2300A040' stroke-width='6'/><path d='M0 130 Q60 110 120 130 T240 130' fill='none' stroke='%237FCFA0' 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='%23007A33'/><rect x='40' y='70' width='160' height='50' fill='rgba(0,122,51,0.25)' stroke='%2300A040' stroke-width='4'/><path d='M40 120 L80 90 L120 120 L160 85 L200 120' fill='none' stroke='%237FCFA0' 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='%231A2620'/><circle cx='60' cy='40' r='10' fill='%2300A040'/><line x1='60' y1='40' x2='60' y2='140' stroke='%2300A040' 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='%2300A040'/><stop offset='1' stop-color='%23004D20'/></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:#0a1222;color:#e9eefb;cursor:pointer;font:inherit;text-align:left}
    .tool-btn2:hover{background:#0d1730;border-color:rgba(0,77,32,.35)}
    .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='%23007A33'/><stop offset='1' stop-color='%23004D20'/></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='%2300A040' 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='%23004D20'/><path d='M0 100 Q60 85 120 100 T240 100' fill='none' stroke='%2300A040' stroke-width='6'/><path d='M0 125 Q60 108 120 125 T240 125' fill='none' stroke='%237FCFA0' 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='%23007A33'/><rect x='40' y='70' width='160' height='50' rx='8' ry='8' fill='rgba(0,122,51,0.25)' stroke='%2300A040' stroke-width='4'/><path d='M40 120 L80 90 L120 120 L160 85 L200 120' fill='none' stroke='%237FCFA0' 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='%231A2620'/><circle cx='60' cy='40' r='10' fill='%2300A040'/><line x1='60' y1='40' x2='60' y2='140' stroke='%2300A040' 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='%2300A040'/><stop offset='1' stop-color='%23004D20'/></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(10,18,34,.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),#004D20);
  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-vaud{color:var(--gold)}
.brand-geol{color:var(--blue)}
.beta-badge{
  padding:.15rem .6rem;border-radius:999px;font-weight:700;font-size:.8rem;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(3,84,195,.12); color:var(--gold)
}
:root{
  --sidebar-w: 320px;            /* 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(12,17,27,.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(0,77,32,.12),rgba(3,84,195,.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:#e9eef7; text-align:left;
}
.tool-btn2:hover{border-color:rgba(3,84,195,.45);box-shadow:0 6px 18px rgba(3,84,195,.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:#e9eef7;
}
.btn-geo:hover{border-color:rgba(3,84,195,.55); box-shadow:0 8px 22px rgba(3,84,195,.22)}
:root{ --sidebar-w:320px; --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(12,17,27,.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(18,25,48,.9), rgba(10,16,36,.9));
  border-radius: 14px;
  color: #e9eef7;
  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(0,77,32,.30); }

.card-btn::before{
  content:"";
  width: 56px; height: 56px;
  border-radius: 12px;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(0,77,32,.22), 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:#e9eef7; 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: #0a1222;
  border: 1px solid var(--border);
  color: #e9eef7;
  padding: 8px 10px;
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
}
.tool-tree button:hover {
  background: #0d1730;
}
.theme-mines{
  --bg: var(--vaud-slate);
  --panel: #142019;
  --card: #1b2a23;
  --card2:#0f1a14;
  --text: var(--vaud-cream);
  --muted:#a3b8ad;
  --brand:  var(--vaud-green);    /* vert sinople */
  --brand2: var(--vaud-green-dark); /* vert foncé */
  --accent: var(--vaud-gold);      /* or de la devise */
  --ring: rgba(0,77,32,.40);
}

.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(3,84,195,.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(0,122,51,.10); color:var(--text);
  border:1px solid rgba(0,77,32,.30);
  width:max-content; transition: transform .12s ease, background .12s ease;
}
.chip-back:hover{ transform: translateY(-1px); background: rgba(0,122,51,.16); }

/* util */
.hidden{ display:none !important; }
body {
  margin:0;
  background:var(--bg);
  color:#1f2937; /* 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(0,122,51,.08) 0%, rgba(59,130,246,.1) 100%);
  backdrop-filter:saturate(130%) blur(8px);
  z-index:20;
}
.brand-text {
  font-weight:900;
  font-size:1.6rem;
}
.brand-vaud { color: var(--purple); }
.brand-geol { color: var(--blue-dark); }
.beta-badge {
  padding:.15rem .6rem;
  border-radius:999px;
  font-weight:600;
  font-size:.8rem;
  border:1px solid var(--purple-light);
  background:rgba(0,122,51,.08);
  color:var(--purple);
}

/* Sidebar claire */
.panel {
  background:var(--panel);
  border-right:1px solid var(--border);
  color:#1f2937;
}
.section-title { color: var(--purple); font-weight:700; }

/* Boutons */
.tool-btn2 {
  display:flex;align-items:center;gap:.8rem;width:100%;
  padding:.75rem 1rem;border-radius:14px;
  background:linear-gradient(180deg, #f3f4f6, #e5e7eb);
  border:1px solid var(--border); color:#7c9dcb; text-align:left;
  transition:all .2s;
}
.tool-btn2:hover {
  border-color:#e9eef7;
    box-shadow:0 4px 12px rgba(152, 185, 239, 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:#fff; color:#1f2937;
  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(18,25,48,.9), rgba(10,16,36,.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: #a7b6d4; margin-top: 2px;
}

/* 5) Effet hover doux (carte + image) */
.tool-buttons .tool-btn2.card-btn:hover{
  transform: translateY(-2px);
  border-color: rgba(0,77,32,.30);
  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(0,77,32,.40);
  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:#1f2937;
  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:#fff;
  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(0,122,51,.30); /* 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(0,122,51,.40);
  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(0,122,51,.18);
}

.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(0,122,51,.22);
}

.nav button:active {
  transform: translateY(0);
  box-shadow: 0 3px 8px rgba(0,122,51,.22);
}
.nav button {
  background: rgba(0,122,51,.12);
  border: 1px solid rgba(0,122,51,.30);
  backdrop-filter: blur(6px);
  color: var(--purple);
}
.nav button:hover {
  background: rgba(0,122,51,.22);
}
.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(0,122,51,.12);     /* violet clair */
  --bd: rgba(0,122,51,.30);
  --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(0,122,51,.20);
  box-shadow: 0 8px 22px rgba(0,122,51,.20);
  border-color: rgba(0,122,51,.45);
}
.topbar .nav .tb-btn:active{ transform: translateY(0); box-shadow: 0 4px 12px rgba(0,122,51,.18); }
.topbar .nav .tb-btn:focus-visible{ outline:3px solid rgba(0,122,51,.40); outline-offset:3px; }

/* Variante “ghost-bleu” (ex: Tutoriel) */
.topbar .nav .tb-btn.ghost{
  --bg: rgba(59,130,246,.12);
  --bd: rgba(59,130,246,.35);
}
.topbar .nav .tb-btn.ghost:hover{
  background: rgba(59,130,246,.2);
  box-shadow: 0 8px 22px rgba(59,130,246,.22);
  border-color: rgba(59,130,246,.5);
}
/* ===== Modal tutoriel (look pro) ===== */
.modal{background:rgba(12,17,27,.45); backdrop-filter: blur(4px); }
.modal .dialog{
  width:min(900px,92vw); max-height:86vh; overflow:auto;
  border-radius:18px; background:#fff; 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:#fff; 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(15,23,42,.2); background:#111827; }
.modal .dialog .close-btn:focus-visible{ outline:3px solid rgba(59,130,246,.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(0,122,51,.22);
}

/* 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(0,122,51,.40);  /* anneau violet actif */
  outline-offset: 2px;
}
:root{
  --header-h: 56px;     /* hauteur compacte du header */
  --sidebar-w: 300px;   /* 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(15,23,42,.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(15,23,42,.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:var(--vaud-green); box-shadow:0 0 0 4px rgba(0,122,51,.18);}

.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:#fff;
}

.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:#fff; 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:#fff; 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: 320px;      /* 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(0,122,51,.08) 0%, rgba(59,130,246,.10) 100%);
  backdrop-filter:saturate(130%) blur(8px);
  z-index:50;
}
.brand-text{font-weight:900; font-size:1.6rem;}
.brand-vaud{color:var(--vaud-green-dark);} .brand-geol{color:var(--vaud-green-dark);}

.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(0,122,51,.30);
  background:rgba(0,122,51,.12); 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(0,122,51,.20);
  box-shadow: 0 8px 22px rgba(0,122,51,.20);
  border-color: rgba(0,122,51,.45);
}
.topbar .nav .tb-btn.ghost{
  border-color: rgba(59,130,246,.35);
  background: rgba(59,130,246,.12);
}
.topbar .nav .tb-btn.ghost:hover{
  background: rgba(59,130,246,.20);
  box-shadow: 0 8px 22px rgba(59,130,246,.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:#fff; color:#1f2937;
  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, var(--vaud-green-dark), var(--vaud-green)); /* 👉 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, var(--vaud-green), var(--vaud-green-dark));
  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(0,122,51,.16);
}

#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: #e9eef7;
  background: linear-gradient(180deg, rgba(18,25,48,.9), rgba(10,16,36,.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(0,122,51,.40);
  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 var(--vaud-green-dark); }

.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:320px; }

/* 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 OFFICIELLE CANTON DE VAUD — OVERRIDES FINAUX
   Vert sinople #007A33 + Vert foncé #004D20 + Blanc
   (couleurs du drapeau, sans or — accents en vert foncé)
========================================================= */

/* 2.1 — Remap final des variables (priorité cascade) */
:root{
  --blue:        var(--vaud-green);
  --blue-dark:   var(--vaud-green-dark);
  --purple:      var(--vaud-green-light);   /* ex-violet → vert clair */
  --purple-light:#7FCFA0;                    /* vert très pâle pour hovers */
  --panel:       var(--vaud-bone);
  --bg:          var(--vaud-cream);
  --border:      rgba(0,77,32,.14);
  --muted:       #5d6d62;
  --ok:          var(--vaud-green);
  --warn:        var(--vaud-gold);
  --bad:         #ef4444;
}

/* 2.2 — Header / topbar : dégradé blanc + vert (drapeau vaudois) */
.app-header,
.topbar{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(0,122,51,.08)) !important;
  border-bottom: 2px solid var(--vaud-green) !important;
}

/* 2.3 — Marque : "Vaud" en vert profond, "Geol" en vert sinople */
.brand-vaud{ color: var(--vaud-green-dark) !important; }
.brand-geol{ color: var(--vaud-green) !important; }

/* 2.4 — Boutons "chip" (Thèmes, Outils…) → vert */
.chip{
  color:#fff !important;
  background: linear-gradient(135deg, var(--vaud-green), var(--vaud-green-dark)) !important;
  border: none !important;
}
.chip:hover{
  background: linear-gradient(135deg, var(--vaud-green-light), var(--vaud-green)) !important;
}

.icon-btn{
  background: linear-gradient(135deg, var(--vaud-green), var(--vaud-green-dark)) !important;
  color:#fff !important; border:none !important;
}

.section-title{ color: var(--vaud-green-dark) !important; }

.tool-buttons .tool-btn2.card-btn{
  background: linear-gradient(180deg, #ffffff, #f5f7f4) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}
.tool-buttons .tool-btn2.card-btn:hover{
  border-color: rgba(0,122,51,.45) !important;
  box-shadow: 0 10px 24px rgba(0,122,51,.14) !important;
}
.tool-buttons .tool-btn2.card-btn .txt strong{ color: var(--vaud-ink) !important; }
.tool-buttons .tool-btn2.card-btn .txt small{ color: var(--muted) !important; }

#tools-sidebar .sidebar-link{
  background: linear-gradient(180deg, #ffffff, #f5f7f4) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}
#tools-sidebar .sidebar-link:hover{
  border-color: rgba(0,122,51,.45) !important;
  box-shadow: 0 8px 20px rgba(0,122,51,.14) !important;
}
#tools-sidebar .sidebar-link i{
  background: linear-gradient(135deg, var(--vaud-green), var(--vaud-green-dark)) !important;
}

.ms-item .ic{
  background: linear-gradient(160deg, var(--vaud-green), var(--vaud-green-dark)) !important;
}
.ms-item:hover{
  border-color: rgba(0,122,51,.5) !important;
  box-shadow: 0 10px 24px rgba(0,122,51,.20) inset !important;
}

/* Mode sombre */
body.dark{
  --bg: var(--vaud-slate);
  --panel: #0f1a14;
  --muted:#9aaa9f;
}
body.dark .panel{ background: var(--panel); }
body.dark .chip,
body.dark .icon-btn{
  filter: saturate(110%);
}

.fab[aria-pressed="true"]{
  outline: 3px solid rgba(0,77,32,.45) !important;   /* or, accent vaudois */
  outline-offset: 2px;
}

.beta-badge{
  border-color: rgba(0,122,51,.4) !important;
  background: rgba(0,122,51,.10) !important;
  color: var(--vaud-green-dark) !important;
  font-weight: 700;
}

/* ===== 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(255,255,255,.95);
  color:#111827;
  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:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,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:#111827;
  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(0,0,0,.12);
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  font-weight:700;
  background:#fff;
  color:#111827;
  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,rgba(0,77,32,.13),rgba(0,122,51,.10));
  border-color:var(--vaud-green-light);
}
.polyline-btn.danger{
  border-color:#ef444444;
  color:#ef4444;
}

.hidden{ display:none !important; }

/* Thème sombre (si body.dark) */
body.dark .polyline-panel{
  background:rgba(15,23,42,.92);
  color:#e5e7eb;
  border-color:rgba(255,255,255,.08);
}
body.dark .polyline-btn{
  background:#0b1222;
  border-color:rgba(255,255,255,.12);
  color:#e5e7eb;
}
body.dark .polyline-btn.primary{ border-color:rgba(0,77,32,.55); }
body.dark .polyline-btn.danger{ border-color:#ef444444; color:#fecaca; }


/* ==== Panneau générique (reutilisable poly/anno) ==== */
.tool-panel {
  position: absolute; right: 18px; top: 84px; z-index: 40;
  width: clamp(280px, 28vw, 420px);
  background: var(--panel-bg, rgba(13,30,49,.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(13,30,49,.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}

/* =========================================================
   ★ THÈME VAUD V2 — OVERRIDES FINAUX (thème clair officiel)
   Élimine les restes de l'ancien thème sombre Maprevo
========================================================= */

/* Corps en clair, texte en encre vert-noir */
body{
  background: var(--vaud-cream) !important;
  color: var(--vaud-ink) !important;
}

/* Search input + chips topbar (anciennement bleu nuit) */
.topbar .search input,
.topbar .nav .tb-btn,
.topbar input[type="text"]{
  background: rgba(0,122,51,.06) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}
.topbar .search input::placeholder{ color: var(--muted); }
.topbar .nav .tb-btn:hover{
  background: rgba(0,122,51,.12) !important;
  border-color: var(--vaud-green) !important;
}

/* Cartes, tool-btns, tool-card, modals, kbd : fond clair */
.card,
.tool-btn,
.tool-card,
.tool-btn2,
.modal .dialog,
.kbd,
.btn.secondary,
input[type="number"],
input[type="text"],
input[type="search"],
select{
  background: var(--vaud-bone) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}
.tool-btn:hover,
.tool-card:hover,
.tool-btn2:hover{
  background: #f5f7f4 !important;
  border-color: var(--vaud-green) !important;
  box-shadow: 0 6px 18px rgba(0,122,51,.10) !important;
}

/* Brand badge logo : drapeau vaudois (blanc en haut, vert en bas) */
.brand .logo,
.brand-badge{
  background: linear-gradient(180deg,
                              #ffffff 0%,
                              #ffffff 50%,
                              var(--vaud-green) 50%,
                              var(--vaud-green) 100%) !important;
  border: 1px solid var(--vaud-green-dark) !important;
  box-shadow: 0 0 0 2px rgba(0,77,32,.18),
              0 8px 22px rgba(0,77,32,.25) !important;
}

/* Beta badge (sur la topbar) */
.beta-badge{
  background: rgba(0,77,32,.12) !important;
  border: 1px solid rgba(0,77,32,.4) !important;
  color: var(--vaud-green-dark) !important;
}

/* Polyligne 3D panel : déjà clair, juste accents */
.polyline-panel h4{ color: var(--vaud-green-dark); }
.polyline-panel button.primary,
.polyline-panel .btn-primary{
  background: linear-gradient(135deg, var(--vaud-green), var(--vaud-green-dark)) !important;
  color: #fff !important;
  border: none !important;
}

/* Tool-drawer (panneau outils flottant) : passer en clair */
.tool-drawer{
  background: rgba(255,255,255,.96) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 12px 36px rgba(0,77,32,.18) !important;
}
.tool-drawer h3{ color: var(--vaud-green-dark); }
.tool-drawer input{
  background: var(--vaud-cream) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}

/* Bottom dock (barre flottante outils en bas de carte) */
.bottom-dock{
  background: rgba(255,255,255,.92) !important;
  border: 1px solid var(--border) !important;
  backdrop-filter: blur(8px) saturate(130%);
}

/* btn-geo (boutons géologie) */
.btn-geo{
  background: linear-gradient(180deg, #ffffff, var(--vaud-cream)) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}
.btn-geo:hover{
  border-color: var(--vaud-green) !important;
  box-shadow: 0 8px 22px rgba(0,122,51,.18) !important;
}

/* Tile-buttons (Étroits, Baulmes, etc.) : style affineé */
.tile-btn{
  background: linear-gradient(180deg, #ffffff, #f5f7f4) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}
.tile-btn:hover{
  border-color: var(--vaud-green) !important;
  box-shadow: 0 10px 24px rgba(0,122,51,.16),
              0 0 0 4px var(--ring) !important;
}
.tile-icon{
  background: radial-gradient(60% 60% at 30% 30%,
                              rgba(0,77,32,.35),
                              transparent 60%),
              linear-gradient(135deg,
                              var(--vaud-green-dark),
                              var(--vaud-green)) !important;
}
.tile-text .t-title{ color: var(--vaud-ink) !important; }
.tile-text .t-sub{ color: var(--muted) !important; }
.tile-caret{ color: var(--vaud-gold) !important; }

/* chip-back (bouton retour des sous-menus) */
.chip-back{
  background: rgba(0,77,32,.10) !important;
  color: var(--vaud-green-dark) !important;
  border: 1px solid rgba(0,77,32,.35) !important;
}
.chip-back:hover{
  background: rgba(0,77,32,.18) !important;
}

/* Sidebar attribution / footer crédits : clair */
.attribs,
.attribs-list{
  background: rgba(255,255,255,.6) !important;
  border-top: 1px solid var(--border) !important;
}
.attrib-item{ color: var(--vaud-ink) !important; }

/* Map FAB buttons : style net, accent or sur pressed */
.fab{
  background: rgba(255,255,255,.95) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 6px 16px rgba(0,77,32,.18) !important;
}
.fab:hover{
  box-shadow: 0 8px 22px rgba(0,77,32,.28) !important;
  border-color: var(--vaud-green) !important;
}
.fab[aria-pressed="true"]{
  outline: 2px solid var(--vaud-green-dark) !important;
  border-color: var(--vaud-green) !important;
}

/* Sidebar tools list links */
.tools-list a.sidebar-link i{
  background: linear-gradient(135deg,
                              var(--vaud-green),
                              var(--vaud-green-dark)) !important;
  color: #fff !important;
}

/* ms-grid tiles (POI sous-menu) */
.ms-item{
  background: var(--vaud-bone) !important;
  border: 1px solid var(--border) !important;
}
.ms-item .tx b{ color: var(--vaud-ink); }
.ms-item .tx small{ color: var(--muted); }

/* Coordonnées HUD bottom */
.coords-hud{
  background: rgba(255,255,255,.94) !important;
  color: var(--vaud-ink) !important;
  border: 1px solid var(--border) !important;
}

/* Modale embed (visionneuse 3D) — bandeau */
#mdlEmbed,
#mdlLocal3D{
  background: rgba(15,26,20,.78) !important;   /* overlay sombre */
}
#mdlEmbed .dialog,
#mdlLocal3D .dialog,
.embed-dialog{
  background: var(--vaud-bone) !important;
  color: var(--vaud-ink) !important;
  border: 2px solid var(--vaud-green) !important;
  box-shadow: 0 20px 60px rgba(0,77,32,.4) !important;
}
.embed-head h3,
.mdl-head h3{ color: var(--vaud-green-dark); }

/* (liseré décoratif retiré — le border-bottom vert de la topbar suffit) */

/* =========================================================
   ★ Sidebar outils enrichie (avec descriptions)
========================================================= */
#tools-sidebar .tools-list{
  list-style: none;
  padding: 12px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
#tools-sidebar .tools-list a.sidebar-link{
  display: grid;
  grid-template-columns: 44px 1fr;
  grid-template-rows: auto auto;
  align-items: center;
  gap: 2px 12px;
  padding: 12px 14px;
  border-radius: 12px;
  text-decoration: none;
  background: #ffffff;
  border: 1px solid var(--border);
  color: var(--vaud-ink);
  transition: transform .12s ease, box-shadow .12s ease,
              border-color .12s ease, background .12s ease;
}
#tools-sidebar .tools-list a.sidebar-link:hover{
  transform: translateX(2px);
  border-color: var(--vaud-green);
  box-shadow: 0 6px 18px rgba(0,122,51,.14);
}
#tools-sidebar .tools-list a.sidebar-link.active{
  border-color: var(--vaud-green);
  box-shadow: 0 0 0 2px rgba(0,122,51,.30);
  background: linear-gradient(180deg, #ffffff, #e8f3ec);
}
#tools-sidebar .tools-list i{
  grid-row: 1 / span 2;
  width: 40px; height: 40px;
  border-radius: 10px;
  display: grid; place-items: center;
  font-size: 16px;
  color: #fff;
  background: linear-gradient(135deg,
                              var(--vaud-green),
                              var(--vaud-green-dark));
  box-shadow: 0 4px 10px rgba(0,77,32,.25);
}
#tools-sidebar .tools-list .lbl{
  font-weight: 700;
  font-size: 14.5px;
  color: var(--vaud-ink);
  line-height: 1.1;
}
#tools-sidebar .tools-list .hint{
  font-size: 11.5px;
  color: var(--muted);
  line-height: 1.25;
}

/* Variante "danger" pour Effacer tout */
#tools-sidebar .tools-list a.danger-link i{
  background: linear-gradient(135deg, #d97757, #b8523a);
}
#tools-sidebar .tools-list a.danger-link:hover{
  border-color: #b8523a;
  box-shadow: 0 6px 18px rgba(184,82,58,.20);
}
