/*!*****************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./src/app/globals.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************/
:root {
  --background: #050812;
  --panel: rgba(13, 22, 42, 0.84);
  --panel-strong: rgba(15, 25, 48, 0.94);
  --panel-border: rgba(114, 234, 255, 0.22);
  --text: #eefaff;
  --muted: #96a8b8;
  --cyan: #49e6ff;
  --cyan-strong: #21d4ff;
  --cyan-soft: rgba(73, 230, 255, 0.16);
  --danger: #ff8a5a;
}

* {
  box-sizing: border-box;
}

/* ── Themed scrollbars (transparent track, cyan thumb) ──────────────── */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(73, 230, 255, 0.35) transparent;
}
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: rgba(73, 230, 255, 0.32);
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(73, 230, 255, 0.6);
  background-clip: padding-box;
}
::-webkit-scrollbar-corner {
  background: transparent;
}

html {
  min-height: 100%;
  scroll-behavior: smooth;
}

body {
  min-height: 100%;
  margin: 0;
  background:
    radial-gradient(circle at 18% 12%, rgba(73, 230, 255, 0.12), transparent 28%),
    radial-gradient(circle at 82% 18%, rgba(33, 212, 255, 0.08), transparent 26%),
    radial-gradient(circle at 50% 92%, rgba(122, 92, 255, 0.08), transparent 34%),
    var(--background);
  color: var(--text);
  font-family:
    Inter,
    ui-sans-serif,
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;
}

button,
input {
  font: inherit;
}

a {
  color: inherit;
}

/* Cockpit layout */

.louna-cockpit {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100vh;
  height: 100dvh; /* fixed height → inner areas scroll, the avatar stays put */
  overflow: hidden;
  padding: 0;
}

.louna-side-panel {
  min-width: 0;
}

.louna-side-panel__sticky {
  position: -webkit-sticky;
  position: sticky;
  top: 28px;
  padding: 28px;
  border: 1px solid var(--panel-border);
  border-radius: 32px;
  background: var(--panel);
  box-shadow:
    0 0 90px rgba(73, 230, 255, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
  text-align: center;
}

.louna-workspace {
  flex: 1 1;
  min-height: 0;
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 18px;
  padding: 0 32px 22px;
}

.louna-workspace-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 26px 28px;
  border: 1px solid var(--panel-border);
  border-radius: 28px;
  background: var(--panel);
  box-shadow:
    0 0 70px rgba(73, 230, 255, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.louna-workspace-header h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(1.8rem, 3vw, 3rem);
  line-height: 1;
}

.louna-workspace-status {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.louna-workspace-status span {
  padding: 10px 14px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 999px;
  background: rgba(73, 230, 255, 0.08);
  color: var(--text);
  font-size: 0.86rem;
  font-weight: 700;
}

.louna-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--panel-border);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.025);
}

.louna-tabs a {
  padding: 11px 15px;
  border: 1px solid rgba(114, 234, 255, 0.18);
  border-radius: 999px;
  color: var(--muted);
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 700;
  transition:
    color 180ms ease,
    border-color 180ms ease,
    background 180ms ease,
    box-shadow 180ms ease;
}

.louna-tabs a:hover {
  color: var(--text);
  border-color: rgba(73, 230, 255, 0.58);
  background: rgba(73, 230, 255, 0.1);
  box-shadow: 0 0 24px rgba(73, 230, 255, 0.08);
}

.louna-tabs a[aria-current='page'] {
  color: var(--cyan);
  border-color: rgba(73, 230, 255, 0.7);
  background: rgba(73, 230, 255, 0.13);
  box-shadow: 0 0 28px rgba(73, 230, 255, 0.12);
}

.louna-workspace-section {
  padding: 26px;
  border: 1px solid var(--panel-border);
  border-radius: 28px;
  background: var(--panel);
  box-shadow:
    0 0 70px rgba(73, 230, 255, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

/* Identity text */

.louna-kicker {
  margin: 0 0 12px;
  color: var(--cyan);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

h1 {
  margin: 0;
  color: var(--text);
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1.05;
}

.louna-description {
  max-width: 620px;
  margin: 22px auto 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.7;
}

.louna-status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  padding: 12px 18px;
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  background: var(--cyan-soft);
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 700;
}

.louna-status span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--cyan);
  box-shadow: 0 0 16px var(--cyan);
}

/* Avatar */

.louna-avatar {
  position: relative;
  display: grid;
  place-items: center;
  width: min(360px, 78vw);
  aspect-ratio: 1;
  margin: 0 auto 22px;
  border-radius: 50%;
  overflow: hidden;
  background:
    radial-gradient(circle, rgba(73, 230, 255, 0.14), transparent 64%),
    transparent;
  animation: louna-idle-float 7s ease-in-out infinite;
}

.louna-avatar::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(73, 230, 255, 0.16) 0%,
    rgba(73, 230, 255, 0.08) 36%,
    transparent 72%
  );
  filter: blur(10px);
}

.louna-avatar::after {
  content: "";
  position: absolute;
  inset: 8%;
  z-index: 0;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(73, 230, 255, 0.16) 0%,
    rgba(73, 230, 255, 0.08) 34%,
    transparent 68%
  );
  opacity: 0.8;
  animation: louna-idle-glow 5.5s ease-in-out infinite;
}

.louna-avatar-image {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  animation: louna-idle-presence 8s ease-in-out infinite;
  filter:
    drop-shadow(0 0 24px rgba(73, 230, 255, 0.22))
    drop-shadow(0 0 64px rgba(73, 230, 255, 0.08));
}

/* Stacked neutral-state videos for the crossfade loop. */
.louna-avatar-video {
  position: absolute;
  inset: 0;
  z-index: 1;
  object-fit: cover;
  object-position: center;
  /* Opacity is driven per-frame in JS to crossfade the loop seam. */
  animation: none;
  will-change: opacity;
}

.louna-avatar-eye-glow {
  position: absolute;
  z-index: 2;
  width: 12%;
  height: 12%;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(120, 245, 255, 0.3) 0%,
    rgba(33, 212, 255, 0.18) 38%,
    transparent 70%
  );
  opacity: 0.45;
  filter: blur(3px);
  animation: louna-eye-presence 7.4s ease-in-out infinite;
  pointer-events: none;
}

