/* ======== QUESTMEE main.css (refactor) ======== */

/* --- Design tokens --- */
:root{
  --qm-bg: #fafbff;
  --qm-text: #23282f;
  --qm-heading: #1a233a;

  --qm-primary: #2878e6;
  --qm-primary-600: #1d5fbc;
  --qm-accent: #2fc67b;

  --qm-link: #286ee6;
  --qm-link-hover: #194aab;

  --qm-border: #e7eaf0;
  --qm-border-strong: #d4d9df;

  --qm-muted: #6c757d;

  --qm-card-bg: #fff;
  --qm-card-shadow: 0 1px 10px rgba(28,44,110,.04);

  --radius-sm: .5rem;
  --radius-md: .75rem;
  --radius-lg: 1.125rem;

  --elev-1: 0 2px 12px rgba(28,44,110,.05);
  --elev-2: 0 .5rem 1rem rgba(13,110,253,.15);
}

/* Dark-mode hook (opcjonalnie – działa gdy system ma dark) */
@media (prefers-color-scheme: dark){
  :root{
    --qm-bg: #0f1320;
    --qm-text: #e8eaf2;
    --qm-heading: #f2f4ff;
    --qm-card-bg: #161a2a;
    --qm-border: #242a3d;
    --qm-border-strong: #2e3550;
    --qm-card-shadow: 0 1px 12px rgba(0,0,0,.25);
  }
}

/* Manual theme override via data-theme attribute (always wins over system) */
:root[data-theme="light"]{
  --qm-bg: #fafbff;
  --qm-text: #23282f;
  --qm-heading: #1a233a;
  --qm-card-bg: #fff;
  --qm-border: #e7eaf0;
  --qm-border-strong: #d4d9df;
  --qm-card-shadow: 0 1px 10px rgba(28,44,110,.04);
}
:root[data-theme="dark"]{
  --qm-bg: #0f1320;
  --qm-text: #e8eaf2;
  --qm-heading: #f2f4ff;
  --qm-card-bg: #161a2a;
  --qm-border: #242a3d;
  --qm-border-strong: #2e3550;
  --qm-card-shadow: 0 1px 12px rgba(0,0,0,.25);
  --qm-link: #8ab4ff;
  --qm-link-hover: #c2d4ff;
  --qm-muted: #a8b3c7;
}

/* Motion-reduction */
@media (prefers-reduced-motion: reduce){
  * { animation: none !important; transition: none !important; }
}

/* --- Reveal animations (on-scroll) --- */
.reveal{ opacity: 0; transform: translateY(12px) scale(.98); transition: transform .7s cubic-bezier(.2,.7,.1,1), opacity .7s ease; }
.reveal.is-visible{ opacity: 1; transform: none; }
.reveal[data-reveal="fade"]{ transform: none; filter: blur(2px); }
.reveal[data-reveal="fade"].is-visible{ filter: none; }
.reveal[data-reveal="scale-in"]{ transform: scale(.94); }
.reveal[data-reveal-delay]{ transition-delay: var(--reveal-delay, 0ms); }

/* --- Hero animated backdrop --- */
.hero-animated{ position: relative; overflow: hidden; }
.hero-animated > .container{ position: relative; z-index: 1; }
.hero-animated::before{
  content: "";
  position: absolute; inset: -45% -35% -55% -35%;
  background: conic-gradient(from 0deg, color-mix(in srgb, var(--qm-primary) 35%, transparent) 0%, color-mix(in srgb, var(--qm-accent) 30%, transparent) 35%, color-mix(in srgb, var(--qm-primary) 35%, transparent) 70%, transparent 100%);
  filter: blur(70px) saturate(120%);
  transform: translateY(-10%) rotate(0deg);
  animation: qm-spinGradient 22s linear infinite;
  opacity: .75;
}
@keyframes qm-spinGradient{ to { transform: translateY(-10%) rotate(360deg); } }
[data-theme="dark"] .hero-animated::before{ opacity: .35; }

/* --- Base --- */
html, body { height: 100%; }
body{
  font-family: 'Inter', system-ui, Arial, sans-serif;
  background: var(--qm-bg);
  color: var(--qm-text);
  margin: 0;
}

