/* ======== 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);
  }
}

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

/* --- 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;
}
.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(--bs-border-color, #dee2e6);
  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: #fff;
}
.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%, #fff);
}
.selectable-option:focus-within{
  outline: 2px solid color-mix(in srgb, var(--qm-primary) 35%, transparent);
  outline-offset: 2px;
}

/* --- 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);
}


/* 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%);
}