.louna-avatar-eye-glow--left {
  top: 43%;
  left: 34%;
}

.louna-avatar-eye-glow--right {
  top: 43%;
  right: 34%;
}

@keyframes louna-idle-float {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-8px);
  }
}

@keyframes louna-idle-glow {
  0%,
  100% {
    opacity: 0.55;
    transform: scale(0.96);
  }

  50% {
    opacity: 0.95;
    transform: scale(1.04);
  }
}

@keyframes louna-idle-presence {
  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.018);
  }
}

@keyframes louna-eye-presence {
  0%,
  72%,
  100% {
    opacity: 0.38;
    transform: scale(1);
  }

  76%,
  78% {
    opacity: 0.08;
    transform: scale(0.72);
  }

  84% {
    opacity: 0.5;
    transform: scale(1.08);
  }
}

/* Avatar tester */

.louna-avatar-tester {
  display: grid;
  place-items: center;
  grid-gap: 18px;
  gap: 18px;
  margin-bottom: 26px;
}

.louna-expression-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.louna-expression-button {
  cursor: pointer;
  padding: 10px 14px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.035);
  color: var(--muted);
  font: inherit;
  font-size: 0.86rem;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    color 180ms ease,
    box-shadow 180ms ease;
}

.louna-expression-button:hover {
  border-color: rgba(114, 234, 255, 0.52);
  color: var(--text);
}

.louna-expression-button--active {
  border-color: rgba(73, 230, 255, 0.8);
  background: rgba(73, 230, 255, 0.14);
  color: var(--text);
  box-shadow: 0 0 24px rgba(73, 230, 255, 0.14);
}

/* Cards and sections */

.louna-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
  margin-top: 20px;
  text-align: left;
}

.louna-grid article {
  padding: 18px;
  border: 1px solid var(--panel-border);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.035);
}

.louna-grid small,
.louna-section-header small,
.louna-model-card small {
  display: block;
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.louna-grid strong,
.louna-model-card strong {
  color: var(--text);
  font-size: 1.05rem;
  font-weight: 800;
}

.louna-section {
  margin-top: 28px;
  padding: 22px;
  border: 1px solid var(--panel-border);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.03);
  text-align: left;
}

.louna-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.louna-section-header h2 {
  margin: 0;
  color: var(--text);
  font-size: 1.35rem;
}

.louna-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 800;
}

.louna-pill--ok {
  border-color: rgba(73, 230, 255, 0.42);
  background: rgba(73, 230, 255, 0.12);
}

.louna-pill--error {
  border-color: rgba(255, 138, 90, 0.42);
  background: rgba(255, 138, 90, 0.12);
  color: #ffd2c1;
}

.louna-model-list {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.louna-model-card {
  padding: 16px;
  border: 1px solid rgba(114, 234, 255, 0.18);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
}

.louna-empty-state {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

/* Chat */

.louna-chat {
  flex: 1 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  margin-top: 0;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
}

.louna-chat-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 16px;
}
/* The avatar + wordmark are the identity — drop the verbose chat title. */
.louna-chat-header > div:first-child { display: none; }
.louna-chat-controls { justify-content: center; }

.louna-chat-header small {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.louna-chat-header h2 {
  margin: 0;
  color: var(--text);
  font-size: 1.35rem;
}

.louna-chat-messages {
  flex: 1 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: auto;
  padding-right: 4px;
}

.louna-chat-message {
  padding: 14px 16px;
  border-radius: 18px;
  line-height: 1.6;
}

.louna-chat-message small {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.louna-chat-message p {
  margin: 0;
  color: var(--text);
  white-space: pre-wrap;
}

.louna-chat-message--louna {
  border: 1px solid rgba(73, 230, 255, 0.2);
  background: rgba(73, 230, 255, 0.07);
}

.louna-chat-message--user {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.055);
}

/* Markdown rendering inside Louna messages */

.louna-markdown {
  color: var(--text);
}

.louna-markdown > *:first-child {
  margin-top: 0;
}

.louna-markdown > *:last-child {
  margin-bottom: 0;
}

.louna-markdown p {
  margin: 0 0 10px;
}

.louna-markdown ul,
.louna-markdown ol {
  margin: 0 0 10px;
  padding-left: 22px;
}

.louna-markdown li {
  margin: 4px 0;
}

.louna-markdown a {
  color: var(--cyan);
  text-decoration: underline;
}

.louna-markdown h1,
.louna-markdown h2,
.louna-markdown h3,
.louna-markdown h4 {
  margin: 14px 0 8px;
  line-height: 1.3;
  color: var(--text);
}

.louna-markdown h1 {
  font-size: 1.3rem;
}

.louna-markdown h2 {
  font-size: 1.15rem;
}

.louna-markdown h3 {
  font-size: 1.02rem;
}

.louna-markdown h4 {
  font-size: 0.92rem;
}

.louna-markdown strong {
  color: #fff;
}

.louna-markdown code {
  padding: 2px 6px;
  border-radius: 6px;
  border: 1px solid rgba(73, 230, 255, 0.18);
  background: rgba(73, 230, 255, 0.12);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.86em;
}

.louna-markdown pre {
  margin: 0 0 10px;
  padding: 14px 16px;
  overflow: auto;
  border-radius: 14px;
  border: 1px solid rgba(73, 230, 255, 0.18);
  background: rgba(5, 8, 18, 0.72);
}

.louna-markdown pre code {
  padding: 0;
  border: 0;
  background: transparent;
}

.louna-markdown blockquote {
  margin: 0 0 10px;
  padding: 6px 14px;
  border-left: 3px solid rgba(73, 230, 255, 0.45);
  color: var(--muted);
}

.louna-markdown table {
  width: 100%;
  margin: 0 0 10px;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.louna-markdown th,
.louna-markdown td {
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  text-align: left;
}

.louna-markdown th {
  background: rgba(73, 230, 255, 0.08);
}

/* ── Speech error feedback ──────────────────────────────────────── */

.louna-speech-error {
  margin: 8px 0 0;
  padding: 8px 14px;
  border-radius: 10px;
  background: rgba(245, 166, 35, 0.1);
  border: 1px solid rgba(245, 166, 35, 0.3);
  color: #f5a623;
  font-size: 0.82rem;
  text-align: center;
  animation: louna-fade-in 0.2s ease;
}

@keyframes louna-fade-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Typing indicator while Louna is thinking */

.louna-typing {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
}

.louna-typing span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cyan);
  opacity: 0.5;
  animation: louna-typing-bounce 1.2s infinite ease-in-out;
}

.louna-typing span:nth-child(2) {
  animation-delay: 0.2s;
}

.louna-typing span:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes louna-typing-bounce {
  0%,
  80%,
  100% {
    transform: translateY(0);
    opacity: 0.35;
  }
  40% {
    transform: translateY(-5px);
    opacity: 1;
  }
}

.louna-chat-form {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
  flex-wrap: nowrap;
}

.louna-chat-form input {
  flex: 1 1;
  min-width: 0;
  padding: 14px 16px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 16px;
  outline: none;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
}

/* Audio group (voix de sortie + micro) — espacé du bouton Send. */
.louna-chat-audio {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: 18px;
}

.louna-chat-form input:focus {
  border-color: rgba(73, 230, 255, 0.72);
  box-shadow: 0 0 24px rgba(73, 230, 255, 0.12);
}

/* ── Wake-word listening indicator ──────────────────────────────── */

.louna-wake-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding: 9px 14px;
  border: 1px solid rgba(73, 230, 255, 0.28);
  border-radius: 999px;
  background: rgba(73, 230, 255, 0.07);
  color: var(--text);
  font-size: 0.85rem;
  line-height: 1.3;
}

