@import url(https://fonts.googleapis.com/css2?family=Raleway:wght@300;400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Monda:wght@400;700&display=swap);:root{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#f0f2f5;--text-primary:#0b1672;--text-secondary:#666;--text-tertiary:#999;--text-inverse:#fff;--color-coral:#f1664a;--color-peach:#fcded7;--color-blue:#84a5f2;--color-navy:#0b1672;--color-orange:#fea367;--color-white:#fff;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--font-heading:"Arial Black","Arial",sans-serif;--font-body:"Raleway","Segoe UI",sans-serif;--font-mono:"Courier New",monospace;--fs-xs:12px;--fs-sm:14px;--fs-base:16px;--fs-lg:18px;--fs-xl:20px;--fs-2xl:24px;--fs-3xl:28px;--fs-4xl:32px;--fs-5xl:36px;--lh-tight:1.2;--lh-normal:1.5;--lh-relaxed:1.8;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:20px;--spacing-2xl:24px;--spacing-3xl:32px;--spacing-4xl:40px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px #0b16720d;--shadow-md:0 4px 12px #0b16721a;--shadow-lg:0 8px 24px #0b167226;--shadow-xl:0 12px 32px #0b167233;--media-path:"/media";--transition-fast:150ms ease-in-out;--transition-base:250ms ease-in-out;--transition-slow:350ms ease-in-out;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070}[data-theme=dark]{--bg-primary:#040a3a;--bg-secondary:#1b2894;--bg-tertiary:#253499;--text-primary:#fff;--text-secondary:#e0e0e0;--text-tertiary:#b0b0b0;--text-inverse:#0b1672;--color-coral:#ff7d66;--color-peach:#ffa89f;--color-blue:#84a5f2;--color-navy:#fff;--color-orange:#fea367;--color-white:#040a3a;--color-success:#34d399;--color-warning:#fbbf24;--color-error:#f87171;--color-info:#60a5fa;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 24px #0006;--shadow-xl:0 12px 32px #00000080}:root{--gradient-warm:linear-gradient(135deg,#fea367,#f1664a);--gradient-sky:linear-gradient(135deg,#fcded7,#84a5f2);--gradient-sunset:linear-gradient(180deg,#84a5f2,#fcded7 50%,#fea367)}[data-theme=dark]{--gradient-warm:linear-gradient(135deg,#ff7d66,#ff6a54);--gradient-sky:linear-gradient(135deg,#84a5f2,#6b8fe6);--gradient-sunset:linear-gradient(180deg,#84a5f2,#7b9fec 50%,#ff7d66)}body{background-color:#fff;background-color:var(--bg-primary);font-family:Raleway,Segoe UI,sans-serif;font-family:var(--font-body);font-size:16px;font-size:var(--fs-base);line-height:1.5;line-height:var(--lh-normal);transition:background-color .25s ease-in-out,color .25s ease-in-out;transition:background-color var(--transition-base),color var(--transition-base)}body,h1,h2,h3,h4,h5,h6{color:#0b1672;color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-family:Arial Black,Arial,sans-serif;font-family:var(--font-heading);font-weight:700;line-height:1.2;line-height:var(--lh-tight)}h1{font-size:36px;font-size:var(--fs-5xl)}h2{font-size:32px;font-size:var(--fs-4xl)}h3{font-size:28px;font-size:var(--fs-3xl)}h4{font-size:24px;font-size:var(--fs-2xl)}h5{font-size:20px;font-size:var(--fs-xl)}h6{font-size:18px;font-size:var(--fs-lg)}p{color:#0b1672;color:var(--text-primary);margin:0}a{color:#f1664a;color:var(--color-coral);text-decoration:none;transition:color .15s ease-in-out;transition:color var(--transition-fast)}a:hover{color:#fea367;color:var(--color-orange);text-decoration:underline}.text-primary{color:#0b1672;color:var(--text-primary)}.text-secondary{color:#666;color:var(--text-secondary)}.text-coral{color:#f1664a;color:var(--color-coral)}.text-blue{color:#84a5f2;color:var(--color-blue)}.text-orange{color:#fea367;color:var(--color-orange)}.bg-light{background-color:#fff;background-color:var(--bg-primary)}.bg-secondary{background-color:#f8f9fa;background-color:var(--bg-secondary)}.shadow-sm{box-shadow:0 1px 2px #0b16720d;box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:0 4px 12px #0b16721a;box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:0 8px 24px #0b167226;box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:0 12px 32px #0b167233;box-shadow:var(--shadow-xl)}.rounded-sm{border-radius:4px;border-radius:var(--radius-sm)}.rounded-md{border-radius:8px;border-radius:var(--radius-md)}.rounded-lg{border-radius:12px;border-radius:var(--radius-lg)}.rounded-xl{border-radius:16px;border-radius:var(--radius-xl)}.transition-fast{transition:all .15s ease-in-out;transition:all var(--transition-fast)}.transition-base{transition:all .25s ease-in-out;transition:all var(--transition-base)}.transition-slow{transition:all .35s ease-in-out;transition:all var(--transition-slow)}.ticket-card{aspect-ratio:1/1.4;background-position:50%;background-repeat:no-repeat;background-size:cover;background:linear-gradient(135deg,var(--color-peach) 0,var(--color-blue) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);color:var(--text-primary);display:flex;flex-direction:column;font-family:var(--font-body);min-height:450px;overflow:hidden;padding:var(--spacing-2xl);position:relative;transition:all var(--transition-base)}.ticket-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}[data-theme=dark] .ticket-card{background:linear-gradient(135deg,var(--color-blue) 0,var(--color-navy) 100%);box-shadow:var(--shadow-lg)}[data-theme=dark] .ticket-card:hover{box-shadow:var(--shadow-xl)}.ticket-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg)}.ticket-card__status{color:var(--color-coral);font-size:var(--fs-xs);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.ticket-card__status--available{color:var(--color-success)}.ticket-card__status--locked{color:var(--color-warning)}.ticket-card__status--completed{color:var(--color-coral)}.ticket-card__price{color:var(--color-coral);line-height:1}.ticket-card__price,.ticket-card__title{font-family:var(--font-heading);font-size:var(--fs-2xl);font-weight:700}.ticket-card__title{color:var(--text-primary);line-height:var(--lh-tight);margin:var(--spacing-md) 0}.ticket-card__description{color:var(--text-secondary);flex-grow:1;font-family:var(--font-body);font-size:var(--fs-sm);line-height:var(--lh-normal);margin-bottom:var(--spacing-lg)}.ticket-card__divider{border-top:2px dashed #0b16724d;margin:var(--spacing-xl) 0}[data-theme=dark] .ticket-card__divider{border-top-color:#ffffff4d}.ticket-card__lessons{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.ticket-card__lesson{align-items:center;background-color:#84a5f21a;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:var(--fs-sm);gap:var(--spacing-md);padding:var(--spacing-md);transition:background-color var(--transition-fast)}.ticket-card__lesson:hover{background-color:#84a5f233}[data-theme=dark] .ticket-card__lesson{background-color:#84a5f226}.ticket-card__lesson-number{align-items:center;background:var(--color-blue);border-radius:var(--radius-full);color:#fff;display:flex;font-family:var(--font-heading);font-size:var(--fs-xs);font-weight:600;height:28px;justify-content:center;min-width:28px;width:28px}.ticket-card__lesson-title{color:var(--text-primary);flex:1 1}.ticket-card__lesson-icon{align-items:center;display:flex;font-size:var(--fs-lg);height:24px;justify-content:center;width:24px}.ticket-card__button{background:var(--color-coral);border:none;border-radius:var(--radius-lg);box-shadow:0 2px 8px #f1664a4d;color:#fff;cursor:pointer;font-family:var(--font-heading);font-size:var(--fs-base);font-weight:600;letter-spacing:.5px;margin-top:auto;padding:var(--spacing-lg) var(--spacing-2xl);text-transform:uppercase;transition:all var(--transition-fast)}.ticket-card__button:hover{background:var(--color-orange);box-shadow:0 4px 12px #f1664a66;transform:translateY(-1px)}.ticket-card__button:active{transform:translateY(0)}[data-theme=dark] .ticket-card__button{box-shadow:0 2px 8px #fea36766}.btn{align-items:center;border-radius:var(--radius-lg);display:inline-flex;font-family:var(--font-body);font-size:var(--fs-base);gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all var(--transition-fast)}.btn-primary{background-color:var(--color-coral);box-shadow:var(--shadow-md)}.btn-primary:hover{background-color:var(--color-orange);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:var(--color-blue)}.btn-secondary:hover{background-color:#6b8fe6}.btn-outline{background-color:initial;border:2px solid var(--color-coral);color:var(--color-coral)}.btn-outline:hover{background-color:var(--color-coral);color:#fff}.card{background-color:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--spacing-2xl);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg)}.card__header{border-bottom:1px solid #0b16721a;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg)}[data-theme=dark] .card__header{border-bottom-color:#ffffff1a}.card__title{font-family:var(--font-heading);font-size:var(--fs-xl);font-weight:700;margin:0}.card__subtitle{color:var(--text-secondary);font-size:var(--fs-sm);margin-top:var(--spacing-sm)}.card__body{margin-bottom:var(--spacing-lg)}.card__footer{border-top:1px solid #0b16721a;display:flex;gap:var(--spacing-lg);padding-top:var(--spacing-lg)}[data-theme=dark] .card__footer{border-top-color:#ffffff1a}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--fs-xs);font-weight:600;gap:var(--spacing-xs);letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-md);text-transform:uppercase}.badge-primary{background-color:#f1664a1a;color:var(--color-coral)}.badge-success{background-color:#10b9811a;color:var(--color-success)}.badge-warning{background-color:#f59e0b1a;color:var(--color-warning)}.header{background:var(--gradient-sky);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);color:#fff;padding:var(--spacing-3xl) var(--spacing-2xl);text-align:center}.header__title{font-family:var(--font-heading);font-size:var(--fs-5xl);font-weight:700;margin:0 0 var(--spacing-md) 0;text-shadow:0 2px 4px #0003}.header__subtitle{font-size:var(--fs-lg);font-weight:400;margin:0;opacity:.95}.progress{background-color:var(--bg-tertiary);height:8px;overflow:hidden;width:100%}.progress,.progress__bar{border-radius:var(--radius-full)}.progress__bar{background:var(--gradient-warm);height:100%;transition:width var(--transition-base)}@media (max-width:768px){.ticket-card{aspect-ratio:auto;min-height:auto;padding:var(--spacing-lg)}.ticket-card__title{font-size:var(--fs-xl)}.btn{width:100%}.card__footer{flex-direction:column}}@media (max-width:480px){.ticket-card{padding:var(--spacing-md)}.ticket-card__header{flex-direction:column;gap:var(--spacing-md)}.ticket-card__title{font-size:var(--fs-lg)}h1{font-size:var(--fs-3xl)}h2{font-size:var(--fs-2xl)}}.block-card{background:linear-gradient(180deg,#fff,#fdfdfe 60%,#fafafd);border:none;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;height:420px;min-height:420px;min-width:300px;overflow:hidden;position:relative;scroll-snap-align:start;scroll-snap-stop:always;transition:transform var(--transition-fast);width:300px}.block-card.completed{background:linear-gradient(180deg,#ecfdf5f2,#f0fcf7fa 60%,#f3fbf8)}.block-card.purchased{background:linear-gradient(180deg,#e3f2fdf2,#f0f8fffa 60%,#f5faff)}.block-card.available{background:linear-gradient(180deg,#fff7edf2,#fffaf3fa 60%,#fffcf8)}.block-card.locked{background:linear-gradient(180deg,#f5f5f5f2,#fafafafa 60%,#fff);opacity:.8}.block-card--compact{height:350px!important;max-height:350px!important;max-width:250px!important;width:250px!important}.block-header{border-bottom:1px solid #00000014;margin-bottom:4px;padding:6px 12px}.block-header h3{color:#0b1672;font-family:Monda,sans-serif;font-size:16px;font-weight:600;line-height:1.2;margin:0}.block-content{display:flex;flex:1 1;flex-direction:column;justify-content:flex-start;min-height:0;padding:0 12px 4px;position:relative}.block-info{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;margin-bottom:8px}.block-reward{display:flex;flex-direction:column;gap:2px}.reward-value{color:#0b1672;font-family:Monda,sans-serif;font-size:18px;font-weight:700}.grant-block{align-items:center;background:linear-gradient(135deg,#ffc10726,#ff980026);border:1px solid #ffc10766;border-radius:6px;bottom:200px;box-shadow:0 1px 4px #ffc10726;display:flex;gap:4px;left:12px;padding:3px 8px;position:absolute;right:12px}.grant-icon{flex-shrink:0;font-size:16px;line-height:1}.grant-content{align-items:center;display:flex;flex:1 1;justify-content:space-between}.grant-label{color:#0b1672b3;font-family:Raleway,sans-serif;font-size:8px;font-weight:600;letter-spacing:.2px;line-height:1.1;text-transform:uppercase}.grant-value{color:#ff9800;font-family:Monda,sans-serif;font-size:14px;font-weight:700;line-height:1;white-space:nowrap}.block-status-inline{align-items:flex-start;display:flex;justify-content:flex-end}.block-status{background-color:#0000000d;border:none;border-radius:6px;color:#0b1672;cursor:pointer;font-family:Raleway,sans-serif;font-size:12px;font-weight:600;padding:6px 12px;text-transform:uppercase;transition:all var(--transition-fast);white-space:nowrap}.block-status.available{background-color:#f1664a;color:#fff}.block-status.available:hover{background-color:#e04c35;transform:scale(1.05)}.block-status.available:disabled{cursor:not-allowed;opacity:.6}.block-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#0b1672;display:block;display:-webkit-box;font-family:Raleway,sans-serif;font-size:13px;line-height:1.4;margin:8px 0;max-height:60px;overflow:hidden;text-overflow:ellipsis}.lessons-section{background:#ffffff4d;border:2px solid #84a5f2;border-radius:8px;bottom:4px;flex:0 0 auto;height:180px;left:12px;overflow:hidden;position:absolute;right:12px}.lessons-list{display:flex;flex-direction:column;gap:2px;height:100%;overflow-x:hidden;overflow-y:auto;padding:4px}.program-lesson-item{background:#ffffff80;border:1px solid #84a5f24d;border-radius:4px;color:#0b1672;cursor:pointer;flex-shrink:0;font-family:Raleway,sans-serif;font-size:12px;font-weight:500;overflow:hidden;padding:8px 10px;text-overflow:ellipsis;transition:all var(--transition-fast);white-space:nowrap}.program-lesson-item.completed{background-color:#4caf5026;border-color:#4caf5066;color:#2e7d32}.program-lesson-item.locked{background-color:#9e9e9e1a;border-color:#9e9e9e4d;color:#757575;cursor:not-allowed;opacity:.6}.program-lesson-item.clickable:hover{background-color:#84a5f21a;border-color:#84a5f299}.lesson-title{display:block}@media (max-width:768px){.block-card{height:392px;max-height:392px;max-width:280px;min-width:280px;width:280px}.block-card--compact{height:350px!important;max-height:350px!important;max-width:250px!important;min-width:250px!important;width:250px!important}}@media (max-width:480px){.block-card{height:442px;max-height:442px;max-width:316px;min-width:316px;width:316px}.block-card--compact{height:408px!important;max-height:408px!important;max-width:292px!important;min-width:292px!important;width:292px!important}}:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#2563eb;--primary-600:#1d4ed8;--primary-700:#1e40af;--primary-800:#1e3a8a;--primary-900:#1e3a8a;--secondary-50:#f5f3ff;--secondary-100:#ede9fe;--secondary-200:#ddd6fe;--secondary-300:#c4b5fd;--secondary-400:#a78bfa;--secondary-500:#7c3aed;--secondary-600:#6d28d9;--secondary-700:#5b21b6;--secondary-800:#4c1d95;--secondary-900:#3b0764;--brand-primary:var(--primary-500);--brand-primary-hover:var(--primary-600);--brand-secondary:var(--secondary-500);--brand-secondary-hover:var(--secondary-600);--brand-accent:#ff7a59;--brand-accent-hover:#e76647;--brand-sand:#f2e9da;--wanderlust-gradient:linear-gradient(135deg,#2563eb,#7c3aed);--gradient-ocean:linear-gradient(135deg,#2563eb,#38bdf8);--gradient-sunset:linear-gradient(135deg,#ff7a59,#fb923c);--gradient-lagoon:linear-gradient(135deg,#2dd4bf,#22d3ee);--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--success-50:#ecfdf5;--success-500:#10b981;--success-600:#059669;--warning-50:#fffbeb;--warning-500:#f59e0b;--warning-600:#d97706;--error-50:#fef2f2;--error-500:#ef4444;--error-600:#dc2626;--info-50:#eff6ff;--info-500:#0ea5e9;--info-600:#2563eb;--icon-success:#10b981;--icon-error:#ef4444;--icon-warning:#f59e0b;--icon-info:#0ea5e9;--icon-muted:#737373;--icon-color:currentColor;--icon-gradient-success:linear-gradient(135deg,#10b981,#059669);--icon-gradient-error:linear-gradient(135deg,#ef4444,#dc2626);--icon-gradient-warning:linear-gradient(135deg,#f59e0b,#d97706);--icon-gradient-primary:var(--wanderlust-gradient);--icon-glow-color:var(--primary-500);--icon-glow-intensity:8px;--gradient-primary:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);--gradient-toolbar:linear-gradient(180deg,#fff 0%,var(--gray-50) 100%);--gradient-dropdown-header:linear-gradient(180deg,var(--gray-50) 0%,var(--gray-100) 100%);--gradient-divider:linear-gradient(90deg,#0000 0%,var(--gray-200) 50%,#0000 100%);--shadow-soft:0 1px 3px #0000000d;--shadow-medium:0 4px 6px #00000012;--shadow-large:0 10px 15px #0000001a;--shadow-primary:0 4px 12px #6366f14d;--elevation-1:0 1px 2px #0000000f,0 0 0 1px #00000005;--elevation-2:0 2px 8px #00000014,0 1px 0 #ffffff4d inset;--elevation-3:0 8px 24px #0000001f;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--transition-fast:0.15s ease;--transition-normal:0.2s ease;--transition-slow:0.3s ease;--transition-emphasis:200ms cubic-bezier(0.2,0.8,0.2,1);--font-h1:32px;--font-h2:24px;--font-h3:18px;--font-body:16px;--font-caption:13px}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{color:#1f2937}h1,h2,h3,h4,h5,h6{color:#111827;color:var(--gray-900);letter-spacing:.01em;line-height:1.4}:focus{outline:none}:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary-500);outline-offset:2px}::placeholder{color:#9ca3af;color:var(--gray-400);opacity:1}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100);border-radius:3px}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--gray-400)}@media(prefers-color-scheme: dark),[data-theme=dark]{:root:not([data-theme=light]){--gray-50:#1f2937;--gray-100:#374151;--gray-200:#4b5563;--gray-300:#6b7280;--gray-400:#9ca3af;--gray-500:#d1d5db;--gray-600:#e5e7eb;--gray-700:#f3f4f6;--gray-800:#f9fafb;--gray-900:#fff;--dark-icon-color:#f1f5f9;--dark-icon-muted:#94a3b8;--icon-color:var(--dark-icon-color);--icon-muted:var(--dark-icon-muted);--dark-bg:#0f172a;--dark-surface:#1e293b;--dark-elevated:#334155;--dark-text-primary:#f1f5f9;--dark-text-secondary:#94a3b8;--gradient-ocean:linear-gradient(135deg,#3b82f6,#22d3ee);--gradient-sunset:linear-gradient(135deg,#fb7185,#f59e0b);--gradient-lagoon:linear-gradient(135deg,#22d3ee,#14b8a6)}}.icon{display:inline-block;flex-shrink:0;vertical-align:middle}.icon-sm{height:16px;width:16px}.icon-md{height:24px;width:24px}.icon-lg{height:32px;width:32px}.icon-xl{height:40px;width:40px}.icon-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:1rem;gap:8px;line-height:1.5;padding:8px 16px;transition:all var(--transition-normal)}.icon-button:hover{background:var(--gray-100);color:var(--brand-primary)}.icon-button:active{transform:scale(.98)}.icon-button:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.icon-button.primary{background:var(--brand-primary);color:#fff}.icon-button.primary:hover{background:var(--brand-primary-hover)}.icon-button.secondary{background:#0000;border:1px solid var(--brand-primary);color:var(--brand-primary)}.icon-button.secondary:hover{background:var(--primary-50)}.icon-spin{animation:icon-spin 1s linear infinite}@keyframes icon-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.icon-pulse{animation:icon-pulse 2s ease-in-out infinite}@keyframes icon-pulse{0%,to{opacity:1}50%{opacity:.5}}.icon-bounce{animation:icon-bounce .6s ease}@keyframes icon-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.icon-success{animation:icon-success .6s ease;color:var(--icon-success)}@keyframes icon-success{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.icon-error{animation:icon-shake .5s ease;color:var(--icon-error)}@keyframes icon-shake{0%,to{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}.icon-glow:hover{filter:drop-shadow(0 0 8px currentColor);transition:filter var(--transition-normal)}@media(prefers-color-scheme: dark),[data-theme=dark] .icon-button{:root:not([data-theme=light]) .icon-button{color:var(--dark-icon-color)}:root:not([data-theme=light]) .icon-button:hover{background:var(--dark-surface);color:var(--brand-primary)}}.icon-button:focus,.icon:focus{border-radius:var(--radius-sm);outline:2px solid var(--brand-primary);outline-offset:2px}.icon-button:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.icon-gradient-wanderlust{-webkit-text-fill-color:#0000;background:var(--wanderlust-gradient);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 2px 4px rgba(37,99,235,.3))}.icon-gradient-success{-webkit-text-fill-color:#0000;background:var(--icon-gradient-success);-webkit-background-clip:text;background-clip:text}.icon-gradient-error{-webkit-text-fill-color:#0000;background:var(--icon-gradient-error);-webkit-background-clip:text;background-clip:text}.icon-gradient-warning{-webkit-text-fill-color:#0000;background:var(--icon-gradient-warning);-webkit-background-clip:text;background-clip:text}.icon-glow-soft{filter:drop-shadow(0 0 4px currentColor)}.icon-glow-medium,.icon-glow-soft{transition:filter var(--transition-normal)}.icon-glow-medium{filter:drop-shadow(0 0 8px currentColor)}.icon-glow-intense{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 24px currentColor);transition:filter var(--transition-normal)}.icon-glow-pulse{animation:icon-glow-pulse 2s ease-in-out infinite}@keyframes icon-glow-pulse{0%,to{filter:drop-shadow(0 0 4px currentColor)}50%{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 24px currentColor)}}.icon-3d{perspective:1000px;transform-style:preserve-3d;will-change:transform}.icon-3d-lift{transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.icon-3d-lift:hover{box-shadow:0 8px 16px #00000026,0 0 20px #2563eb4d;transform:translateY(-4px) translateZ(10px)}.icon-3d-rotate{transition:transform var(--transition-normal)}.icon-3d-rotate:hover{transform:rotateY(10deg) rotateX(-5deg)}.icon-particles{position:relative;will-change:transform,opacity}.icon-particles:after,.icon-particles:before{animation:icon-particles-float 3s ease-in-out infinite;background:currentColor;border-radius:50%;content:"";height:4px;opacity:.6;pointer-events:none;position:absolute;width:4px}.icon-particles:before{animation-delay:0s;left:50%;top:-8px}.icon-particles:after{animation-delay:1.5s;bottom:-8px;right:50%}.icon-particles-intense:after,.icon-particles-intense:before{animation:icon-particles-float 2s ease-in-out infinite;opacity:.8}@keyframes icon-particles-float{0%,to{opacity:.6;transform:translate(0) scale(1)}50%{opacity:.2;transform:translate(20px,-20px) scale(1.5)}}.icon-idle-breathe{animation:icon-breathe 3s ease-in-out infinite}@keyframes icon-breathe{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.02)}}.icon-idle-pulse{animation:icon-idle-pulse 2s ease-in-out infinite}@keyframes icon-idle-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.icon-idle-glow{animation:icon-idle-glow 2.5s ease-in-out infinite}@keyframes icon-idle-glow{0%,to{filter:drop-shadow(0 0 4px currentColor)}50%{filter:drop-shadow(0 0 10px currentColor) drop-shadow(0 0 20px currentColor)}}.icon-hover-lift{transition:transform var(--transition-normal);will-change:transform}.icon-hover-lift:hover{transform:translateY(-4px)}.icon-hover-scale{transition:transform var(--transition-normal);will-change:transform}.icon-hover-scale:hover{transform:scale(1.15)}.icon-hover-rotate{transition:transform var(--transition-normal);will-change:transform}.icon-hover-rotate:hover{transform:rotate(5deg) scale(1.05)}.icon-hover-combo{transition:transform var(--transition-normal),filter var(--transition-normal);will-change:transform,filter}.icon-hover-combo:hover{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 24px currentColor);transform:translateY(-4px) scale(1.1) rotate(2deg)}.icon-gradient-shift{animation:icon-gradient-shift 3s ease infinite;background-size:200% 200%}@keyframes icon-gradient-shift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.icon,.icon-3d-lift,.icon-hover-combo,.icon-hover-lift,.icon-hover-rotate,.icon-hover-scale,.icon-particles{-webkit-font-smoothing:subpixel-antialiased;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}@media(prefers-color-scheme: dark),[data-theme=dark] .icon-glow-intense,[data-theme=dark] .icon-glow-medium,[data-theme=dark] .icon-glow-soft{:root:not([data-theme=light]) .icon-glow-soft{filter:drop-shadow(0 0 6px currentColor)}:root:not([data-theme=light]) .icon-glow-medium{filter:drop-shadow(0 0 12px currentColor)}:root:not([data-theme=light]) .icon-glow-intense{filter:drop-shadow(0 0 16px currentColor) drop-shadow(0 0 32px currentColor)}:root:not([data-theme=light]) .icon-particles:after,:root:not([data-theme=light]) .icon-particles:before{opacity:.9}}.icon-action-hover{transition:transform var(--transition-normal),filter var(--transition-normal);will-change:transform,filter}.icon-action-hover:hover{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 24px currentColor);transform:translateY(-4px)}.icon-action-click{transition:transform var(--transition-fast)}.icon-action-click:active{animation:icon-action-bounce .4s ease}@keyframes icon-action-bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.1)}}.icon-destructive-hover{transition:transform var(--transition-normal),filter var(--transition-normal);will-change:transform,filter}.icon-destructive-hover:hover{animation:icon-destructive-shake .5s ease;filter:drop-shadow(0 0 12px #EF4444) drop-shadow(0 0 24px #EF4444)}@keyframes icon-destructive-shake{0%,to{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}.icon-destructive-click:active{animation:icon-destructive-bounce .3s ease}@keyframes icon-destructive-bounce{0%,to{transform:scale(1)}50%{transform:scale(.9)}}.icon-destructive-idle{animation:icon-destructive-pulse-warn 3s ease-in-out infinite}@keyframes icon-destructive-pulse-warn{0%,to{filter:drop-shadow(0 0 4px rgba(239,68,68,.5))}50%{filter:drop-shadow(0 0 8px rgba(239,68,68,.8))}}.icon-success-hover{transition:transform var(--transition-normal),filter var(--transition-normal);will-change:transform,filter}.icon-success-hover:hover{filter:drop-shadow(0 0 12px #10B981) drop-shadow(0 0 24px #10B981);transform:scale(1.15)}.icon-success-click:active{animation:icon-success-explosion .5s ease}@keyframes icon-success-explosion{0%{transform:scale(1)}30%{transform:scale(1.3)}to{transform:scale(1)}}.icon-success-idle{animation:icon-success-glow 2.5s ease-in-out infinite}@keyframes icon-success-glow{0%,to{filter:drop-shadow(0 0 4px rgba(16,185,129,.5))}50%{filter:drop-shadow(0 0 10px rgba(16,185,129,.8))}}.icon-loading-spin{animation:icon-spin 1s linear infinite}.icon-loading-dots,.icon-loading-dots:after,.icon-loading-dots:before{animation:icon-dots-pulse 1.4s ease-in-out infinite}@keyframes icon-dots-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.25)}}.icon-navigation-hover{transition:transform var(--transition-normal),opacity var(--transition-normal);will-change:transform,opacity}.icon-navigation-hover:hover{opacity:1;transform:translateX(2px)}.icon-navigation-active{filter:drop-shadow(0 0 8px currentColor);opacity:1}.icon-media-hover{transition:transform var(--transition-normal),filter var(--transition-normal);will-change:transform,filter}.icon-media-hover:hover{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 24px currentColor);transform:scale(1.15) rotate(5deg)}.icon-media-click{position:relative}.icon-media-click:active:before{animation:icon-media-ripple .6s ease;background:currentColor;border-radius:50%;content:"";height:0;left:50%;opacity:.5;position:absolute;top:50%;transform:translate(-50%,-50%);width:0}@keyframes icon-media-ripple{0%{height:0;opacity:.5;width:0}to{height:40px;opacity:0;width:40px}}.icon-action-hover,.icon-destructive-hover,.icon-media-hover,.icon-navigation-hover,.icon-success-hover{-webkit-font-smoothing:subpixel-antialiased;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}@media (prefers-reduced-motion:reduce){.icon-action-hover:hover,.icon-bounce,.icon-destructive-hover:hover,.icon-destructive-idle,.icon-error,.icon-glow-pulse,.icon-gradient-shift,.icon-idle-breathe,.icon-idle-glow,.icon-idle-pulse,.icon-loading-dots,.icon-loading-spin,.icon-particles:after,.icon-particles:before,.icon-pulse,.icon-spin,.icon-success,.icon-success-hover:hover,.icon-success-idle{animation:none}.icon-3d-lift,.icon-3d-rotate,.icon-action-hover,.icon-button,.icon-destructive-hover,.icon-hover-combo,.icon-hover-lift,.icon-hover-rotate,.icon-hover-scale,.icon-media-hover,.icon-navigation-hover,.icon-success-hover{transition:none}.icon-action-hover:hover,.icon-destructive-hover:hover,.icon-hover-combo:hover,.icon-hover-lift:hover,.icon-hover-rotate:hover,.icon-hover-scale:hover,.icon-media-hover:hover,.icon-navigation-hover:hover,.icon-success-hover:hover{transform:none}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(1200px 600px at 100% -10%,#22d3ee14,#22d3ee00 60%),radial-gradient(1000px 500px at -10% 0,#2563eb0f,#2563eb00 60%),linear-gradient(180deg,#fff 0,var(--gray-100) 100%);color:var(--gray-800);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0;padding-top:64px}#root,body,html{-webkit-overflow-scrolling:touch;box-sizing:border-box;max-width:100%;overflow-x:hidden;overflow-y:auto;width:100%}#root{min-height:100vh}@media (max-width:768px){body{padding-top:56px}#root,body,html{max-width:100%;overflow-x:hidden;width:100%}}@media (prefers-color-scheme:dark){body:not([data-theme=light]){background:radial-gradient(1000px 500px at 110% -10%,#3b82f61a,#3b82f600 60%),radial-gradient(800px 400px at -10% 0,#22d3ee14,#22d3ee00 60%),linear-gradient(180deg,var(--dark-bg),var(--dark-elevated));color:var(--dark-text-primary)}}h1{font-size:32px;font-size:var(--font-h1,32px);line-height:1.2}h1,h2{font-weight:700}h2{font-size:24px;font-size:var(--font-h2,24px);line-height:1.25}h3{font-size:18px;font-size:var(--font-h3,18px);font-weight:600;line-height:1.3}button,input,li,p{font-size:16px;font-size:var(--font-body,16px)}.caption,small{font-size:13px;font-size:var(--font-caption,13px)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.error-boundary{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:400px;padding:var(--spacing-2xl)}.error-boundary__content{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-width:500px;padding:var(--spacing-3xl);text-align:center;width:100%}.error-boundary__icon{color:var(--color-error);height:64px;margin:0 auto var(--spacing-xl);width:64px}.error-boundary__icon svg{height:100%;width:100%}.error-boundary__title{color:var(--text-primary);font-family:var(--font-heading);font-size:var(--fs-2xl);font-weight:700;margin:0 0 var(--spacing-md) 0}.error-boundary__message{color:var(--text-secondary);font-family:var(--font-body);font-size:var(--fs-base);line-height:var(--lh-relaxed);margin:0 0 var(--spacing-2xl) 0}.error-boundary__details{background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--fs-xs);margin:var(--spacing-xl) 0;padding:var(--spacing-lg);text-align:left}.error-boundary__details summary{color:var(--text-primary);cursor:pointer;font-weight:600;margin-bottom:var(--spacing-sm)}.error-boundary__stack{background:var(--bg-primary);border-radius:var(--radius-sm);font-size:var(--fs-xs);line-height:var(--lh-normal);margin:var(--spacing-md) 0 0 0;overflow-x:auto;padding:var(--spacing-md);white-space:pre-wrap;word-break:break-word}.error-boundary__actions{display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:center}.error-boundary__button{border:none;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-body);font-size:var(--fs-sm);font-weight:600;min-height:40px;padding:var(--spacing-md) var(--spacing-xl);transition:all var(--transition-fast)}.error-boundary__button--primary{background:var(--gradient-warm);box-shadow:0 4px 12px #f1664a33;color:var(--text-inverse)}.error-boundary__button--primary:hover{box-shadow:0 6px 16px #f1664a4d;transform:translateY(-2px)}.error-boundary__button--secondary{background:var(--color-blue);box-shadow:0 4px 12px #84a5f233;color:var(--text-inverse)}.error-boundary__button--secondary:hover{background:#6a8fe8;box-shadow:0 6px 16px #84a5f24d;transform:translateY(-2px)}.error-boundary__button:focus-visible{outline:2px solid var(--color-coral);outline-offset:2px}@media (max-width:768px){.error-boundary{min-height:300px;padding:var(--spacing-lg)}.error-boundary__content{padding:var(--spacing-xl)}.error-boundary__icon{height:48px;margin-bottom:var(--spacing-lg);width:48px}.error-boundary__title{font-size:var(--fs-xl)}.error-boundary__message{font-size:var(--fs-sm)}.error-boundary__actions{flex-direction:column}.error-boundary__button{width:100%}}.user-profile-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:90%}.modal-header{background:#f8f9fa;border-bottom:2px solid #e9ecef;padding:20px 24px}.modal-header h3{color:#1e88e5;font-size:20px}.modal-header-actions{align-items:center;display:flex;gap:12px}.copy-all-btn{align-items:center;background:linear-gradient(135deg,#1e88e5,#1565c0);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.copy-all-btn:hover{box-shadow:0 2px 8px #1e88e54d;transform:translateY(-1px)}.close-btn{background:#0000;padding:4px;transition:color .2s ease}.profile-content{flex:1 1;overflow-y:auto;padding:24px}.profile-section{margin-bottom:32px}.profile-section:last-child{margin-bottom:0}.profile-section h4{border-bottom:2px solid #e9ecef;color:#1e88e5;font-size:18px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.profile-field{align-items:flex-start;border-bottom:1px solid #f0f0f0;display:flex;gap:16px;padding:12px 0}.profile-field:last-child{border-bottom:none}.profile-label{color:#666;flex-shrink:0;font-size:14px;font-weight:600;min-width:180px}.profile-value{flex:1 1;word-break:break-word}.profile-value,.profile-value.clickable{color:#333;font-size:14px;position:relative}.profile-value.clickable{background:#0000;border:none;border-radius:4px;cursor:pointer;font-family:inherit;padding:4px 8px;text-align:left;transition:all .2s ease;width:100%}.profile-value.clickable:hover{background:#f0f7ff;color:#1e88e5}.profile-value.clickable:focus{outline:2px solid #1e88e5;outline-offset:2px}.copy-indicator{animation:fadeIn .2s ease;background:#10b981;border-radius:4px;color:#fff;font-size:12px;padding:4px 8px;position:absolute;right:-120px;top:50%;transform:translateY(-50%);white-space:nowrap}.profile-avatar{border:2px solid #e9ecef;border-radius:50%;height:60px;margin-top:4px;object-fit:cover;width:60px}.modal-overlay{padding:20px}@media (max-width:768px){.user-profile-modal{max-height:95vh;width:95%}.modal-header{flex-wrap:wrap;padding:16px}.modal-header h3{font-size:16px;margin-bottom:8px;width:100%}.modal-header-actions{justify-content:space-between;width:100%}.profile-content{padding:16px}.profile-field{flex-direction:column;gap:8px}.profile-label{min-width:auto}.copy-indicator{display:inline-block;margin-top:4px;position:static;transform:none}}.users-management{box-sizing:border-box;padding:2px 8px 20px;width:100%}.users-header{margin-bottom:8px;padding:0}.users-header h1{align-items:center;color:#1e88e5;display:flex;font-size:24px;font-weight:700;gap:10px;margin:0}.refresh-button{align-items:center;background:linear-gradient(135deg,#1e88e5,#1565c0);border-radius:8px;color:#fff;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.refresh-button:hover{box-shadow:0 4px 12px #1e88e54d;transform:translateY(-2px)}.users-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.admin-stat-card{background:#fff;border-left:4px solid #1e88e5;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center}.admin-stat-card h3{color:#666;font-size:14px;font-weight:500;margin:0 0 10px}.stat-number{color:#1e88e5;font-size:32px;font-weight:700}.users-table-container{background:#fff;border-radius:0;box-shadow:none;margin:0;overflow:visible;width:100%}.users-table{border-collapse:collapse;width:100%}.users-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#333;font-weight:600;padding:8px 12px;text-align:left}.users-table th.balance-header{text-align:right}.users-table tbody{display:table-row-group}.users-table tbody tr:first-child td{padding-top:0}.users-table td{border-bottom:1px solid #e9ecef;padding:12px;vertical-align:middle}.users-table td.balance-cell-td{max-width:100px;text-align:right;width:100px}.users-table th.balance-header-cell{max-width:100px;width:100px}.users-table td.payments-cell-td,.users-table th.payments-header-cell{max-width:120px;width:120px}.col-status{text-align:center;width:72px}.status-indicator{border-radius:50%;display:inline-block;height:12px;vertical-align:middle;width:12px}.status-indicator.active{background-color:#10b981;box-shadow:0 0 0 2px #10b98133}.status-indicator.inactive{background-color:#ef4444;box-shadow:0 0 0 2px #ef444433}.col-date{width:160px}.inline-select{background:#fff;border:1px solid #ddd;border-radius:6px;font-size:11px;max-width:110px;min-width:90px;padding:4px 6px}.muted{color:#aaa}.users-table tr:hover{background:#f8f9fa}.user-info{display:flex;flex-direction:column;gap:4px}.user-name{color:#333;font-size:14px;font-weight:600}.user-email{color:#666;font-size:12px}.role-select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 8px}.balance-cell{align-items:center;color:#ff9800;display:flex;gap:8px;justify-content:flex-end;text-align:right}.balance-amount{color:#ff9800;font-size:14px;font-weight:600}.balance-amount-admin{color:#ff9800!important;font-size:14px;font-weight:600}.edit-balance-btn{align-items:center;background:#ff9800;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:12px;justify-content:center;padding:4px 8px;transition:all .2s ease}.edit-balance-btn svg{color:#fff!important;display:block!important;flex-shrink:0;height:18px!important;opacity:1!important;pointer-events:none;visibility:visible!important;width:18px!important}.edit-balance-btn svg,.edit-balance-btn svg path,.edit-balance-btn svg rect{stroke:#fff!important;fill:none!important}.edit-balance-btn:hover{background:#f57c00;transform:scale(1.05)}.status-badge{border-radius:12px;font-size:12px;font-weight:600;padding:4px 8px;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.action-buttons{display:flex;flex-wrap:nowrap;gap:4px;justify-content:center}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;height:28px;justify-content:center;min-width:32px;padding:4px 8px;transition:all .2s ease}.action-btn svg{display:block;flex-shrink:0;height:18px;width:18px}.action-btn.edit{background:#ff9800;color:#fff}.action-btn.edit:hover{background:#f57c00;transform:translateY(-1px)}.action-btn.block{background:#ffebee;color:#d32f2f}.action-btn.block:hover{background:#ffcdd2;transform:translateY(-1px)}.action-btn.block svg,.action-btn.block svg *{stroke:#d32f2f!important;fill:none!important;color:#d32f2f!important}.action-btn.unblock{background:#e8f5e8;color:#2e7d32}.action-btn.unblock:hover{background:#c8e6c9;transform:translateY(-1px)}.action-btn.unblock svg,.action-btn.unblock svg *{stroke:#2e7d32!important;fill:none!important;color:#2e7d32!important}.action-btn.delete{background:#fce4ec;color:#c2185b}.action-btn.delete:hover{background:#f8bbd9;transform:translateY(-1px)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.close-btn{align-items:center;border-radius:50%;display:flex;height:30px;justify-content:center;padding:0;transition:all .2s ease;width:30px}.close-btn:hover{background:#f8f9fa}.modal-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.user-display{background:#f8f9fa;border-radius:6px;color:#666;font-size:14px;padding:12px}.balance-input{border:1px solid #ddd;border-radius:6px;font-size:16px;font-weight:600;padding:12px;width:100%}.currency{color:#666;font-weight:600;margin-left:8px}.reason-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:12px;width:100%}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;padding:20px}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-primary{background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #1e88e54d;transform:translateY(-1px)}.users-management-error,.users-management-loading{align-items:center;color:#666;display:flex;flex-direction:column;font-size:16px;justify-content:center;min-height:300px;padding:40px 20px;text-align:center}.users-management-error{background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#dc3545;margin:20px}.users-management-error:before{content:"⚠️ ";font-size:24px;margin-bottom:10px}.users-cards-container{display:none}@media (max-width:768px){.users-management{margin:0;max-width:100%;padding:0;width:100%}.users-management,.users-management *{box-sizing:border-box}.users-header h1{font-size:18px}.users-header h1 svg{height:20px;width:20px}.table-totals-row .total-cell{font-size:11px;padding:4px 6px}.refresh-button{font-size:13px;justify-content:center;padding:8px 12px}.refresh-button,.users-stats{box-sizing:border-box;max-width:100%;width:100%}.users-stats{gap:8px;grid-template-columns:1fr;margin-bottom:12px;margin-left:0;margin-right:0}.admin-stat-card{box-sizing:border-box;max-width:100%;padding:10px;width:100%}.admin-stat-card h3{font-size:12px;margin-bottom:8px}.stat-number{font-size:24px}.users-table-container{display:none!important}.users-cards-container{display:flex!important;gap:8px;padding:0}.mobile-user-card,.users-cards-container{box-sizing:border-box;flex-direction:column;margin:0;max-width:100%;width:100%}.mobile-user-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:10px;padding:12px}.mobile-card-header{align-items:flex-start;border-bottom:1px solid #e9ecef;display:flex;gap:8px;justify-content:space-between;padding-bottom:8px}.mobile-user-info{align-items:flex-start;display:flex;flex:1 1;gap:10px;min-width:0}.mobile-user-name{color:#333;font-size:15px;font-weight:600;line-height:1.3;margin-bottom:2px;word-break:break-word}.mobile-user-name a{color:#1e88e5;text-decoration:none}.mobile-user-email{color:#666;font-size:12px;line-height:1.3;word-break:break-all}.mobile-card-indicators{display:flex;flex-shrink:0;gap:4px}.mobile-card-content{display:flex;flex-direction:column;gap:8px}.mobile-card-row{align-items:center;display:flex;gap:8px;justify-content:space-between}.mobile-label{color:#666;flex-shrink:0;font-size:12px;font-weight:600}.mobile-value{color:#333;font-size:13px;text-align:right}.mobile-card-actions{border-top:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:8px;padding-top:8px}.mobile-action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:6px;justify-content:center;min-width:120px;padding:8px 12px;transition:all .2s ease}.mobile-action-btn.unblock{background:#d1fae5;color:#065f46}.mobile-action-btn.block{background:#fee2e2;color:#991b1b}.mobile-action-btn.delete{background:#fef3c7;color:#92400e}.user-card-header{align-items:center;border-bottom:1px solid #e9ecef;box-sizing:border-box;display:flex;gap:6px;justify-content:space-between;margin-bottom:2px;padding-bottom:6px;width:100%}.user-card-header-left{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.user-card-info{flex:1 1;min-width:0}.user-card-name{color:#333;font-size:14px;font-weight:600;line-height:1.3;margin-bottom:2px;word-break:break-word}.user-card-email{color:#666;font-size:11px;line-height:1.3;word-break:break-all}.user-card-field{box-sizing:border-box;display:flex;flex-direction:column;gap:4px;max-width:100%;width:100%}.user-card-field-compact{flex:1 1;gap:3px}.user-card-row{box-sizing:border-box;display:flex;gap:8px;width:100%}.user-card-field-label{color:#666;font-size:10px;font-weight:600;letter-spacing:.3px;line-height:1.2;text-transform:uppercase}.user-card-field-value{color:#333;font-size:12px;line-height:1.3}.user-card-actions{border-top:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:6px;margin-top:2px;padding-top:6px}.analytics-panel{grid-gap:8px!important;display:grid!important;gap:8px!important;grid-template-columns:repeat(2,1fr)!important;margin-bottom:12px!important;padding:12px!important}.analytics-item{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;padding:8px!important}.analytics-label{font-size:10px!important;margin-bottom:4px}.analytics-value{font-size:16px!important}.filters-panel{display:flex;flex-direction:column;gap:8px!important;margin-bottom:12px!important}.filter-select,.search-input{font-size:14px!important;max-width:100%!important;padding:10px 12px!important;width:100%!important}.pagination{align-items:stretch!important;flex-direction:column;gap:12px!important}.pagination-info{font-size:13px!important;text-align:center}.pagination-controls{gap:8px!important;justify-content:center}.pagination-btn{font-size:13px!important;padding:8px 12px!important}.user-card-actions .inline-select,.user-card-actions .role-select{box-sizing:border-box;font-size:12px;max-width:100%;min-width:0;padding:6px;width:100%}.user-card-actions .balance-cell{align-items:center;box-sizing:border-box;display:flex;justify-content:space-between;max-width:100%;padding:0;width:100%}.user-card-actions .balance-cell .edit-balance-btn{flex-shrink:0}.user-card-actions .balance-amount-admin{flex:1 1;font-size:12px;min-width:0;word-break:break-word}.user-card-actions .action-buttons{gap:4px;justify-content:flex-end;margin-top:0;width:100%}.user-card-actions .edit-balance-btn{align-items:center;display:inline-flex;font-size:11px;justify-content:center;padding:4px 6px}.user-card-actions .edit-balance-btn svg{stroke:#fff!important;fill:none!important;color:#fff!important;display:block!important;flex-shrink:0;height:16px!important;opacity:1!important;pointer-events:none;visibility:visible!important;width:16px!important}.user-card-actions .action-btn{align-items:center;display:inline-flex;font-size:11px;height:24px;justify-content:center;min-width:28px;padding:4px 6px}.user-card-actions .action-btn svg{display:block!important;flex-shrink:0;height:16px!important;opacity:1!important;pointer-events:none;visibility:visible!important;width:16px!important}.user-card-actions .action-btn.block svg{color:#d32f2f!important}.user-card-actions .action-btn.block svg,.user-card-actions .action-btn.block svg path,.user-card-actions .action-btn.block svg rect{stroke:#d32f2f!important;fill:none!important}.user-card-actions .action-btn.unblock svg{color:#2e7d32!important}.user-card-actions .action-btn.unblock svg,.user-card-actions .action-btn.unblock svg circle,.user-card-actions .action-btn.unblock svg path{stroke:#2e7d32!important;fill:none!important}.user-card-actions .action-btn.delete svg{color:#c2185b!important}.user-card-actions .action-btn.delete svg,.user-card-actions .action-btn.delete svg path{stroke:#c2185b!important;fill:none!important}.modal{margin:10px;max-width:95%;width:95%}.modal-body,.modal-footer,.modal-header{padding:15px}.modal-header h3{font-size:16px}.form-group label{font-size:13px}.btn{font-size:14px;padding:10px 20px}}.current-balance{background:#f8f9fa;border-radius:6px;color:#495057;font-weight:600;margin-top:8px;padding:8px 12px}.operation-type{display:flex;gap:20px;margin-top:8px}.radio-label{align-items:center;color:#495057;cursor:pointer;display:flex;font-weight:500;gap:8px}.radio-label input[type=radio]{cursor:pointer;margin:0}.radio-label:hover{color:#1e88e5}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.user-info-modal{background:#f8f9fa;border-left:4px solid #1e88e5;border-radius:8px;margin:15px 0;padding:15px}.user-info-modal strong{color:#333;font-size:16px}.user-info-modal .user-email{color:#666;font-size:14px;margin-top:5px}.btn-danger{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s}.btn-danger:hover{background:#c82333;transform:translateY(-1px)}.close-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:20px;padding:5px;transition:all .2s}.close-btn:hover{background:#f5f5f5;color:#333}.users-table-container{position:relative}.users-table thead{background:#f8f9fa;position:relative}.users-table thead tr:not(.filters-row):not(.table-totals-row){background:#f8f9fa;box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:48px;z-index:10}.users-table thead tr:not(.filters-row):not(.table-totals-row) th{background:#f8f9fa}.users-table th{cursor:pointer;-webkit-user-select:none;user-select:none}.users-table th:hover{background:#e9ecef}.filters-row{background:#f8f9fa;box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:11}.filters-cell{background:#f8f9fa;border-bottom:1px solid #dee2e6;padding:6px 12px!important}.table-filters{align-items:center;display:flex;gap:8px}.table-filters .search-input{flex:1 1;min-width:200px}.table-filters .filter-select,.table-filters .search-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:13px;height:28px;padding:4px 8px}.table-filters .filter-select{background:#fff;cursor:pointer;min-width:120px}.table-totals-row{background:#f8f9fa;border-top:2px solid #dee2e6;position:-webkit-sticky;position:sticky;top:88px;z-index:9}.table-totals-row .total-cell{background:#f8f9fa;border-bottom:1px solid #dee2e6;color:#666;font-size:12px;font-weight:600;padding:6px 8px;text-align:center}.table-totals-row .total-cell:first-child{text-align:left}.analytics-panel{background:#f8f9fa;border-radius:8px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:16px;padding:16px}.analytics-item{display:flex;flex-direction:column;gap:4px}.analytics-label{color:#666;font-size:12px;font-weight:500}.analytics-value{color:#1e88e5;font-size:18px;font-weight:700}.user-cell{align-items:center;display:flex;gap:8px}.activity-indicator{border-radius:50%;cursor:help;flex-shrink:0;height:10px;width:10px}.user-info-wrapper{flex:1 1;min-width:0}.user-name-link{color:#1e88e5;font-size:14px;font-weight:600;text-decoration:none}.user-name-link:hover{text-decoration:underline}.user-indicators{align-items:center;display:flex;gap:4px;margin-top:4px}.problem-indicator{border-radius:50%;cursor:help;display:inline-block;height:8px;width:8px}.history-icon-btn{background:none;border:none;cursor:pointer;font-size:14px;opacity:.6;padding:2px 4px;transition:opacity .2s}.history-icon-btn:hover{opacity:1}.role-cell{padding:8px!important;text-align:center;width:62px}.role-btn{align-items:center;border:2px solid;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;min-width:32px;padding:6px 10px;transition:all .2s;width:32px}.role-btn:hover{box-shadow:0 2px 4px #0003;transform:translateY(-1px)}.assignment-cell{max-width:90px;min-width:90px;padding:8px!important;width:90px}.assignment-wrapper{align-items:center;display:flex;width:100%}.assignment-select{background:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;cursor:pointer;font-size:11px;max-width:100%;padding:4px 6px;width:100%}.assignment-select:hover{border-color:#1e88e5}.assignment-empty{color:#999;display:block;text-align:center}.role-assignment-dropdown{background:#f8f9fa;border-radius:6px;display:flex;flex-direction:column;gap:8px;margin-top:8px;padding:8px}.curator-select-dropdown,.role-select-dropdown,.tutor-select-dropdown{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;padding:6px 8px}.date-cell-compact{color:#666;font-size:11px;max-width:70px;min-width:70px;white-space:nowrap;width:70px}.tests-cell{color:#333!important;font-size:13px;font-weight:600;text-align:center}.balance-btn,.payments-btn,.purchases-btn{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;padding:4px 10px;transition:all .2s}.balance-btn{background:#ff9800;color:#fff}.balance-btn:hover{background:#f57c00}.payments-btn{background:#4caf50;color:#fff}.payments-btn:hover{background:#45a049}.purchases-btn{background:#2196f3;color:#fff}.purchases-btn:hover{background:#1976d2}.action-buttons-compact{display:flex;flex-wrap:nowrap;gap:4px;justify-content:center}.actions-modal,.notes-modal,.payments-modal,.purchases-modal{max-height:80vh;max-width:600px;overflow-y:auto}.action-item,.note-item,.payment-item,.purchase-item{background:#f8f9fa;border-left:3px solid #1e88e5;border-radius:6px;margin-bottom:10px;padding:12px}.action-header,.note-header,.payment-header,.purchase-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.action-type,.note-author,.payment-amount,.purchase-title{color:#333;font-weight:600}.action-date,.note-date,.payment-date,.purchase-date{color:#666;font-size:12px}.note-text{color:#555;line-height:1.5}.action-admin{color:#666;font-size:12px;margin-bottom:8px}.action-details{background:#fff;border-radius:4px;color:#555;font-size:12px;overflow-x:auto;padding:8px}.action-details pre{font-family:Courier New,monospace;font-size:11px;margin:0}.payment-description,.purchase-status{color:#666;font-size:13px}.note-input-wrapper{display:flex;flex-direction:column;gap:8px;margin-top:16px}.note-input-wrapper textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;padding:8px;resize:vertical;width:100%}.note-input-wrapper button{align-self:flex-end;background:#1e88e5;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:background .2s}.note-input-wrapper button:hover{background:#1565c0}.empty-state{color:#999;font-style:italic;padding:40px;text-align:center}.actions-list,.payments-list,.purchases-list{max-height:60vh;overflow-y:auto}.chat-list,.chat-list-loading{display:flex;flex-direction:column;height:100%}.chat-list-loading{align-items:center;color:#6c757d;justify-content:center}.loading-spinner{border:4px solid #f3f3f3;height:40px;margin-bottom:16px;width:40px}.chat-list-empty{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.chat-list-empty h3{color:#495057;margin:0 0 8px}.chat-list-empty p{font-size:14px;margin:0 0 20px}.chat-list-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.chat-list-header h3{color:#333;font-size:16px;margin:0}.refresh-button{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:18px;padding:4px;transition:all .2s ease}.refresh-button:hover{background:#e9ecef;color:#495057}.chat-list-content{flex:1 1;overflow-y:auto}.chat-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;padding:12px 16px;transition:background-color .2s ease}.chat-item:hover{background:#f8f9fa}.chat-item.unread{background:#e3f2fd;border-left:3px solid #2196f3}.chat-item-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:44px;justify-content:center;margin-right:10px;overflow:hidden;width:44px}.chat-item-avatar img{border-radius:50%;height:100%;object-fit:cover;width:100%}.chat-item-content{flex:1 1;min-width:0}.chat-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.chat-item-name{color:#333;font-size:14px;font-weight:600}.chat-item-time{color:#6c757d;font-size:12px;white-space:nowrap}.chat-item-message{align-items:center;display:flex;justify-content:space-between}.message-preview{color:#6c757d;flex:1 1;font-size:13px;margin-right:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-indicator{align-items:center;background:#f44;border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:20px;justify-content:center;min-width:20px}@media (max-width:768px){.chat-item{padding:12px 16px}.chat-item-avatar{font-size:16px;height:40px;margin-right:10px;width:40px}.chat-item-name{font-size:13px}.message-preview{font-size:12px}.chat-list-header{padding:12px 16px}.chat-list-header h3{font-size:14px}}.message-input{background:#fff;border-top:1px solid #e0e0e0;padding:16px 20px}.attachments-preview{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.attachment-preview{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;font-size:12px;max-width:200px;padding:8px 12px}.attachment-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.attachment-name{color:#333;font-weight:500;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-size{color:#6c757d;font-size:11px}.remove-attachment{align-items:center;background:none;border:none;border-radius:50%;color:#dc3545;cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;margin-left:8px;padding:0;transition:background-color .2s ease;width:20px}.remove-attachment:hover{background:#f8d7da}.message-input-container{align-items:flex-end;background:#f8f9fa;border:1px solid #e9ecef;border-radius:20px;display:flex;gap:8px;padding:8px 12px;transition:border-color .2s ease}.message-input-container:focus-within{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.attach-button,.send-button{align-items:center;background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:32px;justify-content:center;padding:4px;transition:all .2s ease;width:32px}.attach-button:hover,.send-button:hover{background:#e9ecef;color:#495057}.send-button:disabled{color:#adb5bd;cursor:not-allowed}.send-button:not(:disabled){color:#667eea}.send-button:not(:disabled):hover{background:#667eea;color:#fff}.message-textarea{background:#0000;border:none;color:#333;flex:1 1;font-family:inherit;font-size:14px;line-height:1.4;max-height:120px;min-height:20px;outline:none;overflow-y:auto;resize:none}.message-textarea::placeholder{color:#6c757d}.message-textarea:disabled{color:#adb5bd;cursor:not-allowed}@media (max-width:768px){.message-input{padding:12px 16px}.attachment-preview{font-size:11px;max-width:150px;padding:6px 10px}.message-input-container{padding:6px 10px}.attach-button,.send-button{font-size:16px;height:28px;width:28px}.message-textarea{font-size:13px}}.message-item{display:flex;flex-direction:column;margin-bottom:8px;max-width:70%}.message-item.own{align-items:flex-end;align-self:flex-end}.message-item.other{align-items:flex-start;align-self:flex-start}.message-sender{color:#6c757d;font-size:12px;font-weight:500;margin-bottom:4px}.message-sender.role-USER{color:#6c757d}.message-sender.role-PARTNER{color:#6f42c1;opacity:.8}.message-sender.role-TUTOR{color:#20c997;opacity:.8}.message-sender.role-CURATOR{color:#fd7e14;opacity:.8}.message-sender.role-SUPERADMIN{color:#dc3545;opacity:.8}.message-content{word-wrap:break-word;position:relative}.message-text{background:#e9ecef;border-radius:18px;color:#333;font-size:14px;line-height:1.4;max-width:100%;padding:12px 16px}.message-item.own .message-text{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom-right-radius:4px;color:#fff}.message-item.other .message-text{background:#e9ecef;border-bottom-left-radius:4px;color:#333}.message-image{background:#e9ecef;border-radius:18px;max-width:300px;overflow:hidden}.message-item.own .message-image{background:linear-gradient(135deg,#667eea,#764ba2)}.message-image-content{display:block;height:auto;max-height:200px;object-fit:cover;width:100%}.message-image-caption{background:#ffffffe6;color:#333;font-size:14px;padding:8px 12px}.message-item.own .message-image-caption{background:#0003;color:#fff}.message-audio{background:#e9ecef;border-radius:18px;max-width:300px;padding:8px 12px}.message-item.own .message-audio{background:linear-gradient(135deg,#667eea,#764ba2)}.message-audio-content{height:32px;width:100%}.message-audio-caption{color:#333;font-size:14px;margin-top:4px}.message-item.own .message-audio-caption{color:#fff}.message-attachments{display:flex;flex-direction:column;gap:8px;margin-top:8px}.message-attachment{background:#f8f9fa;border-radius:12px;max-width:200px;overflow:hidden}.attachment-image{height:auto;max-height:150px;object-fit:cover;width:100%}.attachment-audio{height:32px;width:100%}.message-meta{align-items:center;color:#6c757d;display:flex;font-size:11px;gap:4px;margin-top:4px}.message-item.own .message-meta{justify-content:flex-end}.message-time{font-size:11px}.message-status{color:#6c757d;font-size:12px}.message-item.own .message-status{color:#4caf50}@media (max-width:768px){.message-item{max-width:85%}.message-text{font-size:13px;padding:10px 14px}.message-audio,.message-image{max-width:250px}.message-attachment{max-width:150px}.attachment-image{max-height:120px}}.message-list{display:flex;flex-direction:column;gap:12px;padding:16px 20px}.message-list-loading{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:100%;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:32px;margin-bottom:12px;width:32px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.message-list-empty{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.message-list-empty p{font-size:14px;margin:0}@media (max-width:768px){.message-list{gap:10px;padding:12px 16px}.message-list-empty{padding:30px 16px}.empty-icon{font-size:40px}}.chat-room-view{display:flex;flex-direction:column;height:100%}.chat-room-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:16px 20px}.chat-room-header,.chat-room-info,.tutor-avatar{align-items:center;display:flex}.tutor-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;margin-right:12px;overflow:hidden;width:40px}.tutor-avatar img{border-radius:50%;height:100%;object-fit:cover;width:100%}.tutor-details{flex:1 1}.tutor-name{color:#333;font-size:14px;font-weight:600;margin-bottom:2px}.tutor-status{color:#6c757d;font-size:12px}.tutor-status:contains("печатает"){color:#2196f3;font-style:italic}.back-button{align-items:center;background:#e9ecef;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.back-button:hover{background:#dee2e6;color:#495057}.chat-room-content{background:#fafafa;flex:1 1;overflow-y:auto;position:relative}.chat-room-input{background:#fff;border-top:1px solid #e0e0e0}@media (max-width:768px){.chat-room-header{padding:12px 16px}.tutor-avatar{font-size:14px;height:36px;margin-right:10px;width:36px}.tutor-name{font-size:13px}.tutor-status{font-size:11px}.back-button{font-size:14px;height:28px;width:28px}}.chat-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1001}.chat-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;height:80vh;max-height:600px;max-width:800px;overflow:hidden;width:100%}.chat-modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:16px 20px}.chat-modal-title{color:#333;font-size:18px;font-weight:600}.chat-modal-actions{align-items:center;display:flex;gap:8px}.back-button,.close-button{align-items:center;background:#e9ecef;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.back-button:hover,.close-button:hover{background:#dee2e6;color:#495057}.close-button{background:#dc3545;color:#fff}.close-button:hover{background:#c82333}.chat-modal-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}@media (max-width:768px){.chat-modal-overlay{padding:10px}.chat-modal{border-radius:8px;height:90vh;max-height:none}.chat-modal-header{border-radius:8px 8px 0 0;padding:12px 16px}.chat-modal-title{font-size:16px}.back-button,.close-button{font-size:16px;height:28px;width:28px}}@media (max-width:480px){.chat-modal-overlay{padding:0}.chat-modal{height:100vh}.chat-modal,.chat-modal-header{border-radius:0}}.chat-widget{bottom:20px;position:fixed;right:20px;z-index:1000}.chat-widget-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 20px #00000026;color:#fff;cursor:pointer;display:flex;font-size:24px;height:60px;justify-content:center;position:relative;transition:all .3s ease;width:60px}.chat-widget-button:hover{box-shadow:0 6px 25px #0003;transform:translateY(-2px)}.chat-widget-button.connected{background:linear-gradient(135deg,#4caf50,#45a049)}.chat-widget-button.disconnected{background:linear-gradient(135deg,#f44336,#d32f2f)}.chat-icon{font-size:24px}.unread-badge{align-items:center;animation:pulse 1.5s infinite;background:#f44;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;min-width:20px;position:absolute;right:-5px;top:-5px}.connection-indicator{animation:blink 1s infinite;font-size:16px;left:-5px;position:absolute;top:-5px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@media (max-width:768px){.chat-widget{bottom:15px;right:15px}.chat-widget-button{font-size:20px;height:50px;width:50px}.chat-icon{font-size:20px}}.nav-container{background:#84a5f2;border-bottom:1px solid #ffffff1a;box-shadow:0 4px 20px #84a5f24d,inset 0 1px 0 #ffffff1a;height:64px;justify-content:space-between;left:0;padding:0 1rem;position:fixed;right:0;top:0;z-index:1000}.nav-container,.nav-left{align-items:center;display:flex}.nav-left{flex:0 0 auto;gap:1rem;min-width:0}.nav-page-title{color:#fff;font-size:20px;font-weight:700;gap:8px;margin:0 1rem 0 0;white-space:nowrap}.nav-logo,.nav-page-title{align-items:center;display:flex}.nav-logo{background:none!important;position:relative}.nav-logo__img{background:#0000!important;display:block;filter:brightness(1.1) drop-shadow(0 2px 4px rgba(0,0,0,.2));height:44px;max-height:44px;max-width:160px;object-fit:contain;width:auto}.nav-logo--desktop{display:block}.nav-links{margin-left:1rem}.nav-links,.nav-right{display:flex;gap:.5rem}.nav-right{align-items:center;flex-shrink:0}.nav-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;height:44px;justify-content:center;padding:0;position:relative;transition:color var(--transition-fast);width:44px}.nav-button:hover{color:#fff}.nav-button:active{transform:none}.nav-button:focus-visible{outline:2px solid #ffffff80;outline-offset:2px}.nav-button svg{color:#fff;height:26px;width:26px}.nav-button svg,.nav-button--cabinet svg,.nav-button--courses svg,.nav-button--internal svg,.nav-button--profile svg{filter:brightness(0) saturate(100%) invert(100%)}.nav-button--topup{color:#fff;gap:6px;height:44px;padding:0 10px;width:auto}.nav-button--topup:hover{color:#fff}.nav-balance{font-feature-settings:"tnum" 1,"tnum";color:#fff;font-size:18px;font-variant-numeric:tabular-nums;font-weight:900}.nav-balance-text{color:#fff;font-size:14px;font-weight:700}.nav-button--balance{display:flex;gap:6px;padding:0 10px;width:auto}.nav-button__star{bottom:14px;font-size:12px;left:6px;line-height:1;position:absolute}.marketplace-alert{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;left:50%;max-width:300px;padding:24px;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:2000}.marketplace-alert p{color:#1f2937;font-size:16px;margin:0 0 16px}.marketplace-alert button{background:#84a5f2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:background .2s ease}.marketplace-alert button:hover{background:#6d8ccc}.nav-button[data-tooltip]:after,.nav-logo[data-tooltip]:after{background:#111827eb;border-radius:6px;bottom:-8px;box-shadow:0 4px 10px #00000026;color:#fff;content:attr(data-tooltip);font-size:12px;left:50%;line-height:1;opacity:0;padding:6px 8px;pointer-events:none;position:absolute;transform:translate(-50%,100%);transition:opacity .15s ease;visibility:hidden;white-space:nowrap;z-index:1001}.nav-button[data-tooltip]:focus-visible:after,.nav-button[data-tooltip]:hover:after,.nav-logo[data-tooltip]:focus-visible:after,.nav-logo[data-tooltip]:hover:after{opacity:1;transition-delay:.5s;visibility:visible}.nav-button[data-tooltip]:before,.nav-logo[data-tooltip]:before{border:6px solid;border-color:#0000 #0000 #111827eb;bottom:-2px;content:"";left:50%;opacity:0;pointer-events:none;position:absolute;transform:translate(-50%,100%);transition:opacity .15s ease;visibility:hidden;z-index:1001}.nav-button[data-tooltip]:focus-visible:before,.nav-button[data-tooltip]:hover:before,.nav-logo[data-tooltip]:focus-visible:before,.nav-logo[data-tooltip]:hover:before{opacity:1;transition-delay:.5s;visibility:visible}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media (max-width:768px){.nav-container{height:56px;left:0!important;padding:.75rem;position:fixed!important;right:0!important;top:0!important;z-index:1000!important}.nav-logo__img{height:36px;max-height:36px;max-width:140px}.nav-links{display:flex!important;gap:.25rem}.nav-right{gap:.25rem}.nav-button{height:36px;width:36px}.nav-button svg{height:24px;width:24px}.nav-button--admin-menu{height:36px;margin-right:.25rem;width:36px}.nav-button--admin-menu svg{height:24px;width:24px}.nav-button--topup{gap:4px;height:36px;min-width:auto;padding:0 8px}.nav-button--topup .nav-balance{font-size:14px;font-weight:800}.nav-button--topup svg{height:20px;width:20px}.nav-button[data-tooltip]:after,.nav-button[data-tooltip]:before,.nav-logo[data-tooltip]:after,.nav-logo[data-tooltip]:before{display:none!important}}.alert-overlay{align-items:center;animation:fadeIn .2s ease;background:#0b167280;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.alert-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 4px 16px #0b167240,0 8px 32px #0000001f;display:flex;flex-direction:column;max-height:90vh;max-width:480px;overflow:hidden;pointer-events:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.alert-header{border-bottom:1px solid #0b16721a;padding:24px 24px 16px}.alert-title{color:#0b1672;font-family:Monda,sans-serif;font-size:20px;font-weight:700;margin:0}.alert-body{overflow-y:auto;padding:20px 24px}.alert-message{color:#0b1672;font-family:Raleway,sans-serif;font-size:16px;line-height:1.6;margin:0;white-space:pre-line}.alert-footer{border-top:1px solid #0b16721a;display:flex;justify-content:flex-end;padding:16px 24px 24px}.alert-button{align-items:center;background:linear-gradient(135deg,#fea367,#f1664a);border:none;border-radius:10px;box-shadow:0 4px 12px #f1664a33;color:#fff;cursor:pointer;display:flex;font-family:Raleway,sans-serif;font-size:14px;font-weight:600;justify-content:center;min-height:38px;padding:12px 32px;transition:transform .2s ease,box-shadow .2s ease}.alert-button:hover{box-shadow:0 6px 16px #f1664a4d;transform:translateY(-2px)}.alert-button:active{transform:translateY(0)}.alert-success .alert-header{background:linear-gradient(135deg,#f1664a0d,#fea3670d)}.alert-error .alert-header{background:linear-gradient(135deg,#f1664a0d,#f1664a0d)}.alert-warning .alert-header{background:linear-gradient(135deg,#fea3670d,#fea3670d)}.alert-info .alert-header{background:linear-gradient(135deg,#84a5f20d,#84a5f20d)}@media (max-width:768px){.alert-modal{border-radius:12px;max-width:90%}.alert-header{gap:12px;padding:20px 20px 12px}.alert-icon{height:36px;width:36px}.alert-icon svg{height:20px;width:20px}.alert-title{font-size:18px}.alert-body{padding:16px 20px}.alert-message{font-size:14px}.alert-footer{padding:12px 20px 20px}.alert-button{font-size:12px;min-height:36px;padding:10px 24px}}