h1,h2,h3,h4,h5{
  font-weight: 600;
  letter-spacing: -.5px;
  color: var(--qm-heading);
}

a{
  color: var(--qm-link);
  text-decoration: none;
  transition: color .18s ease;
}
a:hover, a:focus{ color: var(--qm-link-hover); text-decoration: underline; }

/* Nie nadpisujemy globalnie Bootstrapa .container (psuło breakpointy).
   Jeśli chcesz węższy layout, dodaj klasę .container-narrow do kontenera. */
.container-narrow{ max-width: 940px; }

/* --- Navbar --- */
.navbar{
  border-bottom: 1px solid var(--qm-border);
  background: #fff !important;
}
/* Dark navbar surface */
[data-theme="dark"] .navbar{
  background: #0f1320 !important;
}
.navbar-brand img{ border-radius: 12px; }

/* --- Buttons --- */
.btn-primary,
.btn-outline-primary{
  border-radius: 8px;
  font-weight: 500;
  padding: .55em 1.2em;
  font-size: 1.08rem;
}

.btn-primary{
  background: linear-gradient(90deg, var(--qm-primary), var(--qm-accent));
  border: 0;
}
.btn-primary:hover{
  background: linear-gradient(90deg, var(--qm-primary-600), #24965a);
}

.btn-outline-primary{
  color: var(--qm-primary);
  border: 1.5px solid var(--qm-primary);
  background: transparent;
}
.btn-outline-primary:hover{
  background: var(--qm-primary);
  color: #fff;
}

/* --- Cards --- */
.card{
  border-radius: 18px;
  border: 1.5px solid var(--qm-border);
  background: var(--qm-card-bg);
  box-shadow: var(--qm-card-shadow);
}

/* --- Badges --- */
.badge{
  font-size: 1rem;
  padding: .4em 1.2em;
  border-radius: 1.3em;
  font-weight: 500;
  letter-spacing: .03em;
}

/* --- Footer --- */
footer{
  background: #f4f7fb;
  color: #606e85;
  border-top: 1.5px solid var(--qm-border);
  padding: 1.2em 0;
}

/* --- Utilities --- */
.text-muted{ color: var(--qm-muted) !important; }
.center-section,
.main-center-section{
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 40vh; text-align: center;
}
.mt-5,.my-5{ margin-top: 3rem !important; }
.mb-5,.my-5{ margin-bottom: 3rem !important; }
.shadow-sm{ box-shadow: var(--elev-1) !important; }

/* --- Cookie Banner --- */
.cookie-banner{
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  z-index: 4000;
  background-color: #f2f2f2;
  padding: .9rem .75rem;
  border-top: 1px solid var(--qm-border-strong);
  font-size: 1rem;
  box-shadow: 0 1px 8px rgba(20,40,90,.06);
}
.cookie-banner .btn{ margin-left: 1rem; }

/* --- Forms (Crispy override) --- */
.form-control, input, textarea, select{
  border-radius: 8px;
  border: 1.5px solid var(--qm-border-strong);
  font-size: 1rem;
  box-shadow: none;
}
.form-control:focus, input:focus, textarea:focus, select:focus{
  border-color: var(--qm-primary);
  box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--qm-primary) 20%, transparent);
  outline: none;
}
.form-label{ font-weight: 500; }

.alert{
  border-radius: 12px;
  font-size: 1.05rem;
}

/* --- Selectable option (kafelki z radiobuttonami) --- */
.selectable-option{
  border: 1px solid var(--qm-border);
  border-radius: var(--radius-sm);
  padding: .75rem;
  cursor: pointer;
  transition: box-shadow .15s ease, border-color .15s ease, transform .15s ease, background-color .2s ease;
  background: var(--qm-card-bg);
}
.selectable-option:hover{ box-shadow: 0 .25rem .75rem rgba(0,0,0,.05); }
.selectable-option.active{
  border-color: var(--qm-primary);
  box-shadow: var(--elev-2);
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--qm-primary) 8%, var(--qm-card-bg));
}
.selectable-option:focus-within{
  outline: 2px solid color-mix(in srgb, var(--qm-primary) 35%, transparent);
  outline-offset: 2px;
}
/* Better contrast for answers in dark theme */
[data-theme="dark"] .selectable-option,