.louna-wake-bar em {
  color: var(--muted);
  font-style: normal;
}

.louna-wake-bar--error {
  border-color: rgba(255, 120, 120, 0.42);
  background: rgba(255, 90, 90, 0.09);
}

.louna-wake-dot {
  flex: 0 0 auto;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #49e6ff;
  animation: louna-wake-pulse 1.6s ease-out infinite;
}

.louna-wake-bar--error .louna-wake-dot {
  background: #ff7a7a;
  animation: none;
}

@keyframes louna-wake-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(73, 230, 255, 0.5); }
  70%  { box-shadow: 0 0 0 9px rgba(73, 230, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(73, 230, 255, 0); }
}

/* ── Burger menu (universal: desktop + mobile) ───────────────────── */
.louna-nav {
  position: relative;
  flex: 0 0 auto;
}

.louna-nav__burger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--panel-border);
  background: rgba(255, 255, 255, 0.02);
  color: var(--text);
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease;
}
.louna-nav__burger:hover {
  border-color: rgba(73, 230, 255, 0.5);
  background: rgba(73, 230, 255, 0.06);
}

.louna-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 50;
  width: 264px;
  max-width: calc(100vw - 24px);
  max-height: calc(100dvh - 80px);
  overflow-y: auto;
  padding: 8px;
  border: 1px solid var(--panel-border);
  border-radius: 16px;
  background: rgba(8, 12, 22, 0.98);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
  -webkit-backdrop-filter: blur(16px);
          backdrop-filter: blur(16px);
}

