/**
 * Foodlyo - Main Stylesheet
 * Minimalist design inspired by Apple, clean UI
 */

/* Google Fonts Import */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

/* CSS Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Root variables - Design system colors */
:root {
    --color-background: #f7f7f7;
    --color-primary: #86BF40;
    --color-accent: #4086BF;
    --color-highlight: #BF4086;
    --color-white: #ffffff;
    --color-black: #000000;
    --color-gray-100: #f5f5f5;
    --color-gray-200: #e0e0e0;
    --color-gray-300: #cccccc;
    --color-gray-400: #999999;
    --color-gray-500: #666666;
    --color-gray-600: #333333;
    
    /* Typography */
    --font-family-heading: 'Work Sans', sans-serif;
    --font-family: 'Inter', 'Helvetica Neue', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-size-xs: 12px;
    --font-size-sm: 14px;
    --font-size-base: 16px;
    --font-size-lg: 18px;
    --font-size-xl: 24px;
    --font-size-2xl: 32px;
    --font-size-3xl: 56px;
    
    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-base: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --spacing-2xl: 48px;
    --spacing-3xl: 64px;
    
    /* Border radius - zvětšeno pro přívětivější vzhled */
    --radius-sm: 8px;
    --radius-base: 12px;
    --radius-lg: 20px;
    --radius-xl: 24px;
    
    /* Shadows (minimalist) */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-base: 0 2px 4px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 4px 8px rgba(0, 0, 0, 0.08);
    
    /* Transitions */
    --transition-fast: 150ms ease-in-out;
    --transition-base: 250ms ease-in-out;
}

/* Base styles */
html {
    font-size: 16px;
    line-height: 1.5;
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    color: var(--color-gray-600);
    background-color: var(--color-background);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Layout containers */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-base);
}

.container-sm {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 var(--spacing-base);
}

/* Grid system */
.grid {
    display: grid;
    gap: var(--spacing-base);
}

.grid-2 {
    grid-template-columns: repeat(2, 1fr);
}

.grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* Flex utilities */
.flex {
    display: flex;
}

.flex-col {
    flex-direction: column;
}

.items-center {
    align-items: center;
}

.justify-between {
    justify-content: space-between;
}

.justify-center {
    justify-content: center;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-family-heading);
    font-weight: 700;
    color: var(--color-gray-600);
    line-height: 1.1;
    margin-bottom: var(--spacing-base);
}

h1 {
    font-size: var(--font-size-2xl);
    letter-spacing: -0.025em;
    text-transform: uppercase;
    line-height: 1;
    font-weight: 600;
}

h2 {
    font-size: var(--font-size-xl);
    font-weight: 700;
}

h3 {
    font-size: var(--font-size-xl);
    font-weight: 600;
}

p {
    margin-bottom: var(--spacing-base);
}

/* Placeholders - zeslabené */
::placeholder {
    color: #a1a1aa;
    opacity: 0.7;
}

::-webkit-input-placeholder {
    color: #a1a1aa;
    opacity: 0.7;
}

::-moz-placeholder {
    color: #a1a1aa;
    opacity: 0.7;
}

:-ms-input-placeholder {
    color: #a1a1aa;
    opacity: 0.7;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-base) var(--spacing-xl);
    font-size: var(--font-size-base);
    font-weight: 500;
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: var(--radius-base);
    cursor: pointer;
    transition: all var(--transition-fast);
    min-height: 52px; /* Touch-friendly, větší */
    gap: var(--spacing-sm);
}

.btn-primary {
    background-color: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}

.btn-primary:hover {
    filter: brightness(0.85);
    transform: translateY(-1px);
}

.btn-accent {
    background-color: var(--color-accent);
    color: var(--color-white);
    border-color: var(--color-accent);
}

.btn-accent:hover {
    filter: brightness(0.85);
    transform: translateY(-1px);
}

.btn-outline {
    background-color: transparent;
    color: var(--color-gray-600);
    border-color: var(--color-gray-300);
}

.btn-outline:hover {
    filter: brightness(0.95);
}

.btn-text {
    background-color: transparent;
    color: var(--color-gray-500);
    border: none;
    padding: var(--spacing-sm);
}

.btn-text:hover {
    filter: brightness(0.9);
}

.btn-large {
    font-size: var(--font-size-lg);
    min-height: 60px;
}

.btn-small {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-sm);
    min-height: 40px;
}

/* AI Glow effect */
.btn-ai-glow {
    background: linear-gradient(45deg, var(--color-primary), var(--color-accent));
    color: var(--color-white);
    border: none;
    box-shadow: 0 0 20px rgba(134, 191, 64, 0.3);
    animation: glow-pulse 2s ease-in-out infinite alternate;
}