/* --- Loading overlay block moved to end of file --- */
[data-theme="dark"] .selectable-option label,
[data-theme="dark"] .selectable-option strong{
  color: var(--qm-heading) !important;
}
[data-theme="dark"] .selectable-option{
  border-color: var(--qm-border-strong);
  background: #1a2234;
}
[data-theme="dark"] .selectable-option.active{
  background: color-mix(in srgb, var(--qm-primary) 16%, #1a2234);
}

/* --- Custom Progress Bar --- */
.custom-progress-bar{
  background: linear-gradient(90deg, #4caf50, #81c784);
  transition: width 1s ease-in-out;
  border-radius: 12px;
  box-shadow: 0 0 5px rgba(0,0,0,.2);
}

/* --- Responsive tweaks --- */
@media (max-width: 900px){
  .navbar-brand img{ height: 34px; }
  h1{ font-size: 2rem; }
  h2{ font-size: 1.4rem; }
}
@media (max-width: 600px){
  .main-center-section, .center-section{ min-height: 22vh; }
  .navbar{ padding: .3rem .7rem; }
  .btn, .btn-sm, .btn-lg{ font-size: 1rem; padding: .5em 1em; }
}

/* subtelny „oddech” nad hero na dużych ekranach */
@media (min-width: 992px){
  .py-lg-6 { padding-top: 4.5rem !important; padding-bottom: 4.5rem !important; }
}

/* karty lekko żywsze w hover (już masz card-hover; to tylko doprecyzowanie) */
.card-hover{ transition: transform .15s ease, box-shadow .15s ease; }
.card-hover:hover{ transform: translateY(-2px); box-shadow: 0 .75rem 1.5rem rgba(28,44,110,.08); }

/* link w „Zobacz wszystkie” bez zmiany układu */
.btn-link{ color: var(--qm-link); }
.btn-link:hover{ color: var(--qm-link-hover); text-decoration: underline; }

/* Kompaktowe przyciski auth w navbarze */
.navbar-auth .btn{
  padding: .5rem 1rem;
  font-size: .98rem;
  border-radius: .6rem;
}

/* Lepsza widoczność ikony burgera przy navbar-light */
.navbar-light .navbar-toggler{
  border-color: rgba(0,0,0,.1);
}
.navbar-light .navbar-toggler:focus{
  box-shadow: 0 0 0 .2rem rgba(40,120,230,.2);
}
[data-theme="dark"] .navbar-light .navbar-toggler{
  border-color: rgba(255,255,255,.35);
}
[data-theme="dark"] .navbar-light .navbar-toggler:focus{
  box-shadow: 0 0 0 .2rem rgba(140,185,255,.25);
}
[data-theme="dark"] .navbar-light .navbar-toggler-icon{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}


/* Brand hover: subtelna kreska i lekkie rozjaśnienie */
.navbar .navbar-brand{
  text-decoration: none;
}

.brand-text{
  position: relative;
  transition: color .25s ease, transform .2s ease;
  /* animowana „podkreska” jako gradient w tle */
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 0% 2px;           /* start: brak linii */
  background-position: 0 100%;       /* przy dolnej krawędzi tekstu */
}

.navbar .navbar-brand:hover .brand-text,
.navbar .navbar-brand:focus .brand-text{
  color: var(--qm-link);              /* delikatne rozjaśnienie */
  background-size: 100% 2px;          /* kreska „wypełnia się” w lewo→prawo */
  transform: translateY(-1px);        /* minimalne uniesienie */
}

/* dla touch i użytkowników preferujących mniej ruchu – kreska bez animacji */
@media (prefers-reduced-motion: reduce){
  .brand-text{ transition: none; }
}


/* Brand: własna „kreska”, zero domyślnego podkreślenia */
.navbar .navbar-brand{ text-decoration: none !important; }
.navbar .navbar-brand:hover,
.navbar .navbar-brand:focus{ text-decoration: none !important; }

.brand-text{
  position: relative;
  transition: color .25s ease, transform .18s ease, background-size .25s ease;
  /* animowana kreska: gradient jak w przycisku (niebieski→zielony) */
  background-image: linear-gradient(90deg, var(--qm-primary), var(--qm-accent));
  background-repeat: no-repeat;
  background-size: 0% 2px;         /* start: brak linii */
  background-position: 0 100%;
}

/* Kolor tekstu na hover – „zielonkawy” miks jak w CTA */
.navbar .navbar-brand:hover .brand-text,
.navbar .navbar-brand:focus .brand-text{
  /* mieszanka primary + accent, bardziej zielona */
  color: color-mix(in srgb, var(--qm-primary) 30%, var(--qm-accent) 70%);
  background-size: 100% 2px;       /* kreska rośnie z lewej → prawej */
  transform: translateY(-1px);
}

/* Fallback, gdy color-mix nie jest wspierany */
@supports not (color: color-mix(in srgb, black, white)){
  .navbar .navbar-brand:hover .brand-text,
  .navbar .navbar-brand:focus .brand-text{
    color: #2fbf87; /* stały zielonkawy odcień */
  }
}

.user-count-badge {
  font-weight: 400;   /* zwykła waga, bez bolda */
}

.navbar .nav-link {
  color: var(--qm-text);
  font-weight: 500;
}
.navbar .nav-link:hover {
  color: color-mix(in srgb, var(--qm-primary) 30%, var(--qm-accent) 70%);
}

[data-theme="dark"] .bg-light{ background-color: #151b2d !important; }
[data-theme="dark"] .text-dark{ color: var(--qm-text) !important; }
[data-theme="dark"] .progress{ background-color: #1a2236 !important; }
[data-theme="dark"] .results-card-header{ background-color: #121a2b !important; color: var(--qm-text) !important; }
[data-theme="dark"] .results-card{ color: var(--qm-text); }
[data-theme="dark"] .result-label{ color: #e6eaf5; }
[data-theme="dark"] .result-meta{ color: #b5c2da !important; }

/* Dark profile readability */
[data-theme="dark"] .profile-card { color: var(--qm-text); }
[data-theme="dark"] .profile-card strong { color: #d7e2f3; font-weight: 600; }
[data-theme="dark"] .profile-card .card-title,
[data-theme="dark"] .profile-card h2 { color: #f0f4ff; }

/* Browse cards – make titles brighter in dark */
[data-theme="dark"] .card .card-title { color: #e9edf6; }

.profile-avatar{
  width: 130px;
  height: 130px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid rgba(40,120,230,.25);
  background: #f4f6fd;
  box-shadow: 0 0 0 3px rgba(255,255,255,.4);
}
.profile-avatar.placeholder{
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.4rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(135deg, var(--qm-primary), var(--qm-accent));
}
[data-theme="dark"] .profile-avatar.placeholder{
  box-shadow: 0 0 0 3px rgba(18,26,43,.6);
}
.profile-avatar.preview{
  width: 96px;
  height: 96px;
  border-width: 2px;
  box-shadow: none;
}
[data-theme="dark"] .profile-avatar{
  border-color: rgba(255,255,255,.18);
  background: #1b2338;
  box-shadow: 0 0 0 3px rgba(18,26,43,.9);
}
.profile-details dt{
  font-weight: 600;
  color: var(--qm-muted);
}
.profile-details dd{
  margin-bottom: .75rem;
}
[data-theme="dark"] .profile-details dt{
  color: #9ba7c2;
}

.profile-map{
  height: 320px;
  border-radius: 12px;
  overflow: hidden;
}

.radius-value-badge{
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .25rem .65rem;
  border-radius: 999px;
  background-color: rgba(18,111,230,.12);
  color: #126fe6;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .01em;
}
[data-theme="dark"] .radius-value-badge{
  background-color: rgba(140,185,255,.18);
  color: #bcd8ff;
}
[data-theme="dark"] .list-group-item{ background-color: #151b2d; color: var(--qm-text); border-color: #252c45; }
[data-theme="dark"] .badge.bg-secondary{ background-color: #3a415f !important; color: #e6eaf5 !important; }

/* Dark theme – general component surfaces */
[data-theme="dark"] body{ color: var(--qm-text); background: var(--qm-bg); }
[data-theme="dark"] .card{ background: var(--qm-card-bg); border-color: var(--qm-border); box-shadow: var(--qm-card-shadow); }
[data-theme="dark"] .btn-outline-primary{ color: var(--qm-link); border-color: var(--qm-link); }
[data-theme="dark"] .btn-outline-primary:hover{ background: var(--qm-link); color: #0b1220; }
[data-theme="dark"] .btn-link{ color: var(--qm-link); }
[data-theme="dark"] .btn-link:hover{ color: var(--qm-link-hover); }
[data-theme="dark"] .text-muted, [data-theme="dark"] .form-text{ color: var(--qm-muted) !important; }
[data-theme="dark"] .text-secondary{ color: #a8b3c7 !important; }
[data-theme="dark"] .navbar .brand-text{ color: #c7efe7; }

/* Dark theme – bg-body-tertiary surfaces (footer, stat bars) */
[data-theme="dark"] .bg-body-tertiary{ background-color: #0f1320 !important; }
[data-theme="dark"] .bg-body-tertiary.border-bottom{ border-bottom-color: #1b2238 !important; }
.stats-bar{ border-bottom: 1px solid var(--qm-border); }
[data-theme="dark"] .stats-bar{ border-bottom: 0 !important; }
[data-theme="dark"] footer.bg-body-tertiary{ background-color: #0f1320 !important; color: var(--qm-text); }
[data-theme="dark"] footer.bg-body-tertiary a{ color: var(--qm-link); }
[data-theme="dark"] footer.bg-body-tertiary a:hover{ color: var(--qm-link-hover); }

/* Dark theme – user count badge */
[data-theme="dark"] .user-count-badge,
[data-theme="dark"] .badge.text-bg-light.user-count-badge{
  background-color: #151b2d !important;
  color: var(--qm-text) !important;
  border-color: var(--qm-border) !important;
}
[data-theme="dark"] .hero-sep{ display: none; }

/* Dark theme – form fields */
[data-theme="dark"] .form-control,
[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select{
  background-color: #151b2d;
  color: var(--qm-text);
  border-color: var(--qm-border-strong);
}
[data-theme="dark"] .form-label{ color: var(--qm-text); }
[data-theme="dark"] .form-control::placeholder{ color: #9aa6bf; }
[data-theme="dark"] input:-webkit-autofill,
[data-theme="dark"] input:-webkit-autofill:hover,
[data-theme="dark"] input:-webkit-autofill:focus{
  -webkit-text-fill-color: var(--qm-text);
  -webkit-box-shadow: 0 0 0px 1000px #151b2d inset;
  caret-color: var(--qm-text);
}
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus{
  border-color: var(--qm-primary);
  box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--qm-primary) 24%, transparent);
}

/* Dark theme – cookie banner & alerts */
[data-theme="dark"] .cookie-banner{
  background: #12182b;
  color: var(--qm-text);
  border-top-color: var(--qm-border-strong);
  box-shadow: 0 -6px 20px rgba(0,0,0,.35);
}
[data-theme="dark"] .alert{
  background: #141b2e;
  border-color: var(--qm-border);
  color: var(--qm-text);
}

/* --- Loading overlay --- */
.qm-loading-overlay{
  position: fixed;
  inset: 0;
  z-index: 5000;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(1.5px);
}
.qm-loading-overlay.is-visible{ display: flex; }
[data-theme="dark"] .qm-loading-overlay{ background: rgba(15,19,32,.65); }
.qm-loading-box{
  display: flex;
  align-items: center;
  gap: .75rem;
  background: var(--qm-card-bg);
  border: 1px solid var(--qm-border);
  border-radius: 12px;
  padding: .9rem 1.1rem;
  box-shadow: var(--qm-card-shadow);
}
.qm-loading-text{ font-weight: 500; }