.louna-menu__label {
  margin: 6px 10px 4px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.louna-menu__links {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.louna-menu__link {
  display: block;
  padding: 11px 12px;
  border-radius: 10px;
  color: var(--text);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 600;
  transition: background 140ms ease, color 140ms ease;
}
.louna-menu__link:hover { background: rgba(255, 255, 255, 0.05); }
.louna-menu__link[aria-current='page'] {
  background: rgba(73, 230, 255, 0.12);
  color: var(--cyan);
}
.louna-menu__link--admin { color: var(--cyan); }

.louna-menu__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 6px;
  padding: 10px 8px 4px;
  border-top: 1px solid var(--panel-border);
}
.louna-menu__user {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 700;
}
.louna-menu__logout {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  font-size: 0.85rem;
  cursor: pointer;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
}
.louna-menu__logout:hover {
  border-color: rgba(248, 113, 113, 0.5);
  background: rgba(248, 113, 113, 0.08);
  color: #fca5a5;
}

/* Conversation history inside the menu */
.louna-menu__new {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  margin-bottom: 4px;
  border: 1px solid rgba(73, 230, 255, 0.28);
  border-radius: 10px;
  color: var(--cyan);
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 700;
  transition: background 140ms ease;
}
.louna-menu__new:hover { background: rgba(73, 230, 255, 0.1); }

.louna-menu__convs {
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 240px;
  overflow-y: auto;
}
.louna-menu__empty {
  margin: 2px 12px;
  color: var(--muted);
  font-size: 0.85rem;
}
.louna-menu__conv {
  display: flex;
  align-items: center;
  border-radius: 10px;
}
.louna-menu__conv:hover { background: rgba(255, 255, 255, 0.05); }
.louna-menu__conv--active { background: rgba(73, 230, 255, 0.12); }
.louna-menu__conv-link {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1;
  min-width: 0;
  padding: 9px 10px;
  color: var(--text);
  text-decoration: none;
  font-size: 0.9rem;
}
.louna-menu__conv-link svg { flex: 0 0 auto; opacity: 0.6; }
.louna-menu__conv-link span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.louna-menu__conv-del {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  margin-right: 4px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  opacity: 0;
  transition: opacity 140ms ease, color 140ms ease, background 140ms ease;
}
.louna-menu__conv:hover .louna-menu__conv-del { opacity: 1; }
.louna-menu__conv-del:hover { color: #fca5a5; background: rgba(248, 113, 113, 0.1); }
@media (pointer: coarse) {
  .louna-menu__conv-del { opacity: 0.7; } /* no hover on touch → always visible */
}

/* Top-bar brand + mobile animated hero — shown only on phones */
.louna-topbar-brand {
  display: none;
  align-items: center;
  gap: 8px;
  font-weight: 800;
  color: var(--text);
}
.louna-topbar-brand img { width: 30px; height: 30px; border-radius: 50%; }

/* Hero: animated avatar + faint wordmark (chat page). Spacer clears the burger
   on the other pages. Shared across desktop and mobile. */
.louna-mobile-hero {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2px;
  padding: 4px 0 10px;
}
.louna-mobile-hero .louna-avatar { width: 168px; margin: 0 auto; }
.louna-hero-name {
  margin-top: 4px;
  font-size: 0.9rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.42em;
  text-indent: 0.42em;
  color: rgba(180, 220, 255, 0.45);
}
.louna-mobile-hero .louna-state-label { font-size: 0.85rem; }
.louna-mobile-hero .louna-state-label[data-state='neutral'] { display: none; }
.louna-burger-spacer { display: block; height: 64px; }

/* Responsive */

/* Stack to one column below ~920px (portrait phones & portrait tablets).
   Landscape tablets (≥920px wide) keep the two-column cockpit. */
@media (max-width: 920px) {
  .louna-cockpit {
    grid-template-columns: 1fr;
  }

  .louna-side-panel__sticky {
    position: relative;
    top: auto;
  }

  .louna-workspace-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .louna-workspace-status {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .louna-grid {
    grid-template-columns: 1fr;
  }

  .louna-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
  }

  .louna-tabs a {
    white-space: nowrap;
  }
}

/* ── Phones (portrait): app shell with top bar + full-height chat ── */
@media (max-width: 640px) {
  /* Whole screen = one vertical app, edge to edge. */
  .louna-cockpit {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
    padding: 0;
    gap: 0;
  }

  /* No floating avatar/heading panel in the middle — it moves to the top bar. */
  .louna-side-panel { display: none; }

  .louna-workspace {
    flex: 1 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch; /* override the desktop grid's align-items:start */
    gap: 0;
    padding: 0;
  }

  /* Burger floats in the corner — no full-width bar — so the avatar sits higher. */
  .louna-workspace-topbar {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 30;
    width: auto;
    padding: 8px;
    background: none;
    -webkit-backdrop-filter: none;
            backdrop-filter: none;
    border: 0;
  }
  /* Show the brand wordmark in the bar (burger styling is shared/universal). */
  .louna-topbar-brand { display: flex; }

  /* On non-chat pages (no hero) reserve space so the floating burger clears. */
  .louna-burger-spacer { display: block; height: 52px; }

  /* Animated Louna presence under the bar: avatar centered, faint wordmark. */
  .louna-mobile-hero {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0;
    padding: 10px 0 2px;
  }
  .louna-mobile-hero .louna-avatar {
    width: 122px;
    margin: 0 auto;
  }
  .louna-hero-name {
    margin-top: 2px;
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.42em;
    text-indent: 0.42em;
    color: rgba(180, 220, 255, 0.45);
  }
  /* Show the status only when meaningful; hide the idle neutral label. */
  .louna-mobile-hero .louna-state-label { font-size: 0.8rem; }
  .louna-mobile-hero .louna-state-label[data-state='neutral'] { display: none; }

  /* Page + chat fill the remaining height; input pinned at the bottom. */
  .louna-page {
    flex: 1 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 12px;
    border: 0;
    border-radius: 0;
    background: transparent;
    gap: 0;
  }
  .louna-chat {
    flex: 1 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
  }
  /* Drop the verbose "Conversation / Parler avec Louna" block — keep controls. */
  .louna-chat-header { margin-bottom: 10px; }
  .louna-chat-header > div:first-child { display: none; }
  .louna-chat-controls {
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
  }
  /* Status is shown under the avatar; the model badge is desktop-only detail. */
  .louna-chat-controls .louna-pill,
  .louna-model-badge { display: none; }

  .louna-chat-messages {
    flex: 1 1;
    min-height: 0;
    max-height: none;
  }
  .louna-chat-form { margin-top: 10px; }

  /* Admin: stack the create-user form and the user rows (no overflow). */
  .louna-admin-create__form { grid-template-columns: 1fr; }
  .louna-admin-row {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .louna-admin-row__info { min-width: 0; }
  .louna-admin-section { padding: 16px; }
  .louna-admin-memory-add { flex-direction: column; }
  .louna-admin-memory-add .louna-login-btn { align-self: stretch; }
}

/* Touch devices (phones + tablets): larger tap targets. */
@media (pointer: coarse) {
  .louna-audio-btn {
    width: 44px;
    height: 44px;
  }

  .louna-chat-form input {
    padding: 16px;
    font-size: 1rem; /* ≥16px avoids mobile zoom-on-focus */
  }

  .louna-model-select {
    padding: 9px 12px;
    font-size: 0.92rem;
  }
}

/* Landscape tablets — keep two columns but compact vertical chrome so the
   avatar panel and the chat both fit the limited height. */
@media (orientation: landscape) and (pointer: coarse) and (max-height: 860px) {
  .louna-avatar {
    width: min(190px, 32vh);
    margin-bottom: 12px;
  }

  .louna-description {
    display: none;
  }

  .louna-side-panel__sticky {
    padding: 18px;
  }

  .louna-side-panel__sticky h1 {
    font-size: 1.7rem;
  }

  .louna-chat-messages {
    max-height: 62vh;
  }
}

/* ── Avatar state label ─────────────────────────────────────────── */

.louna-state-label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: -2px 0 14px;
  font-size: 0.82rem;
  color: var(--muted);
  letter-spacing: 0.03em;
}

.louna-state-dot {
  flex-shrink: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--cyan);
}

[data-state='thinking'] .louna-state-dot,
[data-state='listening'] .louna-state-dot {
  animation: louna-state-pulse 1.2s ease-in-out infinite;
}

[data-state='speaking'] .louna-state-dot {
  animation: louna-state-pulse 0.7s ease-in-out infinite;
}

@keyframes louna-state-pulse {
  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.25;
    transform: scale(0.75);
  }
}

/* ── Page layout ────────────────────────────────────────────────── */

.louna-page {
  flex: 1 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow-y: auto; /* utility pages scroll here; chat scrolls inside messages */
}