/* Uvnitř tlačítka zaručíme bílý text */
.btn-ai-glow .btn-text,
.btn-ai-glow .btn-loading {
    color: var(--color-white) !important;
}

@keyframes glow-pulse {
    from {
        box-shadow: 0 0 20px rgba(134, 191, 64, 0.3);
    }
    to {
        box-shadow: 0 0 30px rgba(134, 191, 64, 0.5);
    }
}

/* Disabled button styles */
.btn:disabled {
    background: var(--color-gray-100) !important;
    color: var(--color-gray-200) !important;
    border-color: var(--color-gray-100) !important;
    cursor: not-allowed !important;
    opacity: 0.8;
    box-shadow: none !important;
    animation: none !important;
    transform: none !important;
}

.btn:disabled:hover {
    filter: none !important;
    box-shadow: none !important;
    transform: none !important;
    animation: none !important;
    background: var(--color-gray-100) !important;
    color: var(--color-gray-200) !important;
    border-color: var(--color-gray-100) !important;
}

/* Form elements - větší a modernější */
.form-group {
    margin-bottom: var(--spacing-lg);
}

.form-label {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-weight: 500;
    color: var(--color-gray-600);
}

.form-input,
.form-textarea,
.form-select {
    width: 100%;
    padding: var(--spacing-lg) var(--spacing-lg);
    font-size: var(--font-size-base);
    font-family: var(--font-family);
    color: var(--color-gray-600);
    background-color: var(--color-white);
    border: 1px solid var(--color-gray-300);
    border-radius: var(--radius-base);
    transition: border-color var(--transition-fast);
    min-height: 52px;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(134, 191, 64, 0.1);
}

.form-textarea {
    min-height: 140px;
    resize: vertical;
    padding-top: var(--spacing-lg);
}

.form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 1rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 3rem;
}

/* Cards */
.card {
    background-color: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-base);
}

.card-header {
    padding: 0.5rem 1.5rem 1.5rem 1rem;
    margin-bottom: 0;
    border-bottom: 1px solid var(--color-gray-200);
}

.card-header h3 {
    margin: 0;
    font-size: 1.25rem;
}

.card-title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

/* Stats boxes */
.stats-box {
    background-color: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-base);
    padding: var(--spacing-base);
    text-align: center;
}

.stats-value {
    font-size: var(--font-size-xl);
    font-weight: 600;
    color: var(--color-primary);
    margin-bottom: var(--spacing-xs);
}

.stats-label {
    font-size: var(--font-size-sm);
    color: var(--color-gray-500);
}

/* Navigation - vylepšená hlavní navigace */
.navbar {
    background-color: var(--color-white);
    border-bottom: 4px solid;
    border-image: linear-gradient(90deg, #86BF40 0%, #4086BF 100%) 1;
    padding: var(--spacing-base) 0;
    margin-bottom: var(--spacing-xl);
    position: relative;
    min-height: 80px; /* Nastavení minimální výšky */
}


.navbar-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0px;
}

.navbar-brand {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--color-primary);
    text-decoration: none;
    font-family: var(--font-family-heading);
}

.navbar-nav {
    display: flex;
    align-items: center;
    gap: var(--spacing-xl);
}

.navbar-link {
    color: var(--color-gray-600);
    text-decoration: none;
    transition: color var(--transition-fast);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    font-size: var(--font-size-base);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.navbar-link:hover {
    color: var(--color-accent);
}

.navbar-link.active {
    color: var(--color-accent);
    font-weight: 800;
    position: relative;
    text-decoration: none;
}

/* Icon + label helpers for navbar */
.nav-icon {
    width: 20px;
    height: 20px;
    stroke-width: 2.25;
}

/* Prevent lucide flicker: hide icon placeholders until lucide is ready */
[data-lucide] { visibility: hidden; }
.lucide-ready [data-lucide] { visibility: visible; }

/* Lightweight sticky action bar (no JS cloning) */
.sticky-actions {
    position: sticky;
    bottom: 0;
    background: var(--color-white);
    padding: .75rem 0;
    display: flex;
    gap: .75rem;
    justify-content: center;
    border-top: 1px solid #eee;
    z-index: 5;
}

/* Extra bottom padding in standalone PWA to avoid iOS home indicator overlap */
@media (display-mode: standalone) {
  .sticky-actions {
    padding-bottom: calc(.75rem + constant(safe-area-inset-bottom)); /* old iOS */
    padding-bottom: calc(.75rem + env(safe-area-inset-bottom));      /* modern */
  }
}

.btn .nav-icon {
    width: 20px;
    height: 20px;
}


/* Language switcher */
.language-switcher {
    display: flex;
    gap: var(--spacing-sm);
}

.language-flag {
    width: 24px;
    height: 18px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    opacity: 0.6;
    transition: opacity var(--transition-fast);
}

.language-flag:hover,
.language-flag.active {
    opacity: 1;
}

/* Language buttons - textové tlačítka */
.language-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm) var(--spacing-base);
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-decoration: none;
    color: var(--color-gray-400);
    background-color: transparent;
    border: none;
    cursor: pointer;
    transition: color var(--transition-fast);
    min-width: 48px;
    min-height: 44px;
}

