[data-theme=base1]{--primary-color: var(--primary-color);--secondary-color: var(--secondary-color);--accent-color: var(--accent-color);--text-color: var(--text-color);--text-light: var(--gray-700);--text-muted: var(--gray-500);--bg-color: var(--bg-secondary);--bg-secondary: var(--border-light);--white: var(--white);--gray-light: var(--border-light);--card-bg: var(--white);--card-shadow: 0 4px 15px rgba(0,0,0,.1);--card-radius: 15px;--navbar-bg: var(--white);--navbar-shadow: 0 2px 10px rgba(0,0,0,.1);--btn-primary-bg: var(--secondary-color);--btn-primary-text: var(--white);--btn-primary-hover: var(--secondary-color-dark);--btn-secondary-bg: var(--accent-color);--btn-secondary-text: var(--white);--btn-secondary-hover: var(--accent-color-dark);--input-border: var(--gray-300);--input-focus: var(--accent-color);--input-bg: var(--white);--footer-bg: var(--primary-color);--footer-text: var(--white);--font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--font-size-base: 16px;--line-height: 1.6;--transition-speed: .3s}[data-theme=base1] .hero-section{background:linear-gradient(135deg,var(--primary-color),var(--accent-color))}[data-theme=base1] .btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);transition:all var(--transition-speed)}[data-theme=base1] .btn-primary:hover{background:var(--btn-primary-hover);transform:translateY(-2px)}[data-theme=base1] .btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text)}[data-theme=base1] .btn-secondary:hover{background:var(--btn-secondary-hover)}[data-theme=modern-dark]{--primary-color: var(--bg-dark);--secondary-color: var(--accent-red);--accent-color: var(--blue-900);--text-color: #eaeaea;--text-light: #b0b0b0;--text-muted: #707070;--bg-color: var(--bg-dark-secondary);--bg-secondary: var(--bg-dark);--white: var(--white);--gray-light: #2a2a4a;--card-bg: var(--bg-dark);--card-shadow: 0 4px 20px rgba(0,0,0,.4);--card-radius: 20px;--navbar-bg: var(--bg-dark);--navbar-shadow: 0 2px 15px rgba(0,0,0,.3);--btn-primary-bg: var(--accent-red);--btn-primary-text: var(--white);--btn-primary-hover: var(--red-500);--btn-secondary-bg: var(--blue-900);--btn-secondary-text: var(--white);--btn-secondary-hover: #1a5276;--input-border: #3a3a5a;--input-focus: var(--accent-red);--input-bg: var(--bg-dark);--footer-bg: #0f0f1a;--footer-text: #eaeaea;--font-family: "Poppins", "Segoe UI", sans-serif;--font-size-base: 16px;--line-height: 1.7;--transition-speed: .4s}[data-theme=modern-dark] body{background-color:var(--bg-color)}[data-theme=modern-dark] .hero-section{background:linear-gradient(135deg,var(--bg-dark) 0%,var(--bg-dark-secondary) 50%,var(--blue-900) 100%)}[data-theme=modern-dark] h1,[data-theme=modern-dark] h2,[data-theme=modern-dark] h3{color:var(--white)}[data-theme=modern-dark] .card{background:var(--card-bg);border:1px solid rgba(255,255,255,.1)}[data-theme=modern-dark] .navbar{background:#1a1a2ef2;backdrop-filter:blur(10px)}[data-theme=modern-dark] .btn-primary{background:linear-gradient(135deg,var(--accent-red),var(--red-500));box-shadow:0 4px 15px #e9456066}[data-theme=modern-dark] .btn-primary:hover{transform:translateY(-3px);box-shadow:0 6px 20px #e9456099}[data-theme=modern-dark] input,[data-theme=modern-dark] textarea,[data-theme=modern-dark] select{background:var(--input-bg);border-color:var(--input-border);color:var(--text-color)}[data-theme=nature-green]{--primary-color: var(--green-800);--secondary-color: #8b4513;--accent-color: var(--green-dark);--text-color: #2c3e2c;--text-light: #4a6741;--text-muted: #7a9a6a;--bg-color: #f0f5e9;--bg-secondary: #e8f0e0;--white: var(--white);--gray-light: #d4e5c7;--card-bg: var(--white);--card-shadow: 0 4px 15px rgba(45, 90, 39, .15);--card-radius: 12px;--navbar-bg: var(--white);--navbar-shadow: 0 2px 10px rgba(45, 90, 39, .1);--btn-primary-bg: var(--green-dark);--btn-primary-text: var(--white);--btn-primary-hover: #1e7a1e;--btn-secondary-bg: #8b4513;--btn-secondary-text: var(--white);--btn-secondary-hover: #723a0f;--input-border: #b8d4a8;--input-focus: var(--green-dark);--input-bg: var(--white);--footer-bg: var(--green-800);--footer-text: var(--white);--font-family: "Georgia", "Times New Roman", serif;--font-size-base: 17px;--line-height: 1.7;--transition-speed: .35s}[data-theme=nature-green] .hero-section{background:linear-gradient(135deg,var(--green-800),var(--green-dark),#3cb371)}[data-theme=nature-green] h1,[data-theme=nature-green] h2,[data-theme=nature-green] h3{color:var(--primary-color)}[data-theme=nature-green] .card{border-left:4px solid var(--accent-color)}[data-theme=nature-green] .btn-primary{background:var(--btn-primary-bg);border-radius:var(--radius-xl)}[data-theme=nature-green] .btn-primary:hover{background:var(--btn-primary-hover);transform:scale(1.02)}[data-theme=nature-green] a:hover{color:var(--accent-color)}[data-theme=moderne]{--primary-color: var(--warning-color-alt);--secondary-color: #ea580c;--accent-color: #92400e;--text-color: #44403c;--text-light: #78716c;--text-muted: #a8a29e;--bg-color: #faf7f5;--bg-secondary: #fff7ed;--white: var(--white);--gray-light: #f5f0eb;--card-bg: var(--white);--card-shadow: 0 2px 8px rgba(217, 119, 6, .08);--card-shadow-hover: 0 12px 24px rgba(217, 119, 6, .15);--card-radius: 16px;--navbar-bg: var(--white);--navbar-shadow: 0 2px 12px rgba(217, 119, 6, .1);--navbar-height: 70px;--navbar-height-mobile: 60px;--btn-primary-bg: linear-gradient(135deg, var(--warning-color-alt) 0%, #ea580c 100%);--btn-primary-text: var(--white);--btn-primary-hover: linear-gradient(135deg, #b45309 0%, #c2410c 100%);--btn-secondary-bg: var(--warning-bg-light);--btn-secondary-text: #92400e;--btn-secondary-hover: #fde68a;--input-border: #e7e5e4;--input-focus: var(--warning-color-alt);--input-bg: var(--white);--footer-bg: #44403c;--footer-text: #faf7f5;--hero-height: 350px;--hero-height-mobile: 240px;--hero-bg: linear-gradient(135deg, var(--warning-color-alt) 0%, #ea580c 50%, var(--warning-color) 100%);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;--font-size-base: 16px;--line-height: 1.4;--transition-speed: .25s;--transition-smooth: cubic-bezier(.4, 0, .2, 1)}[data-theme=moderne] body{background-color:var(--bg-color);font-family:var(--font-family);-webkit-font-smoothing:antialiased}[data-theme=moderne] h1,[data-theme=moderne] h2,[data-theme=moderne] h3,[data-theme=moderne] h4{color:var(--primary-color);font-weight:700}[data-theme=moderne] .navbar{background:var(--navbar-bg);box-shadow:var(--navbar-shadow)}[data-theme=moderne] .navbar-link{color:var(--text-color)}[data-theme=moderne] .navbar-link:hover{color:var(--primary-color)}[data-theme=moderne] .hero-section,[data-theme=moderne] .page-hero,[data-theme=moderne] .hero{background:var(--hero-bg);background-size:cover;background-position:center center;background-repeat:no-repeat;min-height:var(--hero-height);display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 20px 60px;margin-top:var(--navbar-height);overflow:hidden}[data-theme=moderne] .hero-section h1,[data-theme=moderne] .page-hero h1,[data-theme=moderne] .hero h1{color:var(--white);font-size:2.5rem;margin-bottom:16px;text-shadow:0 2px 4px rgba(0,0,0,.1)}[data-theme=moderne] .hero-section p,[data-theme=moderne] .page-hero p,[data-theme=moderne] .hero p{color:#ffffffe6;font-size:1.2rem;max-width:600px;margin:0 auto}[data-theme=moderne] .card,[data-theme=moderne] .course-card,[data-theme=moderne] .teacher-card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);border:1px solid rgba(217,119,6,.1);transition:all var(--transition-speed) var(--transition-smooth);overflow:hidden}[data-theme=moderne] .card:hover,[data-theme=moderne] .course-card:hover,[data-theme=moderne] .teacher-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-4px)}[data-theme=moderne] .btn,[data-theme=moderne] .btn-primary,[data-theme=moderne] .btn-secondary{min-height:50px;padding:14px 28px;border-radius:var(--radius-md);font-weight:600;font-size:16px;border:none;cursor:pointer;transition:all var(--transition-speed) var(--transition-smooth);touch-action:manipulation;-webkit-tap-highlight-color:transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px}[data-theme=moderne] .btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:0 4px 12px #d977064d}[data-theme=moderne] .btn-primary:hover{background:var(--btn-primary-hover);box-shadow:0 6px 20px #d9770666;transform:translateY(-2px)}[data-theme=moderne] .btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:2px solid transparent}[data-theme=moderne] .btn-secondary:hover{background:var(--btn-secondary-hover);border-color:var(--primary-color)}[data-theme=moderne] input,[data-theme=moderne] textarea,[data-theme=moderne] select{min-height:50px;padding:14px 18px;border:2px solid var(--input-border);border-radius:var(--radius-md);font-size:16px;background:var(--input-bg);color:var(--text-color);transition:all var(--transition-speed);width:100%}[data-theme=moderne] input:focus,[data-theme=moderne] textarea:focus,[data-theme=moderne] select:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 4px #d977061a}[data-theme=moderne] .footer{background:var(--footer-bg);color:var(--footer-text);padding:48px 24px}@media (max-width: 768px){[data-theme=moderne]{--navbar-height: var(--navbar-height-mobile);--hero-height: var(--hero-height-mobile)}[data-theme=moderne] .navbar{padding:0 16px;height:var(--navbar-height-mobile)}[data-theme=moderne] .navbar .logo{height:38px}[data-theme=moderne] .navbar .nav-links{position:fixed;top:var(--navbar-height-mobile);left:0;right:0;background:var(--navbar-bg);flex-direction:column;padding:16px;gap:8px;box-shadow:var(--navbar-shadow);display:none}[data-theme=moderne] .navbar .nav-links.open{display:flex}[data-theme=moderne] .navbar a{width:100%;text-align:center;padding:14px;font-size:16px}[data-theme=moderne] .hero-section h1,[data-theme=moderne] .page-hero h1,[data-theme=moderne] .hero h1{font-size:1.8rem}[data-theme=moderne] .hero-section p,[data-theme=moderne] .page-hero p{font-size:1rem}[data-theme=moderne] .btn,[data-theme=moderne] .btn-primary,[data-theme=moderne] .btn-secondary{width:100%;min-height:54px}[data-theme=moderne] .card{margin:12px 16px}}@media (max-width: 380px){[data-theme=moderne] .navbar .logo{height:32px}[data-theme=moderne] .hero-section h1{font-size:1.5rem}}[data-theme=moderne] ::-webkit-scrollbar{width:8px}[data-theme=moderne] ::-webkit-scrollbar-track{background:var(--gray-light)}[data-theme=moderne] ::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:var(--radius-sm)}[data-theme=moderne] .main-content{margin-top:var(--navbar-height)}@media (max-width: 768px){[data-theme=moderne] .main-content{margin-top:var(--navbar-height-mobile)}}[data-theme=elegant]{--primary-color: var(--blue-900);--secondary-color: #c9a227;--accent-color: #2563eb;--text-color: var(--slate-800);--text-light: var(--slate-600);--text-muted: var(--slate-400);--bg-color: var(--gray-150);--bg-secondary: var(--gray-150);--white: var(--white);--gray-light: var(--border-color);--card-bg: var(--white);--card-shadow: 0 4px 20px rgba(30, 58, 95, .08);--card-shadow-hover: 0 20px 40px rgba(30, 58, 95, .15);--card-radius: 12px;--navbar-bg: var(--white);--navbar-shadow: 0 1px 0 rgba(30, 58, 95, .1);--navbar-height: 72px;--navbar-height-mobile: 64px;--btn-primary-bg: var(--blue-900);--btn-primary-text: var(--white);--btn-primary-hover: #152a47;--btn-secondary-bg: transparent;--btn-secondary-text: #c9a227;--btn-secondary-border: #c9a227;--btn-secondary-hover: #c9a227;--input-border: var(--gray-450);--input-focus: var(--blue-900);--input-bg: var(--white);--footer-bg: var(--blue-900);--footer-text: var(--gray-150);--hero-height: 320px;--hero-height-mobile: 260px;--hero-bg: linear-gradient(135deg, var(--blue-900) 0%, #2563eb 100%);--font-family: "Georgia", "Times New Roman", serif;--font-heading: "Georgia", serif;--font-size-base: 17px;--line-height: 1.7;--transition-speed: .3s;--transition-smooth: cubic-bezier(.4, 0, .2, 1)}[data-theme=elegant] body{background-color:var(--bg-color);font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height);-webkit-font-smoothing:antialiased}[data-theme=elegant] h1,[data-theme=elegant] h2,[data-theme=elegant] h3,[data-theme=elegant] h4{font-family:var(--font-heading);color:var(--primary-color);font-weight:600;letter-spacing:-.01em}[data-theme=elegant] .navbar{background:var(--navbar-bg);box-shadow:var(--navbar-shadow);border-bottom:2px solid var(--secondary-color)}[data-theme=elegant] .navbar-link{color:var(--text-color)}[data-theme=elegant] .navbar-link:hover{color:var(--primary-color)}[data-theme=elegant] .hero-section,[data-theme=elegant] .page-hero,[data-theme=elegant] .hero{background:var(--hero-bg);min-height:var(--hero-height);display:flex;align-items:center;justify-content:center;text-align:center;padding:50px 24px;margin-top:var(--navbar-height);position:relative;overflow:hidden}[data-theme=elegant] .hero-section:before{content:"♪ ♫ ♪ ♫ ♪ ♫ ♪ ♫";position:absolute;bottom:20px;left:0;right:0;font-size:24px;color:#ffffff26;letter-spacing:40px;text-align:center}[data-theme=elegant] .hero-section h1,[data-theme=elegant] .page-hero h1,[data-theme=elegant] .hero h1{color:var(--white);font-size:3rem;margin-bottom:20px;font-weight:400;letter-spacing:.02em}[data-theme=elegant] .hero-section p,[data-theme=elegant] .page-hero p,[data-theme=elegant] .hero p{color:#ffffffe6;font-size:1.25rem;max-width:650px;margin:0 auto;font-style:italic}[data-theme=elegant] .card,[data-theme=elegant] .course-card,[data-theme=elegant] .teacher-card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);border:1px solid var(--gray-light);transition:all var(--transition-speed) var(--transition-smooth);overflow:hidden}[data-theme=elegant] .card:hover,[data-theme=elegant] .course-card:hover,[data-theme=elegant] .teacher-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-6px);border-color:var(--secondary-color)}[data-theme=elegant] .course-card:before,[data-theme=elegant] .teacher-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--secondary-color),transparent)}[data-theme=elegant] .btn,[data-theme=elegant] .btn-primary,[data-theme=elegant] .btn-secondary{min-height:52px;padding:14px 32px;border-radius:var(--radius-md);font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-weight:600;font-size:15px;letter-spacing:.02em;cursor:pointer;transition:all var(--transition-speed) var(--transition-smooth);touch-action:manipulation;display:inline-flex;align-items:center;justify-content:center;gap:10px}[data-theme=elegant] .btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;box-shadow:0 4px 14px #1e3a5f40}[data-theme=elegant] .btn-primary:hover{background:var(--btn-primary-hover);box-shadow:0 8px 25px #1e3a5f59;transform:translateY(-2px)}[data-theme=elegant] .btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:2px solid var(--btn-secondary-border)}[data-theme=elegant] .btn-secondary:hover{background:var(--btn-secondary-hover);color:var(--white)}[data-theme=elegant] input,[data-theme=elegant] textarea,[data-theme=elegant] select{min-height:52px;padding:14px 18px;border:1px solid var(--input-border);border-radius:var(--radius-md);font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;background:var(--input-bg);color:var(--text-color);transition:all var(--transition-speed);width:100%}[data-theme=elegant] input:focus,[data-theme=elegant] textarea:focus,[data-theme=elegant] select:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px #1e3a5f1a}[data-theme=elegant] .footer{background:var(--footer-bg);color:var(--footer-text);padding:60px 32px;border-top:3px solid var(--secondary-color)}[data-theme=elegant] .footer a{color:var(--footer-text);transition:color var(--transition-speed)}[data-theme=elegant] .footer a:hover{color:var(--secondary-color)}[data-theme=elegant] section{padding:80px 24px}[data-theme=elegant] section h2{text-align:center;margin-bottom:50px;position:relative}[data-theme=elegant] section h2:after{content:"♫";display:block;margin-top:15px;color:var(--secondary-color);font-size:20px}@media (max-width: 768px){[data-theme=elegant]{--navbar-height: var(--navbar-height-mobile);--hero-height: var(--hero-height-mobile);--font-size-base: 16px}[data-theme=elegant] .navbar{padding:0 16px}[data-theme=elegant] .navbar .logo{height:40px}[data-theme=elegant] .navbar .nav-links{position:fixed;top:var(--navbar-height-mobile);left:0;right:0;background:var(--navbar-bg);flex-direction:column;padding:20px;gap:8px;border-top:1px solid var(--gray-light);box-shadow:0 10px 30px #0000001a;display:none}[data-theme=elegant] .navbar .nav-links.open{display:flex}[data-theme=elegant] .navbar a{width:100%;text-align:center;padding:16px;font-size:16px}[data-theme=elegant] .navbar a:after{display:none}[data-theme=elegant] .hero-section h1{font-size:2rem}[data-theme=elegant] .hero-section p{font-size:1rem}[data-theme=elegant] .btn,[data-theme=elegant] .btn-primary,[data-theme=elegant] .btn-secondary{width:100%;min-height:56px}[data-theme=elegant] section{padding:50px 20px}}[data-theme=elegant] .main-content{margin-top:var(--navbar-height)}@media (max-width: 768px){[data-theme=elegant] .main-content{margin-top:var(--navbar-height-mobile)}}[data-theme=elegant] ::-webkit-scrollbar{width:10px}[data-theme=elegant] ::-webkit-scrollbar-track{background:var(--bg-secondary)}[data-theme=elegant] ::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:var(--radius-sm)}[data-theme=elegant] ::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}[data-theme=elegant] ::selection{background:#c9a2274d;color:var(--primary-color)}@font-face{font-family:Komoda;src:url(/assets/Komoda-jeRl3Hpa.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}.navbar{position:fixed;top:0;left:0;right:0;background-color:#fff;box-shadow:var(--shadow-sm);z-index:var(--z-navbar);padding:15px 0}.navbar-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.navbar-logo{display:flex;align-items:center}.logo-full{height:70px;width:auto;object-fit:contain}.navbar-menu{display:flex;list-style:none;gap:15px;align-items:center;flex-wrap:wrap}.navbar-link{color:var(--primary-color);font-weight:500;transition:color var(--transition-normal);padding:8px 12px;white-space:nowrap;font-size:15px}.navbar-link:hover{color:var(--secondary-color)}.message-badge{position:absolute;top:-8px;right:-10px;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color-dark) 100%);color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:var(--radius-md);min-width:18px;text-align:center;box-shadow:0 2px 8px #e74c3c66;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.navbar-link-cta{background-color:var(--secondary-color);color:var(--white);border-radius:var(--radius-sm);padding:8px 16px;font-size:14px;white-space:nowrap}.navbar-link-cta:hover{background-color:var(--secondary-color-dark);color:var(--white)}.navbar-link-inscription{background-color:var(--accent-color);color:var(--white);border-radius:var(--radius-sm);padding:8px 16px;font-size:14px;white-space:nowrap}.navbar-link-inscription:hover{background-color:var(--accent-color-dark);color:var(--white)}.navbar-teacher-auth{position:relative;margin-left:10px}.teacher-button{background:linear-gradient(135deg,var(--brand-color) 0%,var(--brand-color-dark, var(--brand-color-dark)) 100%);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-xl);font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;white-space:nowrap}.teacher-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.teacher-button.logged-in{background:linear-gradient(135deg,var(--success-color) 0%,var(--success-color-dark) 100%)}.teacher-dropdown{position:relative}.teacher-dropdown-menu{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;padding:8px 0;z-index:var(--z-navbar)}.dropdown-item{display:block;padding:12px 20px;color:var(--text-color);text-decoration:none;font-size:14px;transition:all .2s ease;background:none;border:none;width:100%;text-align:left;cursor:pointer}.dropdown-item:hover{background-color:var(--bg-tertiary);color:var(--brand-color)}.dropdown-item.logout{color:var(--secondary-color);border-top:1px solid var(--gray-200);margin-top:5px;padding-top:15px}.dropdown-item.logout:hover{background-color:var(--error-bg-subtle);color:var(--secondary-color-dark)}.hamburger,.mobile-only{display:none}.desktop-only{display:block}.menu-overlay{display:none}@media (max-width: 1024px){.navbar-menu{gap:8px}.navbar-link{padding:6px 8px;font-size:13px}.navbar-link-cta,.navbar-link-inscription{padding:6px 10px;font-size:12px}.teacher-button{padding:6px 10px;font-size:11px}.logo-full{height:55px}}@media (min-width: 769px) and (max-width: 900px){.navbar-menu{gap:4px}.navbar-link{padding:5px 6px;font-size:12px}.navbar-link-cta,.navbar-link-inscription{padding:5px 8px;font-size:11px}.logo-full{height:50px}.navbar-container{padding:0 12px}}@media (max-width: 768px){.navbar{padding:15px 0}.logo-full{height:50px}.navbar-container{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 20px}.navbar-logo{grid-column:2;justify-self:center}.hamburger{display:flex;flex-direction:column;justify-content:space-around;width:30px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:var(--z-navbar-overlay);grid-column:3;justify-self:end}.hamburger span{width:30px;height:3px;background-color:var(--primary-color);border-radius:var(--radius-sm);transition:all .3s ease;transform-origin:left}.hamburger.active span:nth-child(1){transform:rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0;transform:translate(-10px)}.hamburger.active span:nth-child(3){transform:rotate(-45deg)}.desktop-only{display:none}.mobile-only{display:block}.navbar-menu{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#fff;flex-direction:column;justify-content:flex-start;align-items:stretch;padding:80px 20px 30px;gap:0;box-shadow:-5px 0 25px #00000026;transition:right .3s ease;z-index:var(--z-navbar-menu);overflow-y:auto}.navbar-menu.open{right:0}.navbar-item{width:100%;border-bottom:1px solid var(--gray-100)}.navbar-item:last-child{border-bottom:none}.navbar-link{display:block;padding:16px 15px;font-size:16px;color:var(--text-color);border-radius:var(--radius-md);transition:all .2s ease}.navbar-link:hover{background-color:var(--bg-tertiary);color:var(--primary-color)}.navbar-link-cta{margin-top:10px;text-align:center;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color-dark) 100%);color:#fff;font-size:16px;padding:16px 20px}.navbar-link-inscription{text-align:center;font-size:16px;padding:16px 20px;margin-bottom:10px;color:#fff}.teacher-button{width:100%;margin-top:15px;padding:14px 20px;font-size:15px;text-align:center}.menu-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:var(--z-navbar)}.navbar-menu.open~.menu-overlay,.menu-overlay{display:block}.navbar-container:not(:has(.navbar-menu.open)) .menu-overlay{display:none}}@media (max-width: 480px){.logo-full{height:40px}.quick-btn{padding:7px 12px;font-size:12px}.hamburger{width:26px;height:20px}.hamburger span{width:26px;height:2.5px}.navbar-menu{width:260px;padding:70px 15px 25px}.navbar-link{padding:14px 12px;font-size:15px}}.footer{background-color:var(--primary-color);color:var(--white);padding:25px 0 12px;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto 15px;padding:0 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:60px}.footer-section h3,.footer-section h4{color:var(--white);margin-bottom:8px;font-size:1rem}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:4px}.footer-section a{color:var(--gray-light);transition:color .3s ease;text-decoration:none}.footer-section a:hover{color:var(--secondary-color)}.footer-section p{color:var(--gray-light);line-height:1.4;font-size:.9rem}.footer-section p a{color:var(--gray-light);text-decoration:none}.footer-section p a:hover{color:var(--secondary-color)}.footer-social{display:flex;gap:10px;margin-top:10px}.social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);background:#ffffff1a;color:var(--gray-light);transition:all .3s ease}.social-link:hover{background:var(--secondary-color);color:var(--white);transform:translateY(-3px);box-shadow:0 4px 12px #0000004d}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;text-align:center;color:var(--gray-light);font-size:.85rem}.footer-legal-links{margin-top:8px;font-size:.85em}.footer-legal-links a{color:var(--text-hint);text-decoration:none;transition:color .3s}.footer-legal-links a:hover{color:var(--secondary-color);text-decoration:underline}.footer-separator{margin:0 10px;color:var(--text-muted)}@media (min-width: 769px) and (max-width: 1024px){.footer-container{grid-template-columns:repeat(2,1fr);gap:30px}}@media (max-width: 768px){.footer{padding:15px 0 10px}.footer-container{grid-template-columns:1fr;text-align:center;gap:12px;margin-bottom:10px}.footer-section h3,.footer-section h4{margin-bottom:5px;font-size:.95rem}.footer-section p{font-size:.85rem;line-height:1.3}.footer-section ul li{margin-bottom:2px;font-size:.85rem}.footer-social{justify-content:center}.footer-bottom{padding-top:8px;font-size:.8rem}.footer-legal-links{margin-top:4px;font-size:.8em}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;min-height:60vh;padding:40px 20px}.spinner-wheel{border:4px solid var(--border-color, var(--border-color));border-top:4px solid var(--brand-color, var(--brand-color));border-radius:var(--radius-full);animation:spin .8s linear infinite}.loading-spinner-small .spinner-wheel{width:24px;height:24px;border-width:3px}.loading-spinner-medium .spinner-wheel{width:40px;height:40px;border-width:4px}.loading-spinner-large .spinner-wheel{width:60px;height:60px;border-width:5px}.loading-spinner-fullscreen{position:fixed;inset:0;background:linear-gradient(135deg,var(--bg-dark) 0%,var(--bg-dark-secondary) 50%,var(--blue-900) 100%);z-index:var(--z-splash)}.loading-spinner-fullscreen .spinner-wheel{width:60px;height:60px;border-width:5px;border-color:#fff3;border-top-color:var(--white)}.loading-text{color:var(--text-color, var(--gray-900));font-size:1.1rem;font-weight:500;margin:0;text-align:center;opacity:.8}.loading-spinner-fullscreen .loading-text{color:var(--white)}.loading-spinner-container{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.loading-spinner-inline{display:inline-flex;align-items:center;gap:8px;min-height:auto;padding:0}.loading-spinner-inline .spinner-wheel{width:16px;height:16px;border-width:2px}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-dark) 0%,var(--bg-dark-secondary) 50%,var(--blue-900) 100%);padding:20px}.error-boundary-content{background:#fff;border-radius:var(--radius-xl);padding:40px;max-width:500px;text-align:center;box-shadow:0 20px 60px #0000004d}.error-icon{font-size:4rem;margin-bottom:20px;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.error-boundary h1{color:var(--bg-dark);font-size:1.8rem;margin-bottom:15px}.error-message{color:var(--text-muted);font-size:1.1rem;line-height:1.6;margin-bottom:25px}.error-details{background:var(--bg-secondary);border-radius:var(--radius-md);padding:15px;margin-bottom:25px;text-align:left}.error-details summary{cursor:pointer;color:var(--text-muted);font-weight:500;margin-bottom:10px}.error-details pre{background:var(--bg-dark);color:var(--warning-color);padding:15px;border-radius:var(--radius-md);overflow-x:auto;font-size:.8rem;margin:10px 0}.error-actions{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.error-actions button{padding:12px 24px;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.error-actions .btn-primary{background:linear-gradient(135deg,var(--indigo-500),var(--purple-vivid));color:#fff}.error-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4f46e566}.error-actions .btn-secondary{background:var(--gray-100);color:var(--text-color)}.error-actions .btn-secondary:hover{background:var(--border-color)}@media (max-width: 480px){.error-boundary-content{padding:30px 20px}.error-actions{flex-direction:column}.error-actions button{width:100%}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#1a1a2ef7;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--white);z-index:var(--z-cookie);padding:0;animation:cookieSlideUp .4s ease-out;box-shadow:0 -4px 20px #0000004d}@keyframes cookieSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-content{max-width:1200px;margin:0 auto;padding:20px 30px;display:flex;align-items:center;gap:30px}.cookie-text{flex:1}.cookie-text p{margin:0;font-size:.95rem;line-height:1.4;color:var(--gray-300)}.cookie-text strong{color:var(--white)}.cookie-link{margin-top:5px;font-size:.85rem;color:var(--neutral-gray-alt)}.cookie-detail{margin-top:4px;font-size:.85rem;color:var(--text-hint);font-style:italic}.cookie-link a{color:var(--brand-color);text-decoration:none;transition:color .2s}.cookie-link a:hover{color:var(--blue-indigo-bg);text-decoration:underline}.cookie-actions{display:flex;gap:12px;flex-shrink:0}.cookie-btn{padding:12px 28px;border-radius:var(--radius-xl);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;white-space:nowrap}.cookie-btn-accept{background:linear-gradient(135deg,var(--success-color),var(--success-color-alt));color:var(--white)}.cookie-btn-accept:hover{transform:translateY(-2px);box-shadow:0 4px 15px #27ae6066}.cookie-btn-refuse{background:transparent;color:var(--text-hint);border:1px solid var(--gray-800)}.cookie-btn-refuse:hover{background:#ffffff1a;color:var(--white);border-color:var(--text-subtle)}@media (max-width: 768px){.cookie-content{flex-direction:column;padding:20px;gap:15px;text-align:center}.cookie-text p{font-size:.85rem}.cookie-actions{width:100%;justify-content:center}.cookie-btn{padding:10px 22px;font-size:.9rem}}@media (prefers-reduced-motion: reduce){.cookie-banner{animation:none}.cookie-btn-accept:hover,.cookie-btn-refuse:hover{transform:none}}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:10000;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;padding-top:calc(10px + env(safe-area-inset-top));background:linear-gradient(135deg,var(--error-color),var(--error-dark));color:#fff;font-size:.85rem;font-weight:600;text-align:center;box-shadow:0 2px 8px #0003;animation:offlineBannerSlide .3s ease-out}.offline-banner-icon{font-size:1.1rem;flex-shrink:0}.offline-banner-text{line-height:1.3}@keyframes offlineBannerSlide{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.page-progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--secondary-color, var(--secondary-color)),var(--accent-color, var(--accent-color)),var(--secondary-color, var(--secondary-color)));background-size:200% 100%;z-index:var(--z-splash);pointer-events:none;width:0;opacity:0;border-radius:0 2px 2px 0;box-shadow:0 0 8px #e74c3c66}.page-progress-bar.running{width:70%;opacity:1;transition:width .8s cubic-bezier(.4,0,.2,1),opacity .15s ease;animation:progressShimmer 1.5s ease infinite}.page-progress-bar.finishing{width:100%;opacity:0;transition:width .2s ease-out,opacity .25s ease .15s}@keyframes progressShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.App{text-align:center;display:flex;flex-direction:column;min-height:100vh;background:var(--bg-color, #F3DCB0)}.App>.main-content{flex:1;min-height:calc(100vh - 80px)}.container{max-width:1200px;margin:0 auto;padding:0 20px}.section{padding:60px 0}.section-title{font-size:2.5rem;text-align:center;margin-bottom:3rem;color:var(--primary-color)}.btn{display:inline-block;padding:12px 30px;font-size:1rem;font-weight:600;border-radius:var(--radius-sm);transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.btn-primary{background-color:var(--secondary-color);color:var(--white)}.btn-primary:hover{background-color:var(--secondary-color-dark);transform:translateY(-2px);box-shadow:0 5px 15px #e74c3c4d}.btn-secondary{background-color:var(--accent-color);color:var(--white)}.btn-secondary:hover{background-color:var(--accent-color-dark);transform:translateY(-2px);box-shadow:0 5px 15px #3498db4d}.card{background:var(--white);border-radius:var(--radius-md);padding:30px;box-shadow:0 5px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #00000026}.grid{display:grid;gap:30px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}@media (min-width: 769px) and (max-width: 1024px){.section{padding:45px 0}.section-title{font-size:2.2rem;margin-bottom:2rem}.container{padding:0 24px}.grid-2,.grid-3{grid-template-columns:repeat(2,1fr);gap:24px}}@media (max-width: 768px){.section-title{font-size:2rem}.main-content{margin-top:70px}}.lazy-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.lazy-loading-container p{color:var(--primary-color);font-size:1rem;opacity:.7}.lazy-loading-spinner{width:50px;height:50px;border:4px solid var(--gray-light);border-top-color:var(--secondary-color);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.main-content.app-mode{margin-top:0;min-height:100vh;padding-top:max(env(safe-area-inset-top,20px),44px);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);overflow:hidden}.app-mode .unified-login-page{min-height:100vh;padding-top:0;margin-top:calc(-1*max(env(safe-area-inset-top,20px),44px))}body.no-scroll{overflow:hidden;position:fixed;width:100%;height:100%}.cms-page{min-height:100vh;overflow-x:hidden;width:100%}.cms-loading,.cms-error{display:flex;align-items:center;justify-content:center;min-height:300px;font-size:1.2rem;color:var(--text-muted)}.cms-hero{position:relative;height:700px;max-height:700px;background-size:cover;background-position:center center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;overflow:hidden;width:100%;max-width:100vw}.cms-hero.full-height{height:100vh;max-height:100vh}.cms-hero-overlay{position:absolute;inset:0;background:var(--black)}.cms-hero-content{position:absolute;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--white);z-index:1;width:90%;max-width:900px;padding:0 20px;box-sizing:border-box}.cms-hero-content h1{font-size:3rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.cms-hero-subtitle{font-size:1.3rem;margin-bottom:2rem;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.cms-hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cms-text-section{padding:4rem 0}.cms-text-content{max-width:800px;margin:0 auto;line-height:1.5;font-size:1.1rem}.cms-features-section{padding:4rem 0}.cms-features-grid{display:grid;gap:2rem;margin-top:2rem}.cms-features-grid.columns-2{grid-template-columns:repeat(2,1fr)}.cms-features-grid.columns-3{grid-template-columns:repeat(3,1fr)}.cms-features-grid.columns-4{grid-template-columns:repeat(4,1fr)}.cms-feature-item{text-align:center;padding:2rem;background:var(--white);border-radius:var(--radius-md);box-shadow:0 2px 10px #00000014;transition:transform .3s,box-shadow .3s}.cms-feature-item:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.cms-feature-icon{font-size:2.5rem;display:block;margin-bottom:1rem}.cms-feature-item h3{margin-bottom:.5rem;color:var(--primary-color)}.cms-feature-item p{color:var(--text-muted);line-height:1.4}.cms-disciplines-section{padding:4rem 0;content-visibility:auto;contain-intrinsic-size:auto 600px;overflow:hidden;width:100%;box-sizing:border-box}.cms-disciplines-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:2rem;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 20px}.cms-discipline-card{background:var(--white);border-radius:var(--radius-lg);padding:30px;box-shadow:0 5px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column;cursor:pointer;width:auto;max-width:100%}.cms-discipline-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.cms-discipline-image{width:100%;height:250px;aspect-ratio:4/3;margin-bottom:20px;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 15px #00000026;background:linear-gradient(135deg,var(--brand-color) 0%,var(--brand-color-dark, var(--brand-color-dark)) 100%);display:flex;align-items:center;justify-content:center}.cms-discipline-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.cms-discipline-card:hover .cms-discipline-image img{transform:scale(1.05)}.cms-discipline-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.5rem;font-weight:600;text-align:center;opacity:.9}.cms-discipline-content{flex:1;display:flex;flex-direction:column}.cms-discipline-content h3{color:var(--primary-color);font-size:1.8rem;margin-bottom:15px;text-align:center}.cms-discipline-content p{color:var(--text-muted);margin-bottom:20px;line-height:1.4;text-align:center;flex-grow:1}.cms-discipline-content .btn{width:100%;text-align:center;margin-top:auto}.cms-discipline-price{font-size:1.2rem;font-weight:600;color:var(--accent-color);text-align:center;margin-bottom:1rem}@media (max-width: 768px){.cms-disciplines-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 15px}.cms-discipline-card{padding:20px}.cms-discipline-image{height:180px}}.cms-team-section{padding:4rem 0;content-visibility:auto;contain-intrinsic-size:auto 500px}.cms-team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.cms-team-member{text-align:center;padding:2rem;background:var(--white);border-radius:var(--radius-md);box-shadow:0 2px 10px #00000014}.cms-team-photo{width:150px;height:150px;margin:0 auto 1rem;border-radius:var(--radius-full);overflow:hidden;border:1.5px solid #000}.cms-team-photo img{width:100%;height:100%;object-fit:cover}.cms-team-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--border-color);font-size:3rem}.cms-team-member h3{margin-bottom:.25rem;color:var(--primary-color)}.cms-team-specialty{color:var(--accent-color);font-weight:500;margin-bottom:.5rem}.cms-team-bio{color:var(--text-muted);font-size:.9rem;line-height:1.4}.cms-team-disciplines{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-bottom:.75rem}.cms-team-discipline-tag{display:inline-block;background:var(--bg-secondary, var(--orange-bg-dawn));color:var(--primary-color, var(--warning-color-alt));padding:.2rem .6rem;border-radius:var(--radius-xl);font-size:.8rem;font-weight:500}.cms-team-availability{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--gray-200);font-size:.85rem;color:var(--text-muted)}.cms-team-avail-label{font-weight:600;color:var(--text-color, var(--gray-900))}.cms-cta-section{padding:4rem 0;text-align:center}.cms-cta-content h2{margin-bottom:1rem;font-size:2rem}.cms-cta-content p{margin-bottom:2rem;font-size:1.1rem;opacity:.9}.btn-light{background:var(--white);color:var(--primary-color);padding:.8rem 2rem;border-radius:var(--radius-md);font-weight:600;text-decoration:none;display:inline-block;transition:transform .3s,box-shadow .3s}.btn-light:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0003}.cta-store-badges{margin-top:1.5rem;display:flex;justify-content:center}.cta-store-badge-link{display:inline-flex;transition:transform .3s ease}.cta-store-badge-link:hover{transform:scale(1.05)}.cta-store-badges .store-badge-img{height:50px;width:auto}.cms-contact-section{padding:4rem 0}.cms-contact-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2rem}.cms-contact-info{display:flex;flex-direction:column;gap:1.5rem}.cms-contact-item{display:flex;gap:1rem;padding:1.5rem;background:#fff9;border-radius:var(--radius-md)}.cms-contact-icon{font-size:2rem}.cms-contact-item h3{margin-bottom:.25rem;font-size:1rem;color:var(--primary-color)}.cms-contact-item a{color:inherit;text-decoration:none}.cms-contact-item a:hover{color:var(--accent-color)}.cms-contact-form-title{font-size:1.4rem;color:var(--primary-color);margin-bottom:.5rem;text-align:center}.cms-contact-form{display:flex;flex-direction:column;gap:1rem}.cms-contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.cms-contact-form .form-group{display:flex;flex-direction:column}.cms-contact-form label{margin-bottom:.5rem;font-weight:500}.cms-contact-form input,.cms-contact-form textarea{padding:.8rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:1rem;transition:border-color .3s}.cms-contact-form input:focus,.cms-contact-form textarea:focus{outline:none;border-color:var(--primary-color)}.cms-image-section{padding:2rem 0}.cms-image-figure{margin:0}.cms-image-figure.center{text-align:center}.cms-image-figure.left{text-align:left}.cms-image-figure.right{text-align:right}.cms-image-figure img{border-radius:var(--radius-md)}.cms-image-figure figcaption{margin-top:.5rem;color:var(--text-muted);font-style:italic}.cms-gallery-section{padding:4rem 0}.cms-gallery-grid{display:grid;gap:1rem;margin-top:2rem}.cms-gallery-grid.columns-2{grid-template-columns:repeat(2,1fr)}.cms-gallery-grid.columns-3{grid-template-columns:repeat(3,1fr)}.cms-gallery-grid.columns-4{grid-template-columns:repeat(4,1fr)}.cms-gallery-item img{width:100%;height:200px;object-fit:cover;border-radius:var(--radius-md);transition:transform .3s}.cms-gallery-item img:hover{transform:scale(1.05)}.cms-video-section{padding:4rem 0}.cms-video-container{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--radius-md);max-width:800px;margin:2rem auto 0}.cms-video-container iframe,.cms-video-container video{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:var(--radius-md)}.cms-testimonials-section{padding:4rem 0}.cms-testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.cms-testimonial-card{background:var(--white);padding:2rem;border-radius:var(--radius-md);box-shadow:0 2px 10px #00000014}.cms-testimonial-text{font-style:italic;font-size:1.1rem;line-height:1.4;margin-bottom:1.5rem;color:var(--text-muted)}.cms-testimonial-author{display:flex;flex-direction:column;gap:.25rem}.cms-testimonial-author strong{color:var(--primary-color)}.cms-testimonial-author span{font-size:.9rem;color:var(--text-subtle)}.cms-spacer{width:100%}.cms-divider-container{padding:1rem 0}.cms-divider{border:none;border-top:1px solid var(--border-color);margin:0 auto}.cms-html-section{padding:2rem 0}.cms-app-showcase{padding:4rem 0}.cms-app-showcase .section-title{text-align:center;font-size:2.2rem;margin-bottom:.5rem}.cms-app-showcase .section-subtitle{text-align:center;font-size:1.1rem;color:var(--text-secondary);max-width:600px;margin:0 auto 3rem;line-height:1.6}.app-features-list{display:flex;flex-direction:column;gap:4rem}.app-feature-row{display:flex;align-items:center;gap:3rem}.app-feature-row.reverse{flex-direction:row-reverse}.app-feature-text{flex:1}.app-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#ea88171f,#ea88170a);font-size:1.6rem;margin-bottom:1rem}.app-feature-text h3{font-size:1.5rem;font-weight:700;margin:0 0 .75rem;line-height:1.3}.app-feature-text p{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);margin:0}.app-feature-phone{flex:0 0 auto}.phone-frame{position:relative;width:260px;background:#1a1a1a;border-radius:36px;padding:12px;box-shadow:0 25px 60px #00000026,0 8px 20px #0000001a,inset 0 1px #ffffff1a}.phone-frame:before{content:"";position:absolute;inset:-1px;border-radius:37px;background:linear-gradient(145deg,rgba(255,255,255,.15),transparent 50%);pointer-events:none;z-index:0}.phone-notch{width:120px;height:28px;background:#1a1a1a;border-radius:0 0 18px 18px;margin:-12px auto -14px;position:relative;z-index:2}.phone-frame img{width:100%;display:block;border-radius:24px;position:relative;z-index:1}.phone-frame.glow{box-shadow:0 25px 60px #ea881733,0 8px 20px #ea88171a,inset 0 1px #ffffff1a}.cms-app-download{padding:5rem 0;overflow:hidden}.app-download-content{display:flex;align-items:center;gap:4rem;max-width:1000px;margin:0 auto}.app-download-text{flex:1}.app-download-text h2{font-size:2.2rem;font-weight:800;margin:0 0 1rem;line-height:1.2}.app-download-text p{font-size:1.1rem;line-height:1.7;margin:0 0 2rem}.app-store-badges{display:flex;gap:12px;flex-wrap:wrap}.store-badge{display:inline-flex;transition:transform .3s ease,opacity .3s ease}.store-badge:hover{transform:scale(1.05)}.store-badge .badge-icon{height:50px;width:auto}.store-badge-img{height:50px;width:auto;border-radius:8px;transition:transform .3s ease,opacity .3s ease}.store-badge-img:hover{transform:scale(1.05)}.hero-store-badge{display:inline-flex;text-decoration:none}.hero-store-badge .store-badge-img{height:55px}.app-coming-soon{margin-top:1rem;font-size:.9rem;font-style:italic;opacity:.7}.app-download-visual{flex:0 0 auto}@media (max-width: 768px){.cms-app-showcase{padding:2rem 0}.cms-app-showcase .section-title{font-size:1.6rem}.cms-app-showcase .section-subtitle{font-size:.95rem;margin-bottom:2rem}.app-features-list{gap:2.5rem}.app-feature-row,.app-feature-row.reverse{flex-direction:column;text-align:center}.app-feature-icon{margin:0 auto .75rem}.app-feature-text h3{font-size:1.25rem}.app-feature-text p{font-size:.95rem}.phone-frame{width:200px}.cms-app-download{padding:3rem 0}.app-download-content{flex-direction:column;text-align:center;gap:2rem}.app-download-text h2{font-size:1.6rem}.app-download-text p{font-size:.95rem}.app-store-badges{justify-content:center}.app-download-visual .phone-frame{width:180px}}.cms-carousel{position:relative;overflow:hidden}.cms-carousel-banner{padding:2rem 0}.cms-carousel-banner .carousel-container{position:relative;overflow:hidden;border-radius:var(--radius-md);max-width:1200px;margin:0 auto}.carousel-track{display:flex;transition:transform .5s ease-in-out}.carousel-slide{min-width:100%;position:relative;aspect-ratio:16/9}.carousel-slide img{width:100%;height:100%;object-fit:cover}.carousel-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:#fff;padding:30px 20px 15px;font-size:1rem}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#00000040;color:#fff;border:none;width:40px;height:40px;border-radius:var(--radius-full);font-size:1.2rem;cursor:pointer;z-index:10;transition:all .3s ease;box-shadow:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.carousel-arrow:hover{background:#00000073;transform:translateY(-50%) scale(1.1)}.carousel-prev{left:15px}.carousel-next{right:15px}.carousel-dots{display:flex;justify-content:center;gap:8px;padding:15px;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.carousel-dot{width:10px;height:10px;border-radius:var(--radius-full);background:#ffffff80;border:2px solid rgba(255,255,255,.8);cursor:pointer;transition:all .3s ease;padding:0}.carousel-dot.active{background:#fff;transform:scale(1.2)}.cms-carousel-cards{padding:3rem 0}.carousel-cards-container{position:relative;overflow:hidden;padding:10px}.carousel-cards-track{display:flex;gap:20px;transition:transform .5s ease-in-out}.carousel-card{flex:0 0 calc(33.333% - 14px);background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 15px #0000001a;cursor:pointer;transition:all .3s ease}.carousel-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.carousel-card img{width:100%;aspect-ratio:1;object-fit:cover}.carousel-card-caption{padding:12px 15px;font-weight:500;text-align:center;color:var(--text-color)}.cms-carousel-fullwidth{position:relative;width:100%}.carousel-fullwidth-slide{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;opacity:0;transition:opacity .8s ease-in-out}.carousel-fullwidth-slide.active{opacity:1}.carousel-fullwidth-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:60px 20px 30px;text-align:center}.carousel-fullwidth-caption h3{color:#fff;font-size:1.8rem;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.cms-carousel-fullwidth .carousel-dots{bottom:20px}.cms-carousel-fullwidth .carousel-arrow{background:#0000004d;color:#fff}.cms-carousel-fullwidth .carousel-arrow:hover{background:#0000008c}.cms-carousel-thumbnails{padding:3rem 0}.carousel-thumbnails-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.carousel-thumbnail{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;aspect-ratio:1}.carousel-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.carousel-thumbnail:hover img{transform:scale(1.05)}.carousel-thumbnail-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:#fff;padding:20px 10px 8px;font-size:.85rem;text-align:center}.carousel-lightbox{position:fixed;inset:0;background:#000000f2;z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center}.carousel-lightbox img{max-width:90%;max-height:85vh;object-fit:contain;border-radius:var(--radius-sm)}.lightbox-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;z-index:10}.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:#fff3;border:none;color:#fff;font-size:2rem;padding:20px 15px;cursor:pointer;transition:background .3s ease}.lightbox-prev:hover,.lightbox-next:hover{background:#ffffff4d}.lightbox-prev{left:20px}.lightbox-next{right:20px}.lightbox-caption{position:absolute;bottom:30px;left:50%;transform:translate(-50%);color:#fff;font-size:1.1rem;text-align:center;padding:10px 20px;background:#00000080;border-radius:var(--radius-md)}@media (min-width: 769px) and (max-width: 1024px){.cms-hero{height:500px;max-height:500px}.cms-hero-content h1{font-size:2.4rem}.cms-hero-subtitle{font-size:1.1rem}.cms-disciplines-grid{grid-template-columns:repeat(2,1fr);gap:1.2rem;padding:0 30px;max-width:100%;box-sizing:border-box}.cms-discipline-card{padding:20px;min-width:0}.cms-discipline-image{height:190px}.cms-discipline-content h3{font-size:1.4rem}.cms-discipline-content p{font-size:.95rem}.cms-discipline-price{font-size:1.05rem}.cms-features-grid.columns-4,.cms-features-grid.columns-3{grid-template-columns:repeat(2,1fr)}.cms-contact-content{gap:2rem}.cms-team-grid,.cms-testimonials-grid{grid-template-columns:repeat(2,1fr)}.app-feature-row,.app-feature-row.reverse{gap:2rem}.phone-frame{width:220px}.app-download-content{gap:2.5rem}.carousel-card{flex:0 0 calc(50% - 14px)}.carousel-thumbnails-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.cms-hero{height:300px;max-height:300px;background-size:cover;background-attachment:scroll}.cms-hero.full-height{height:100vh;max-height:100vh}.cms-hero-content{padding:0 20px;width:90%;max-width:100%}.cms-hero-content h1{font-size:1.8rem;line-height:1.2}.cms-hero-subtitle{font-size:.95rem;line-height:1.4;margin-top:20px}.cms-hero-buttons{flex-direction:column;width:100%}.cms-hero-buttons .btn{width:100%;font-size:.75rem;padding:12px;letter-spacing:0;box-sizing:border-box;text-align:center;white-space:normal;word-wrap:break-word}.cms-features-grid.columns-2,.cms-features-grid.columns-3,.cms-features-grid.columns-4,.cms-contact-content,.cms-contact-form .form-row{grid-template-columns:1fr}.cms-gallery-grid.columns-3,.cms-gallery-grid.columns-4{grid-template-columns:repeat(2,1fr)}.cms-carousel-banner .carousel-container{height:auto!important}.cms-carousel-banner{padding:.5rem 0}.carousel-card{flex:0 0 calc(100% - 14px)}.carousel-thumbnails-grid{grid-template-columns:repeat(2,1fr)}.carousel-arrow{width:32px;height:32px;font-size:.9rem}.carousel-prev{left:6px}.carousel-next{right:6px}.carousel-fullwidth-caption h3{font-size:1.2rem}.lightbox-prev,.lightbox-next{padding:15px 10px;font-size:1.5rem}}.course-details{display:flex;justify-content:center;gap:20px;margin-top:auto;padding-top:15px;padding-bottom:5px;border-top:1px solid var(--gray-200)}.course-details .detail-item{display:flex;flex-direction:row;align-items:baseline;gap:6px}.course-details .detail-item strong{color:var(--primary-color, var(--gray-900));font-size:.95rem}.course-details .detail-item span{font-size:1rem;color:var(--text-color)}.course-details+.btn{margin-top:15px}.home{width:100%;overflow-x:hidden;max-width:100vw}.hero{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);background-size:cover;background-position:center;background-repeat:no-repeat;color:var(--white);padding:100px 20px;text-align:center;min-height:500px;position:relative;display:flex;align-items:center;justify-content:center;width:100%;max-width:100vw;box-sizing:border-box}.hero-content{max-width:800px;z-index:2;width:100%;box-sizing:border-box}.hero h1{font-size:3.5rem;margin-bottom:20px;color:var(--white)}.hero-subtitle{font-size:1.3rem;margin-bottom:40px;opacity:.95}.hero-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.instrument-card{text-align:center}.instrument-icon{font-size:4rem;margin-bottom:20px}.instrument-image-container{width:100%;height:200px;margin-bottom:20px;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 15px #00000026;background:linear-gradient(135deg,var(--brand-color) 0%,var(--brand-color-dark, var(--brand-color-dark)) 100%);display:flex;align-items:center;justify-content:center}.instrument-placeholder{color:#fff;font-size:1.3rem;font-weight:600;text-align:center;opacity:.9}.instrument-image{width:100%;height:100%;object-fit:cover;transition:transform .3s}.instrument-card:hover .instrument-image{transform:scale(1.05)}.instrument-card h3{font-size:1.8rem;margin-bottom:15px}.instrument-card p{margin-bottom:20px;color:var(--text-muted);line-height:1.6}.benefits-section{background-color:var(--bg-color)}.benefit-item{padding:20px}.benefit-item h3{color:var(--secondary-color);margin-bottom:10px;font-size:1.3rem}.benefit-item p{color:var(--text-muted);line-height:1.6}.cta-section{background-color:var(--primary-color);color:var(--white)}.cta-content h2{color:var(--white);font-size:2.5rem;margin-bottom:20px}.cta-content p{font-size:1.2rem;margin-bottom:30px;opacity:.95}@media (min-width: 769px) and (max-width: 1024px){.hero{padding:80px 20px;min-height:400px}.hero h1{font-size:2.8rem}.hero-subtitle{font-size:1.15rem}.instrument-card h3{font-size:1.5rem}.instrument-image-container{height:180px}.cta-content h2{font-size:2.2rem}}@media (max-width: 768px){.hero h1{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:column;align-items:center}.instrument-icon{font-size:3rem}}.courses{width:100%}.courses-hero{position:relative;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);background-size:cover;background-position:center center;background-repeat:no-repeat;color:var(--white);min-height:350px;display:flex;align-items:center;justify-content:center;padding:80px 20px 60px;overflow:hidden}.courses-hero .hero-content{text-align:center;z-index:2;max-width:800px;margin:0 auto}.courses-hero h1{color:var(--white);font-size:2.8rem;margin-bottom:15px;text-shadow:0 2px 8px rgba(0,0,0,.2)}.courses-hero p{font-size:1.25rem;opacity:.95;text-shadow:0 1px 4px rgba(0,0,0,.15)}.course-detail{background:var(--white);border-radius:var(--radius-lg);padding:40px;margin-bottom:40px;box-shadow:0 5px 20px #0000001a}.atelier-section{background:var(--bg-color);padding:0;margin-top:20px}.atelier-hero{position:relative;min-height:400px;display:flex;align-items:center;justify-content:center;margin-bottom:40px}.atelier-hero .hero-content{text-align:center;z-index:2;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.atelier-hero h2{font-size:2.5rem;margin-bottom:15px;color:#fff}.atelier-hero p{font-size:1.2rem;color:#fff}.atelier-content{padding:40px 20px}.atelier-header{text-align:center;margin-bottom:40px;padding-top:40px}.atelier-header h2{font-size:2.5rem;color:var(--primary-color);margin-bottom:15px}.atelier-header p{font-size:1.2rem;color:var(--text-color)}.atelier-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:1200px;margin:40px auto 0;padding:0 20px 40px}.atelier-card{background:#fff;border-radius:var(--radius-lg);padding:30px;box-shadow:0 5px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column;width:auto;max-width:100%}.atelier-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.course-card-clickable{cursor:pointer}.course-card-clickable:hover h3{color:var(--accent-color);transition:color .3s ease}.course-card-clickable .btn{pointer-events:none}.atelier-card h3{color:var(--primary-color);font-size:1.8rem;margin-bottom:15px}.course-header{display:flex;align-items:center;gap:30px;margin-bottom:30px;padding-bottom:30px;border-bottom:2px solid var(--gray-light)}.course-icon{font-size:5rem}.course-image-container{width:100%;height:250px;aspect-ratio:4/3;margin-bottom:20px;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 15px #00000026;background:linear-gradient(135deg,var(--brand-color) 0%,var(--brand-color-dark, var(--brand-color-dark)) 100%);display:flex;align-items:center;justify-content:center}.course-placeholder{color:#fff;font-size:1.5rem;font-weight:600;text-align:center;opacity:.9}.course-image{width:100%;height:100%;object-fit:cover;transition:transform .3s}.course-card:hover .course-image{transform:scale(1.05)}.courses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:30px;margin-top:40px}.course-card{background:var(--white);border-radius:var(--radius-lg);padding:30px;box-shadow:0 5px 20px #0000001a;transition:all .3s;display:flex;flex-direction:column}.course-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.course-card .course-icon{font-size:4rem;margin-bottom:20px;text-align:center}.course-card h2{color:var(--primary-color);margin-bottom:15px;text-align:center}.course-card .course-description{color:var(--text-muted);margin-bottom:20px;line-height:1.6;text-align:center;flex-grow:1}.course-additional-text{font-size:.95rem;color:var(--text-subtle);font-style:italic;text-align:center;margin:15px 0 20px;line-height:1.4}.course-card .course-details{background:#ffffff80;border-radius:var(--radius-md);padding:20px;margin-bottom:30px;text-align:center}.course-card .detail-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 0;color:var(--text-muted);text-align:center}.course-card .detail-item strong{color:var(--primary-color);margin-bottom:5px;font-size:1rem}.course-card .detail-item>span{text-align:center;font-size:1.1rem}.price-includes{display:block;font-size:.85em;color:var(--accent-color);font-weight:600;font-style:italic;margin-top:4px}.course-card .btn{width:100%;text-align:center;margin-top:auto;padding:15px 20px}.course-info h2{font-size:2.5rem;margin-bottom:10px}.course-description{font-size:1.2rem;color:var(--text-muted)}.course-body{display:grid;gap:30px}.course-section h3{color:var(--secondary-color);margin-bottom:15px;font-size:1.5rem}.levels{display:flex;gap:15px;flex-wrap:wrap}.level-badge{background-color:var(--accent-color);color:var(--white);padding:8px 20px;border-radius:var(--radius-xl);font-weight:500;font-size:.95rem}.features-list{list-style:none}.features-list li{padding:10px 0 10px 30px;position:relative;color:var(--text-muted);line-height:1.6}.features-list li:before{content:"✓";position:absolute;left:0;color:var(--secondary-color);font-weight:700;font-size:1.2rem}.course-footer{display:flex;justify-content:space-between;align-items:center;margin-top:30px;padding-top:30px;border-top:2px solid var(--gray-light)}.course-pricing{display:flex;flex-direction:column;gap:10px}.duration{font-size:1rem;color:var(--text-muted)}.price{font-size:1.5rem;font-weight:700;color:var(--secondary-color)}.cta-section{background-color:transparent}.cta-content{text-align:center;max-width:700px;margin:0 auto}.cta-content h2{font-size:2.5rem;margin-bottom:20px}.cta-content p{font-size:1.2rem;margin-bottom:30px;color:var(--text-muted)}@media (min-width: 769px) and (max-width: 1024px){.courses-hero{min-height:280px;padding:70px 20px 50px}.courses-hero h1{font-size:2.2rem}.courses-grid{grid-template-columns:repeat(2,1fr);gap:24px;padding:0 16px}.course-card{padding:24px}.course-card .course-image-container{height:200px}.course-card h2{font-size:1.5rem}.atelier-grid{grid-template-columns:repeat(2,1fr);gap:24px;padding:0 16px 40px}.atelier-card{padding:24px}.atelier-header h2{font-size:2rem}.course-detail{padding:30px}}@media (max-width: 768px){.course-header{flex-direction:column;text-align:center}.course-footer{flex-direction:column;gap:20px}.course-icon{font-size:4rem}.course-info h2{font-size:2rem}.courses-hero{min-height:240px;padding:60px 16px 40px}.courses-hero h1{font-size:1.8rem}.courses-grid{grid-template-columns:1fr;gap:20px;padding:0 10px}.course-card{padding:20px;display:flex;flex-direction:column}.course-card .course-image-container{height:180px;margin-bottom:15px}.course-card h2{font-size:1.4rem;margin-bottom:10px}.course-card .course-description{font-size:.95rem;margin-bottom:15px}.course-card .course-details{padding:15px;margin-bottom:15px}.course-card .detail-item{padding:6px 0;font-size:.95rem}.atelier-grid{grid-template-columns:1fr;gap:20px;padding:0 10px 40px}.atelier-card{padding:20px}.atelier-card .course-image-container{height:180px;margin-bottom:15px}.atelier-card h3{font-size:1.4rem}.atelier-header{padding-top:30px;margin-bottom:25px}.atelier-header h2{font-size:1.6rem}}.calendar{max-width:500px;width:100%;margin:0 auto;background:var(--white);border:2px solid var(--gray-light);border-radius:var(--radius-md);padding:20px;box-sizing:border-box;overflow:hidden}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendar-title{font-size:1.3rem;color:var(--primary-color);margin:0}.calendar-nav{background:var(--accent-color);color:var(--white);border:none;width:40px;height:40px;border-radius:var(--radius-full);font-size:1.5rem;cursor:pointer;transition:background-color .3s ease}.calendar-nav:hover:not(:disabled){background-color:var(--accent-color-dark)}.calendar-nav:disabled{background-color:var(--gray-light);cursor:not-allowed}.calendar-days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:10px}.calendar-day-name{text-align:center;font-weight:600;color:var(--primary-color);padding:10px 0;font-size:.9rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.calendar-day{aspect-ratio:1;min-width:35px;min-height:35px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all .2s ease;border:2px solid transparent;position:relative;font-size:.85rem}.calendar-day:not(.empty):not(.disabled):not(.blocked):not(.unavailable){border:2px solid var(--gray-900);background-color:#fff}.calendar-day .day-number{font-size:1rem;line-height:1}.calendar-day:not(.empty):not(.disabled):not(.blocked):not(.unavailable):hover{background-color:#3498db1a;border-color:var(--accent-color)}.calendar-day.empty{cursor:default}.calendar-day.disabled{color:var(--text-hint);background-color:var(--gray-100);cursor:not-allowed;opacity:.5;border:2px solid transparent;pointer-events:none}.calendar-day.blocked{background-color:var(--border-color);color:var(--text-light);cursor:not-allowed;border:2px solid transparent;opacity:.5;pointer-events:none}.calendar-day.unavailable{background-color:var(--gray-100);color:var(--text-hint);cursor:not-allowed;opacity:.5;border:2px solid transparent;pointer-events:none}.calendar-day.selected,.calendar-day.selected:not(.empty):not(.disabled):not(.blocked):not(.unavailable){background-color:var(--accent-color);color:var(--white);border-color:var(--accent-color);font-weight:700}@media (max-width: 768px){.calendar{padding:15px}.calendar-title{font-size:1.1rem}.calendar-nav{width:35px;height:35px;font-size:1.3rem}.calendar-day-name{font-size:.8rem}.calendar-day{min-width:30px;min-height:30px;font-size:.85rem}.calendar-day .day-number{font-size:.9rem}}.toast{position:fixed;top:20px;right:20px;background:#fff;padding:16px 20px;border-radius:var(--radius-md);box-shadow:0 8px 24px #00000026;display:flex;align-items:center;gap:12px;min-width:300px;max-width:500px;z-index:var(--z-toast);animation:slideIn .3s ease-out;border-left:4px solid}.toast-success{border-left-color:var(--success-color)}.toast-error{border-left-color:var(--error-color)}.toast-warning{border-left-color:var(--warning-color)}.toast-info{border-left-color:var(--blue-info-bootstrap)}.toast-icon{font-size:1.5rem;flex-shrink:0}.toast-message{flex:1;color:var(--text-color);font-weight:500}.toast-close{background:none;border:none;font-size:1.5rem;color:var(--text-light);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:all .2s;flex-shrink:0}.toast-close:hover{background:#0000000d;color:var(--text-color)}.toast-exit{animation:slideOut .3s ease-in forwards}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}@media (max-width: 768px){.toast{left:20px;right:20px;min-width:auto;max-width:none}@keyframes slideIn{0%{transform:translateY(-100px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100px);opacity:0}}}.booking{width:100%}.booking .form-step{scroll-margin-top:20px}.booking-hero{position:relative;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--primary-color) 100%);background-size:cover;background-position:center center;background-repeat:no-repeat;color:var(--white);min-height:350px;display:flex;align-items:center;justify-content:center;padding:80px 20px 60px;overflow:hidden}.booking-hero .hero-content{text-align:center;z-index:2;max-width:800px;margin:0 auto}.booking-hero h1{color:var(--white);font-size:2.8rem;margin-bottom:15px;text-shadow:0 2px 8px rgba(0,0,0,.2)}.booking-hero p{font-size:1.25rem;opacity:.95;text-shadow:0 1px 4px rgba(0,0,0,.15)}.booking-form{max-width:900px;margin:0 auto}.form-step{background:var(--white);border-radius:var(--radius-lg);padding:40px;margin-bottom:30px;box-shadow:0 5px 15px #0000001a}.form-step h2{color:var(--primary-color);margin-bottom:30px;font-size:1.8rem}.course-options{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:600px;margin:0 auto}.course-option{position:relative;cursor:pointer}.course-option input[type=radio]{position:absolute;opacity:0}.option-content{display:flex;flex-direction:column;align-items:center;gap:15px;padding:30px;border:3px solid var(--gray-light);border-radius:var(--radius-md);transition:all .3s ease}.course-option:hover .option-content{border-color:var(--accent-color);transform:translateY(-5px);box-shadow:0 5px 15px #3498db33}.course-option.selected .option-content{border-color:var(--secondary-color);background-color:#e74c3c0d}.option-icon{font-size:3rem}.option-text{font-size:1.2rem;font-weight:600;color:var(--primary-color)}.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px}.time-slot{padding:15px 20px;border:2px solid var(--gray-light);border-radius:var(--radius-md);background:var(--white);font-size:1.1rem;font-weight:500;transition:all .3s ease}.time-slot:hover{border-color:var(--accent-color);background-color:#3498db0d}.time-slot.selected{border-color:var(--secondary-color);background-color:var(--secondary-color);color:var(--white)}.time-slot small{display:block;font-size:.8rem;margin-top:5px;opacity:.8}.no-slots{padding:20px;text-align:center;color:var(--text-muted);background-color:#ffffff80;border-radius:var(--radius-md)}.info-message{padding:20px;text-align:center;color:var(--text-muted);background-color:var(--warning-bg-light);border:1px solid var(--warning-color);border-radius:var(--radius-md)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{margin-bottom:8px;font-weight:500;color:var(--primary-color)}.form-group input,.form-group select,.form-group textarea{padding:12px 15px;border:2px solid var(--gray-light);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color)}.form-group textarea{resize:vertical}.submit-btn{width:100%;margin-top:20px;padding:18px;font-size:1.2rem}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.input-error{border-color:var(--secondary-color)}.field-error{color:var(--secondary-color);font-size:.85rem;margin-top:4px;display:block}.loading-inline{display:flex;align-items:center;gap:12px;padding:15px;color:var(--text-muted)}@media (min-width: 769px) and (max-width: 1024px){.booking-hero{min-height:280px;padding:70px 20px 50px}.booking-hero h1{font-size:2.3rem}.form-step{padding:30px}.booking-form{max-width:750px}.course-options{grid-template-columns:repeat(2,1fr);max-width:500px}}@media (max-width: 768px){.booking-hero{min-height:240px;padding:60px 16px 40px}.booking-hero h1{font-size:1.8rem}.booking-hero p{font-size:1.05rem}.form-step{padding:25px}.form-grid,.course-options{grid-template-columns:1fr}.time-slots{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.animated-splash{position:fixed;inset:0;z-index:var(--z-splash, 9999);background:var(--brand-color, var(--brand-color));transition:opacity .3s ease-out}.animated-splash.fade-out{opacity:0;pointer-events:none}.animated-splash .splash-video{display:block;width:100%;height:100%;object-fit:cover}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden;max-width:100vw;background:#f3dcb0}:root{--keyboard-height: 0px;--font-family-primary: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--font-family-mono: "Monaco", "Consolas", monospace;--primary-color: #2c3e50;--secondary-color: #e74c3c;--secondary-color-dark: #c0392b;--accent-color: #3498db;--accent-color-dark: #2980b9;--brand-color: #ea8817;--brand-color-dark: #d4770f;--text-color: #333;--text-muted: #555;--text-light: #767676;--text-dark: #222;--text-subtle: #6b6b6b;--text-hint: #767676;--text-inverse: #ffffff;--bg-color: #F3DCB0;--bg-secondary: #f8f9fa;--bg-tertiary: #f5f7fa;--bg-card: #ffffff;--bg-hover: #f0f2f5;--bg-dark: #1a1a2e;--bg-dark-secondary: #16213e;--white: #ffffff;--gray-light: #ecf0f1;--border-color: #e0e0e0;--border-light: #e9ecef;--border-focus: #667eea;--accent-purple: #667eea;--accent-purple-dark: #764ba2;--success-color: #27ae60;--success-color-dark: #229954;--success-color-alt: #2ecc71;--success-bg-light: #d4edda;--success-text-dark: #155724;--success-border-light: #c3e6cb;--error-color: #e74c3c;--error-color-dark: #c0392b;--error-bg-light: #f8d7da;--error-text-dark: #721c24;--error-border-light: #f5c6cb;--warning-color: #f39c12;--warning-color-alt: #e67e22;--warning-bg-light: #fff3cd;--warning-text-dark: #856404;--info-color: #3498db;--info-bg-light: #e8f4fd;--purple-500: #9b59b6;--purple-600: #8e44ad;--purple-700: #7b1fa2;--purple-400: #a78bfa;--indigo-500: #6366f1;--green-500: #4caf50;--green-600: #2e7d32;--green-700: #28a745;--red-500: #ff4444;--red-600: #c62828;--red-700: #c00;--orange-500: #ff9800;--orange-600: #e65100;--gold-color: #ffd700;--yellow-500: #f1c40f;--blue-500: #3b82f6;--blue-400: #60a5fa;--blue-600: #1976d2;--blue-700: #0056b3;--blue-800: #1565c0;--blue-900: #1e3a5f;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-800: #1e293b;--slate-900: #0f172a;--ios-blue: #007AFF;--ios-gray: #8e8e93;--ios-separator: #e5e5ea;--ios-bg: #f2f2f7;--ios-dark: #1c1c1e;--ios-red: #ff3b30;--ios-teal: #5ac8fa;--flat-muted: #7f8c8d;--flat-silver: #bdc3c7;--flat-asbestos: #95a5a6;--flat-dark: #34495e;--gray-50: #fafafa;--gray-100: #f0f0f0;--gray-150: #f1f5f9;--gray-200: #eee;--gray-250: #e5e5ea;--gray-300: #ddd;--gray-350: #d0d0d0;--gray-400: #ccc;--gray-450: #cbd5e1;--gray-500: #767676;--gray-600: #888;--gray-650: #667781;--gray-700: #555;--gray-750: #636e72;--gray-800: #555;--gray-900: #333;--black: #000;--error-bg-subtle: #fee;--error-bg-lighter: #fcc;--error-inline: #c33;--muted-gray: #6c757d;--green-dark: #228b22;--green-800: #2d5a27;--accent-red: #e94560;--orange-warm: #ff9500;--orange-deep: #ff6b00;--orange-muted: #d68910;--orange-accent: #e8a44a;--orange-bg-light: #fff8e1;--orange-bg-cream: #fffbf0;--orange-bg-warm: #fff3e0;--orange-bg-soft: #fff8f0;--orange-bg-pale: #fffbea;--orange-bg-subtle: #fff9e6;--orange-amber: #ffcc80;--yellow-light: #fff9c4;--yellow-bright: #fff176;--purple-vivid: #7c3aed;--purple-deep: #5a67d8;--pink-500: #e91e63;--pink-700: #c2185b;--red-warm: #ff6b81;--red-macos: #ff5f56;--red-danger: #dc3545;--red-dark: #d63027;--red-burnt: #e04b42;--green-whatsapp: #25d366;--green-bright: #219a52;--teal-500: #607d8b;--brown-500: #5d4037;--brown-dark: #92400e;--blue-bg-light: #f0f7ff;--blue-bg-soft: #e8f4fc;--indigo-bg-soft: #e8ecff;--neutral-bg: #f5f6f6;--neutral-bg-cool: #e8ecf3;--neutral-border: #e3e8ef;--neutral-gray: #cfd8dc;--neutral-dim: #eceff1;--slate-dim: #5a6268;--slate-deep: #54656f;--dark-500: #374151;--gray-muted: #adb5bd;--success-bg-soft: #e8f8f0;--error-bg-rose: #fef5f5;--blue-bootstrap: #007bff;--blue-material: #0d47a1;--blue-material-500: #1e88e5;--blue-link: #1f618d;--blue-indigo: #4338ca;--blue-gradient: #4facfe;--blue-sky: #53bdeb;--blue-periwinkle: #5a6fd6;--blue-stripe: #6772e5;--blue-indigo-300: #818cf8;--blue-indigo-bg: #8b9cf7;--blue-info-bootstrap: #17a2b8;--blue-bg-pale: #b8daff;--blue-bg-wash: #bfdbfe;--blue-bg-ice: #d1e9f9;--blue-info-bg: #d1ecf1;--blue-bg-cloud: #d4e9f7;--blue-bg-frost: #e1f2fb;--blue-bg-mist: #e8f4f8;--blue-bg-sky: #eff6ff;--blue-indigo-bg-light: #e0e7ff;--blue-indigo-bg-pale: #eef0ff;--blue-bg-faint: #f0f3ff;--green-emerald: #059669;--green-forest: #065f46;--green-jade: #10b981;--green-teal-dark: #1a6b47;--green-material-dark: #1e7e34;--green-material: #1e8449;--green-mid: #2c8a61;--green-neon: #38ef7d;--green-material-300: #81c784;--green-material-200: #a5d6a7;--green-whatsapp-bg: #dcf8c6;--green-emerald-bg: #d1fae5;--green-bg-fresh: #e8f8f5;--green-teal-accent: #11998e;--red-crimson: #a00;--red-bootstrap-dark: #c82333;--red-coral: #f5576c;--red-400: #f87171;--red-bg-light: #fee2e2;--red-bg-blush: #fdeaea;--red-bg-pink: #ffe8e8;--red-bg-faint: #fdd;--orange-material: #ffb74d;--orange-leather: #d47a14;--orange-amber-dark: #78350f;--orange-amber-muted: #664d03;--amber-300: #fcd34d;--amber-400: #fbbf24;--amber-200: #fde68a;--orange-butter: #ffeaa7;--orange-bg-peach: #fef3e2;--orange-bg-bisque: #fde8cc;--orange-bg-dawn: #fff7ed;--purple-deep-dark: #383d8f;--purple-vivid-dark: #7b4fc4;--purple-gradient: #f093fb;--purple-bg-light: #f0e6ff;--purple-bg-subtle: #e2e3ff;--dark-navy: #1a2634;--dark-700: #1f2937;--dark-600: #2d3748;--dark-chat-bg: #41525d;--neutral-silver: #9e9e9e;--neutral-gray-alt: #aaa;--neutral-cool: #a0aec0;--neutral-sand: #b8956a;--neutral-beige: #d4c4ad;--neutral-warm: #e5ddd5;--neutral-divider: #d1d1d6;--neutral-border-soft: #d5dbdb;--neutral-border-light: #dee2e6;--neutral-border-faint: #e2e3e5;--neutral-border-cool: #e4e6e9;--neutral-bg-warm: #e8ecf1;--neutral-bg-soft: #ebebeb;--neutral-bg-blue: #f0f1f5;--neutral-bg-pale: #f3f4f6;--brown-accent: #8c6d4f;--info-dark: #0c5460;--cyan-gradient: #00f2fe;--shadow-sm: 0 2px 5px rgba(0, 0, 0, .08);--shadow-md: 0 5px 15px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .3);--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-navbar: 1000;--z-navbar-menu: 1001;--z-navbar-overlay: 1002;--z-modal-backdrop: 2000;--z-modal: 2001;--z-toast: 3000;--z-cookie: 4000;--z-loading: 5000;--z-splash: 9999;--radius-sm: 5px;--radius-md: 10px;--radius-lg: 15px;--radius-xl: 20px;--radius-pill: 50px;--radius-full: 50%;--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}body{font-family:var(--font-family-primary);line-height:1.4;color:var(--text-color);background-color:var(--bg-color);min-height:100vh;min-height:-webkit-fill-available}#root{min-height:100vh;min-height:-webkit-fill-available;display:flex;flex-direction:column}.App{display:flex;flex-direction:column;min-height:100vh;min-height:-webkit-fill-available;width:100%;overflow-x:hidden;max-width:100vw}.main-content{flex:1;margin-top:80px;width:100%;overflow-x:hidden;max-width:100vw}h1,h2,h3,h4,h5,h6{color:var(--primary-color);margin-bottom:1rem}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none}button:focus:not(:focus-visible){outline:none}button:focus-visible{outline:2px solid var(--brand-color);outline-offset:2px}input,textarea,select{font-size:16px!important}.btn-back-floating{position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);left:16px;z-index:1001;display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:#fffffff2!important;backdrop-filter:blur(10px);border-radius:var(--radius-full);color:var(--brand-color)!important;font-size:1.3rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;box-shadow:0 2px 10px #00000026;border:none}.platform-android .btn-back-floating{top:calc(max(env(safe-area-inset-top,0px),36px) + 12px)}.btn-back-floating:hover{background:var(--brand-color)!important;color:var(--white)!important;transform:scale(1.1);box-shadow:0 4px 15px #667eea66}body.chordsheet-fullscreen-active .btn-back-floating:not(.chord-sheet__fs-back){display:none!important}.modal-close{position:absolute;top:15px;right:15px;background:#0000001a!important;color:var(--text-muted)!important;border:none;width:35px;height:35px;border-radius:var(--radius-full);font-size:18px;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#667eea33!important;color:var(--brand-color)!important;transform:scale(1.1)}@media (max-width: 768px){input,textarea,select{font-size:16px!important}input[type=text],input[type=email],input[type=password],input[type=tel],textarea{-webkit-appearance:none;appearance:none}}.spinner-inline{width:24px;height:24px;border:3px solid var(--border-color);border-top:3px solid var(--brand-color);border-radius:var(--radius-full);animation:spin .8s linear infinite;display:inline-block}.spinner-wheel{border:4px solid var(--border-color);border-top:4px solid var(--brand-color);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:15px}.loading-container .spinner-wheel{width:40px;height:40px}.loading-container p{color:var(--text-muted);font-size:1rem}.teacher-dashboard,.teacher-students,.teacher-schedule,.teacher-management,.teacher-trials,.teacher-events,.teacher-gallery,.teacher-settings,.teacher-hours-history,.teacher-cancel-courses,.student-dashboard,.student-schedule,.student-profile,.student-calendar,.student-enrollments,.student-reservations,.student-enroll-course,.student-events,.my-tickets,.student-settings,.student-gallery{padding-bottom:calc(env(safe-area-inset-bottom,20px) + 40px)}.messages-v2 .conversations-sidebar,.messages-v2 .conversation-view{padding-bottom:calc(env(safe-area-inset-bottom,0px) + 15px)}.fullscreen-page{padding-top:calc(env(safe-area-inset-top,0px) + 64px)}a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--brand-color);outline-offset:2px}.skip-to-content{position:absolute;top:-100%;left:50%;transform:translate(-50%);background:var(--brand-color);color:#fff;padding:12px 24px;border-radius:0 0 var(--radius-md) var(--radius-md);z-index:10000;font-weight:600;transition:top .2s ease;text-decoration:none}.skip-to-content:focus{top:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.card:hover,.btn:hover,.btn-primary:hover,.btn-secondary:hover,.social-link:hover,.cookie-btn-accept:hover,.btn-back-floating:hover,.teacher-button:hover{transform:none!important}}@media (prefers-contrast: high){:root{--shadow-sm: 0 0 0 1px var(--border-color);--shadow-md: 0 0 0 2px var(--border-color);--shadow-lg: 0 0 0 3px var(--border-color)}.card{border:2px solid var(--text-color)}.navbar{border-bottom:2px solid var(--text-color)}}@media (hover: none) and (pointer: coarse){.card:hover,[class*=-card]:hover,.ds-card:hover,.ds-stat-card:hover,.ds-list-item:hover,.list-item:hover,.notif-item:hover,.event-section:hover,.conversation-item:hover,.teacher-item:hover,.preview-item:hover,.proposal-item:hover,.quick-stat:hover,.hours-entry:hover,.payment-item:hover,.subscription-item:hover,.cms-feature-item:hover,.cms-discipline-card:hover,.value-card:hover,.discipline-card:hover,.schedule-day:hover,.filter-btn:hover,.tab-btn:hover,.tab:hover,.tier-quantity-row:hover,.date-option-header:hover,.time-slot:hover,.btn-primary:hover,.btn-secondary:hover,.btn-danger:hover,.btn-submit:hover,.btn-cancel:hover,.btn-confirm:hover,.btn-add-media:hover,.btn-send:hover,.btn-retry:hover,.btn-book:hover,.btn-save:hover,.btn-logout:hover,.btn-grouped-payment:hover,.btn-finalize:hover,.btn-reenroll:hover,.btn-pay-enrollment:hover,.btn-pay-all-alert:hover{transform:none!important}}.btn,.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;font-family:inherit;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);text-decoration:none;line-height:1.4;white-space:nowrap;user-select:none}.btn:disabled,.ds-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary,.ds-btn-primary{background:var(--brand-color);color:var(--white)}.btn-primary:hover:not(:disabled),.ds-btn-primary:hover:not(:disabled){background:var(--brand-color-dark);transform:translateY(-2px);box-shadow:0 4px 15px #ea881759}.btn-secondary,.ds-btn-secondary{background:var(--white);color:var(--brand-color);border:2px solid var(--brand-color)}.btn-secondary:hover:not(:disabled),.ds-btn-secondary:hover:not(:disabled){background:var(--brand-color);color:var(--white);transform:translateY(-2px)}.btn-danger,.ds-btn-danger{background:var(--error-color);color:var(--white)}.btn-danger:hover:not(:disabled),.ds-btn-danger:hover:not(:disabled){background:var(--error-color-dark);transform:translateY(-2px);box-shadow:0 4px 15px #e74c3c59}.btn-cancel,.ds-btn-cancel{background:var(--gray-light);color:var(--text-color)}.btn-cancel:hover:not(:disabled),.ds-btn-cancel:hover:not(:disabled){background:var(--gray-300)}.btn-success,.ds-btn-success{background:var(--success-color);color:var(--white)}.btn-success:hover:not(:disabled),.ds-btn-success:hover:not(:disabled){background:var(--success-color-dark);transform:translateY(-2px);box-shadow:0 4px 15px #27ae6059}.btn-ghost,.ds-btn-ghost{background:transparent;color:var(--brand-color);padding:8px 16px}.btn-ghost:hover:not(:disabled),.ds-btn-ghost:hover:not(:disabled){background:#ea881714}.btn-sm{padding:8px 16px;font-size:.85rem;border-radius:var(--radius-sm)}.btn-lg{padding:16px 32px;font-size:1.1rem;border-radius:var(--radius-lg)}.btn-block{width:100%}.btn-icon,.btn-icon-small{width:36px;height:36px;padding:0;border-radius:var(--radius-full);font-size:1rem}.btn-icon-small{width:30px;height:30px;font-size:.85rem}.card,.ds-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover,.ds-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.card-static,.ds-card-static{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.stat-card,.ds-stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px 24px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:all var(--transition-normal);text-decoration:none;color:inherit}.stat-card:hover,.ds-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat-card.clickable{cursor:pointer}.stat-card.primary,.stat-card.brand{border-left:4px solid var(--brand-color)}.stat-card.success{border-left:4px solid var(--success-color)}.stat-card.info{border-left:4px solid var(--accent-color)}.stat-card.warning{border-left:4px solid var(--warning-color)}.stat-card.danger{border-left:4px solid var(--error-color)}.stat-card.students{border-left:4px solid var(--accent-color)}.stat-card.trials{border-left:4px solid var(--warning-color)}.stat-card.messages{border-left:4px solid var(--brand-color);cursor:pointer}.stat-card.hours{border-left:4px solid var(--success-color)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-info{flex:1;min-width:0}.stat-label{font-size:.85rem;color:var(--text-muted);margin-bottom:4px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-dark);line-height:1.2}.modal-overlay,.ds-modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:20px;padding-top:calc(env(safe-area-inset-top,20px) + 20px);padding-bottom:calc(env(safe-area-inset-bottom,20px) + 20px);animation:ds-fadeIn .2s ease}.modal-content,.ds-modal-content{background:var(--bg-card);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:calc(100vh - env(safe-area-inset-top,40px) - env(safe-area-inset-bottom,40px) - 60px);height:-webkit-fit-content;height:fit-content;overflow-y:auto;box-shadow:var(--shadow-xl);position:relative;animation:ds-slideUp .3s ease;margin:auto}.modal-header,.ds-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border-light)}.modal-header h2,.modal-header h3,.ds-modal-header h2,.ds-modal-header h3{margin:0;font-size:1.2rem;color:var(--primary-color)}.modal-body,.ds-modal-body{padding:20px 24px}.modal-footer,.modal-actions,.ds-modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 20px;border-top:1px solid var(--border-light)}.modal-content.modal-sm{max-width:400px}.modal-content.modal-lg{max-width:700px}.modal-content.modal-xl{max-width:900px}@keyframes ds-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes ds-slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.form-group,.ds-form-group{margin-bottom:20px}.form-group label,.ds-form-group label{display:block;margin-bottom:6px;font-weight:600;color:var(--primary-color);font-size:.9rem}.form-group input,.form-group select,.form-group textarea,.ds-form-group input,.ds-form-group select,.ds-form-group textarea{width:100%;padding:12px 15px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;transition:border-color var(--transition-normal),box-shadow var(--transition-normal);background:var(--bg-card);color:var(--text-color)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.ds-form-group input:focus,.ds-form-group select:focus,.ds-form-group textarea:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 3px #ea88171f}.form-group textarea,.ds-form-group textarea{resize:vertical;min-height:100px}.form-group small,.ds-form-group small{display:block;margin-top:4px;color:var(--text-light);font-size:.8rem}.form-row,.ds-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 480px){.form-row,.ds-form-row{grid-template-columns:1fr}}.empty-state,.ds-empty-state{text-align:center;padding:48px 24px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.empty-state-icon,.ds-empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.6}.empty-state h3,.ds-empty-state h3{font-size:1.3rem;margin:0 0 8px;color:var(--primary-color)}.empty-state p,.ds-empty-state p{font-size:.95rem;color:var(--text-muted);margin:0;line-height:1.5}.badge,.ds-badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:var(--radius-xl);line-height:1.3;white-space:nowrap}.badge-success{background:var(--success-bg-light);color:var(--success-text-dark)}.badge-danger{background:var(--error-bg-light);color:var(--error-text-dark)}.badge-warning{background:var(--warning-bg-light);color:var(--warning-text-dark)}.badge-info{background:var(--info-bg-light);color:var(--info-color)}.badge-brand{background:#ea88171f;color:var(--brand-color)}.badge-neutral{background:var(--gray-100);color:var(--text-muted)}.detail-row,.ds-detail-row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-light)}.detail-row:last-child,.ds-detail-row:last-child{border-bottom:none}.detail-icon,.ds-detail-icon{flex-shrink:0;width:24px;text-align:center;color:var(--brand-color);font-size:1rem;margin-top:2px}.detail-row .label,.ds-detail-row .label{font-size:.85rem;color:var(--text-muted);min-width:100px}.detail-row .value,.ds-detail-row .value{font-size:.95rem;color:var(--text-color);font-weight:500}.settings-section,.ds-settings-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.settings-section h3,.ds-settings-section h3{font-size:1.1rem;color:var(--primary-color);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.page-header,.ds-page-header{text-align:center;padding:40px 20px 30px}.page-header h1,.ds-page-header h1{font-size:1.8rem;color:var(--primary-color);margin:0 0 8px}.page-header p,.ds-page-header p{font-size:1rem;color:var(--text-muted);margin:0}.alert,.ds-alert{padding:14px 18px;border-radius:var(--radius-md);font-size:.9rem;line-height:1.5;margin-bottom:16px}.alert-success{background:var(--success-bg-light);color:var(--success-text-dark);border:1px solid var(--success-border-light)}.alert-danger,.alert-error{background:var(--error-bg-light);color:var(--error-text-dark);border:1px solid var(--error-border-light)}.alert-warning{background:var(--warning-bg-light);color:var(--warning-text-dark);border:1px solid rgba(243,156,18,.2)}.alert-info{background:var(--info-bg-light);color:var(--info-color);border:1px solid rgba(52,152,219,.2)}.error-message,.ds-error-message{color:var(--error-color);font-size:.85rem;margin-top:6px}.success-message,.ds-success-message{color:var(--success-color);font-size:.85rem;margin-top:6px}.ds-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden}.ds-table th{background:var(--bg-secondary);padding:12px 16px;font-weight:600;font-size:.85rem;color:var(--text-muted);text-align:left;border-bottom:2px solid var(--border-light)}.ds-table td{padding:12px 16px;font-size:.9rem;border-bottom:1px solid var(--border-light)}.ds-table tbody tr:hover{background:var(--bg-hover)}.tabs,.ds-tabs{display:flex;gap:4px;background:var(--gray-100);border-radius:var(--radius-md);padding:4px;margin-bottom:24px}.tab,.ds-tab{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);text-align:center;font-family:inherit}.tab:hover,.ds-tab:hover{color:var(--text-color)}.tab.active,.ds-tab.active{background:var(--bg-card);color:var(--brand-color);font-weight:600;box-shadow:var(--shadow-sm)}.search-bar,.ds-search-bar{position:relative;margin-bottom:20px}.search-bar input,.ds-search-bar input{width:100%;padding:12px 16px 12px 44px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:.95rem;font-family:inherit;transition:border-color var(--transition-normal);background:var(--bg-card)}.search-bar input:focus,.ds-search-bar input:focus{outline:none;border-color:var(--brand-color)}.search-bar .search-icon,.ds-search-bar .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:1rem;pointer-events:none}.list-item,.ds-list-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:all var(--transition-fast);margin-bottom:8px}.list-item:hover,.ds-list-item:hover{border-color:var(--brand-color);box-shadow:0 2px 8px #ea881714}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-brand{color:var(--brand-color)}.text-danger{color:var(--error-color)}.text-success{color:var(--success-color)}.text-sm{font-size:.85rem}.text-lg{font-size:1.2rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.p-0{padding:0}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}.d-flex{display:flex}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.align-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1}.hidden{display:none}.visible{display:block}@media (min-width: 769px) and (max-width: 1024px){.stat-card,.ds-stat-card{padding:16px 20px;gap:12px}.stat-icon{width:40px;height:40px;font-size:1.1rem}.stat-value{font-size:1.3rem}.stat-label{font-size:.8rem}.modal-content,.ds-modal-content{max-width:80vw}.modal-content.modal-lg{max-width:85vw}.modal-content.modal-xl{max-width:90vw}.ds-table th{padding:10px 12px;font-size:.82rem}.ds-table td{padding:10px 12px;font-size:.88rem}.tabs,.ds-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab,.ds-tab{padding:8px 14px;font-size:.85rem;white-space:nowrap}.card,.ds-card,.settings-section,.ds-settings-section{padding:20px}.page-header h1,.ds-page-header h1{font-size:1.6rem}.hide-tablet{display:none}}@media (max-width: 768px){.hide-mobile{display:none}.stat-card,.ds-stat-card{padding:14px 16px;gap:10px}.stat-icon{width:36px;height:36px;font-size:1rem}.stat-value{font-size:1.2rem}.card,.ds-card{padding:16px}.modal-content,.ds-modal-content{max-width:95vw}.modal-header,.ds-modal-header{padding:16px 18px 12px}.modal-body,.ds-modal-body{padding:16px 18px}.modal-footer,.modal-actions,.ds-modal-footer{padding:12px 18px 16px;flex-wrap:wrap}.page-header,.ds-page-header{padding:30px 16px 20px}.page-header h1,.ds-page-header h1{font-size:1.4rem}.settings-section,.ds-settings-section{padding:16px}.btn,.ds-btn{padding:10px 20px;font-size:.9rem}.btn-lg{padding:14px 28px;font-size:1rem}.tabs,.ds-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab,.ds-tab{padding:8px 12px;font-size:.85rem;white-space:nowrap}}@media (min-width: 769px){.hide-desktop{display:none}}