.louna-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.louna-page-header small {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.louna-page-header h2 {
  margin: 0;
  font-size: 1.35rem;
  color: var(--text);
}

/* ── Chat controls (model selector + audio toggle) ──────────────── */

.louna-chat-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.louna-model-select {
  padding: 6px 10px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 10px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  font-size: 0.82rem;
  cursor: pointer;
  outline: none;
  max-width: 180px;
}

.louna-model-select:focus {
  border-color: rgba(73, 230, 255, 0.6);
}

.louna-model-badge {
  padding: 4px 10px;
  border: 1px solid rgba(73, 230, 255, 0.2);
  border-radius: 10px;
  color: var(--muted);
  font-size: 0.78rem;
}

/* ── Audio buttons ──────────────────────────────────────────────── */

.louna-audio-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(73, 230, 255, 0.28);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition:
    color 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.louna-audio-btn:hover {
  border-color: rgba(73, 230, 255, 0.6);
  color: var(--cyan);
}

.louna-audio-btn--active {
  border-color: rgba(73, 230, 255, 0.7);
  background: rgba(73, 230, 255, 0.12);
  color: var(--cyan);
}

.louna-audio-btn--recording {
  border-color: var(--cyan);
  background: rgba(73, 230, 255, 0.18);
  color: var(--cyan);
  animation: louna-state-pulse 1s ease-in-out infinite;
}

.louna-audio-btn--conversation {
  border-color: rgba(73, 230, 255, 0.9);
  background: rgba(73, 230, 255, 0.2);
  color: var(--cyan);
  box-shadow: 0 0 16px rgba(73, 230, 255, 0.25);
}

.louna-audio-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.louna-chat-send {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(73, 230, 255, 0.5);
  background: rgba(73, 230, 255, 0.14);
  color: var(--text);
  cursor: pointer;
  transition:
    background 160ms ease,
    border-color 160ms ease;
}

.louna-chat-send:hover {
  background: rgba(73, 230, 255, 0.24);
  border-color: rgba(73, 230, 255, 0.8);
}

.louna-chat-send:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}


/* ── System metrics ─────────────────────────────────────────────── */

.louna-metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.louna-metric-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 20px;
  border: 1px solid var(--panel-border);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.025);
}

.louna-metric-card--wide {
  grid-column: span 2;
}

.louna-metric-card small {
  color: var(--muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.louna-metric-card strong {
  font-size: 1.1rem;
  color: var(--text);
}

.louna-metric-card span {
  font-size: 0.82rem;
  color: var(--muted);
}

.louna-metric-bar-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.louna-metric-bar {
  height: 6px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.08);
  overflow: hidden;
}

.louna-metric-bar__fill {
  height: 100%;
  border-radius: 99px;
  background: var(--cyan);
  transition: width 600ms ease;
}

.louna-metric-bar__fill[data-warn='true'] {
  background: #f5a623;
}

/* ── Ollama model cards ──────────────────────────────────────────── */

.louna-model-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

/* ── Future modules grid ────────────────────────────────────────── */

.louna-future-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.louna-future-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px;
  border: 1px solid var(--panel-border);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.02);
  transition: border-color 200ms ease;
}

.louna-future-card:hover {
  border-color: rgba(73, 230, 255, 0.3);
}

.louna-future-card--future {
  opacity: 0.65;
}

.louna-future-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.louna-future-card__top small {
  color: var(--muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.louna-future-card strong {
  font-size: 1rem;
  color: var(--text);
}

.louna-future-card p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--muted);
  line-height: 1.55;
}
/* ── Login page ─────────────────────────────────────────────────── */

.louna-login-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 24px;
}

.louna-login-card {
  width: 100%;
  max-width: 400px;
  padding: 40px;
  border: 1px solid var(--panel-border);
  border-radius: 32px;
  background: var(--panel);
  box-shadow: 0 0 90px rgba(73, 230, 255, 0.1), inset 0 1px 0 rgba(255,255,255,0.08);
  text-align: center;
}

.louna-login-avatar {
  margin: 0 auto 20px;
  width: 120px;
  height: 120px;
}

.louna-login-title {
  margin: 0 0 6px;
  font-size: 1.6rem;
  color: var(--text);
}

.louna-login-subtitle {
  margin: 0 0 28px;
  font-size: 0.875rem;
  color: var(--muted);
}

.louna-login-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  text-align: left;
}

.louna-login-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.louna-login-field label {
  font-size: 0.8rem;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.louna-login-field input {
  padding: 12px 16px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 14px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  outline: none;
  font-size: 1rem;
}

.louna-login-field input:focus {
  border-color: rgba(73, 230, 255, 0.72);
  box-shadow: 0 0 20px rgba(73, 230, 255, 0.1);
}

.louna-login-field input:disabled {
  opacity: 0.5;
}

.louna-login-error {
  margin: 0;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(220, 38, 38, 0.1);
  border: 1px solid rgba(220, 38, 38, 0.3);
  color: #f87171;
  font-size: 0.85rem;
  text-align: center;
}

.louna-login-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 4px;
  padding: 14px;
  border: 1px solid rgba(73, 230, 255, 0.5);
  border-radius: 16px;
  background: rgba(73, 230, 255, 0.14);
  color: var(--text);
  font-weight: 800;
  font-size: 1rem;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease;
}

.louna-login-btn:hover:not(:disabled) {
  background: rgba(73, 230, 255, 0.24);
  border-color: rgba(73, 230, 255, 0.8);
}

.louna-login-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ── Workspace topbar (nav + user badge) ────────────────────────── */

.louna-workspace-topbar {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 30;
  padding: 14px;
}

/* ── User badge ─────────────────────────────────────────────────── */

.louna-user-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  padding: 6px 12px;
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  background: var(--panel);
  font-size: 0.82rem;
  color: var(--muted);
  white-space: nowrap;
}

.louna-user-badge__icon {
  color: var(--cyan);
}

.louna-user-badge__logout {
  display: flex;
  align-items: center;
  padding: 2px;
  border: none;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  border-radius: 4px;
  transition: color 160ms ease;
}

.louna-user-badge__logout:hover {
  color: var(--cyan);
}

/* Admin link in nav */
.louna-tabs__admin {
  color: var(--cyan-strong) !important;
  border-color: rgba(73, 230, 255, 0.35) !important;
}

/* ── Admin panel ────────────────────────────────────────────────── */

.louna-admin {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.louna-admin-table {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.louna-admin-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  border: 1px solid var(--panel-border);
  border-radius: 18px;
  background: rgba(255,255,255,0.025);
  flex-wrap: wrap;
}

.louna-admin-row--inactive {
  opacity: 0.5;
}

.louna-admin-row__info {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 140px;
}

.louna-admin-row__pages {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1 1;
  flex-wrap: wrap;
}

.louna-admin-page-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--muted);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.louna-admin-page-toggle input {
  accent-color: var(--cyan);
  width: 14px;
  height: 14px;
  cursor: pointer;
}