.language-btn:hover {
    color: var(--color-gray-500);
}

.language-btn.active {
    color: var(--color-black);
}


/* Loading overlay */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(247, 247, 247, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.loading-content {
    background-color: var(--color-white);
    padding: var(--spacing-xl);
    border-radius: var(--radius-lg);
    text-align: center;
}

/* Loader - therapist photo */
.loading-therapist {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 1rem;
    position: relative;
    border: 5px solid #fff;
    box-shadow: 0 0 0 0 rgba(64, 134, 191, 0.0);
    animation: blueGlow 2.0s ease-in-out infinite;
}

/* Pulsující modrý glow (bez zelené) */
@keyframes blueGlow {
  0% {
    box-shadow: 0 0 0 0 rgba(64, 134, 191, 0.25);
    filter: drop-shadow(0 0 0 rgba(64, 134, 191, 0.0));
  }
  50% {
    box-shadow: 0 0 24px 12px rgba(64, 134, 191, 0.45);
    filter: drop-shadow(0 0 10px rgba(64, 134, 191, 0.35));
  }
  100% {
    box-shadow: 0 0 0 0 rgba(64, 134, 191, 0.0);
    filter: drop-shadow(0 0 0 rgba(64, 134, 191, 0.0));
  }
}

/* Loader message + fade */
.loading-message {
    font-size: 1.25rem;
    font-weight: 600;
    opacity: 1;
    transition: opacity 0.5s ease;
}

.loading-microcopy {
    font-size: 0.875rem;
    color: var(--color-gray-500);
    margin-top: 1rem;
}

.fade-out {
    opacity: 0;
}

.fade-in {
    opacity: 1;
}

/* Partial loader - for card sections */
.partial-loader {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.95);
    display: flex;
    justify-content: center;
    z-index: 50;
    border-radius: inherit;
}

.partial-loader .loading-content {
    padding: var(--spacing-lg);
}

/* Ensure card body has relative positioning for partial loader */
.card-body {
    position: relative;
}

/* Hide obsah card-body při slow loadingu, kromě stats a loader */
.card-body.loading-active > *:not(.stats-card):not(.partial-loader):not(#partialLoadingOverlay) {
    display: none !important;
}

/* Ensure loader area has reasonable height */
.card-body.loading-active {
    min-height: 400px;
}

