/* =========================================================
   Maui Mastermind – Brand Theme (cleaned, mobile fixes)
   ========================================================= */

/* ---------- Colors ---------- */
:root{
  --mm-base:#004250;
  --mm-teal:#158A89;
  --mm-teal-2:#8CC7C3;
  --mm-teal-very:#E9F2ED;
  --mm-salmon:#F3776C;
  --mm-sand:#FFFAEE;
  --mm-yellow:#FAE280;
  --mm-white:#ffffff;
  --mm-text:#15352B;
  --mm-border:#ECF3F2;

  /* search cards */
  --asset-bg:#FFE9E3; --asset-bg-hover:#FFD9CF; --asset-ring:#F6B1A9;
  --tool-bg:#EAF7EF;  --tool-bg-hover:#D9EFE3;  --tool-ring:#95D1B7;
}

/* ---------- Typography ---------- */
html{ font-size:16px; }
body{
  font-family:"Helvetica Neue", Helvetica, Arial, sans-serif;
  color:var(--mm-text);
  background:var(--mm-white);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
h1,h2,h3,h4{
  font-family:Georgia, "Times New Roman", serif;
  color:var(--mm-base);
  margin:0 0 .6rem;
}
a{ color:var(--mm-teal); text-decoration:none; }
a:hover{ color:var(--mm-base); }

/* =========================================================
   HEADER & NAV
   ========================================================= */
.branding-header{
  background:var(--mm-white);
  padding:18px 32px 0;
  display:grid;
  grid-template-columns:auto 1fr auto; /* logo | center | menu */
  align-items:center;
  column-gap:18px;
  position:relative;
}
.branding-header::after{
  content:"";
  height:4px;
  display:block;
  grid-column:1/-1;
  margin-top:14px;
  background:linear-gradient(90deg, var(--mm-teal), var(--mm-teal-2));
}
.header-left .main-logo{ max-width:240px; height:auto; display:block; margin:0; }
.header-center{ text-align:center; justify-self:center; }
.branding-sub{ color:var(--mm-teal); font-weight:600; letter-spacing:.2px; font-size:1.02rem; white-space:nowrap; }

.nav-bar{
  display:flex; align-items:center; gap:18px;
  justify-content:flex-end; justify-self:end;
}
.nav-bar a{
  color:var(--mm-base); font-weight:700; font-size:1.08rem;
  text-decoration:none !important; border-bottom:none !important;
  padding:6px 6px; transition:color .18s ease;
}
.nav-bar a:hover{ color:var(--mm-teal); }
.nav-bar a.active,
.nav-bar a[aria-current="page"],
.nav-bar a:active{ color:var(--mm-salmon); }

.user-info{
  color:var(--mm-teal); font-weight:600; margin-left:4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  max-width: clamp(220px, 22vw, 360px);
}
@media (max-width:900px){ .user-info{ display:none; } }

/* Buttons inside nav keep proper padding */
.nav-bar .btn,
.nav-bar .btn-logout,
.nav-bar .btn.secondary{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 20px !important; border-radius:10px; line-height:1.1; white-space:nowrap;
}

/* Log Out button (blue flat) */
.btn-logout{
  background:#2e89d9; color:#fff !important;
  padding:10px 20px; border-radius:4px; font-weight:600; font-size:1rem;
  text-decoration:none !important; transition:background .2s;
}
.btn-logout:hover{ background:#226fb3; }
.btn-logout:active{ background:#1a5a94; }

/* Hamburger (mobile) */
.hamburger{
  display:none; background:transparent; border:0; font-size:28px;
  color:var(--mm-base); margin-left:12px; cursor:pointer;
}

/* =========================================================
   PAGE WRAPPER
   ========================================================= */
.main-content{ width:100%; margin:0; padding:44px 20px 56px; background:var(--mm-white); color:var(--mm-text); }
.main-content > *{ max-width:1200px; margin-inline:auto; }


/* hard center the explainer button row */
.main-content > .search-tagline + .center{
  display: flex;
  justify-content: center;
}

.main-heading{ margin:18px 0 16px; }
.section{ margin:18px 0; }
.card-pad{ padding:16px; }

/* =========================================================
   CARDS / PANELS
   ========================================================= */
.card, .result-card, #adminFormCol, #assetsListCol, .log-box, .auth-card{
  background:var(--mm-white);
  border:1px solid var(--mm-border);
  border-radius:18px;
  box-shadow:0 10px 24px rgba(0,0,0,.10);
}

/* =========================================================
   UTILITIES
   ========================================================= */
.preline{ white-space:pre-line; }
.hidden{ display:none !important; }
.blurred{ filter:blur(2.5px); pointer-events:none; opacity:.55; }
*, *::before, *::after { box-sizing:border-box; }
img { max-width:100%; height:auto; display:block; }

/* =========================================================
   FORMS
   ========================================================= */
label, .form-group, .field-label{
  background:var(--mm-sand);
  padding:12px 14px 10px;
  border-radius:12px; font-weight:600;
  box-shadow:0 1px 3px rgba(0,0,0,.03);
  color:var(--mm-text);
  display:block;
  width:100%;
}
input[type="text"], input[type="email"], input[type="password"], input[type="date"],
input[type="url"], textarea, select{
  background:var(--mm-teal-very);
  border:2px solid var(--mm-teal-2);
  color:var(--mm-text); border-radius:12px; padding:12px 16px;
  transition:border .18s, background .18s, box-shadow .18s;
  width:100%; box-sizing:border-box; margin-top:8px;
}
input:focus, textarea:focus, select:focus{
  background:#fff; border-color:var(--mm-teal);
  box-shadow:0 0 0 3px rgba(21,138,137,.18);
  outline:0;
}
.required-star{ color:#C13232; font-weight:700; margin-left:2px; }
.required-note{ font-size:.93rem; color:#555; margin:4px 0 8px 2px; }

/* Checkbox “chips” */
.inline-label{
  background:#fff; border:2px solid var(--mm-teal-2);
  color:var(--mm-base); border-radius:999px;
  padding:6px 10px; margin:4px 8px 0 0;
  font-weight:600; display:inline-flex; align-items:center; gap:6px;
  box-shadow:none; white-space:nowrap;
}
.inline-label input{ margin:0; }
.inline-label:hover{ border-color:var(--mm-teal); }

/* =========================================================
   TABLES (dashboard logs)
   ========================================================= */
.table, .log-table{ width:100%; border-collapse:separate; border-spacing:0; }
.log-table thead tr{ background:var(--mm-teal-very); color:var(--mm-base); font-weight:800; }
.log-table th, .log-table td{ padding:12px 14px; border-bottom:1px solid var(--mm-border); }
.log-table tbody tr:hover{ background:var(--mm-sand); }
.log-table thead th{ position:sticky; top:0; background:var(--mm-teal-very); z-index:1; }

/* status pills */
.log-status{ display:inline-block; padding:6px 12px; border-radius:999px; font-weight:700; }
.log-success{ background:var(--mm-teal-very); color:var(--mm-teal); border:1px solid var(--mm-teal-2); }
.log-fail{ background:rgba(243,119,108,.15); color:#a7443f; border:1px solid rgba(243,119,108,.45); }

/* =========================================================
   BUTTONS
   ========================================================= */
button, .btn{
  background:var(--mm-base); color:#fff; border:none; border-radius:14px;
  padding:10px 16px; font-weight:700; cursor:pointer;
  transition:background .18s, transform .06s;
}
button:hover, .btn:hover{ background:var(--mm-teal); }
button:active, .btn:active{ transform:translateY(1px); }

.btn.cta, .btn-primary{ background:var(--mm-salmon); }
.btn.cta:hover, .btn-primary:hover{ background:#D65C56; }

.btn.secondary{
  background:#fff; color:var(--mm-teal);
  border:2px solid var(--mm-teal-2); box-shadow:none;
}
.btn.secondary:hover{ color:var(--mm-base); border-color:var(--mm-teal); }

.btn.edit{ background:var(--mm-teal); }
.btn.edit:hover{ background:#0f6f6e; }
.btn.delete{ background:#c93f3a; }
.btn.delete:hover{ background:#a73531; }

/* Loader */
.spinner{
  width:28px; height:28px; border-radius:50%;
  border:3px solid var(--mm-teal-2); border-top-color:var(--mm-teal);
  animation:spin 1s linear infinite; margin:0 auto 10px;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* Video iframe */
.video-embed,
.asset-details-row iframe{
  width:100%; max-width:100%; height:auto; aspect-ratio:16/9;
  border:0; border-radius:14px; box-shadow:0 2px 12px rgba(0,0,0,.1);
}

/* Footer */
.site-footer{ background:var(--mm-base); color:#fff; text-align:center; padding:22px 16px; margin-top:46px; }

/* =========================================================
   ADMIN PAGE
   ========================================================= */
#adminMainWrap{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:26px; align-items:start; margin-top:10px; overflow-x:hidden;
}
#adminFormCol, #assetsListCol{ padding:20px; }
#adminFormCol h2, #assetsListCol h2{ margin:6px 6px 14px; color:var(--mm-base); }
#assetForm label{ margin:12px 0; }
#assetForm label > input,
#assetForm label > textarea,
#assetForm label > select{ margin-top:8px; width:100%; box-sizing:border-box; }
#assetForm .hint{ display:block; margin-top:6px; font-size:.92rem; color:var(--mm-base); opacity:.6; }

/* Categories in Admin */
#categoriesBox{ display:flex; flex-wrap:wrap; gap:10px 12px; align-items:center; }
#categoriesBox .inline-label{ font-size:clamp(12px,1.6vw,16px); line-height:1.1; }

/* Assets list */
.assets-list{ margin-top:8px; }
.asset-row-collapsible{
  background:#fff; border:1px solid var(--mm-border);
  border-radius:14px; padding:12px 14px; margin-top:12px;
  display:flex; justify-content:space-between; align-items:center;
  box-shadow:0 6px 14px rgba(0,0,0,.06); position:relative; z-index:1;
  transition:background .15s ease, border-color .15s ease;
}
.asset-row-collapsible:hover{ background:#FAFEFC; border-color:var(--mm-teal-2); }
.asset-row-title b{ color:var(--mm-base); }
.asset-row-title .muted{ color:#6a7; opacity:.7; margin-left:6px; }
.asset-btns{ display:flex; gap:8px; }
.asset-details-row{
  position:relative; z-index:2;
  background:#FAFEFC; border:1px solid var(--mm-border); border-top:1px solid var(--mm-border);
  border-radius:0 0 14px 14px; padding:14px 16px;
  overflow:hidden; overflow-wrap:anywhere;
}

/* --- Admin Assets: fix na "uciekanie" w prawo przy długich tytułach --- */
.asset-row-title{
  flex: 1 1 auto;
  min-width: 0;                 /* klucz – pozwala się ścisnąć w flexie */
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.asset-btns{ flex: 0 0 auto; }  /* przyciski bez kurczenia */

/* linki w detalach łamią się agresywnie */
.asset-details-row a{ word-break: break-all; }


/* Keep list blurred/disabled while saving edits */
#assetsList.blurred .btn{ filter:grayscale(60%); }

/* =========================================================
   DASHBOARD LIST CONTAINERS
   ========================================================= */
.fancy-log-table{
  background:#fff; border:1px solid var(--mm-border);
  border-radius:18px; box-shadow:0 8px 18px rgba(0,0,0,.08);
  padding:0; max-height:360px; overflow:auto;
}
.log-section{ margin:18px 0; }
.main-content h2, .main-content > p, .log-section{ margin-left:auto; margin-right:auto; padding:0 14px; }

/* =========================================================
   SEARCH (layout + cards)
   ========================================================= */
.main-heading.center{ text-align:center }
.search-hero{ display:flex; justify-content:center; }
.search-bar-wrapper{
  display:flex; gap:10px; align-items:center;
  width:min(900px,92vw); margin:0 auto 18px;
}
.search-bar-wrapper.center{ justify-content:center; }
.search-bar-input{ flex:1; min-width:620px; max-width:920px; min-width:0; }

.results-wrap{ width:min(1100px,95vw); margin:0 auto; position:relative; }
.results-wrap{ padding-bottom: 28px; }


/* centered loader overlay */
.search-loading{
  position:absolute;             /* potrzebne do inset */
  inset:60px 0 auto 0;
  display:none; justify-content:center; align-items:center; gap:12px;
  color:var(--mm-teal); font-weight:600; text-align:center;
}
.search-loading .spinner{
  width:20px; height:20px; border-radius:50%;
  border:3px solid #cfe6de; border-top-color:var(--mm-teal);
  animation:spin .9s linear infinite;
}

/* results – header clickable only */
.result-card{
  background:#fff; border:1px solid #e6eef0; border-radius:12px; padding:0; margin:14px 0;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
}
.result-header{
  border-radius:12px; padding:10px 12px; display:flex; gap:10px; align-items:center;
  cursor:pointer; user-select:none; transition:background-color .12s ease;
}
.result-header.asset{ background:var(--asset-bg); }
.result-header.tool{  background:var(--tool-bg); }

.result-card.open .result-header.asset,
.result-header.asset:hover, .result-header.asset:active{
  background:var(--asset-bg-hover); box-shadow:inset 0 0 0 2px var(--asset-ring);
}
.result-card.open .result-header.tool,
.result-header.tool:hover, .result-header.tool:active{
  background:var(--tool-bg-hover); box-shadow:inset 0 0 0 2px var(--tool-ring);
}

.result-title{ font-weight:700; flex:1; overflow-wrap:anywhere; }
.pill{ padding:2px 8px; border-radius:999px; font-weight:700; font-size:.78rem; letter-spacing:.02em; text-transform:uppercase; }
.pill.asset{ background:#e6f7ff; }
.pill.tool{  background:#eefbe8; }
.score{ margin-left:auto; font-weight:600; color:#476470; font-size:.92rem; }
.vote{ display:flex; gap:6px; margin-left:8px; }
.thumb{ border:0; background:#fff; border-radius:8px; padding:4px 8px; cursor:pointer; }

.result-body{ padding:12px 14px; user-select:text; }
.meta{ color:#1f3b39; opacity:.9; margin-top:6px; }
.snippet{ color:#233; opacity:.92; }
.preline{ white-space:pre-line; }

.vimeo-wrap{ margin-top:10px; }
.vimeo-wrap iframe{ width:100%; height:360px; border-radius:10px; border:0; }

/* Admin “Tools” list: header clickable (collapse) */
.admin-tools .result-header{ cursor:pointer; }
.admin-tools #assetsListCol .result-card{ padding-bottom:8px; }

/* =========================================================
   TOASTS
   ========================================================= */
.toast{
  position:fixed; left:50%; bottom:28px; transform:translateX(-50%);
  background:var(--mm-base); color:#fff; padding:12px 18px;
  border-radius:12px; box-shadow:0 10px 24px rgba(0,0,0,.18);
  z-index:9999; font-weight:700; max-width:min(92vw,680px); text-align:center;
}
.toast.toast-error{ background:var(--mm-salmon); }

/* =========================================================
   MISC / LAYOUT
   ========================================================= */
.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.two-col .col h3{ margin:6px 0 8px; }

.tool-checklist{
  max-height:260px; overflow:auto; border:1px solid #c5e2de;
  border-radius:10px; padding:6px; display:flex; flex-direction:column; gap:6px;
}
.tool-row{ display:flex; align-items:center; gap:10px; padding:10px; border:1px solid #e8f2f1; border-radius:10px; margin:6px 0; background:#fff; transition:background .15s ease, border-color .15s ease; }
.tool-row:hover{ background:#F7FBFF; border-color:#d9ebff; }
.tool-main{ display:flex; justify-content:space-between; width:100%; }
.tool-name{ font-weight:600; }
.tool-link{ font-size:.9em; color:#486; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:50%; }

.blocked #assetsListCol, .blocked .result-card button{ pointer-events:none; opacity:.5; }

.badge{ display:inline-block; padding:2px 8px; border-radius:999px; font-size:.75rem; background:#eef3ff; margin-right:8px; }
.nav-bar a[disabled]{ pointer-events:none; opacity:.45; cursor:default; }

/* =========================================================
   MOBILE (≤ 900px & ≤ 640px)
   ========================================================= */
@media (max-width:900px){
  .branding-header{
    grid-template-columns:1fr auto;
    grid-template-areas:"logo nav" "center center";
    row-gap:8px; padding-right:16px; z-index:3000;
  }
  .header-left{ grid-area:logo; }
  .header-center{ grid-area:center; }
  .hamburger{ display:block; }
  .nav-bar{ display:none; }

  /* WIDOCZNE menu po kliknięciu */
  .nav-bar.open{
    display:flex;                 /* <- klucz */
    flex-direction:column;
    position:fixed;
    top:70px; right:12px; left:auto;
    background:#fff;
    padding:12px 14px;
    border-radius:12px;
    box-shadow:0 12px 26px rgba(0,0,0,.15);
    z-index:9998;
  }
  .nav-bar.open .btn,
  .nav-bar.open .btn-logout,
  .nav-bar.open .btn.secondary{
    width:100%; padding:12px 16px !important; line-height:1.15;
  }

  /* Admin: jedna kolumna */
  #adminMainWrap{ grid-template-columns:1fr !important; gap:16px; }

  .two-col{ grid-template-columns:1fr; }
}

@media (max-width:640px){
  html, body{ overflow-x:hidden; }
  .main-content{ padding:20px 14px; }
  .main-content > *{ max-width:100%; }
  .header-left .main-logo{ max-width:180px; }
  .branding-header{ padding:14px 16px 0; }
  .branding-header::after{ height:3px; }

  /* Search bar: pełna szerokość */
  .search-bar-wrapper{ flex-direction:column; align-items:stretch; gap:10px; width:100%; max-width:100%; }
  .search-bar-input{ width:100% !important; min-width:0; display:block; }
  .search-bar-wrapper .btn{ width:100%; display:block; }

  /* Search card: tytuł NA GÓRZE */
  .result-card{ margin:14px 0; }
  .result-header{ flex-wrap:wrap; gap:6px; align-items:flex-start; }
  .result-header .result-title{ order:1; flex-basis:100%; }
  .result-header .pill,
  .result-header .chip{ order:2; }
  .result-header .score,
  .result-header .vote{ order:3; margin-left:0; width:100%; }

  /* Admin kolumny & listy */
  #adminFormCol, #assetsListCol{ padding:16px; }
  .asset-row-collapsible{ flex-direction:column; align-items:flex-start; gap:8px; }
  .asset-btns{ align-self:flex-end; }

  .fancy-log-table{ max-height:260px; overflow:auto; padding:0; }
  .log-table th, .log-table td{ padding:10px 12px; }

  .toast{ bottom:18px; padding:10px 14px; left:12px; right:12px; transform:none; max-width:unset; }

  /* pełna szerokość kart/form */
  #adminFormCol, #assetsListCol, #loginForm, #registerForm, .result-card, .card, .auth-card{
    width:100%; margin:0;
  }

  .tool-link{ max-width:100%; }
}

/* =========================================================
   SEARCH: dodatkowe elementy
   ========================================================= */
/* hint pod paskiem wyszukiwania */
.search-hint{
  width:min(900px,92vw);
  margin:6px auto 18px;
  text-align:center;
  font-size:.9rem;
  color:var(--mm-teal);
  opacity:.85;
  line-height:1.3;
}

/* subline chipy */
.result-subline{ margin:6px 14px 0; display:flex; gap:8px; flex-wrap:wrap; }
.chip{
  background:#fff; border:1px solid var(--mm-teal-2); color:var(--mm-base);
  border-radius:999px; padding:2px 8px; font-size:.86rem;
}
.chip.dim{ opacity:.75; }

/* Zajawka fragmentu nad detalami; znika po rozwinięciu */
.result-fragment-preview{ margin:8px 14px 0; color:#243; opacity:.95; }
.frag-label{
  background:var(--mm-sand); border:1px solid var(--mm-border);
  border-radius:6px; padding:2px 6px; margin-right:8px; font-weight:600;
}
.result-card.open .result-fragment-preview{ display:none; }

/* listy bez kropek */
ul.flat{ list-style:none; padding-left:0; margin:6px 0 0; }
ul.flat li{ margin:2px 0; }

/* --- ZABEZPIECZENIA PRZED „UCIEKANIEM W PRAWO” --- */
a, .result-card, .asset-row-title, #assetsListCol, #assetsList, #toolsList,
.result-body, .result-header, .preline { overflow-wrap:anywhere; word-break:break-word; }
#assetsListCol, #assetsListCol * { max-width:100%; }
.admin-tools #assetsListCol .result-card a{ word-break:break-all; }


/* --- Admin Assets: anty-overflow po załadowaniu listy --- */
#assetsListCol,
#assetsListCol * {
  max-width: 100%;
  box-sizing: border-box;
}

.asset-row-collapsible {
  overflow: hidden;              /* nic nie wypchnie kontenera */
}

.asset-row-title{
  flex: 1 1 auto;
  min-width: 0;                  /* KLUCZ: pozwala flex-owi się ścisnąć */
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.asset-btns{ flex: 0 0 auto; }

.asset-details-row a{
  word-break: break-all;         /* długie URL-e łamiemy „na siłę” */
}
.asset-details-row .preline{
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Na bardzo wąskich ekranach wszystko w 1 kolumnie + bez rozpychania */
@media (max-width: 640px){
  #adminMainWrap{ grid-template-columns: 1fr !important; }
  .asset-row-collapsible{ flex-direction: column; align-items: flex-start; gap: 8px; }
  .asset-btns{ align-self: flex-end; }
}


/* === FIX: Admin Assets – Tools (pick from existing) niech nie rozpycha w prawo === */
#toolCheckboxes,
.tool-checklist{
  overflow-x: hidden;            /* żadnych poziomych scrolli */
}

/* element wiersza z checkboxem */
.tool-row{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;                  /* klucz w flexboxie: pozwól się ścisnąć */
}

/* kontener na tytuł i link narzędzia */
.tool-main{
  display: flex;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  min-width: 0;                  /* pozwól dzieciom się ścisnąć */
}

/* tytuł i link MUSZĄ móc się łamać, inaczej wypychają widok */
.tool-name,
.tool-link{
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Desktop/większe – link ucinamy wielokropkiem */
.tool-link{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 62%;
}

/* Węższe ekrany – link może się normalnie zawijać i być mniejszy */
@media (max-width: 640px){
  .tool-row{ padding: 8px; }
  .tool-name{ font-size: .95rem; }
  .tool-link{
    font-size: .82rem;
    white-space: normal;         /* pozwól zawijać */
    overflow: visible;
    text-overflow: unset;
    word-break: break-all;       /* bezlitosne łamanie bardzo długich URL-i */
    max-width: 100%;
  }
  #toolCheckboxes{ max-height: 320px; } /* trochę większe okno listy */
}

/* Dodatkowe bezpieczniki, gdy lista assetów jest już pod spodem */
.asset-row-title{ min-width: 0; overflow-wrap:anywhere; word-break:break-word; }
#assetsListCol, #assetsListCol *{ max-width:100%; box-sizing:border-box; }
.asset-details-row a{ word-break: break-all; }


/* video helper nad searchbarem */
.video-helper{
  width:min(900px,92vw);
  margin:0 auto 16px;
}
.video-helper .vh-inner{
  background:#fff;
  border:1px solid var(--mm-border);
  border-radius:14px;
  padding:10px;
  box-shadow:0 6px 14px rgba(0,0,0,.06);
}

.feedback-teaser{
  width:min(900px,92vw);
  margin:12px auto 0;
  display:flex; justify-content:center;
}
.pulse{
  animation: pulse 1.8s ease-out infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(21,138,137,.35); }
  70%{ box-shadow:0 0 0 12px rgba(21,138,137,0); }
  100%{ box-shadow:0 0 0 0 rgba(21,138,137,0); }
}
.feedback-card{
  width:min(900px,92vw);
  margin:10px auto;
  background:#fff;
  border:1px solid var(--mm-border);
  border-radius:12px;
  padding:12px 14px;
  box-shadow:0 8px 18px rgba(0,0,0,.06);
}
.feedback-card h3{ margin:0 0 8px; color:var(--mm-base); }
.feedback-q{ margin:10px 0; }
.feedback-q .q-label{ display:block; font-weight:700; margin-bottom:6px; }
.scale-row{ display:flex; flex-wrap:wrap; gap:8px; }
.feedback-actions{ display:flex; gap:8px; justify-content:flex-end; margin-top:12px; }
.hidden{ display:none !important; } /* już masz, ale zostawiam jako przypomnienie */


/* === MODAL POPUP (feedback) === */
.modal{ position:fixed; inset:0; display:flex; align-items:center; justify-content:center; z-index:10050; }
.modal.hidden{ display:none !important; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.45); }
.modal-panel{
  position:relative; width:min(720px,92vw);
  background:#fff; border:1px solid var(--mm-border); border-radius:14px;
  padding:16px; box-shadow:0 16px 44px rgba(0,0,0,.25);
}
.modal-panel h3{ margin:0 0 10px; color:var(--mm-base); }

.feedback-q{ margin:10px 0; }
.feedback-actions{ display:flex; gap:8px; justify-content:flex-end; margin-top:12px; }

/* === STAR RATING (dla type=scale) === */
.stars{ display:flex; gap:8px; }
.stars input{ display:none; }
.stars label{
  font-size:26px; line-height:1; cursor:pointer; user-select:none;
  color:#c8c8c8; transition:transform .06s ease;
}
.stars label.on{ color:#F6B300; }            /* wypełnione */
.stars label:hover{ transform:scale(1.06); } /* lekka interakcja */

/* === Transcript Q&A === */
.qa-box{ margin-top:12px; }
.qa-open{ width:100%; }

.qa-panel{
  background:#f7fbff;
  border:1px solid #cfe6de;
  border-radius:12px;
  padding:10px;
  margin-top:8px;
}

.qa-messages{
  max-height:200px; overflow:auto;
  background:#fff; border:1px solid #e8f2f1; border-radius:10px;
  padding:10px; margin-bottom:8px;
}

.qa-msg{ padding:6px 10px; border-radius:10px; margin:6px 0; white-space:pre-wrap; }
.qa-msg.user{ background:#eef8ff; align-self:flex-end; }
.qa-msg.assistant{ background:#eefbe8; }

.qa-input{ display:flex; gap:8px; }
.qa-input input{ flex:1; }

.qa-note{ font-size:.86rem; color:#476470; opacity:.9; margin-top:6px; }


/* Typing indicator (3 dots) */
.qa-typing { display:inline-flex; gap:6px; align-items:center; }
.qa-typing .dot{
  width:6px; height:6px; border-radius:50%;
  background:#8BB; opacity:.35; animation:qaBounce 1.1s infinite ease-in-out;
}
.qa-typing .dot:nth-child(2){ animation-delay:.15s }
.qa-typing .dot:nth-child(3){ animation-delay:.30s }

@keyframes qaBounce{
  0%, 80%, 100% { transform:translateY(0); opacity:.35; }
  40% { transform:translateY(-5px); opacity:1; }
}

/* Darker chat panel */
.qa-panel{
  background:#102a2d;            /* ciemne tło panelu */
  border-color:#0f3a3f;
  color:#e7f2f1;
}
.qa-messages{
  background:#0b1f22;            /* jeszcze ciemniej dla okna wiadomości */
  border-color:#134246;
}
.qa-msg.user{
  background:#144b57;            /* bąbel użytkownika – morski */
  color:#e9f6f5;
}
.qa-msg.assistant{
  background:#1f3f2a;            /* bąbel asystenta – zieleń */
  color:#eaf5ea;
}
.qa-input input{
  background:#ffffff;
  color:#0f2b2e;
  border:1px solid #cfe6de;
}


/* === Transcript Q&A (light / messenger style) === */
.qa-box{ margin-top:12px; }
.qa-open{ width:100%; }

.qa-panel{
  background:#fff;
  border:1px solid #e6eef0;
  border-radius:12px;
  padding:10px;
  margin-top:8px;
  color:#15352B;
}

.qa-messages{
  display:flex;                 /* ważne dla align-self */
  flex-direction:column;
  gap:8px;
  max-height:260px;
  overflow:auto;
  background:#f8fafb;
  border:1px solid #e6eef0;
  border-radius:12px;
  padding:10px;
}

.qa-msg{
  max-width:72%;
  padding:8px 12px;
  border-radius:16px;
  margin:0;                     /* odstępy daje gap */
  line-height:1.25;
  font-size:.95rem;
  white-space:pre-wrap;
  word-wrap:anywhere;
}

.qa-msg.user{
  align-self:flex-end;          /* bąbelek po prawej */
  background:#0b93f6;
  color:#fff;
  border-top-right-radius:6px;
}

.qa-msg.assistant{
  align-self:flex-start;        /* bąbelek po lewej */
  background:#e9ecef;
  color:#111;
  border-top-left-radius:6px;
}

.qa-input{ display:flex; gap:8px; margin-top:8px; }
.qa-input input{
  flex:1;
  background:#fff;
  color:#0f2b2e;
  border:1px solid #cfe6de;
  border-radius:10px;
  padding:10px 12px;
}

.qa-note{ font-size:.86rem; color:#476470; opacity:.9; margin-top:6px; }

/* Typing indicator (3 dots) – jasny wariant */
.qa-typing { display:inline-flex; gap:6px; align-items:center; }
.qa-typing .dot{
  width:6px; height:6px; border-radius:50%;
  background:#8BB;
  opacity:.45;
  animation:qaBounce 1.1s infinite ease-in-out;
}
.qa-typing .dot:nth-child(2){ animation-delay:.15s }
.qa-typing .dot:nth-child(3){ animation-delay:.30s }
@keyframes qaBounce{
  0%,80%,100% { transform:translateY(0); opacity:.45; }
  40%         { transform:translateY(-5px); opacity:1; }
}


.is-busy { position: relative; }
.is-busy::after{
  content:'';
  position: fixed; inset:0;
  background: rgba(0,0,0,.25);
  z-index: 999;
}


.log-status.log-pending {
  background: #ccc;
  color: #222;
  padding: 2px 6px;
  border-radius: 6px;
  font-weight: bold;
}


.help-tip{
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; margin-left:8px; border-radius:50%;
  border:1px solid var(--mm-teal-2); background:#fff; color:var(--mm-base);
  font-weight:800; cursor:pointer; user-select:none;
}
.help-tip:hover{ border-color:var(--mm-teal); }


/* === QA CTA row + tooltip (fixed) === */
.qa-cta-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;              /* na wąskich może się zwinąć do 2 linii */
}

/* guzik: już NIE full-width */
.qa-box .qa-open{
  width:auto;
  max-width:100%;
  white-space:nowrap;          /* nie łam guzikowego tekstu na desktopie */
  padding:10px 14px;
  font-size:.95rem;
}

/* znak zapytania przy guziku */
.help-tip{
  position:relative;
  display:inline-flex;
  align-items:center; justify-content:center;
  width:22px; height:22px; margin-left:8px;
  border-radius:50%;
  border:1px solid var(--mm-teal-2);
  background:#fff; color:var(--mm-base);
  font-weight:800; cursor:pointer; user-select:none;
}

/* sam dymek */
.help-tip .qa-tooltip{
  position:absolute;
  left:50%; bottom:calc(100% + 10px);
  transform:translateX(-50%);
  display:block;
  writing-mode:horizontal-tb;   /* twardy reset przed pionowym składem */
  white-space:normal;           /* zresetuj ustawienia z rodziców */
  word-break:normal;
  overflow-wrap:normal;
  text-align:left;

  min-width:240px;
  max-width:min(60ch, 92vw);

  background:#0f2b2e; color:#e7f2f1;
  border:1px solid #0f3a3f; border-radius:10px;
  padding:10px 12px; line-height:1.25; font-size:.9rem;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
  opacity:0; pointer-events:none;
  transition:opacity .12s ease, transform .12s ease;
  z-index:1000;
}

.help-tip .qa-tooltip::after{
  content:"";
  position:absolute; top:100%; left:50%; transform:translateX(-50%);
  border:8px solid transparent; border-top-color:#0f2b2e;
}

/* pokaż dymek na hover/focus i na mobile po .open */
.help-tip:hover .qa-tooltip,
.help-tip:focus-within .qa-tooltip,
.help-tip.open .qa-tooltip{
  opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0);
}

/* mobile: pozwól guzikowi się łamać; “?” zostaje obok albo spadnie pod spód */
@media (max-width:640px){
  .qa-box .qa-open{ white-space:normal; }  /* guzik może złamać tekst */
}


.search-notice{ width:min(1100px,95vw); margin:8px auto 0; }
.search-notice .notice{
  background:#fff; border:1px solid var(--mm-border);
  border-left:6px solid var(--mm-teal);
  border-radius:10px; padding:10px 12px; margin:8px 0; box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.search-notice .notice-warn{ border-left-color:#F6B300; }
.search-notice .notice-error{ border-left-color:#c93f3a; }
.search-notice .notice-info{ border-left-color:#2e89d9; }


.search-tagline{
  margin:-8px auto 14px;
  font-size:.98rem;
  color:#476470;
  opacity:.9;
}

/* ensure center text & center as flex item */
.main-content .search-tagline.center{
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  text-align:center;       /* multi-line centering */
  margin:-8px auto 14px;   /* zostawiasz poprzedni margin */
}

/* awaryjnie, gdyby rodzic dawał align-items:flex-start */
header + .main-content .search-tagline.center{
  align-self:center;
}

/* center the explainer button row under the tagline */
.search-tagline + .center {
  text-align: center;
}


/* Title */
.main-heading.center {
  font-size: 38px;     /* zostaje większy tytuł */
  line-height: 1.15;
  margin-bottom: 0;    /* żeby odstęp liczył się z margin-top tagline */
}

/* Tagline — “Navigate Maui’s Knowledge Library” */
.search-tagline.center{
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; /* Light/Regular fallback */
  font-weight: 300;          /* Light; jeśli brak — przeglądarka użyje Regular (400) */
  color: #158a89;            /* Maui Teal */
  font-size: 1.25rem;        /* ≈ 20px */
  letter-spacing: 0.01em;
  line-height: 1.3;
  margin: 0.4em 0 12px;      /* 0.4em poniżej tytułu */
  text-align: center;        /* zachowujemy centrowanie */
}

/* Counter badge (bez zmian) */
.count-badge { font-weight: 600; opacity: .75; }