.louna-admin-create {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px;
  border: 1px solid rgba(73, 230, 255, 0.15);
  border-radius: 20px;
  background: rgba(73, 230, 255, 0.03);
}

.louna-admin-create h3 {
  margin: 0;
  font-size: 1rem;
  color: var(--text);
}

.louna-admin-create__form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 12px;
  gap: 12px;
}

.louna-admin-create__form input {
  min-width: 0; /* allow shrinking inside the grid (prevents overflow) */
  width: 100%;
  padding: 10px 14px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 12px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  outline: none;
  font-size: 0.9rem;
}

.louna-admin-create__form input:focus {
  border-color: rgba(73, 230, 255, 0.6);
}

/* Admin sections (memory + users) */
.louna-admin-section {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px;
  border: 1px solid var(--panel-border);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.02);
}
.louna-admin-section__title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 1.1rem;
  color: var(--text);
}
.louna-admin-hint {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.5;
}

.louna-admin-memory-add {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.louna-admin-memory-add textarea {
  flex: 1 1;
  min-width: 0;
  resize: vertical;
  padding: 12px 14px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 12px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  outline: none;
  font: inherit;
  font-size: 0.92rem;
}
.louna-admin-memory-add textarea:focus {
  border-color: rgba(73, 230, 255, 0.6);
}
.louna-admin-memory-add .louna-login-btn {
  flex: 0 0 auto;
  align-self: flex-start;
  white-space: nowrap;
}

.louna-admin-memory-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.louna-admin-memory {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--panel-border);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.025);
}
.louna-admin-memory span {
  flex: 1 1;
  min-width: 0;
  color: var(--text);
  font-size: 0.92rem;
  line-height: 1.5;
  word-break: break-word;
}

.louna-admin-row__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.louna-audio-btn--danger:hover {
  border-color: rgba(248, 113, 113, 0.6);
  color: #fca5a5;
  background: rgba(248, 113, 113, 0.08);
}

/* ── Ambient / kiosk mode (wall tablets) ────────────────────────── */

.louna-ambient {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 4vh 5vw;
  text-align: center;
}

.louna-ambient__exit {
  position: absolute;
  top: 16px;
  right: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(114, 234, 255, 0.18);
  color: var(--muted);
  background: rgba(255, 255, 255, 0.03);
  opacity: 0.5;
  transition: opacity 160ms ease;
}
.louna-ambient__exit:hover { opacity: 1; }

.louna-ambient__avatar .louna-avatar {
  width: min(46vh, 78vw);
  margin: 0;
}

.louna-ambient__status {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: clamp(0.95rem, 2.2vw, 1.25rem);
  letter-spacing: 0.01em;
}

.louna-ambient__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #49e6ff;
  opacity: 0.7;
}
.louna-ambient__status[data-listening='true'] .louna-ambient__dot {
  animation: louna-wake-pulse 1.6s ease-out infinite;
}

.louna-ambient__lines {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: min(900px, 92vw);
  min-height: 4.5em; /* reserve space so the avatar doesn't jump */
}

.louna-ambient__line {
  margin: 0;
  font-size: clamp(1.1rem, 2.6vw, 1.7rem);
  line-height: 1.4;
  /* Keep each turn to roughly two lines, then ellipsize. */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.louna-ambient__line span {
  display: inline-block;
  margin-right: 8px;
  font-size: 0.7em;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.55;
}

.louna-ambient__line--user { color: var(--muted); }
.louna-ambient__line--louna { color: var(--text); }

.louna-ambient__start {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border: 0;
  background: rgba(2, 5, 12, 0.72);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  color: var(--text);
  font-size: clamp(1.1rem, 3vw, 1.6rem);
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  z-index: 5;
}

/* Landscape tablet: avatar and last exchange side-aware sizing already fluid. */
@media (orientation: landscape) and (pointer: coarse) {
  .louna-ambient { gap: 22px; }
  .louna-ambient__avatar .louna-avatar { width: min(52vh, 60vw); }
}

/* ── Admin: comportement (settings) ─────────────────────────────────── */
.louna-admin-cta {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border: 1px solid rgba(73, 230, 255, 0.22);
  border-radius: 20px;
  background: rgba(73, 230, 255, 0.05);
  color: var(--text);
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.louna-admin-cta:hover {
  background: rgba(73, 230, 255, 0.09);
  border-color: rgba(73, 230, 255, 0.5);
}
.louna-admin-cta span {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.louna-admin-cta small {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.louna-setting {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px;
  border: 1px solid var(--panel-border);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.015);
}
.louna-setting__head {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.louna-setting__key {
  font-size: 0.72rem;
  color: var(--muted);
  opacity: 0.7;
}
.louna-setting__textarea {
  width: 100%;
  min-height: 70px;
  padding: 12px 14px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 12px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  outline: none;
  font-size: 0.9rem;
  line-height: 1.5;
  resize: vertical;
  font-family: inherit;
}
.louna-setting__textarea:focus {
  border-color: rgba(73, 230, 255, 0.6);
}
.louna-setting__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.louna-setting__history {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px;
  border: 1px dashed var(--panel-border);
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.2);
}
.louna-setting__history-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.8rem;
}
.louna-setting__history-date {
  color: var(--muted);
  white-space: nowrap;
}
.louna-setting__history-preview {
  flex: 1 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--muted);
  opacity: 0.85;
}

.louna-keywords {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.louna-keywords__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.louna-keyword {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px 4px 11px;
  border: 1px solid rgba(114, 234, 255, 0.28);
  border-radius: 999px;
  background: rgba(73, 230, 255, 0.07);
  font-size: 0.82rem;
  color: var(--text);
}
.louna-keyword button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px;
  border: none;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}
.louna-keyword button:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.1);
}
.louna-keywords__add {
  display: flex;
  gap: 8px;
  align-items: stretch;
}
.louna-keywords__add input {
  flex: 1 1;
  min-width: 0;
}