/* Cancel button for slow analysis */
.cancel-analysis-btn {
    margin-top: 1rem;
    padding: 0.5rem 1rem;
    background: transparent;
    border: 1px solid var(--color-gray-300);
    color: var(--color-gray-500);
    font-size: 0.8rem;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.cancel-analysis-btn:hover {
    background: var(--color-gray-100);
    color: var(--color-gray-600);
    border-color: var(--color-gray-400);
}

.loading {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid var(--color-gray-300);
    border-radius: 50%;
    border-top-color: var(--color-primary);
    animation: spin 1s ease-in-out infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Skeleton loading states */
.stats-box.skeleton .stats-value {
    background: #e0e0e0;
    border-radius: 4px;
    height: 2.5rem;
    color: transparent;
    animation: skeleton-loading 1.5s infinite;
}

.stats-box.skeleton .stats-label {
    color: var(--color-gray-500);
}

.stats-box.fallback .stats-value {
    color: var(--color-gray-400);
    font-size: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 2.5rem;
}

@keyframes skeleton-loading {
    0% { background-color: #e0e0e0; }
    50% { background-color: #f0f0f0; }
    100% { background-color: #e0e0e0; }
}

/* Footer - vizuálně utlumený */
footer {
    opacity: 0.5;
    transition: opacity var(--transition-base);
}

footer:hover {
    opacity: 1;
}

/* Responsive design */
@media (max-width: 768px) {
    .container {
        padding: 0 var(--spacing-sm);
    }
    
    .grid-2,
    .grid-3,
    .grid-4 {
        grid-template-columns: 1fr;
    }
    
    .navbar-content {
        flex-direction: column;
        gap: var(--spacing-base);
    }
    
    .btn {
        min-height: 48px; /* Larger touch targets on mobile */
    }
    
    h1 {
        font-size: var(--font-size-2xl);
    }
    
    h2 {
        font-size: var(--font-size-xl);
    }
    
    .navbar-nav {
        gap: var(--spacing-lg);
    }
}

/* Utility classes */
.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.text-primary {
    color: var(--color-primary);
}

.text-accent {
    color: var(--color-accent);
}

.text-gray {
    color: var(--color-gray-500);
}

.text-small {
    font-size: var(--font-size-sm);
}

.mb-0 {
    margin-bottom: 0;
}

.mb-sm {
    margin-bottom: var(--spacing-sm);
}

.mb-base {
    margin-bottom: var(--spacing-base);
}

.mb-lg {
    margin-bottom: var(--spacing-lg);
}

.mt-lg {
    margin-top: var(--spacing-lg);
}

.hidden {
    display: none;
}

.block {
    display: block;
}

.inline-block {
    display: inline-block;
} 

.navbar-logo-img {
    max-height: 25px;
    width: auto;
    vertical-align: middle;
} 

/* Home2 split layout */
.home2-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: calc(100vh - 0px);
}

.home2-left {
    background: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.home2-left-inner {
    width: 100%;
    max-width: 520px;
    padding: 48px 32px;
}

.home2-logo {
    height: 38px;
    margin-bottom: 60px;
}

.home2-slogan {
    font-size: 25px;
    line-height: 1.05;
    color: var(--color-gray-500);
    margin-bottom: 20px;
    letter-spacing: -0.02em;
}

.home2-subtitle {
    font-size: 16px;
    color: var(--color-gray-500);
    margin-bottom: 20px;
}

.home2-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 8px;
}

.home2-input {
    height: 54px;
    border-radius: var(--radius-base);
    padding: 0 16px;
    font-size: 16px;
}

.home2-submit {
    height: 54px;
    font-weight: 600;
}

.home2-terms {
    font-size: 12px;
    color: var(--color-gray-400);
    margin-top: 8px;
}

.home2-footer {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 24px;
    width: 100%;
    max-width: 520px;
    padding: 0 32px;
    font-size: 12px;
    color: var(--color-gray-400);
}

.home2-footer a { color: var(--color-gray-400); }

/* Hide global footer on homepage-like pages */
.homepage-fix footer {
    display: none;
}

.home2-right {
    background: #f3f4f6;
    display: flex;
    flex-direction: column;
}

.home2-right-header {
    display: flex;
    justify-content: flex-end;
    padding: 16px 24px;
}

.language-switcher-inline .language-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    color: #374151;
    text-decoration: none;
    margin-left: 8px;
    font-weight: 600;
}

.language-switcher-inline .language-btn.active {
    background: var(--color-white);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.home2-carousel {
    flex: 1;
    display: grid;
    place-items: center;
    position: relative;
    overflow: hidden;
}

.home2-slide {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    opacity: 0;
    transform: translateX(20px) scale(0.98);
    transition: all 400ms ease;
}

.home2-slide.active {
    opacity: 1;
    transform: translateX(0) scale(1);
}

.home2-therapist {
    background: var(--color-white);
    border-radius: 16px;
    box-shadow: var(--shadow-lg);
    padding: 32px;
    max-width: 480px;
    text-align: center;
}

.home2-therapist-img {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 16px;
}

.home2-quote {
    font-size: 18px;
    color: #111827;
    margin-bottom: 8px;
}

.home2-name {
    font-size: 14px;
    color: #6b7280;
}

.home2-dots {
    position: absolute;
    bottom: 24px;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.home2-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    border: none;
    background: #d1d5db;
    cursor: pointer;
}

.home2-dot.active {
    background: var(--color-primary);
}

.home2-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 999px;
    border: none;
    background: transparent;
    color: #111827;
    font-size: 22px;
    line-height: 38px;
    text-align: center;
    cursor: pointer;
    box-shadow: none;
}

.home2-arrow-left { left: 16px; }
.home2-arrow-right { right: 16px; }

@media (max-width: 900px) {
    .home2-split {
        grid-template-columns: 1fr;
    }
    .home2-right-header {
        justify-content: flex-start;
        position: absolute;
        top: 8px;
        right: 8px;
        padding: 6px 10px;
        z-index: 1001;
        background: transparent;
    }
    /* Mobilní layout: menší horní mezera a přirozená výška karuselu podle obsahu */
    .home2-right { padding-top: 5px; min-height: auto; }
    .home2-carousel { min-height: auto; padding: 12px 16px 40px; }
    .home2-logo {margin-top: 40px;}
    /* Karuselové slidy nechť na mobilu určují výšku kontejneru */
    .home2-slide { position: relative; inset: auto; opacity: 1; transform: none; transition: none; display: none; }
    .home2-slide.active { display: grid; }
    /* Tečky pod karuselem do běžného toku stránky */
    .home2-dots { position: static; margin-top: 20px; }
    /* Menší šipky na mobilu */
    .home2-arrow { width: 32px; height: 32px; font-size: 18px; line-height: 30px; }
    /* Mobile: použij globální footer dole, lokální footer skryj */
    .home2-footer { display: none; }
    .homepage-fix footer { display: block; text-align: center;}
}

/* Homepage specific fixes */
.homepage-fix .navbar {
    margin-bottom: 0;
    border-bottom: none;
}
.homepage-fix .mb-lg {
    padding-top: 2em;
}
.homepage-fix .mb-sm {
    padding-top: 1em;
} 

.settings-container {
    max-width: 800px;
    margin: 2rem auto;
    padding: 0;
    background-color: transparent;
    border: none;
}

.onboarding-container {
    max-width: 800px;
    margin: 2rem auto;
    padding: 0 0 0rem 0; /* Velký padding dole kvůli floating tlačítku */
    background-color: transparent;
    border: none;
}

.settings-container h2 {
    margin-bottom: 2rem;
    text-align: left;
}

.onboarding-container h2 {
    margin-bottom: 1rem;
    text-align: center;
}

/* Větší odsazení pro první form-group v onboardingu */
.onboarding-container .first-form-group-onboarding {
    margin-top: 3rem !important;
}

.settings-container .card {
    background-color: #fff;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    margin-bottom: 2rem;
    overflow: hidden;
}



.settings-container .card-body {
    padding: 1.5rem;
}



/* Checkbox styling */
.settings-container .form-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-base);
}

.settings-container .form-checkbox input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin: 0;
    margin-top: 2px;
    border: 2px solid var(--color-gray-300);
    border-radius: var(--radius-sm);
    background-color: var(--color-white);
    cursor: pointer;
    appearance: none;
    position: relative;
    flex-shrink: 0;
}

