:root{--bg:#0b0b0b;--text:#f2f2f2;--muted:#b9b9b9;--accent:#e0392d;--card:#121212;--border:#1e1e1e}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica Neue,Arial,sans-serif}.wrapper{max-width:1100px;margin:0 auto;padding:24px}.header{display:flex;align-items:center;gap:16px;padding:8px 0 24px}.logo{width:72px;height:auto}.title{margin:0;font-size:40px;letter-spacing:1px}.accent{color:var(--accent)}.hero{background:linear-gradient(180deg,rgba(224,57,45,.12),transparent 60%);border:1px solid var(--border);border-radius:16px;padding:28px}.hero h2{margin:0 0 8px;font-size:28px}.hero p{margin:0 0 18px;color:var(--muted);line-height:1.6}.cta{display:inline-block;padding:12px 18px;border-radius:999px;background:var(--accent);color:#fff;text-decoration:none;font-weight:600;transition:transform .08s ease}.cta:active{transform:scale(.98)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:24px 0}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px}.card h3{margin:0 0 6px}.card p{margin:0;color:var(--muted)}.footer{margin-top:28px;color:var(--muted);font-size:14px;border-top:1px solid var(--border);padding-top:14px;text-align:center}.navbar{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border);margin-bottom:24px}.navbar ul{list-style:none;display:flex;gap:18px;margin:0;padding:0}.navbar a{color:var(--text);text-decoration:none;font-weight:500}.nav-logo{display:flex;align-items:center;gap:8px;font-size:20px}.nav-logo img{width:40px;height:auto}.page{animation:fadeIn .3s ease;min-height:calc(100vh - 160px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.content-wrapper{max-width:1000px;margin:0 auto;padding:0 24px 40px}.contact-form{display:flex;flex-direction:column;gap:16px;margin-top:24px}.contact-form label{display:flex;flex-direction:column;font-weight:500;color:var(--text)}.contact-form input,.contact-form textarea,.contact-form select{margin-top:6px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:15px;resize:vertical}.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--accent)}.product-card{margin-top:24px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px}.product-card h3{margin-top:0;color:var(--accent)}.product-card ul{margin:10px 0 20px 20px;color:var(--muted)}.navbar{display:flex;justify-content:space-between;align-items:center;margin:0 auto;padding:16px 32px;border-bottom:1px solid var(--border);max-width:1100px}.navbar ul{list-style:none;display:flex;align-items:center;gap:20px;margin:0;padding:0}.navbar a{color:var(--text);text-decoration:none;font-weight:500;transition:color .15s ease}.navbar a:hover{color:var(--accent)}.nav-logo{display:flex;align-items:center;gap:10px;font-size:22px}.nav-logo img{width:44px;height:auto;border-radius:4px}.mobile-nav-action,.mobile-nav-menu{display:none}.mobile-menu-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:0 11px;border:1px solid var(--border);border-radius:8px;background:#181818;cursor:pointer}.mobile-menu-toggle:hover,.mobile-menu-toggle[aria-expanded=true]{border-color:var(--accent)}.mobile-menu-toggle span{display:block;width:100%;height:2px;border-radius:999px;background:var(--text)}.nav-profile{position:relative}.nav-profile-trigger{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:1px solid var(--border);border-radius:50%;background:#181818;color:var(--text);cursor:pointer}.nav-profile-trigger:hover,.nav-profile-trigger[aria-expanded=true]{border-color:var(--accent)}.nav-profile-trigger img,.nav-profile-trigger span,.nav-profile-head img,.nav-profile-head>span{width:34px;height:34px;border-radius:50%;object-fit:cover;display:inline-flex;align-items:center;justify-content:center;background:#e0392d2e;color:var(--text);font-weight:800}.nav-profile-menu{position:absolute;top:calc(100% + 12px);right:0;z-index:20;width:min(360px,calc(100vw - 32px));padding:14px;border:1px solid var(--border);border-radius:8px;background:#111;box-shadow:0 18px 48px #00000073}.nav-profile-head{display:grid;grid-template-columns:44px minmax(0,1fr);gap:10px;align-items:center;padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:12px}.nav-profile-head img,.nav-profile-head>span{width:44px;height:44px}.nav-profile-head strong,.nav-profile-head small{display:block;min-width:0}.nav-profile-head small{color:var(--muted);font-size:13px}.nav-profile-actions,.nav-profile-form{display:flex;flex-direction:column;gap:10px}.nav-profile-form label{display:flex;flex-direction:column;gap:6px;color:var(--text);font-weight:650;font-size:14px}.nav-profile-form input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#0f0f0f;color:var(--text);font:inherit}.nav-profile-form input:focus{outline:none;border-color:var(--accent)}.error-text{color:#ff8b83;font-weight:700}.footer{max-width:1100px;margin:40px auto 0;padding:16px 32px;border-top:1px solid var(--border);text-align:center}.calendar .fc{--fc-page-bg: transparent;--fc-neutral-bg-color: rgba(255,255,255,.02);--fc-border-color: var(--border);--fc-button-text-color: #fff;--fc-button-bg-color: var(--accent);--fc-button-border-color: var(--accent);--fc-button-hover-bg-color: #c12f24;--fc-button-hover-border-color: #c12f24;--fc-button-active-bg-color: #a6281f;--fc-button-active-border-color: #a6281f;--fc-event-bg-color: var(--accent);--fc-event-border-color: #00000000;--fc-today-bg-color: rgba(224,57,45,.12);color:var(--text)}.calendar .fc a{color:var(--text)}.calendar .fc .fc-toolbar-title{font-weight:700;letter-spacing:.3px}.calendar .fc .fc-daygrid-day-number{color:var(--muted)}.calendar .fc .fc-event{border-radius:8px;padding:2px 4px}.calendar-page{display:flex;flex-direction:column;gap:20px}.calendar-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:end;padding:24px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(135deg,#e0392d21,#ffffff09),var(--card)}.calendar-hero h1{margin:0 0 8px;font-size:clamp(30px,4vw,46px)}.calendar-hero p{margin:0;color:var(--muted)}.calendar-legend{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.calendar-legend span{display:inline-flex;align-items:center;gap:6px;padding:7px 9px;border:1px solid var(--border);border-radius:999px;background:#ffffff0a;color:var(--muted);font-size:13px;font-weight:750}.legend-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.event-dot{background:var(--accent)}.course-dot{background:#7b2fe0}.preview-dot{background:#6d7785}.calendar-board,.detail-panel{border:1px solid var(--border);border-radius:8px;background:var(--card)}.calendar-board{overflow:hidden}.calendar-controls{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px;border-bottom:1px solid var(--border)}.calendar-controls h2{margin:0;text-align:center;text-transform:capitalize}.weekday-row,.month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.weekday-row span{padding:10px;border-bottom:1px solid var(--border);color:var(--muted);font-weight:800;text-align:center}.month-day{min-height:138px;padding:9px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:#ffffff03}.month-day:nth-child(7n){border-right:none}.month-day.muted{opacity:.48}.month-day.today{background:#e0392d1a}.day-number{display:flex;justify-content:space-between;gap:8px;color:var(--text);font-weight:800;margin-bottom:8px}.day-number small{color:var(--muted)}.day-items{display:flex;flex-direction:column;gap:5px}.calendar-item{display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px;width:100%;min-height:30px;padding:5px 7px;border:1px solid rgba(255,255,255,.08);border-radius:7px;background:#e0392d29;color:var(--text);cursor:pointer;text-align:left}.calendar-item.course{background:#7b2fe038}.calendar-item.preview{background:#6d77852e;color:var(--muted)}.calendar-item.active{border-color:var(--accent);box-shadow:0 0 0 1px #e0392d59}.calendar-item span,.calendar-item strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.calendar-item span{color:var(--muted);font-weight:750}.more-items{color:var(--muted);padding-left:3px}.detail-panel{padding:16px}.detail-panel h2{margin:8px 0 10px;font-size:22px}.detail-panel p{margin:0 0 8px;color:var(--muted);line-height:1.5}.detail-description{padding-top:8px;border-top:1px solid var(--border)}.detail-badge{display:inline-flex;padding:6px 9px;border-radius:999px;background:#e0392d29;color:var(--text);font-size:12px;font-weight:850}.detail-badge.course{background:#7b2fe038}.detail-badge.preview{background:#6d77852e;color:var(--muted)}.calendar-detail-inline{display:grid;gap:12px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px 14px}.events-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}.event-item{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--card)}.btn-danger{background:#c73b2f;color:#fff;border:none;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:600}.btn-danger:hover{filter:brightness(.95)}.faq-link{color:var(--accent);text-decoration:none;font-weight:600}.faq-link:hover{text-decoration:underline;color:color-mix(in srgb,var(--accent) 70%,white)}.courses-page,.admin-page,.auth-page{display:flex;flex-direction:column;gap:22px}.courses-header,.admin-toolbar,.auth-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,360px);gap:20px;align-items:start;padding:24px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(135deg,#e0392d24,#ffffff05 48%,#ffffff0a),var(--card)}.admin-toolbar{display:flex;justify-content:space-between;align-items:center}.eyebrow{margin:0 0 6px;color:var(--accent);font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:0}.courses-header h1,.admin-toolbar h1,.admin-login h1,.auth-hero h1{margin:0 0 10px;font-size:clamp(30px,4vw,46px);line-height:1.05}.courses-header p,.admin-toolbar p,.auth-hero p{margin:0;color:var(--muted);line-height:1.6}.auth-panel{min-width:0}.login-card,.admin-form,.profile-form{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--border);border-radius:8px;background:#00000038}.login-card label,.admin-form label,.profile-form label{display:flex;flex-direction:column;gap:6px;color:var(--text);font-weight:650;font-size:14px}.login-card input,.admin-form input,.admin-form textarea,.admin-form select,.profile-form input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#0f0f0f;color:var(--text);font:inherit}.login-card input:focus,.admin-form input:focus,.admin-form textarea:focus,.admin-form select:focus,.profile-form input:focus{outline:none;border-color:var(--accent)}.profile-box{display:flex;flex-direction:column;gap:10px}.profile-form{background:#0000004d}.success-text{color:#7fe39f;font-weight:700}.optional-text{color:var(--muted);font-weight:600;font-size:12px}.form-hint{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.form-hint a,.auth-link{color:var(--accent);font-weight:800;text-decoration:none}.form-hint a:hover,.auth-link:hover{text-decoration:underline}.auth-shell{width:min(520px,100%);margin:0 auto;display:flex;flex-direction:column;gap:14px}.auth-card{background:var(--card)}.tabs.compact{justify-content:center}.user-chip{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:8px;background:#00000038}.user-chip img,.user-chip>span,.user-row img,.avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;display:inline-flex;align-items:center;justify-content:center;background:#e0392d2e;color:var(--text);font-weight:800}.user-chip strong,.user-chip small{display:block;min-width:0}.user-chip small{color:var(--muted)}.admin-inline-link{display:inline-flex;margin-top:4px;color:var(--accent);font-size:13px;font-weight:800;text-decoration:none}.admin-inline-link:hover{text-decoration:underline}.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-auto-rows:1fr;align-items:stretch;gap:16px}.course-card{display:flex;flex-direction:column;gap:14px;height:100%;min-height:320px;padding:18px;border:1px solid var(--border);border-radius:8px;background:var(--card)}.course-topline{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.course-status-group{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.course-badge,.status-pill,.enrolled-pill{display:inline-flex;align-items:center;min-height:28px;padding:6px 9px;border:1px solid var(--border);border-radius:999px;background:#ffffff0a;color:var(--muted);font-size:12px;font-weight:800}.course-badge.weekly{color:#fff;border-color:#e0392d61;background:#e0392d29}.status-pill{color:#8ee6a8}.status-pill.full{color:#ff8b83}.enrolled-pill{color:#7fe39f;border-color:#7fe39f61;background:#7fe39f1f}.course-card h2{margin:0;min-height:56px;font-size:24px;line-height:1.15}.course-facts{display:grid;grid-template-columns:1fr;gap:8px}.course-facts div{display:grid;gap:3px;padding:10px;border:1px solid var(--border);border-radius:8px;background:#ffffff08}.course-facts span{color:var(--muted);font-size:12px;font-weight:750;text-transform:uppercase}.course-facts strong{color:var(--text);font-size:14px}.course-card p{margin:0;color:var(--muted);line-height:1.55;flex:1}.course-card-footer{display:flex;flex-direction:column;gap:14px;margin-top:auto}.course-card-footer .cta,.course-card-footer .course-withdraw-button,.course-card-footer .btn-error{width:100%;min-height:44px;text-align:center}.course-withdraw-button{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:#ffffff0a;color:var(--text);font-weight:700;cursor:pointer;transition:border-color .15s ease,background .15s ease}.course-withdraw-button:hover{border-color:#e0392d8c;background:#e0392d1a}.course-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:13px}.course-meta span{padding:6px 8px;border:1px solid var(--border);border-radius:8px;background:#ffffff08}.capacity{display:grid;gap:8px}.capacity div:first-child{display:flex;justify-content:space-between;align-items:end;gap:12px}.capacity span{color:var(--muted)}.capacity-bar{height:8px;overflow:hidden;border-radius:999px;background:#252525}.capacity-bar span{display:block;height:100%;background:var(--accent)}.notice{margin:0;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--muted)}.notice.error{color:#ff8b83;border-color:#e0392d73}.notice.success{color:#7fe39f;border-color:#7fe39f61}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:#181818;color:var(--text);font-weight:700;cursor:pointer}.btn-secondary:hover{border-color:var(--accent)}.btn-error{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border:1px solid rgba(224,57,45,.45);border-radius:8px;background:#e0392d29;color:#ff8b83;font-weight:800}.text-button{border:none;background:transparent;color:var(--accent);font:inherit;font-weight:800;text-align:left;padding:0;cursor:pointer}.text-button:hover{text-decoration:underline}button:disabled{opacity:.58;cursor:not-allowed}.admin-login{max-width:440px;margin:0 auto;width:100%}.tabs{display:flex;gap:8px;border-bottom:1px solid var(--border)}.tabs button{padding:10px 14px;border:1px solid transparent;border-bottom:none;border-radius:8px 8px 0 0;background:transparent;color:var(--muted);font-weight:800;cursor:pointer}.tabs button.active{background:var(--card);border-color:var(--border);color:var(--text)}.admin-grid{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:18px;align-items:start}.admin-form{position:sticky;top:16px;background:var(--card)}.admin-form h2{margin:0;font-size:22px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.button-row,.item-actions{display:flex;flex-wrap:wrap;gap:8px}.admin-list{display:flex;flex-direction:column;gap:10px}.admin-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:start;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--card)}.admin-item h3{margin:0 0 4px;font-size:18px}.admin-item p{margin:0;color:var(--muted)}.user-row{grid-template-columns:48px minmax(0,1fr) auto;align-items:center}.participant-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.participant-list span,.participant-list small{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border-radius:999px;background:#ffffff0d;color:var(--muted);font-size:12px}.participant-list img{width:20px;height:20px;border-radius:50%;object-fit:cover}@media (max-width: 860px){.navbar{position:relative;min-height:72px;align-items:center;gap:12px}.desktop-nav-links{display:none}.mobile-nav-action{display:flex;align-items:center;margin-left:auto}.mobile-nav-menu{position:absolute;top:calc(100% + 8px);left:16px;right:16px;z-index:18;display:flex;flex-direction:column;gap:4px;padding:8px;border:1px solid var(--border);border-radius:8px;background:#111;box-shadow:0 18px 48px #00000073}.mobile-nav-menu a{display:flex;align-items:center;min-height:44px;padding:10px 12px;border-radius:8px}.mobile-nav-menu a:hover{background:#e0392d1f}.courses-header,.admin-toolbar,.admin-grid,.auth-hero,.calendar-hero{grid-template-columns:1fr}.admin-form{position:static}.calendar-legend{justify-content:flex-start}.month-grid,.weekday-row{min-width:760px}.calendar-board{overflow-x:auto}}@media (max-width: 560px){.content-wrapper{padding:0 16px 32px}.navbar,.footer{padding-left:16px;padding-right:16px}.nav-profile-menu{position:fixed;top:92px;left:16px;right:16px;width:auto;max-height:calc(100vh - 112px);overflow:auto}.courses-header,.admin-toolbar,.auth-hero,.calendar-hero{padding:18px}.user-chip,.admin-item,.user-row,.form-row{grid-template-columns:1fr}.course-card{min-height:0}.calendar-controls{grid-template-columns:1fr}.calendar-controls h2{order:-1}}