/* ── Admin: collapsible sections ────────────────────────────────────── */
.louna-admin-section__toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text);
  font-size: 1.1rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
}
.louna-admin-section__title-text {
  flex: 1 1;
  min-width: 0;
}
.louna-admin-section__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(73, 230, 255, 0.12);
  border: 1px solid rgba(73, 230, 255, 0.25);
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 600;
}
.louna-chevron {
  flex-shrink: 0;
  color: var(--muted);
  transition: transform 0.18s ease;
}
.louna-chevron--open {
  transform: rotate(90deg);
}
.louna-admin-section__body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 14px;
}

/* Pill-shaped secondary button (icon + text) — unlike the round audio-btn. */
.louna-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 12px;
  border: 1px solid rgba(73, 230, 255, 0.28);
  background: transparent;
  color: var(--muted);
  font-size: 0.85rem;
  white-space: nowrap;
  cursor: pointer;
  transition: color 160ms ease, border-color 160ms ease, background 160ms ease;
}
.louna-btn-ghost:hover {
  border-color: rgba(73, 230, 255, 0.6);
  color: var(--cyan);
}
.louna-btn-ghost:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Boolean setting toggle */
.louna-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  font-size: 0.9rem;
  color: var(--text);
}
.louna-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--cyan);
  cursor: pointer;
}

/* Pending memory proposals (auto-learned, awaiting validation) */
.louna-memory-proposal {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  border: 1px solid rgba(73, 230, 255, 0.22);
  border-radius: 14px;
  background: rgba(73, 230, 255, 0.04);
}
.louna-memory-proposal__content {
  color: var(--text);
  font-size: 0.92rem;
  line-height: 1.45;
}
.louna-memory-proposal__origin {
  color: var(--muted);
  font-size: 0.78rem;
  font-style: italic;
  opacity: 0.85;
}
.louna-memory-proposal__actions {
  display: flex;
  gap: 10px;
}
.louna-btn-approve {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 12px;
  border: 1px solid rgba(80, 230, 140, 0.45);
  background: rgba(80, 230, 140, 0.12);
  color: #8af0b0;
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease;
}
.louna-btn-approve:hover { background: rgba(80, 230, 140, 0.2); }
.louna-btn-reject {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255, 120, 120, 0.4);
  background: transparent;
  color: #ff9b9b;
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 160ms ease;
}
.louna-btn-reject:hover { background: rgba(255, 120, 120, 0.12); }

/* ── Admin: journal (épisodes) ──────────────────────────────────────── */
.louna-admin-cta-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  grid-gap: 12px;
  gap: 12px;
}
@media (max-width: 640px) {
  .louna-admin-cta-row { grid-template-columns: 1fr; }
}
.louna-admin-group-title {
  margin: 26px 0 2px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.louna-journal-toolbar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.louna-journal-toolbar select { max-width: 220px; }
.louna-journal-search {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1;
  min-width: 180px;
  padding: 0 12px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 12px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--muted);
}
.louna-journal-search input {
  flex: 1 1;
  min-width: 0;
  padding: 10px 0;
  border: none;
  background: transparent;
  color: var(--text);
  outline: none;
  font-size: 0.9rem;
}

.louna-journal-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.louna-journal-row {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: 'meta actions' 'text actions';
  align-items: center;
  grid-gap: 4px 12px;
  gap: 4px 12px;
  padding: 12px 16px;
  border: 1px solid var(--panel-border);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.015);
}
.louna-journal-meta {
  grid-area: meta;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 0.76rem;
  color: var(--muted);
}
.louna-journal-date { white-space: nowrap; }
.louna-journal-type {
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.7;
}
.louna-journal-imp { color: var(--cyan); letter-spacing: 1px; opacity: 0.7; }
.louna-journal-text {
  grid-area: text;
  color: var(--text);
  font-size: 0.92rem;
  line-height: 1.4;
}
.louna-journal-confirm {
  grid-area: actions;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--muted);
}
.louna-journal-row .louna-audio-btn--danger { grid-area: actions; }

/* ── Admin: lists ───────────────────────────────────────────────────── */
.louna-lists-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  grid-gap: 12px;
  gap: 12px;
}
.louna-list-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  border: 1px solid var(--panel-border);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.015);
}
.louna-list-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.louna-list-card__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--text);
}
.louna-list-card__title small { color: var(--muted); font-weight: 400; }
.louna-list-items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.louna-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 8px;
  border-radius: 9px;
  font-size: 0.9rem;
  color: var(--text);
}
.louna-list-item:hover { background: rgba(255, 255, 255, 0.03); }
.louna-list-item--done .louna-list-item__text {
  text-decoration: line-through;
  opacity: 0.55;
}
.louna-list-item__text { min-width: 0; word-break: break-word; }
.louna-list-item__del {
  flex: none;
  display: inline-flex;
  align-items: center;
  padding: 4px;
  border: none;
  border-radius: 7px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.12s ease, color 0.12s ease;
}
.louna-list-item:hover .louna-list-item__del { opacity: 1; }
.louna-list-item__del:hover { color: #ff8e8e; }
.louna-list-item__confirm {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  color: var(--muted);
}


/* Carnet: editable note */
.louna-carnet-note {
  cursor: text;
  display: inline-block;
  min-width: 60px;
}
.louna-carnet-note:hover { color: var(--cyan); }

/* ── Admin: surveillance ────────────────────────────────────────────── */
.louna-year-input {
  width: 92px;
  padding: 4px 8px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 8px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  font-size: 0.82rem;
}
.louna-count--alert {
  background: rgba(255, 120, 120, 0.18);
  border-color: rgba(255, 120, 120, 0.4);
  color: #ff9b9b;
}
.louna-surveil-alert {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 120, 120, 0.3);
  border-radius: 12px;
  background: rgba(255, 120, 120, 0.06);
}
.louna-surveil-alert--read {
  border-color: var(--panel-border);
  background: rgba(255, 255, 255, 0.015);
  opacity: 0.6;
}
.louna-surveil-alert__main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.louna-surveil-alert__msg { color: var(--text); font-size: 0.9rem; }
.louna-surveil-conv {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  text-align: left;
  padding: 11px 14px;
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.015);
  color: var(--text);
  cursor: pointer;
}
.louna-surveil-conv:hover { border-color: rgba(73, 230, 255, 0.5); }
.louna-surveil-conv__title { flex: 1 1; min-width: 0; }
.louna-surveil-conv-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.louna-surveil-conv-row .louna-surveil-conv { flex: 1 1; width: auto; }