.settings-container .form-checkbox input[type="checkbox"]:checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

.settings-container .form-checkbox input[type="checkbox"]:checked::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 12px;
    font-weight: bold;
}

.settings-container .form-checkbox label {
    cursor: pointer;
    font-weight: 500;
    margin-bottom: var(--spacing-xs);
}

.settings-container .form-checkbox .text-muted {
    font-size: var(--font-size-sm);
    color: var(--color-gray-500);
    margin: 0;
}


/* Therapist Selection */
.therapist-selection-container {
    margin-bottom: 2rem;
    text-align: center;
}

.therapist-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.therapist-card {
    background-color: #f9f9f9;
    border: 2px solid transparent;
    border-radius: var(--radius-lg);
    padding: 1.5rem 1rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    overflow: visible;
}

.therapist-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.therapist-card.selected {
    border-color: var(--color-primary);
    background-color: #f0f9f0;
    box-shadow: 0 6px 20px rgba(134, 191, 64, 0.2);
}

.therapist-card img {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    margin-bottom: 1rem;
    object-fit: cover;
    border: 3px solid #fff;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.therapist-card h4 {
    margin-bottom: 0.5rem;
    font-size: 1.1rem;
    color: var(--color-gray-600);
}

.therapist-card p {
    font-size: 0.9rem;
    color: var(--color-gray-500);
}

.therapist-emoji {
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    background: white;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    transition: all 0.3s ease;
    z-index: 10;

}

.therapist-card.selected .therapist-emoji {
    border-color: var(--color-primary);
    transform: translateX(-50%) scale(1.1);
}

.therapist-card:hover .therapist-emoji {
    transform: translateX(-50%) scale(1.05);
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* Personal Info Form */
.personal-info-form .form-group {
    margin-bottom: 1.5rem;
}

.personal-info-form .form-row {
    display: flex;
    gap: 1.5rem;
}

.personal-info-form .form-row .form-group {
    flex: 1;
}

/* Alert komponenty */
.alert {
    padding: var(--spacing-lg) var(--spacing-xl);
    border-radius: var(--radius-lg);
    border: none;
    margin-bottom: var(--spacing-lg);
    font-weight: 500;
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    box-shadow: var(--shadow-base);
    position: relative;
    overflow: hidden;
}

.alert::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 2px 0 0 2px;
}

/* Success alert - zelená */
.alert-success {
    background-color: #f0f9f0;
    color: #2d5a2d;
    border-left: 4px solid var(--color-primary);
}

.alert-success::before {
    background-color: var(--color-primary);
}

/* Error alert - růžová */
.alert-error,
.alert-danger {
    background-color: #fdf0f5;
    color: #6b2344;
    border-left: 4px solid var(--color-highlight);
}