/* Household dossier: the big long-term-memory notepad */
.louna-dossier {
  width: 100%;
  min-height: 280px;
  resize: vertical;
  padding: 12px 14px;
  margin-bottom: 10px;
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.55;
  font-family: inherit;
}
.louna-dossier:focus { outline: none; border-color: var(--cyan); }
.louna-surveil-thread {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.louna-surveil-msg {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid var(--panel-border);
}
.louna-surveil-msg--user { background: rgba(255, 255, 255, 0.03); }
.louna-surveil-msg--assistant { background: rgba(73, 230, 255, 0.05); }
.louna-surveil-msg__who {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}

/* Supervised account: birth-year field (not a checkbox toggle) */
.louna-age-field {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--muted);
}

.louna-age-field select {
  padding: 4px 8px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 9px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  font-size: 0.82rem;
}

/* ── Per-user voice rights + access schedule (admin) ───────────────── */
.louna-admin-row__voice,
.louna-admin-row__schedule {
  flex-basis: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 10px;
  border-top: 1px dashed rgba(114, 234, 255, 0.12);
}

.louna-admin-sub__label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--cyan);
  min-width: 54px;
}

.louna-cap-ic {
  opacity: 0.7;
}

.louna-schedule-editor {
  flex-basis: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
  padding: 14px;
  border: 1px solid rgba(114, 234, 255, 0.14);
  border-radius: 14px;
  background: rgba(73, 230, 255, 0.025);
}

.louna-schedule-days {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.louna-schedule-day {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 120px;
  padding: 8px 10px;
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  background: rgba(5, 8, 18, 0.4);
}

.louna-schedule-day__name {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.louna-schedule-day__wins {
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: flex-start;
}

.louna-schedule-free {
  font-size: 0.74rem;
  color: var(--muted);
  opacity: 0.6;
}

.louna-schedule-win {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.74rem;
  color: var(--muted);
}

.louna-schedule-win input[type='time'] {
  padding: 3px 5px;
  border: 1px solid rgba(114, 234, 255, 0.24);
  border-radius: 8px;
  background: rgba(5, 8, 18, 0.72);
  color: var(--text);
  font-size: 0.74rem;
  color-scheme: dark;
}

.louna-schedule-x,
.louna-schedule-add {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border: 1px solid rgba(114, 234, 255, 0.2);
  border-radius: 7px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}

.louna-schedule-x:hover {
  color: #ff8a8a;
  border-color: rgba(255, 138, 138, 0.5);
}

.louna-schedule-add:hover {
  color: var(--cyan);
  border-color: var(--cyan);
}

.louna-schedule-opts {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
}

.louna-schedule-override {
  padding: 5px 12px;
  border: 1px solid rgba(114, 234, 255, 0.35);
  border-radius: 10px;
  background: rgba(73, 230, 255, 0.06);
  color: var(--cyan);
  font-size: 0.78rem;
  cursor: pointer;
}

.louna-schedule-override:hover {
  background: rgba(73, 230, 255, 0.12);
}

.louna-schedule-override--off {
  border-color: rgba(255, 138, 138, 0.4);
  background: transparent;
  color: #ff8a8a;
}

/* ── Lock screen (access schedule active) ──────────────────────────── */
.louna-lock {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(73, 230, 255, 0.08), transparent),
    #04060f;
}

.louna-lock-card {
  max-width: 420px;
  width: 100%;
  text-align: center;
  padding: 40px 32px;
  border: 1px solid rgba(114, 234, 255, 0.16);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.03);
}

.louna-lock-emoji {
  font-size: 3rem;
  line-height: 1;
  margin-bottom: 16px;
}

.louna-lock-title {
  margin: 0 0 10px;
  font-size: 1.4rem;
  color: var(--text);
}

.louna-lock-text {
  margin: 0 0 8px;
  color: var(--muted);
  line-height: 1.5;
}

.louna-lock-until {
  margin: 0 0 22px;
  font-size: 0.9rem;
  color: var(--cyan);
}

.louna-lock-logout {
  padding: 9px 20px;
  border: 1px solid rgba(114, 234, 255, 0.3);
  border-radius: 12px;
  background: transparent;
  color: var(--muted);
  font-size: 0.85rem;
  cursor: pointer;
}

.louna-lock-logout:hover {
  color: var(--text);
  border-color: var(--cyan);
}

/* Ambient kiosk: account without voice rights */
.louna-ambient__blocked {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
  color: var(--muted);
}

/* ── Chat : pièces jointes (trombone + glisser-déposer) ───────────── */
.louna-chat { position: relative; }

.louna-chat-dropzone {
  position: absolute;
  inset: 0;
  z-index: 20;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  border: 2px dashed var(--accent, #5ad);
  border-radius: 14px;
  background: rgba(10, 20, 35, 0.82);
  color: var(--text, #eaf2ff);
  font-weight: 600;
  pointer-events: none;
}

/* Vignettes/chips des fichiers en attente d'envoi */
.louna-chat-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.5rem 0.25rem 0;
}
.louna-chat-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  max-width: 220px;
  padding: 0.3rem 0.5rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 0.82rem;
}
.louna-chat-chip-thumb {
  width: 28px;
  height: 28px;
  object-fit: cover;
  border-radius: 6px;
}
.louna-chat-chip-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.louna-chat-chip-x {
  display: inline-flex;
  align-items: center;
  border: none;
  background: transparent;
  color: var(--muted, #9ab);
  cursor: pointer;
  padding: 2px;
  border-radius: 6px;
}
.louna-chat-chip-x:hover { color: #ff7676; background: rgba(255, 118, 118, 0.12); }

/* Rendu des pièces jointes dans une bulle envoyée */
.louna-chat-attach-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.4rem;
}
.louna-chat-attach-thumb {
  max-width: 180px;
  max-height: 180px;
  border-radius: 10px;
  object-fit: cover;
}
.louna-chat-attach-file {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.5rem;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  font-size: 0.82rem;
}

/* Horodatage d'un message (date + heure) */
.louna-chat-time {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.72rem;
  color: var(--muted, #8aa);
  opacity: 0.7;
  text-align: right;
}