.alert-error::before,
.alert-danger::before {
    background-color: var(--color-highlight);
}

/* Warning alert - oranžová */
.alert-warning {
    background-color: #fef8f0;
    color: #8b4513;
    border-left: 4px solid #ff8c00;
}

.alert-warning::before {
    background-color: #ff8c00;
}

/* Info alert - modrá */
.alert-info {
    background-color: #f0f6ff;
    color: #1e3a5f;
    border-left: 4px solid var(--color-accent);
}

.alert-info::before {
    background-color: var(--color-accent);
}

/* Alert ikony */
.alert-icon {
    flex-shrink: 0;
    margin-top: 2px;
    font-size: 18px;
}

.alert-success .alert-icon {
    color: var(--color-primary);
}

.alert-error .alert-icon,
.alert-danger .alert-icon {
    color: var(--color-highlight);
}

.alert-warning .alert-icon {
    color: #ff8c00;
}

.alert-info .alert-icon {
    color: var(--color-accent);
}

/* Alert content */
.alert-content {
    flex: 1;
}

.alert-title {
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-base);
}

.alert-message {
    margin: 0;
    line-height: 1.5;
}

/* Dismissible alerts */
.alert-dismissible {
    padding-right: 3rem;
}

.alert-close {
    position: absolute;
    top: var(--spacing-sm);
    right: var(--spacing-sm);
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    opacity: 0.5;
    transition: opacity var(--transition-fast);
    padding: var(--spacing-xs);
    border-radius: var(--radius-sm);
}

.alert-close:hover {
    opacity: 1;
    background-color: rgba(0, 0, 0, 0.1);
}

/* Compact alert variant */
.alert-compact {
    padding: var(--spacing-sm) var(--spacing-base);
    font-size: var(--font-size-sm);
}

.alert-compact .alert-icon {
    font-size: 16px;
}

/* Fixed Action Button */
.fixed-action-button-container {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(255,255,255,1) 70%, rgba(255,255,255,0));
    padding: 2rem;
    text-align: center;
    z-index: 100;
}

/* Animated Hero Background */
.hero-animated {
    background: linear-gradient(-45deg, #86BF40, #4086BF);
    background-size: 400% 400%;
    animation: gradient-flow 15s ease infinite;
    position: relative;
    overflow: hidden;
    will-change: background-position;
}

.hero-animated::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(45deg, 
        rgba(134, 191, 64, 0.1) 0%, 
        rgba(64, 134, 191, 0.1) 50%,
        rgba(134, 191, 64, 0.1) 100%);
    background-size: 200% 200%;
    animation: shimmer 20s ease-in-out infinite alternate;
    pointer-events: none;
}

@keyframes gradient-flow {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

@keyframes shimmer {
    0% {
        background-position: 0% 0%;
        opacity: 0.3;
    }
    50% {
        background-position: 100% 100%;
        opacity: 0.6;
    }
    100% {
        background-position: 0% 0%;
        opacity: 0.3;
    }
}

/* Hero floating particles */
.hero-particles {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
}

.hero-particles::before,
.hero-particles::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    animation: float 25s infinite linear;
}

.hero-particles::before {
    top: 20%;
    left: 20%;
    animation-delay: -5s;
    animation-duration: 20s;
}

.hero-particles::after {
    top: 60%;
    right: 20%;
    animation-delay: -15s;
    animation-duration: 30s;
    width: 30px;
    height: 30px;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0px) rotate(0deg);
        opacity: 0;
    }
    10%, 90% {
        opacity: 1;
    }
    50% {
        transform: translateY(-100px) rotate(180deg);
    }
}

/* Animace tlačítka Přihlášení synchronizovaná s hero */
.homepage-fix .btn-primary {
    background: linear-gradient(-45deg, #86BF40, #4086BF);
    background-size: 400% 400%;
    animation: gradient-flow 15s ease infinite;
    border: none;
    position: relative;
    overflow: hidden;
}

.homepage-fix .btn-primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.1);
    opacity: 0;
    transition: opacity 0.3s ease;
    border-radius: inherit;
}

.homepage-fix .btn-primary:hover::before {
    opacity: 1;
}

.homepage-fix .btn-primary:hover {
    filter: none;
    transform: translateY(-1px);
}

/* Animované CTA tlačítko v hero sekci */
.hero-cta-animated {
    background-color: white !important;
    background-image: none !important;
    border: none !important;
    font-weight: 700;
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.hero-cta-animated .btn-text {
    background: linear-gradient(-45deg, #86BF40, #4086BF);
    background-size: 400% 400%;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    animation: gradient-flow 15s ease infinite;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.1em;
    letter-spacing: 0.5px;
}

.hero-cta-animated .btn-arrow {
    background: linear-gradient(-45deg, #86BF40, #4086BF);
    background-size: 400% 400%;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    animation: gradient-flow 15s ease infinite;
    font-size: 18px;
    display: inline-block;
    transition: transform 0.3s ease;
    font-weight: 700;
}

.hero-cta-animated:hover .btn-arrow {
    transform: translateX(3px);
}

.hero-cta-animated:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}



/* Respektování předvoleb redukovaných animací */
@media (prefers-reduced-motion: reduce) {
    .hero-animated {
        animation: none;
        background: linear-gradient(-45deg, #86BF40, #4086BF);
    }
    
    .hero-animated::before {
        animation: none;
        opacity: 0.2;
    }
    
    .hero-particles::before,
    .hero-particles::after {
        animation: none;
        opacity: 0;
    }
    
    .homepage-fix .btn-primary {
        animation: none;
        background: var(--color-primary);
    }
    
    .hero-cta-animated .btn-text,
    .hero-cta-animated .btn-arrow {
        animation: none !important;
        background: #86BF40;
        background-clip: text;
        -webkit-background-clip: text;
        color: transparent;
    }
} 

:root {
    --altcha-border-radius: 10px;
    --altcha-color-base: #FFF;
    --altcha-color-border: #dfdfdf;
    --altcha-max-width: 260px;
  }

/* Therapist section redesign */
.therapist-section{display:grid;grid-template-columns:1fr 2fr;gap:2rem;align-items:flex-start;background:var(--color-gray-100);padding:1.5rem;border-radius:12px;margin-bottom:2rem;} 
.therapist-col1{display:flex;flex-direction:column;align-items:center;text-align:center;} 
.therapist-col2{display:flex;flex-direction:column;} 
.pros-cons-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;} 
.therapist-photo-lg{width:180px;height:180px;border-radius:50%;object-fit:cover;box-shadow:0 6px 12px rgba(0,0,0,.15);}
.speech-bubble{background:var(--color-white);border-radius:16px;padding:1rem 1.25rem 4rem;border:2px solid var(--color-gray-200);box-shadow:0 4px 12px rgba(0,0,0,.08);max-width:380px;margin-top:1rem;margin-bottom:1rem;text-align:left;} 
.bubble-centered{margin-left:auto;margin-right:auto;}
.speech-bubble::after{content:'';position:absolute;top:-12px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-bottom:12px solid var(--color-white);}
.grade-display{background:var(--color-primary);color:var(--color-white);border:3px solid var(--color-white);border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.75rem;box-shadow:0 4px 12px rgba(0,0,0,.25);} 
.pros-box,.cons-box{padding:1rem 1.25rem;border-radius:8px;}
.pros-box{background:rgba(134,191,64,0.12);border-left:4px solid var(--color-primary);}
.cons-box{background:rgba(191,64,134,0.12);border-left:4px solid var(--color-highlight);}
.pros-list li,.cons-list li{margin-bottom:0.35rem;list-style:none;color:var(--color-gray-600);} 
.pros-list li::before{content:'➕ ';color:var(--color-primary);} 
.cons-list li::before{content:'➖ ';color:var(--color-highlight);} 
.interesting-fact{background:#f0f8ff;padding:1rem 1.25rem;border-left:4px solid var(--color-accent);border-radius:8px;color:var(--color-accent);} 
.bubble-grade{text-align:center;margin-top:1rem;position:relative;} 
.grade-label{display:block;margin-bottom:0.5rem;} 
.grade-badge{width:80px;height:80px;font-size:1.75rem;position:absolute;left:50%;transform:translateX(-50%);bottom:-36px;} 
.grade-badge{background-color: var(--color-gray-400);color:var(--color-white);border-radius:50%;width:80px;height:80px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 12px rgba(0,0,0,.25);top:40px;font-size:2rem;font-weight: bold; } 
.gauge{position:relative;border-radius:50%;background:var(--color-gray-200);display:flex;align-items:center;justify-content:center;color:var(--color-black);} .gauge > div{pointer-events:none;} 
.gauge-ring{position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-family-heading);color:var(--color-gray-600);margin-top:-1rem;} 
.gauge-ring {
    --fill: var(--color-gray-400);
    --percent: 0%;
    background: conic-gradient(var(--fill) var(--percent), var(--color-gray-200) 0);
}

/* Uzavřený den – zelená vizualizace */
.day-closed .gauge-ring {
    --fill: var(--color-primary);
}

.day-closed .card {
    box-shadow: 0 0 10px rgba(0, 160, 0, 0.7);
    border-color: var(--color-success-500);
}

.gauge-ring::after{content:'';position:absolute;inset:12%;border-radius:50%;background:var(--color-white);} 
.gauge-content{position:relative;z-index:1;text-align:center;line-height:1.1;} 
.gauge-current{font-weight:700;} 
.gauge-ideal{font-size:0.7rem;color:var(--color-gray-500);} 
.gauge-label{position:absolute;bottom:-2.5rem;font-size:0.75rem;color:var(--color-gray-600);white-space:nowrap;width:100%;text-align:center;font-weight:700;text-transform:uppercase;padding:0.3rem 0;color:var(--color-gray-500);} 
.stats-gauges-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;width:100%;gap:1rem;} 
.gauge-big{margin-top:0;} 
.gauge-big-box{background:var(--color-gray-300);padding:1.5rem 1.5rem 3rem 1.5rem;border-radius:20px;display:flex;align-items:center;justify-content:center;} 
.stats-card{background:var(--color-gray-100);padding:1.5rem;border-radius:12px;margin-top:2rem;} 
.stats-gauges-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;width:100%;gap:1rem;} 
.gauge-ring.skeleton{background:var(--color-gray-200) !important;position:relative;overflow:hidden;} 
.gauge-ring.skeleton::after{content:'';position:absolute;inset:0;border-radius:50%;background:linear-gradient(90deg,#f0f0f0 25%,#e6e6e6 50%,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-flow 1.2s ease-in-out infinite;} 
.gauge-ring.skeleton .gauge-content{visibility:hidden;} 
@keyframes skeleton-flow{0%{background-position:200% 0}100%{background-position:-200% 0}} 

.meal-table tbody tr{border-bottom:1px solid var(--color-gray-200);}
.meal-table tbody tr.meal-sep {border-bottom:1px solid var(--color-gray-400);} 
.meal-table thead th{padding:1rem;text-align:left;border-bottom:1px solid var(--color-gray-400);font-weight:600;background:var(--color-gray-100);} 

@media (max-width: 600px){
  /* Utility: hide on small screens */
  .mobile-hide{display:none !important;}
  
  /* Therapist detail: stack boxes vertically on mobile */
  .therapist-section{grid-template-columns:1fr;}
  .therapist-col2{margin-top:1rem;}
  .pros-cons-grid{grid-template-columns:1fr;}
  .speech-bubble{max-width:100%;}
  
  /* Add/Edit Food modal – fullscreen and keyboard-safe on mobile */
  #addFoodModal .modal-card{
    position: fixed !important;
    inset: 0 !important;
    transform: none !important;
    width: 100% !important;
    height: 100dvh;
    max-width: none !important;
    max-height: none !important;
    border-radius: 0 !important;
    padding: 16px 16px max(16px, env(safe-area-inset-bottom));
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  #addFoodModal .modal-card > form{
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1 1 auto;
    min-height: 0;
  }
  #addFoodModal .modal-card .form-group{
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
  }
  #addFoodModal .modal-card .form-textarea{
    flex: 1 1 auto;
    min-height: 220px;
  }
  #addFoodModal .modal-card .modal-actions{
    position: sticky;
    bottom: 0;
    background: #fff;
    padding-top: 12px;
    padding-bottom: max(12px, env(safe-area-inset-bottom));
    box-shadow: 0 -6px 16px rgba(0,0,0,0.06);
  }

  /* Day actions: center and stack */
  .day-actions{flex-direction:column; align-items:center !important;}
  .day-actions .actions-row{justify-content:center;}
  .day-actions .day-time-meta{margin-left:0 !important; text-align:center;}
  /* Utility: hide on small screens */
  .mobile-hide{display:none !important;}
  
  /* Therapist detail: stack boxes vertically on mobile */
  .therapist-section{grid-template-columns:1fr;}
  .therapist-col2{margin-top:1rem;}
  .pros-cons-grid{grid-template-columns:1fr;}
  .speech-bubble{max-width:100%;}
  /* Mobile top navigation: full width grid of large icon buttons */
  .navbar-nav{
    width:100%;
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(64px, 1fr));
    gap:8px;
    overflow:visible;
  }
  .navbar-nav::-webkit-scrollbar{display:none;}

  /* Only icons on mobile */
  .navbar .nav-label{display:none;}

  /* Bigger touch targets */
  .navbar-nav .navbar-link,
  .navbar-nav .btn{
    justify-content:center;
    padding:14px 0;
    min-height:56px;
    border-radius:12px;
  }
  .navbar .nav-icon{width:28px;height:28px;}

  /* Gauge row horizontal scroll */
  .stats-gauges-row{flex-wrap:nowrap !important;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .stats-gauges-row>*{flex:0 0 auto;}
  .stats-card{overflow-x:hidden;}
} 