@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap";:root{--ocean-50: #f0f9ff;--ocean-100: #e0f2fe;--ocean-200: #bae6fd;--ocean-300: #7dd3fc;--ocean-400: #38bdf8;--ocean-500: #0ea5e9;--ocean-600: #0284c7;--ocean-700: #0369a1;--ocean-800: #075985;--ocean-900: #0c4a6e;--sunset-50: #fff7ed;--sunset-100: #ffedd5;--sunset-200: #fed7aa;--sunset-300: #fdba74;--sunset-400: #fb923c;--sunset-500: #f97316;--sunset-600: #ea580c;--sunset-700: #c2410c;--sunset-800: #9a3412;--palm-50: #f0fdf4;--palm-100: #dcfce7;--palm-200: #bbf7d0;--palm-300: #86efac;--palm-400: #4ade80;--palm-500: #22c55e;--palm-600: #16a34a;--palm-700: #15803d;--sand-50: #fefce8;--sand-100: #fef9c3;--sand-200: #fef08a;--sand-300: #fde047;--lava-500: #ef4444;--lava-100: #fee2e2;--warm-50: #fafaf9;--warm-100: #f5f5f4;--warm-200: #e7e5e4;--warm-300: #d6d3d1;--warm-400: #a8a29e;--warm-500: #78716c;--warm-600: #57534e;--warm-700: #44403c;--warm-800: #292524;--warm-900: #1c1917;--bg: linear-gradient(180deg, var(--ocean-50) 0%, var(--warm-50) 50%, var(--sand-50) 100%);--card: #ffffff;--text: var(--warm-900);--text-secondary: var(--warm-500);--border: var(--warm-200);--primary: var(--ocean-600);--primary-hover: var(--ocean-700);--accent: var(--sunset-500);--success: var(--palm-500);--success-light: var(--palm-100);--error: var(--lava-500);--error-light: var(--lava-100);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-md: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-lg: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: 8px;--radius: 12px;--radius-lg: 20px;--radius-full: 9999px}*{box-sizing:border-box;margin:0;padding:0}html{min-height:100%}body{min-height:100%;min-height:100dvh}@supports (-webkit-touch-callout: none){body{min-height:-webkit-fill-available}}@media (max-width: 768px){html{scrollbar-width:none}body::-webkit-scrollbar,.card::-webkit-scrollbar,.pull-to-refresh-children::-webkit-scrollbar{display:none;width:0;height:0}body,.card,.pull-to-refresh-children{-ms-overflow-style:none;scrollbar-width:none}}img,svg,video{max-width:100%;height:auto}@supports (-webkit-touch-callout: none){input,textarea,select{font-size:16px!important}}@media (max-width: 768px){input[type=text],input[type=email],input[type=password],input[type=search],input[type=tel],input[type=url],input[type=number],textarea,select{font-size:16px!important;min-height:44px;padding:12px 14px;-webkit-text-size-adjust:100%}}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}.app{min-height:100dvh;padding:24px;display:flex;flex-direction:column;align-items:center;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5 L35 15 L30 12 L25 15 Z' fill='%230ea5e9' fill-opacity='0.03'/%3E%3C/svg%3E"),linear-gradient(180deg,var(--ocean-100) 0%,var(--warm-50) 40%,var(--sand-100) 100%)}.card{background:var(--card);border-radius:var(--radius-lg);padding:100px;width:100%;max-width:1200px;box-shadow:var(--shadow-lg);border:1px solid var(--border);position:relative}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--ocean-500),var(--sunset-500),var(--palm-500))}.header{display:flex;justify-content:space-between;align-items:center;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--border);flex-shrink:0}.header .brand{display:flex;align-items:center;gap:16px}.header .logo{width:56px;height:56px;display:flex;align-items:center;justify-content:center}.header .logo svg{width:100%;height:100%}.header .brand-text .title{font-size:28px;font-weight:800;background:linear-gradient(135deg,var(--ocean-600),var(--ocean-800));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.header .brand-text .subtitle{font-size:13px;color:var(--text-secondary);font-weight:500}.header .user-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.title{font-size:24px;font-weight:700;color:var(--warm-900);letter-spacing:-.02em}.title-lg{font-size:32px;font-weight:800;color:var(--warm-900);letter-spacing:-.03em}.title-sm{font-size:18px;font-weight:600;color:var(--warm-800)}.subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.label{font-size:13px;font-weight:600;color:var(--warm-600);margin-bottom:8px;display:block;text-transform:uppercase;letter-spacing:.03em}button{font-family:inherit;cursor:pointer;transition:all .2s ease;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary,button.primary{background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;border:none;padding:14px 28px;border-radius:var(--radius-full);font-size:15px;font-weight:600;box-shadow:0 4px 14px #0ea5e966}.btn-primary:hover,button.primary:hover{background:linear-gradient(135deg,var(--ocean-600),var(--ocean-700));box-shadow:0 6px 20px #0ea5e980;transform:translateY(-2px)}.btn-primary:active,button.primary:active{transform:translateY(0)}.btn-secondary,button.secondary{background:var(--warm-100);color:var(--warm-700);border:1px solid var(--warm-200);padding:12px 20px;border-radius:var(--radius-full);font-size:14px}.btn-secondary:hover,button.secondary:hover{background:var(--warm-200);border-color:var(--warm-300)}.btn-ghost,button.ghost{background:transparent;color:var(--warm-600);border:1px solid var(--border);padding:10px 16px;border-radius:var(--radius);font-size:13px}.btn-ghost:hover,button.ghost:hover{background:var(--warm-50);color:var(--warm-800)}.btn-danger{background:var(--error-light);color:var(--error);border:1px solid rgba(239,68,68,.2);padding:10px 16px;border-radius:var(--radius);font-size:13px}.btn-danger:hover{background:#fecaca}.btn-success{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border:1px solid rgba(22,163,74,.2);padding:10px 16px;border-radius:var(--radius);font-size:13px}.btn-success:hover{background:#bbf7d0}.inactive-card{background:var(--warm-50);border-color:var(--warm-200)}.link-subtle{background:transparent;border:none;color:var(--warm-400);font-size:12px;font-weight:500;padding:8px 0;margin-top:12px;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.link-subtle:hover{color:var(--warm-600)}.link-subtle:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:inherit;width:100%;padding:14px 18px;border:2px solid var(--border);border-radius:var(--radius);font-size:15px;background:#fff;color:var(--text);transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ocean-400);box-shadow:0 0 0 4px #0ea5e926}input::placeholder{color:var(--warm-400)}input[type=checkbox]{width:20px;height:20px;accent-color:var(--ocean-500);cursor:pointer}input[type=time]{max-width:100%;width:100%;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2378716c' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:44px}.form-group{margin-bottom:20px}.form-stack{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;width:100%;max-width:100%;box-sizing:border-box}.form-row input,.form-row select{width:100%;max-width:100%;box-sizing:border-box}.guest-fields{display:flex;flex-direction:column;gap:12px;margin-top:12px}.guest-field input{flex:1}.guest-field .btn-action--icon{flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:var(--ocean-100);color:var(--ocean-700);border:1px solid var(--ocean-200);white-space:nowrap}.badge.success{background:var(--success-light);color:var(--palm-700);border-color:var(--palm-200)}.badge.warning{background:var(--sand-100);color:var(--sunset-700);border-color:var(--sand-200)}.badge.error{background:var(--error-light);color:var(--lava-500);border-color:#fecaca}.badge.neutral{background:var(--warm-100);color:var(--warm-600);border-color:var(--warm-200)}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:0 10px;height:22px;border-radius:11px;font-size:10px;font-weight:600;white-space:nowrap;border:1px solid}.status-badge.success{background:var(--success-light);color:var(--palm-700);border-color:var(--palm-200)}.status-badge.error{background:var(--error-light);color:var(--lava-500);border-color:#fecaca}.status-badge.neutral{background:var(--warm-100);color:var(--warm-600);border-color:var(--warm-200)}.chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.chip.super-admin{background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff}.chip.admin{background:linear-gradient(135deg,var(--sunset-100),var(--sunset-200));color:var(--sunset-700)}.chip.trainer{background:linear-gradient(135deg,var(--ocean-100),var(--ocean-200));color:var(--ocean-700)}.chip.student{background:linear-gradient(135deg,var(--palm-100),var(--palm-200));color:var(--palm-700)}.chip.present{background:var(--success-light);color:var(--palm-700);text-transform:none}.chip.pending{background:var(--warm-100);color:var(--warm-600);text-transform:none}.chip.full{background:var(--error-light);color:var(--lava-500);text-transform:none}.chip.school{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca;text-transform:none;font-size:10px}.chip.spots{background:var(--warm-100);color:var(--warm-600);text-transform:none}.chip.guest{background:var(--ocean-100);color:var(--ocean-700);text-transform:none;font-size:10px;padding:4px 8px;margin-left:8px}.pill-nav{display:inline-flex;gap:4px;background:var(--warm-100);padding:6px;border-radius:var(--radius);border:1px solid var(--warm-200)}.pill{padding:12px 24px;border:none;background:transparent;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--warm-500);cursor:pointer;transition:all .2s}.pill:hover{color:var(--warm-700)}.pill.active{background:#fff;color:var(--ocean-700);box-shadow:var(--shadow)}.school-selector-web{display:none;align-items:center;gap:8px;background:var(--warm-100);padding:6px 12px;border-radius:var(--radius);border:1px solid var(--warm-200)}.school-selector-label{font-size:16px}.school-selector-dropdown{padding:8px 12px;font-size:14px;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--warm-200);background:#fff;color:var(--ocean-700);cursor:pointer;min-width:180px;transition:all .2s}.school-selector-dropdown:hover{border-color:var(--ocean-400)}.school-selector-dropdown:focus{outline:none;border-color:var(--ocean-500);box-shadow:0 0 0 3px #0ea5e91a}@media (min-width: 768px){.school-selector-web{display:flex}}.section{margin-top:28px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.filters-bar{display:flex;gap:12px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.filter-group{flex:1;min-width:150px}.filter-search{width:100%;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius);font-size:14px}.filter-select{width:100%;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius);font-size:14px;background:#fff}.filter-clear{white-space:nowrap;font-size:13px}@media (max-width: 768px){.filters-bar{flex-direction:column}.filter-group{width:100%}}.list{display:flex;flex-direction:column;gap:16px}.list-item{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;display:flex;justify-content:space-between;align-items:center;gap:20px;transition:all .2s}.list-item:hover{border-color:var(--ocean-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.list-item.selected{border-color:var(--ocean-500);background:var(--ocean-50)}.training-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all .25s;cursor:pointer;position:relative}.training-card:hover{border-color:var(--ocean-400);box-shadow:var(--shadow-md)}.training-card.next{border:3px solid var(--ocean-500);background:linear-gradient(135deg,var(--ocean-50) 0%,white 100%)}.training-card.next:before{content:"🌊 PRÓXIMO TREINO";display:inline-block;background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;font-size:11px;font-weight:700;padding:6px 12px;border-radius:var(--radius-sm);margin-bottom:16px;letter-spacing:.05em}.training-card .title{font-size:20px;margin-bottom:8px;color:var(--warm-900)}.training-card .schedule{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.training-card .schedule .time{display:inline-flex;align-items:center;gap:8px;background:var(--warm-100);padding:8px 14px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--warm-700)}.training-card .days{display:flex;gap:4px;margin-top:16px;flex-wrap:nowrap}.training-card .day-chip{padding:5px 7px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;background:var(--warm-100);color:var(--warm-500);border:1px solid var(--warm-200)}.training-card .day-chip.active{background:linear-gradient(135deg,var(--ocean-100),var(--ocean-200));color:var(--ocean-700);border-color:var(--ocean-300)}.training-card-expanded{background:#fff;border:2px solid var(--ocean-400);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-md)}.training-card-expanded--inactive{opacity:.7;border-color:var(--warm-300)}.training-card-expanded__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.training-card-expanded__info{flex:1}.training-card-expanded__title{font-size:18px;font-weight:700;color:var(--warm-900);margin:0}.training-card-expanded__header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.training-card-expanded__date-section{margin-bottom:8px}.training-card-expanded__date{font-size:13px;color:var(--warm-500);display:inline-block;background:var(--warm-100);padding:4px 10px;border-radius:var(--radius-full)}.training-card-expanded__hint{font-size:11px;color:var(--warm-400);text-align:center;margin:0 0 12px;font-style:italic}.training-card-expanded__badges{display:flex;gap:8px}.training-card-expanded__crew{background:var(--warm-50);border-radius:var(--radius);padding:16px;margin-bottom:16px}.training-card-expanded__crew .crew-grid--compact{gap:10px}.training-card-expanded__crew .crew-avatar,.training-card-expanded__crew .crew-avatar--empty{width:64px;height:64px}.training-card-expanded__crew .crew-avatar--empty svg{width:24px;height:24px}.training-card-expanded__crew .crew-name{font-size:11px;margin-top:4px}.training-card-expanded__crew .crew-avatar__tag{font-size:8px;padding:2px 5px;bottom:-4px}.crew-slot--more{display:flex;align-items:center;justify-content:center}.crew-more{font-size:12px;font-weight:600;color:var(--warm-500)}.training-card__crew--loading{opacity:.7}.crew-slot--skeleton{display:flex;flex-direction:column;align-items:center;gap:4px}.crew-avatar--skeleton{width:64px;height:64px;border-radius:50%;background:linear-gradient(90deg,var(--warm-200) 25%,var(--warm-100) 50%,var(--warm-200) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.crew-name--skeleton{width:32px;height:10px;border-radius:4px;background:linear-gradient(90deg,var(--warm-200) 25%,var(--warm-100) 50%,var(--warm-200) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.training-card-expanded__checkin{margin-bottom:16px}.btn-checkin{width:100%;padding:14px;font-size:16px;font-weight:600;background:linear-gradient(135deg,var(--palm-500),var(--palm-600));color:#fff;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s}.btn-checkin:hover{background:linear-gradient(135deg,var(--palm-600),var(--palm-700));transform:translateY(-1px)}.btn-checkin:disabled{opacity:.6;cursor:not-allowed;transform:none}.training-card-expanded__actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--border)}.training-card-expanded__actions .btn-action{flex:1;min-width:80px}.modal--compact{max-width:360px;min-height:auto!important;height:auto!important;margin-top:20px;margin-bottom:auto}.modal--compact .modal-header{padding:16px;margin-bottom:0;display:flex;justify-content:space-between;align-items:center}.modal--compact .modal-header h3{margin:0;font-size:18px;font-weight:600}.modal--compact .close-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;color:var(--warm-500);border-radius:var(--radius);transition:all .2s}.modal--compact .close-btn:hover{background:var(--warm-100);color:var(--warm-700)}.modal--compact .form-stack{padding:0 16px 16px}@media (max-width: 768px){.overlay:has(.modal--compact){padding:20px;align-items:flex-start;overflow:hidden}.modal--compact{max-width:100%;width:100%;border-radius:var(--radius-lg);min-height:auto!important;height:auto!important;max-height:calc(100dvh - 40px);overflow-y:auto;display:flex;flex-direction:column}.modal--compact .form-stack{flex:1;overflow:visible}}.overlay--fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;z-index:1200;display:flex;flex-direction:column}.screen-panel{display:flex;flex-direction:column;height:100%;width:100%;background:#fff}.screen-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;min-height:56px}.screen-header .back-btn{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;border:none;width:40px;height:40px;border-radius:var(--radius-full);font-size:18px;cursor:pointer;transition:all .2s;flex-shrink:0;box-shadow:0 2px 8px #0ea5e94d}.screen-header .back-btn:hover{background:linear-gradient(135deg,var(--ocean-600),var(--ocean-700));transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e966}.screen-header .back-btn:active{transform:translateY(0);box-shadow:0 2px 6px #0ea5e94d}.screen-title{font-size:16px;font-weight:700;color:var(--warm-900);margin:0;flex:1}.screen-content{flex:1;padding:24px 20px;overflow-y:auto;background:var(--warm-50)}.screen-footer{padding:16px 20px;border-top:1px solid var(--border);background:#fff}.btn-primary--full{width:100%;padding:16px;font-size:16px;font-weight:600;background:linear-gradient(135deg,var(--ocean-500),var(--palm-500));color:#fff;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s}.btn-primary--full:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary--full:disabled{opacity:.5;cursor:not-allowed}.detail-panel{background:linear-gradient(180deg,var(--warm-50) 0%,white 100%);border:2px solid var(--border);border-radius:var(--radius-lg);padding:28px}.detail-panel .empty{text-align:center;padding:60px 24px;color:var(--warm-400)}.detail-panel .empty .icon{font-size:64px;margin-bottom:16px}.detail-section{padding:20px 0;border-bottom:1px solid var(--border)}.detail-section:last-child{border-bottom:none}.detail-compact-info{display:flex;justify-content:center;padding:12px 0;margin-bottom:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0}.detail-row .label{font-size:13px;color:var(--warm-500);margin:0;text-transform:none}.detail-row .value{font-size:15px;font-weight:600;color:var(--warm-900)}.week-calendar{display:flex;gap:4px}.week-day{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:11px;font-weight:600;background:var(--warm-100);color:var(--warm-400);border:1px solid var(--warm-200)}.week-day.active{background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;border-color:var(--ocean-600);box-shadow:0 2px 4px #0ea5e94d}.checkin-cta{background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));border-radius:var(--radius-lg);padding:32px;text-align:center;margin-top:20px;position:relative;overflow:hidden}.checkin-cta:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 5 L25 15 L20 12 L15 15 Z' fill='white' fill-opacity='0.1'/%3E%3C/svg%3E");animation:wave 20s linear infinite}@keyframes wave{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.checkin-cta .title{color:#fff;font-size:20px;margin-bottom:16px;position:relative;z-index:1}.checkin-cta button{background:#fff;color:var(--ocean-700);border:none;padding:16px 40px;border-radius:var(--radius-full);font-size:16px;font-weight:700;box-shadow:var(--shadow-lg);position:relative;z-index:1}.checkin-cta button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 40px #0003}.checkin-done{background:linear-gradient(135deg,var(--palm-100),var(--palm-50));border:2px solid var(--palm-300);border-radius:var(--radius-lg);padding:28px;text-align:center;margin-top:20px}.checkin-done .icon{font-size:48px;margin-bottom:12px}.checkin-done .text{color:var(--palm-700);font-weight:700;font-size:16px}.table-wrap{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg)}.table{width:100%;border-collapse:collapse}.table th{background:var(--warm-50);padding:16px 20px;text-align:left;font-size:12px;font-weight:700;color:var(--warm-500);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border)}.table td{padding:16px 20px;font-size:14px;color:var(--warm-700);border-bottom:1px solid var(--warm-100)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--warm-50)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1917b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:flex-start;padding:48px 24px;z-index:1100;overflow-y:auto}body:has(.overlay) .bottom-nav{display:none!important}.modal{background:#fff;border-radius:var(--radius-lg);padding:32px;width:100%;max-width:500px;box-shadow:var(--shadow-lg);animation:modalIn .3s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.modal-header .title{font-size:22px}@media (max-width: 768px){.overlay{padding:0;align-items:stretch}.modal{max-width:none;border-radius:0;min-height:100dvh;padding:0;display:flex;flex-direction:column;animation:none}.modal .form{padding:20px;flex:1;overflow-y:auto;display:flex;flex-direction:column}.modal .form-stack{flex:1;display:flex;flex-direction:column}.modal .modal-header{display:none}.modal .modal-actions,.modal .form-actions{background:#fff;padding:16px 20px;border-top:1px solid var(--border);margin:auto -20px -20px;width:calc(100% + 40px)}.modal .payment-info{margin:0;padding:16px 20px;border-radius:0;border-bottom:1px solid var(--border)}.modal .plan-preview{margin:0 0 16px}}.alert{padding:16px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;display:flex;align-items:center;gap:12px;margin-bottom:20px}.alert.info{background:var(--ocean-50);color:var(--ocean-700);border:1px solid var(--ocean-200)}.alert.success{background:var(--success-light);color:var(--palm-700);border:1px solid var(--palm-200)}.error{background:var(--error-light);color:var(--lava-500);border:1px solid #fecaca;padding:16px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;margin-top:20px}.row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.flex-1{flex:1;min-width:0}.layout{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start;flex:1;min-height:0}.layout--single{grid-template-columns:1fr;max-width:720px}.layout-list,.layout-detail{min-width:0;min-height:0}.bottom-nav{display:none}.profile-screen{padding:20px 0}.profile-card{text-align:center;padding:32px 20px;background:linear-gradient(135deg,var(--ocean-500) 0%,var(--ocean-700) 100%);border-radius:var(--radius-lg);color:#fff;margin-bottom:24px}.profile-card--compact{padding:14px 20px 8px;text-align:left;display:flex;flex-direction:column;align-items:stretch;gap:6px;position:relative;background:linear-gradient(135deg,var(--ocean-500) 0%,var(--ocean-600) 50%,var(--ocean-700) 100%);box-shadow:0 4px 12px #00000026}.profile-card--compact.profile-card--clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.profile-card--compact.profile-card--clickable:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.profile-card--compact.profile-card--clickable:active{transform:translateY(0)}.profile-card__row{display:flex;align-items:center;gap:14px}.profile-card__badge{position:absolute;top:8px;right:10px;background:#fff3;color:#ffffffe6;font-size:9px;font-weight:600;letter-spacing:.5px;padding:3px 8px;border-radius:var(--radius-full);text-transform:uppercase}.profile-card--compact .profile-card__header{flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;min-width:0}.profile-card--compact .profile-name{font-size:18px;font-weight:700;margin-bottom:0;line-height:1.2}.profile-card--compact .profile-email{font-size:13px;font-weight:300;margin-bottom:0;opacity:.75;line-height:1.2}.profile-card--compact .profile-avatar--small{width:44px;height:44px;font-size:22px;margin:0;flex-shrink:0;display:flex;align-items:center;justify-content:center;align-self:center;background:#ffffff26;border-radius:50%}.profile-card__edit-text{display:block;text-align:center;font-size:11px;font-weight:400;font-style:italic;color:#ffffff73;margin:0 -20px;padding:0 20px}.profile-avatar--small{width:44px;height:44px;font-size:22px;margin:0;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:50%}.profile-card__edit-link{display:block;width:100%;padding:0;background:transparent;border:none;font-size:11px;font-weight:400;font-style:italic;color:#ffffff73;cursor:pointer;transition:color .2s;text-align:center;margin-top:4px}.profile-card__edit-link:hover{color:#fffc}.profile-card__edit-link:active{color:#fff}.profile-card--clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.profile-card--clickable:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0ea5e966}.profile-card--clickable:active{transform:translateY(0)}.profile-edit-hint{display:block;font-size:12px;opacity:.7;margin-top:12px;font-weight:500}.profile-avatar{width:80px;height:80px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;flex-shrink:0}.avatar-icon{font-size:40px}.profile-name{font-size:24px;font-weight:700;margin-bottom:4px}.profile-email{font-size:14px;opacity:.9;margin-bottom:12px}.profile-card .chip{background:#fff3;color:#fff}.profile-card .profile-section-title{display:flex;align-items:center;justify-content:center;gap:8px;font-size:18px;font-weight:600;margin-bottom:8px}.profile-card .profile-section-description{font-size:14px;opacity:.9;margin-bottom:0}.profile-card .profile-section-hint{font-size:13px;opacity:.85;margin-top:12px;margin-bottom:0}.profile-card .school-context-select{width:100%;padding:12px 16px;font-size:16px;border-radius:var(--radius);border:2px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;cursor:pointer;transition:all .2s}.profile-card .school-context-select:focus{outline:none;border-color:#ffffff80;background:#fff3}.profile-card .school-context-select option{background:var(--ocean-700);color:#fff}.profile-actions{display:flex;flex-direction:column;gap:12px}.profile-action-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 20px;background:#fff;border:2px solid var(--border);border-radius:var(--radius);font-size:16px;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s}.profile-action-btn:active{transform:scale(.98);background:var(--warm-50)}.profile-action-btn.danger{color:var(--lava-500);border-color:var(--lava-100)}.profile-action-btn.danger:active{background:var(--lava-100)}.profile-card__header{display:flex;align-items:center;gap:12px}.profile-card__info{flex:1;text-align:left;display:flex;flex-direction:column;justify-content:center}.settings-accordion{margin-top:24px;border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:0 2px 8px #00000014,0 4px 16px #0000000a;border:1px solid var(--border);position:relative}.settings-accordion:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--ocean-500),var(--ocean-600))}.settings-accordion__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:44px;padding:25px 20px 20px;background:transparent;border:none;font-size:16px;font-weight:600;color:#1e3a8a;cursor:pointer;transition:all .2s ease}.settings-accordion__trigger:hover{background:#f9fafb}.settings-accordion__trigger:focus{outline:2px solid var(--ocean-300);outline-offset:-2px}.settings-accordion__icon{font-size:10px;color:#9ca3af;transition:transform .2s ease}.settings-accordion__icon.open{transform:rotate(90deg)}.settings-accordion__content{padding:0 20px 20px;display:flex;flex-direction:column;gap:0}.settings-accordion__divider{height:1px;background:#e5e7eb;margin:0}.settings-accordion__item{display:flex;align-items:center;justify-content:flex-start;gap:10px;width:100%;min-height:44px;padding:14px 0;background:transparent;border:none;border-bottom:1px solid #F3F4F6;font-size:15px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;text-align:left}.settings-accordion__item:last-child{border-bottom:none}.settings-accordion__item:hover{background:#f9fafb;margin:0 -20px;padding:14px 20px;width:calc(100% + 40px)}.settings-accordion__item:focus{outline:2px solid var(--ocean-300);outline-offset:-2px}.settings-accordion__item--danger{color:#ef4444}.settings-accordion__item--danger:hover{color:#dc2626;background:#fef2f2}.mobile-hidden,.desktop-only{display:block}.mobile-only,.mobile-header{display:none}.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:28px}.mb-sm{margin-bottom:8px}.mb-md{margin-bottom:16px}.mb-lg{margin-bottom:24px}.login-container{max-width:420px;margin:0 auto;padding:40px 0}.login-logo{display:flex;justify-content:center;margin-bottom:32px}.login-logo svg{width:120px;height:120px;filter:drop-shadow(0 10px 30px rgba(14,165,233,.3))}.login-container .welcome{text-align:center;margin-bottom:40px}.login-container .welcome .title{font-size:32px;font-weight:800;background:linear-gradient(135deg,var(--ocean-600),var(--sunset-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.login-container .welcome .subtitle{font-size:16px;color:var(--warm-500);line-height:1.6}.login-container form{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-lg)}.login-container .form-group{margin-bottom:24px}.login-container button.primary{width:100%;padding:16px;font-size:16px;margin-top:8px}.login-container .hint{text-align:center;margin-top:28px;font-size:13px;color:var(--warm-400);line-height:1.6}.wave-decoration{position:absolute;bottom:0;left:0;right:0;height:100px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 1200 120' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,60 C150,120 350,0 600,60 C850,120 1050,0 1200,60 L1200,120 L0,120 Z' fill='%230ea5e9' fill-opacity='0.05'/%3E%3C/svg%3E");background-size:cover;pointer-events:none}@media (max-width: 1024px){.layout{grid-template-columns:1fr}}@media (max-width: 768px){.layout{display:block}.mobile-hidden,.desktop-only,.table-wrap.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-header{display:flex;align-items:center;justify-content:flex-start;padding:12px 16px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;min-height:56px;gap:12px}.mobile-header-back{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 12px;background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;font-size:16px;font-weight:600;cursor:pointer;border:none;border-radius:var(--radius-full);transition:all .2s;width:40px;height:40px;flex-shrink:0;box-shadow:0 2px 8px #0ea5e94d;text-decoration:none}.mobile-header-back:hover{background:linear-gradient(135deg,var(--ocean-600),var(--ocean-700));color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e966}.mobile-header-back:active{transform:translateY(0);box-shadow:0 2px 6px #0ea5e94d}.mobile-header-title{font-size:16px;font-weight:700;color:var(--warm-900);flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-header-action{display:flex;align-items:center;min-width:44px;justify-content:flex-end;flex-shrink:0}.layout-list,.layout-detail{width:100%}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:6px 0;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));z-index:1000;box-shadow:0 -2px 10px #0000001a;height:calc(65px + env(safe-area-inset-bottom,0px));-webkit-transform:translate3d(0,0,0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;will-change:transform;min-height:calc(65px + env(safe-area-inset-bottom,0px));max-height:calc(65px + env(safe-area-inset-bottom,0px));flex-shrink:0}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:4px 2px;background:none;border:none;cursor:pointer;color:var(--warm-400);transition:color .2s;-webkit-tap-highlight-color:transparent;min-width:0}.bottom-nav-item.active{color:var(--ocean-600)}.bottom-nav-item:active{transform:scale(.95)}.bottom-nav-icon{font-size:18px;line-height:1}.bottom-nav-label{font-size:9px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.card{padding:16px;padding-bottom:calc(60px + env(safe-area-inset-bottom,0px));border-radius:0;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.header .user-actions{display:none}.header{padding-bottom:12px;margin-bottom:12px}.tab-nav-container{display:none!important}.app{padding:0;background:var(--warm-50);height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.header{flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;padding-bottom:12px;margin-bottom:12px}.header .brand{justify-content:flex-start;gap:10px}.header .logo{width:40px;height:40px}.header .brand-text{text-align:left}.header .brand-text .title{font-size:18px;text-align:left}.header .brand-text .subtitle{display:none}.header .user-actions{display:none!important}.title{font-size:18px}.title-sm{font-size:16px}.training-card .day-chip{padding:4px 5px!important;font-size:9px!important;min-width:0;flex-shrink:0}.training-card__days{flex-wrap:nowrap!important;gap:2px!important}.day-pill{padding:4px 5px!important;font-size:9px!important;flex-shrink:0}.training-card .row{gap:6px;margin-top:8px}.badge{padding:4px 8px;font-size:10px}.form-row{grid-template-columns:1fr;gap:12px}.form-group{margin-bottom:12px}input,select,textarea{padding:12px 14px;font-size:14px}.table-wrap{border:none;background:transparent}.table{display:block}.table thead{display:none}.table tbody{display:flex;flex-direction:column;gap:12px}.table tr{display:block;background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:12px}.table td{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border:none;font-size:13px}.table td:before{content:attr(data-label);font-weight:600;color:var(--warm-500);font-size:11px}.overlay:not(.confirm-overlay){padding:0;align-items:flex-start;background:#fff;z-index:1100;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal:not(.confirm-modal){margin-top:0;max-height:none;max-width:100%;width:100%;min-height:100dvh;padding:0;border-radius:0;box-shadow:none;overflow-x:hidden;overflow-y:visible;display:flex;flex-direction:column}.modal .form-stack{padding:16px;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px));flex:1;display:flex;flex-direction:column;gap:16px;overflow-x:hidden;width:100%;max-width:100%}.modal .form-row{display:flex;flex-direction:column;gap:12px;width:100%;max-width:100%}.modal input[type=time]{width:100%;max-width:100%;box-sizing:border-box}.modal .form-field{width:100%;max-width:100%;min-width:0}.modal input,.modal select,.modal textarea{max-width:100%;box-sizing:border-box}.modal .form-stack>*{flex-shrink:0}.modal .modal-footer{padding:16px;position:sticky;bottom:0;background:#fff;z-index:4100;border-top:1px solid var(--border);padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.modal-header.desktop-only{display:none!important}.pill-nav{width:100%;padding:3px;gap:2px}.pill{flex:1;text-align:center;padding:10px 8px;font-size:13px;min-height:44px;display:flex;align-items:center;justify-content:center}.training-card{padding:16px;margin-bottom:12px;border-radius:var(--radius);background:#fff;border:2px solid var(--border);transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.training-card:active{transform:scale(.98)}.training-card.next{border-color:var(--ocean-400);background:linear-gradient(135deg,var(--ocean-50) 0%,white 100%);box-shadow:0 4px 12px #0ea5e926}.training-card.next:before{content:"🏄 PRÓXIMO TREINO";display:block;font-size:10px;font-weight:800;color:var(--ocean-600);background:var(--ocean-100);padding:6px 12px;border-radius:var(--radius-sm);margin:-8px -8px 12px;width:fit-content}.training-card .title{font-size:17px;font-weight:700;margin-bottom:6px;color:var(--text)}.training-card .subtitle{font-size:13px;color:var(--warm-500);margin-bottom:12px}.training-card .schedule{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.training-card .schedule .time{font-size:13px;padding:6px 12px;background:var(--warm-100);border-radius:var(--radius-sm);font-weight:600}.training-card .days{flex-wrap:nowrap!important;gap:2px!important;margin-top:8px}.training-card .day-chip{padding:4px 5px!important;font-size:9px!important;flex-shrink:0}}.available-plans-list{padding:16px;max-height:400px;overflow-y:auto}.available-plan-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;position:relative}.available-plan-card:last-child{margin-bottom:0}.available-plan-card--current{border-color:var(--ocean-400);background:var(--ocean-50)}.available-plan-card__badge{position:absolute;top:-10px;right:12px;background:var(--ocean-500);color:#fff;font-size:11px;font-weight:600;padding:4px 10px;border-radius:var(--radius-full)}.available-plan-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.available-plan-card__name{font-size:18px;font-weight:700;color:var(--text);margin:0}.available-plan-card__price{font-size:20px;font-weight:800;color:var(--ocean-600)}.available-plan-card__description{font-size:14px;color:var(--text-secondary);margin:0 0 16px;line-height:1.5}.available-plan-card__details{display:flex;gap:24px}.available-plan-card__detail{display:flex;flex-direction:column;gap:4px}.available-plan-card__label{font-size:12px;color:var(--text-secondary)}.available-plan-card__value{font-size:14px;font-weight:600;color:var(--text)}.available-plans-footer{padding:16px 20px;background:var(--warm-50);border-top:1px solid var(--border)}.available-plans-hint{font-size:13px;color:var(--text-secondary);text-align:center;margin:0}.pull-to-refresh-container{position:relative;width:100%;flex:1;min-height:0;display:flex;flex-direction:column;overflow:visible;touch-action:pan-y}.pull-to-refresh-indicator{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:100;background:linear-gradient(180deg,var(--ocean-50) 0%,transparent 100%);border-radius:0 0 var(--radius) var(--radius);transition:opacity .2s ease}.pull-to-refresh-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px}.pull-to-refresh-arrow{font-size:24px;color:var(--primary);transition:transform .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.pull-to-refresh-indicator.ready .pull-to-refresh-arrow{color:var(--success)}.pull-to-refresh-text{font-size:13px;font-weight:500;color:var(--text-secondary);text-align:center;white-space:nowrap}.pull-to-refresh-indicator.ready .pull-to-refresh-text{color:var(--success)}.pull-to-refresh-indicator.refreshing .pull-to-refresh-text{color:var(--primary)}.pull-to-refresh-spinner{width:24px;height:24px;border:3px solid var(--ocean-200);border-top-color:var(--primary);border-radius:50%;animation:pull-to-refresh-spin .8s linear infinite}@keyframes pull-to-refresh-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pull-to-refresh-children{position:relative;width:100%;flex:1;min-height:0;will-change:transform;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.pull-to-refresh-children{padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}}@supports (padding-top: env(safe-area-inset-top)){.pull-to-refresh-indicator{padding-top:env(safe-area-inset-top)}}@media (hover: hover) and (pointer: fine){.pull-to-refresh-indicator{display:none}.pull-to-refresh-children{transform:none!important}}.toggle-switch-container{display:flex;align-items:center;gap:10px}.toggle-switch{position:relative;width:44px;height:24px;padding:0;border:none;background:transparent;cursor:pointer;flex-shrink:0}.toggle-switch:focus-visible{outline:2px solid var(--ocean-400);outline-offset:2px;border-radius:var(--radius-full)}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}.toggle-switch__track{display:block;width:100%;height:100%;background:var(--warm-300);border-radius:var(--radius-full);transition:background-color .2s ease}.toggle-switch--active .toggle-switch__track{background:linear-gradient(135deg,var(--palm-500),var(--palm-600))}.toggle-switch--inactive .toggle-switch__track{background:var(--warm-300)}.toggle-switch__thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.toggle-switch--active .toggle-switch__thumb{transform:translate(20px)}.toggle-switch__label{cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch__status{font-size:13px;font-weight:600}.toggle-switch__status--active{color:var(--palm-700)}.toggle-switch__status--inactive{color:var(--warm-500)}.day-selector{display:flex;flex-wrap:nowrap;gap:6px;width:100%}.day-selector__button{display:flex;align-items:center;justify-content:center;flex:1;min-width:0;height:40px;padding:0 4px;border:none;border-radius:var(--radius-sm);background:var(--warm-100);color:var(--warm-500);font-size:12px;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all .2s ease;touch-action:manipulation}.day-selector__button:hover{background:var(--warm-200);color:var(--warm-700)}.day-selector__button:focus{outline:none}.day-selector__button:focus-visible{outline:none}.day-selector__button:active{transform:scale(.95)}.day-selector__button--selected{background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff}.day-selector__button--selected:hover,.day-selector__button--selected:focus,.day-selector__button--selected:active{background:linear-gradient(135deg,var(--ocean-600),var(--ocean-700));color:#fff}.day-selector__button:disabled{opacity:.4;cursor:not-allowed}.form-field{display:flex;flex-direction:column;gap:8px;min-width:0;max-width:100%}.form-field--error input,.form-field--error select,.form-field--error textarea{border-color:var(--lava-500)}.form-field--error input:focus,.form-field--error select:focus,.form-field--error textarea:focus{border-color:var(--lava-500);box-shadow:0 0 0 4px #ef444426}.form-field__label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--warm-600);text-transform:uppercase;letter-spacing:.03em}.form-field__icon{font-size:16px}.form-field__required{color:var(--lava-500);font-weight:700}.form-field__hint{font-size:13px;color:var(--warm-500);margin-top:8px}.form-field__error{font-size:12px;color:var(--lava-500);font-weight:500;display:flex;align-items:center;gap:4px}.form-field__error:before{content:"⚠";font-size:14px}.student-limit-group{display:flex;flex-direction:column;gap:12px;width:100%;max-width:100%}.student-limit-input{display:flex;align-items:center;gap:8px;width:100%;max-width:100%}.student-limit-input__field{width:80px;max-width:80px;flex-shrink:0;text-align:center}.student-limit-input__suffix{font-size:14px;color:var(--warm-500)}.training-form{width:100%}.training-form .form-actions{display:flex;gap:12px;margin-top:8px;padding-top:16px;border-top:1px solid var(--border)}.training-form .form-actions button{flex:1;min-height:48px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 768px){.toggle-switch,.toggle-switch__track{width:44px;height:24px}.toggle-switch__thumb{width:18px;height:18px;top:3px;left:3px}.toggle-switch--active .toggle-switch__thumb{transform:translate(20px)}.day-selector{gap:4px}.day-selector__button{height:38px;font-size:11px}.student-limit-group{gap:16px}.student-limit-input__field{min-height:44px;width:80px;max-width:80px;flex-shrink:0}.training-form .form-actions{flex-direction:column}.training-form .form-actions button{width:100%}.form-field__hint{font-size:13px}}.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}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;white-space:nowrap;border:1px solid transparent}.status-badge--sm{padding:4px 8px;font-size:10px;margin-left:8px}.status-badge__icon{font-size:.9em}.status-badge--success{background:var(--success-light);color:var(--palm-700);border-color:var(--palm-200)}.status-badge--warning{background:var(--sand-100);color:var(--sunset-700);border-color:var(--sand-200)}.status-badge--error{background:var(--error-light);color:var(--lava-500);border-color:#fecaca}.status-badge--neutral{background:var(--warm-100);color:var(--warm-600);border-color:var(--warm-200)}.status-badge--info{background:var(--ocean-100);color:var(--ocean-700);border-color:var(--ocean-200)}.status-badge--role-admin{background:linear-gradient(135deg,var(--sunset-100),var(--sunset-200));color:var(--sunset-700)}.status-badge--role-trainer{background:linear-gradient(135deg,var(--ocean-100),var(--ocean-200));color:var(--ocean-700)}.status-badge--role-student{background:linear-gradient(135deg,var(--palm-100),var(--palm-200));color:var(--palm-700)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;transition:all .2s;border-radius:var(--radius);min-width:44px;min-height:44px}.icon-btn--sm{min-width:32px;min-height:32px;font-size:14px}.icon-btn--md{min-width:44px;min-height:44px;font-size:18px}.icon-btn--lg{min-width:56px;min-height:56px;font-size:24px}.icon-btn--ghost{color:var(--warm-600)}.icon-btn--ghost:hover{background:var(--warm-100);color:var(--warm-800)}.icon-btn--danger{color:var(--lava-500)}.icon-btn--danger:hover{background:var(--error-light)}.icon-btn--primary{background:var(--ocean-500);color:#fff}.icon-btn--primary:hover{background:var(--ocean-600)}.fab{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));z-index:900;display:flex;align-items:center;justify-content:center;gap:8px;min-width:56px;min-height:56px;padding:16px;background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;border:none;border-radius:var(--radius-full);font-size:24px;font-weight:600;cursor:pointer;box-shadow:0 4px 14px #0ea5e966;transition:all .3s ease}.fab:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px #0ea5e980}.fab:active{transform:translateY(0) scale(.98)}.fab--right{right:20px}.fab--center{left:50%;transform:translate(-50%)}.fab--center:hover{transform:translate(-50%) translateY(-2px)}.fab--extended{padding:16px 24px;border-radius:var(--radius-full)}.fab__icon{font-size:20px;line-height:1}.fab__text{font-size:14px;font-weight:600}@media (min-width: 769px){.fab{display:none}}.action-menu{position:relative;display:inline-flex}.action-menu--open{z-index:1001}.action-menu__trigger{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:transparent;font-size:20px;color:var(--warm-500);cursor:pointer;border-radius:var(--radius);transition:all .2s}.action-menu__trigger:hover{background:var(--warm-100);color:var(--warm-700)}.action-menu__dropdown{position:absolute;top:100%;right:0;z-index:1000;min-width:180px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;margin-top:4px}.action-menu__dropdown--upward{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.action-menu__item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:transparent;font-size:14px;font-weight:500;color:var(--warm-700);cursor:pointer;text-align:left;transition:background .15s}.action-menu__item:hover{background:var(--warm-50)}.action-menu__item--danger{color:var(--lava-500)}.action-menu__item--danger:hover{background:var(--error-light)}.action-menu__item-icon{font-size:16px}.confirm-overlay{z-index:1200;display:flex;align-items:center;justify-content:center;padding:24px;background:#1c191799;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal{position:relative;background:#fff;border-radius:var(--radius-lg);padding:32px 24px;max-width:360px;width:100%;text-align:center;box-shadow:var(--shadow-lg);animation:confirmModalIn .25s ease}@keyframes confirmModalIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-modal__close{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;background:var(--warm-100);color:var(--warm-500);border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.confirm-modal__close:hover{background:var(--warm-200);color:var(--warm-700)}.confirm-modal__icon{font-size:48px;margin-bottom:16px;line-height:1}.confirm-modal__title{font-size:18px;font-weight:700;color:var(--warm-900);margin:0 0 12px}.confirm-modal__message{font-size:14px;line-height:1.6;color:var(--warm-600);margin:0 0 24px}.confirm-modal__actions{display:flex;flex-direction:column;gap:10px}.confirm-modal__btn{width:100%;padding:14px 24px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:2px solid transparent}.confirm-modal__btn:disabled{opacity:.6;cursor:not-allowed}.confirm-modal__btn--primary{background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff;border-color:var(--ocean-500)}.confirm-modal__btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--ocean-600),var(--ocean-700));transform:translateY(-1px)}.confirm-modal__btn--danger{background:var(--lava-500);color:#fff;border-color:var(--lava-500)}.confirm-modal__btn--danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.confirm-modal__btn--warning{background:var(--sunset-500);color:#fff;border-color:var(--sunset-500)}.confirm-modal__btn--warning:hover:not(:disabled){background:var(--sunset-600);transform:translateY(-1px)}.confirm-modal__btn--cancel{background:#fff;color:var(--warm-600);border-color:var(--border)}.confirm-modal__btn--cancel:hover:not(:disabled){background:var(--warm-50);border-color:var(--warm-300)}.confirm-modal--danger .confirm-modal__icon{width:64px;height:64px;margin:0 auto 16px;background:var(--error-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px}.confirm-modal--warning .confirm-modal__icon{width:64px;height:64px;margin:0 auto 16px;background:var(--sand-100);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px}.confirm-modal--primary .confirm-modal__icon{width:64px;height:64px;margin:0 auto 16px;background:var(--ocean-100);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px}@media (max-width: 768px){.confirm-overlay{padding:16px;background:#1c191799!important;align-items:center!important}.confirm-modal{max-width:100%;padding:28px 20px;min-height:auto!important;margin:0!important;border-radius:var(--radius-lg)!important;background:#fff!important}.confirm-modal__btn{min-height:50px}}.user-cards{display:none;flex-direction:column;gap:12px}.user-cards.mobile-only{display:none}@media (max-width: 768px){.user-cards.mobile-only{display:flex!important}}.user-card{position:relative;background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .2s}.user-card__content{display:flex;align-items:center;gap:12px}.user-card__avatar{width:48px;height:48px;background:linear-gradient(135deg,var(--ocean-100),var(--ocean-200));color:var(--ocean-700);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.user-card__info{flex:1;min-width:0}.user-card__name{font-size:16px;font-weight:600;color:var(--warm-900);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card__email{font-size:13px;color:var(--warm-500);margin:0 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card__badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.empty-state{text-align:center;padding:48px 24px;color:var(--warm-400)}.empty-state--compact{padding:24px 16px}.empty-state__icon{font-size:48px;margin-bottom:16px;display:block}.empty-state--compact .empty-state__icon{font-size:32px;margin-bottom:8px}.empty-state__text{font-size:16px;font-weight:600;color:var(--warm-600);margin:0 0 8px}.empty-state__subtext{font-size:14px;color:var(--warm-400);margin:0}.training-card--inactive{opacity:.6}.training-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.training-card__info{flex:1;min-width:0}.training-card__title{font-size:18px;font-weight:700;color:var(--warm-900);margin:0 0 6px;display:flex;align-items:center;gap:8px}.training-card__status-icon{font-size:14px}.training-card__subtitle{font-size:14px;color:var(--warm-500);margin:0}.training-card__badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.training-card__header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.training-card__hint{font-size:11px;color:var(--warm-400);text-align:center;margin:8px 0 0;font-style:italic}.training-card__schedule-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px}.training-card__days{display:flex;gap:3px;flex-wrap:nowrap}.day-pill--sm{padding:4px 6px;font-size:10px;min-width:auto}.training-card__schedule{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.training-card__time,.training-card__date{display:inline-flex;align-items:center;gap:6px;background:var(--warm-100);padding:5px 10px;border-radius:var(--radius-full);font-size:13px;font-weight:600;color:var(--warm-700);white-space:nowrap}.training-card__checkin{margin:12px -8px -8px}.training-card__checkin .checkin-done{margin-top:0;padding:12px;flex-direction:row;gap:10px}.training-card__checkin .checkin-done .icon{font-size:20px;margin-bottom:0}.training-card__checkin .checkin-done .text{font-size:13px;margin:0}.training-card__checkin .checkin-done .link-subtle{margin-top:0;margin-left:auto}.training-card__checkin .checkin-cta{margin-top:0;padding:10px;border-radius:var(--radius)}.training-card__checkin .checkin-cta .title{font-size:16px;margin-bottom:8px;color:#fff}.training-card__checkin .checkin-cta button{padding:8px 16px;font-size:12px}.training-card__checkin .checkin-unavailable{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:var(--warm-100);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--warm-500)}.training-card__checkin .checkin-unavailable--full{background:var(--sand-100);border-color:var(--sand-200);color:var(--sunset-700)}.training-card__actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);flex-wrap:wrap}.training-card__crew{background:var(--warm-50);border-radius:var(--radius);padding:16px;margin-top:16px}.training-card__crew .crew-grid--compact{gap:10px}.training-card__crew .crew-avatar,.training-card__crew .crew-avatar--empty{width:64px;height:64px}.training-card__crew .crew-avatar--empty svg{width:24px;height:24px}.training-card__crew .crew-name{font-size:11px;margin-top:4px}.training-card__crew .crew-avatar__tag{font-size:8px;padding:2px 5px;bottom:-4px}.training-card__crew .crew-add-btn{margin-top:12px;font-size:12px;padding:8px 12px}.day-pill{padding:5px 7px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;background:var(--warm-100);color:var(--warm-400);border:1px solid var(--warm-200);transition:all .2s}.day-pill--active{background:linear-gradient(135deg,var(--ocean-100),var(--ocean-200));color:var(--ocean-700);border-color:var(--ocean-300)}.btn-action{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid transparent;min-height:36px}.btn-action--primary{background:linear-gradient(135deg,var(--ocean-500),var(--ocean-600));color:#fff}.btn-action--primary:hover{background:linear-gradient(135deg,var(--ocean-600),var(--ocean-700))}.btn-action--secondary{background:var(--warm-100);color:var(--warm-700);border-color:var(--warm-200)}.btn-action--secondary:hover{background:var(--warm-200)}.btn-action--ghost{background:transparent;color:var(--warm-600);border-color:var(--border)}.btn-action--ghost:hover{background:var(--warm-50);color:var(--warm-800)}.btn-action--danger{background:var(--error-light);color:var(--lava-500);border-color:#ef444433}.btn-action--danger:hover{background:#fecaca}.btn-action--primary{background:var(--ocean-500);color:#fff;border-color:var(--ocean-500)}.btn-action--primary:hover{background:var(--ocean-600);border-color:var(--ocean-600)}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.detail-header__title{font-size:22px;font-weight:700;color:var(--warm-900);margin:0;display:flex;align-items:center;gap:8px}.detail-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.detail-row__label{font-size:13px;color:var(--warm-500);display:flex;align-items:center;gap:6px}.detail-row__value{font-size:15px;font-weight:600;color:var(--warm-900)}.detail-row__value--help{font-size:14px;font-weight:500}.detail-row--top{align-items:flex-start}.detail-days{display:flex;gap:4px;flex-wrap:nowrap}.checkin-cta__title{color:#fff;font-size:20px;font-weight:700;margin:0 0 16px;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:8px}.checkin-done__icon{font-size:48px;margin-bottom:12px;display:block}.checkin-done__text{color:var(--palm-700);font-weight:700;font-size:16px;margin:0}.alert--warning{background:var(--sand-100);color:var(--sunset-700);border:1px solid var(--sand-200);display:flex;align-items:center;gap:10px;padding:16px 20px;border-radius:var(--radius);margin-top:16px}.alert--info{background:var(--ocean-50);color:var(--ocean-700);border:1px solid var(--ocean-200);display:flex;align-items:center;gap:10px;padding:16px 20px;border-radius:var(--radius);margin-top:16px}.presence-cards{display:none;flex-direction:column;gap:8px}@media (max-width: 768px){.presence-cards{display:flex}.presence-cards.mobile-only{display:flex!important}}.presence-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius)}.presence-card__info{flex:1;min-width:0}.presence-card__name{font-size:14px;font-weight:600;color:var(--warm-900);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.presence-card__time{font-size:12px;color:var(--warm-500);margin-top:4px;display:block}.crew-section{margin-top:24px}.crew-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.crew-title{font-size:16px;font-weight:600;color:var(--text);margin:0}.crew-counter{font-size:14px;font-weight:600;color:var(--text-secondary)}.crew-counter--full{color:var(--palm-600)}.crew-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (min-width: 480px){.crew-grid{gap:12px}}.crew-slot{display:flex;flex-direction:column;align-items:center;gap:6px;padding:6px 2px;border-radius:var(--radius);transition:background .15s ease}.crew-slot--filled{cursor:pointer}.crew-slot--filled:hover{background:var(--warm-100)}.crew-slot--empty{opacity:1}.crew-slot--clickable{cursor:pointer}.crew-slot--clickable:hover .crew-avatar--empty{opacity:.6}.crew-avatar{position:relative;width:64px;height:64px;border-radius:50%;overflow:visible;display:flex;align-items:center;justify-content:center}.crew-avatar--empty{width:64px;height:64px;border-radius:50%;border:none;background:var(--warm-100);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.crew-avatar--empty svg{width:24px;height:24px;color:var(--warm-300);opacity:.7}.crew-slot--clickable:hover .crew-avatar--empty{background:var(--ocean-100)}.crew-slot--clickable:hover .crew-avatar--empty svg{color:var(--ocean-400);opacity:1}.crew-avatar__img{width:100%;height:100%;border-radius:50%;object-fit:cover}.crew-avatar__tag{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);font-size:9px;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:8px;letter-spacing:.3px;white-space:nowrap}.crew-avatar__tag--me{color:#fff;background:var(--ocean-500)}.crew-slot--me .crew-avatar{width:64px;height:64px}.crew-slot--me .crew-avatar:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;pointer-events:none}.crew-avatar__tag--guest{color:#fff;background:var(--palm-500)}.crew-name{font-size:12px;font-weight:600;color:var(--text);text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.crew-name--empty{color:var(--warm-400);font-weight:500}.crew-hint{margin-top:16px;font-size:13px;color:var(--text-secondary);text-align:center}.crew-full-message{margin-top:16px;font-size:13px;font-weight:500;color:var(--palm-600);text-align:center}.beach-avatar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:8px 0}.beach-avatar-slot{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px;border-radius:12px;transition:all .2s ease;cursor:default}.beach-avatar-slot--present:hover{background:#0ea5e914}.beach-avatar-slot--me{background:#0ea5e91a}.beach-avatar-slot__avatar{position:relative;width:52px;height:52px}.beach-avatar-slot__img{width:100%;height:100%;border-radius:50%;object-fit:cover}.beach-avatar-slot__tag{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);font-size:9px;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:8px;letter-spacing:.3px;white-space:nowrap}.beach-avatar-slot__tag--me{color:#fff;background:var(--ocean-500)}.beach-avatar-slot__tag--guest{color:#fff;background:var(--palm-500)}.beach-avatar-slot__name{font-size:12px;font-weight:600;color:var(--text);text-align:center;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.beach-avatar-slot__name--empty{color:var(--warm-400);font-weight:500}.crew-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;color:var(--text-secondary);font-size:14px}.crew-add-btn{margin-top:16px;padding:10px 20px;background:transparent;border:1px dashed var(--warm-300);border-radius:var(--radius);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;width:100%}.crew-add-btn:hover{background:var(--ocean-50);border-color:var(--ocean-400);color:var(--ocean-600)}.training-modern{display:flex;flex-direction:column;min-height:100vh;background:var(--warm-50)}.training-modern__header{background:linear-gradient(135deg,#1e293b,#334155);padding:0 0 24px;color:#fff}.training-modern__header .mobile-header{background:transparent}.training-modern__header .mobile-header__back{color:#fff;background:#ffffff1a}.training-modern__header .mobile-header__back:hover{background:#fff3}.training-modern__header-content{padding:0 20px}.training-modern__title{font-size:24px;font-weight:700;margin:0 0 16px;color:#fff}.training-modern__meta{display:flex;flex-direction:column;gap:8px}.training-modern__meta-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#fffc}.training-modern__meta-icon{width:16px;height:16px;opacity:.7}.training-modern__content{flex:1;padding:24px 20px 100px}.training-modern__crew{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 3px #0000000d}.training-modern__crew-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.training-modern__crew-title{font-size:16px;font-weight:600;color:var(--text);margin:0}.training-modern__crew-count{font-size:14px;font-weight:600;color:var(--text-secondary);background:var(--warm-100);padding:4px 12px;border-radius:20px}.training-modern__crew-count--full{background:var(--palm-100);color:var(--palm-700)}.training-modern__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.training-modern__slot{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px;border-radius:12px;transition:all .2s ease}.training-modern__slot--filled{cursor:pointer}.training-modern__slot--filled:hover{background:var(--warm-50)}.training-modern__slot--me{background:#6366f114}.training-modern__slot--me:hover{background:#6366f11f}.training-modern__slot--empty{opacity:1}.training-modern__avatar{position:relative;width:52px;height:52px;border-radius:50%;overflow:visible;display:flex;align-items:center;justify-content:center}.training-modern__avatar>svg{border-radius:50%}.training-modern__avatar--empty{opacity:.4;filter:grayscale(100%)}.training-modern__avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.training-modern__check{position:absolute;top:-4px;right:-4px;width:20px;height:20px;background:#10b981;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.training-modern__check svg{width:12px;height:12px;color:#fff}.training-modern__me-label{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);font-size:9px;font-weight:700;text-transform:uppercase;color:#fff;background:#6366f1;padding:2px 6px;border-radius:4px;letter-spacing:.5px}.training-modern__name{font-size:12px;font-weight:600;color:var(--text);text-align:center;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.training-modern__name--empty{color:var(--warm-400);font-weight:500}.training-modern__full-message{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;padding:12px;background:var(--palm-50);border-radius:8px;font-size:14px;font-weight:500;color:var(--palm-700)}.training-modern__full-message svg{width:18px;height:18px}.training-modern__hint{margin-top:16px;font-size:13px;color:var(--text-secondary);text-align:center}.training-modern__footer{position:fixed;bottom:0;left:0;right:0;padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 12px #0000000d}.training-modern__action{width:100%;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.training-modern__action--checkin{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.training-modern__action--checkin:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.training-modern__action--checkin:disabled{background:var(--warm-300);color:var(--warm-500);box-shadow:none;cursor:not-allowed}.training-modern__action--cancel{background:#fff;color:#ef4444;border:2px solid #ef4444}.training-modern__action--cancel:hover:not(:disabled){background:#fef2f2}.training-modern__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px;text-align:center;color:var(--text-secondary)}.training-modern__empty-icon{font-size:48px;margin-bottom:16px}.training-modern__modal{max-width:400px}@media (min-width: 768px){.training-modern{max-width:480px;margin:0 auto;min-height:auto;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #0000001a}.training-modern__header{border-radius:16px 16px 0 0}.training-modern__footer{position:relative;border-radius:0 0 16px 16px}}.rower-info{display:flex;align-items:center;gap:12px}.rower-name{font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.guest-fields{display:flex;flex-direction:column;gap:12px;margin-top:16px}.guest-field{display:flex;gap:8px;align-items:center}.guest-field input{flex:1;min-height:52px}.form-hint{font-size:13px;color:var(--warm-500);margin-top:8px}.form-hint--error{color:var(--lava-500)}.form-hint--success{color:var(--palm-600)}.form-hint--warning{color:var(--sunset-600);font-weight:500}.label-hint{font-size:12px;font-weight:400;color:var(--warm-500);margin-left:4px}.modal-actions{display:flex;gap:12px;margin-top:24px}.modal-actions--row{flex-direction:row!important}.modal-actions--row button{flex:1}@media (max-width: 768px){.modal-actions{flex-direction:column}.modal-actions button{width:100%;min-height:52px}.modal-actions--row{flex-direction:row!important}.modal-actions--row button{flex:1;min-height:44px}}.profile-actions__divider{height:1px;background:var(--border);margin:8px 0}.profile-action-btn--danger{color:var(--lava-500);border-color:var(--error-light)}.profile-action-btn--danger:active{background:var(--error-light)}.btn-warning{background:var(--sand-100);color:var(--sunset-700);border:1px solid var(--sand-200);padding:12px 24px;border-radius:var(--radius);font-size:14px;font-weight:600}.btn-warning:hover{background:var(--sand-200)}.school-context-display{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--ocean-50);border:2px solid var(--ocean-200);border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--ocean-700)}.school-context-icon{font-size:18px}.school-context-warning{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--sand-100);border:2px solid var(--sand-200);border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--sunset-700)}.toast{position:fixed;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;border-radius:var(--radius-full);font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);max-width:calc(100vw - 32px);animation:toastIn .3s ease;cursor:pointer}.toast--bottom{bottom:calc(80px + env(safe-area-inset-bottom,0px))}.toast--top{top:calc(16px + env(safe-area-inset-top,0px))}.toast--error{background:var(--lava-500);color:#fff}.toast--success{background:var(--palm-600);color:#fff}.toast--warning{background:var(--sunset-500);color:#fff}.toast--info{background:var(--ocean-600);color:#fff}.toast--exit{animation:toastOut .3s ease forwards}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(20px)}}.toast__icon{font-size:18px;flex-shrink:0}.toast__message{text-align:center;line-height:1.4}.error-toast{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top,0px));background:var(--lava-500);color:#fff;font-size:14px;font-weight:600;box-shadow:0 4px 20px #ef444466;animation:errorToastIn .3s ease}@keyframes errorToastIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.error-toast__icon{font-size:18px;flex-shrink:0}.error-toast__message{text-align:center;line-height:1.4}.plans-panel{width:100%}.plan-name-cell{display:flex;flex-direction:column;gap:4px}.plan-name-cell .plan-name{font-weight:600;color:var(--text)}.plan-name-cell .plan-description{font-size:12px;color:var(--text-secondary)}.plan-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.plan-card.inactive{opacity:.6;background:var(--warm-100)}.plan-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.plan-card__info{flex:1}.plan-card__name{font-size:16px;font-weight:600;color:var(--text);margin:0 0 4px}.plan-card__description{font-size:13px;color:var(--text-secondary);margin:0}.plan-card__details{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.plan-card__detail{display:flex;flex-direction:column;gap:4px}.plan-card__label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.plan-card__value{font-size:14px;font-weight:600;color:var(--text)}.plan-card__price{color:var(--ocean-600)}.plan-card__footer{display:flex;justify-content:flex-end}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600}.status-badge.active,.status-badge.success{background:var(--palm-100);color:var(--palm-700)}.status-badge.inactive,.status-badge.muted{background:var(--warm-200);color:var(--warm-600)}.status-badge.warning{background:var(--sand-100);color:var(--sunset-700)}.status-badge.danger{background:var(--lava-100);color:var(--lava-500)}.inactive-row{opacity:.6;background:var(--warm-50)}.subscriptions-panel{width:100%}.user-cell{display:flex;flex-direction:column;gap:2px}.user-cell .user-name{font-weight:600;color:var(--text)}.user-cell .user-email{font-size:12px;color:var(--text-secondary)}.plan-cell{display:flex;flex-direction:column;gap:2px}.plan-cell .plan-name{font-weight:500;color:var(--text)}.plan-cell .plan-price{font-size:12px;color:var(--ocean-600);font-weight:600}.checkins-unlimited{color:var(--palm-600);font-weight:600}.checkins-count{font-weight:600;color:var(--text)}.validity-cell{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:13px}.validity-separator{color:var(--text-secondary)}.subscription-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.subscription-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.subscription-card__user{flex:1}.subscription-card__name{font-size:16px;font-weight:600;color:var(--text);margin:0}.subscription-card__email{font-size:12px;color:var(--text-secondary);display:block;margin-top:2px}.subscription-card__body{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.subscription-card__plan{display:flex;flex-direction:column;gap:2px}.subscription-card__plan-name{font-weight:500;color:var(--text)}.subscription-card__plan-price{font-size:14px;color:var(--ocean-600);font-weight:600}.subscription-card__details{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.subscription-card__detail{display:flex;flex-direction:column;gap:4px}.subscription-card__label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.subscription-card__value{font-size:13px;font-weight:500;color:var(--text)}.payment-info{background:var(--warm-50);padding:16px;border-radius:var(--radius);margin-bottom:20px}.payment-info p{margin:0 0 8px;font-size:14px}.payment-info p:last-child{margin-bottom:0}.plan-preview{background:var(--ocean-50);padding:16px;border-radius:var(--radius);margin-bottom:20px;border:1px solid var(--ocean-200)}.plan-preview h4{margin:0 0 12px;font-size:14px;color:var(--ocean-700)}.plan-preview p{margin:0 0 6px;font-size:13px;color:var(--text)}.plan-preview p:last-child{margin-bottom:0}.my-subscription-card{background:var(--card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}.my-subscription-card.empty{padding:24px 20px;text-align:center;background:linear-gradient(135deg,var(--ocean-500) 0%,var(--ocean-600) 50%,var(--ocean-700) 100%);color:#fff}.my-subscription-card.empty .my-subscription-card__title{color:#fff}.my-subscription-card.empty .my-subscription-card__text{color:#fffc}.my-subscription-card.loading{padding:20px}.my-subscription-card__icon{font-size:48px;margin-bottom:12px}.my-subscription-card__title{font-size:16px;font-weight:600;color:var(--text);margin:0 0 8px}.my-subscription-card__text{font-size:14px;color:var(--text-secondary);margin:0}.my-subscription-card__header{padding:14px 20px;background:linear-gradient(135deg,var(--ocean-500) 0%,var(--ocean-600) 50%,var(--ocean-700) 100%);color:#fff;position:relative}.my-subscription-card__plan{display:flex;justify-content:space-between;align-items:center}.my-subscription-card__plan-name{font-size:18px;font-weight:700;margin:0}.my-subscription-card__header .status-badge{background:#fff3;color:#ffffffe6;font-size:9px;font-weight:600;letter-spacing:.5px;padding:4px 10px;border-radius:var(--radius-full);text-transform:uppercase}.my-subscription-card__header .status-badge.success{background:#fff3}.my-subscription-card__header .status-badge.warning{background:#f973164d}.my-subscription-card__header .status-badge.danger{background:#ef44444d}.my-subscription-card__body{padding:16px 20px;background:#fff}.my-subscription-card__checkins{margin-bottom:12px}.my-subscription-card__checkins-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.my-subscription-card__label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.my-subscription-card__value{font-size:16px;font-weight:700;color:var(--text)}.my-subscription-card__value.unlimited{color:var(--palm-600)}.my-subscription-card__value.warning{color:var(--sunset-600)}.my-subscription-card__progress{height:8px;background:var(--warm-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:8px}.my-subscription-card__progress-bar{height:100%;background:linear-gradient(90deg,var(--ocean-500),var(--palm-500));border-radius:var(--radius-full);transition:width .3s ease}.my-subscription-card__checkins-detail{font-size:12px;color:var(--text-secondary)}.my-subscription-card__validity{padding-top:8px}.my-subscription-card__pending-info{display:flex;flex-direction:column;gap:12px}.my-subscription-card__pending-info .my-subscription-card__detail{display:flex;justify-content:space-between;align-items:center}.my-subscription-card__pending-info .my-subscription-card__label{color:var(--text-secondary);font-size:13px}.my-subscription-card__pending-info .my-subscription-card__value{font-weight:600;font-size:14px;color:var(--text)}.my-subscription-card__dates{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text);margin-top:6px}.my-subscription-card__dates .separator{color:var(--text-secondary)}.my-subscription-card__days-remaining{font-size:13px;color:var(--palm-600);font-weight:500;margin-top:6px;display:block}.my-subscription-card__days-remaining.warning{color:var(--sunset-600)}.my-subscription-card__alerts{padding:0 20px 12px}.my-subscription-card__alert{padding:10px 14px;border-radius:var(--radius);font-size:12px;font-weight:500;margin-bottom:6px}.my-subscription-card__alert:last-child{margin-bottom:0}.my-subscription-card__alert.warning{background:var(--sand-100);color:var(--sunset-700)}.my-subscription-card__alert.danger{background:var(--lava-100);color:var(--lava-500)}.my-subscription-card__alert.info{background:var(--ocean-100);color:var(--ocean-700)}.my-subscription-card--clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.my-subscription-card--clickable:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.my-subscription-card--clickable:active{transform:translateY(0)}.my-subscription-card__divider{height:1px;background:var(--border);margin:0 20px}.my-subscription-card__footer{padding:8px 20px 10px;text-align:center;background:#fff}.my-subscription-card__cta{display:inline-block;padding:0;background:transparent;border:none;font-size:12px;font-weight:400;font-style:italic;color:var(--text-secondary);cursor:pointer;transition:all .2s;opacity:.7}.my-subscription-card__cta:hover{opacity:1;color:var(--ocean-600)}.my-subscription-card__cta:active{transform:scale(.98)}.my-subscription-card.empty .my-subscription-card__cta{margin-top:16px;padding:10px 24px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius);font-size:14px;font-weight:500;font-style:normal;color:#fff;opacity:1}.my-subscription-card.empty .my-subscription-card__cta:hover{background:#ffffff4d;color:#fff}.my-subscription-card__hint{font-size:12px;color:var(--text-secondary);font-weight:500}.payments-list{padding:16px;max-height:400px;overflow-y:auto}.payment-item{background:var(--warm-50);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.payment-item:last-child{margin-bottom:0}.payment-item__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.payment-item__amount{font-size:18px;font-weight:700;color:var(--palm-600)}.payment-item__method{font-size:12px;font-weight:600;padding:4px 8px;background:var(--ocean-100);color:var(--ocean-700);border-radius:var(--radius-full)}.payment-item__date{font-size:13px;color:var(--text-secondary)}.payment-item__notes{font-size:12px;color:var(--text-secondary);margin-top:8px;padding-top:8px;border-top:1px dashed var(--border);font-style:italic}.loading-state{text-align:center;padding:40px;color:var(--text-secondary)}.profile-card--subscription{padding:0;background:transparent;color:var(--text);text-align:left;box-shadow:none;border:none}.profile-card--subscription .profile-section-title{margin-bottom:8px;padding:0;color:var(--text-secondary);justify-content:flex-start;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.profile-card--subscription .my-subscription-card{width:100%}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;width:100%;max-width:100%;box-sizing:border-box}.form-row>*{min-width:0;width:100%;box-sizing:border-box}.form-row input,.form-row select,.form-row textarea{width:100%;max-width:100%;box-sizing:border-box}@media (max-width: 600px){.form-row{grid-template-columns:1fr;gap:12px}}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--ocean-600);cursor:pointer}.skeleton{background:linear-gradient(90deg,var(--warm-200) 25%,var(--warm-100) 50%,var(--warm-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-title{height:24px;width:60%;margin-bottom:12px}.skeleton-text{height:16px;width:80%;margin-bottom:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:48px 20px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:48px;display:block;margin-bottom:12px;opacity:.5}.empty-state p{margin:0;font-size:14px}.empty-message{text-align:center;padding:32px 20px;color:var(--text-secondary);font-style:italic}.table-row--clickable{cursor:pointer;transition:background-color .2s ease}.table-row--clickable:hover{background-color:var(--ocean-50)}.subscription-card--clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.subscription-card--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.modal--large{max-width:600px;width:95%}.subscription-details{padding:20px}.subscription-details__info{margin-bottom:24px}.subscription-details__row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.subscription-details__row:last-child{border-bottom:none}.subscription-details__label{font-size:14px;color:var(--text-secondary);font-weight:500}.subscription-details__value{font-size:14px;font-weight:600;color:var(--text)}.subscription-details__payments{background:var(--warm-50);border-radius:var(--radius);padding:16px}.subscription-details__payments-title{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text)}.multi-select-list{border:1px solid var(--border);border-radius:var(--radius);max-height:250px;overflow-y:auto;background:var(--warm-50)}.edit-info-card{background:var(--warm-50);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin:0 0 20px}.edit-info-card__row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.edit-info-card__row:first-child{padding-top:0}.edit-info-card__row:last-child{padding-bottom:0}.edit-info-card__row:not(:last-child){border-bottom:1px solid var(--border)}.edit-info-card__label{font-size:13px;color:var(--text-secondary);font-weight:500}.edit-info-card__value{font-size:15px;font-weight:600;color:var(--text)}.plan-change-alert{background:var(--sunset-50);border:1px solid var(--sunset-200);border-radius:var(--radius);padding:16px;margin-bottom:8px}.plan-change-alert__warning{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px}.plan-change-alert__icon{font-size:18px;flex-shrink:0}.plan-change-alert__text{font-size:13px;color:var(--sunset-700);line-height:1.5}.plan-change-alert__text strong{color:var(--sunset-800)}.plan-preview-card{background:linear-gradient(135deg,var(--ocean-50) 0%,var(--palm-50) 100%);border:1px solid var(--ocean-200);border-radius:var(--radius);padding:16px}.plan-preview-card--compact{background:#fff;border:1px solid var(--ocean-200)}.plan-preview-card__header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--ocean-200)}.plan-preview-card__icon{font-size:18px}.plan-preview-card__name{font-size:15px;font-weight:600;color:var(--ocean-700)}.plan-preview-card__details{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.plan-preview-card__item{display:flex;flex-direction:column;gap:2px}.plan-preview-card__label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.plan-preview-card__value{font-size:14px;font-weight:600;color:var(--text)}.plan-preview-card__value--price{color:var(--palm-600)}.plan-preview-card__total{margin-top:12px;padding-top:12px;border-top:1px dashed var(--ocean-300);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--ocean-700)}.plan-preview-card__total strong{font-size:16px;color:var(--palm-600)}.form-divider{display:flex;align-items:center;gap:12px;margin:8px 0}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--border)}.form-divider span{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.selection-badge{background:var(--ocean-100);color:var(--ocean-700);font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px}.form-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.form-label-row .label{margin-bottom:0}.multi-select-items{max-height:200px;overflow-y:auto}.multi-select-item--selected{background:var(--ocean-50);border-left:3px solid var(--ocean-500)}.multi-select-item__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.multi-select-item__check{color:var(--ocean-600);font-weight:700;font-size:16px}.select--large{padding:14px 16px;font-size:15px}.link-subtle--danger{color:var(--text-secondary)!important}.link-subtle--danger:hover{color:var(--lava-500)!important}.btn--large{padding:14px 24px;font-size:15px}.empty-state--compact{padding:24px 16px;text-align:center}.empty-state--compact .empty-state__icon{font-size:32px;margin-bottom:8px;display:block}.empty-state--compact .empty-state__title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.empty-state--compact .empty-state__description{font-size:13px;color:var(--text-secondary);margin:0}.modal-actions{display:flex;flex-direction:column;gap:8px;margin-top:12px}.modal-actions .primary{width:100%}.modal-actions .ghost{width:100%;color:var(--text-secondary)}.modal--subscription{max-width:480px}@media (max-width: 480px){.plan-preview-card__details{grid-template-columns:1fr 1fr}.plan-preview-card__item:last-child{grid-column:span 2;text-align:center;padding-top:8px;border-top:1px solid var(--ocean-100);margin-top:4px}.edit-info-card{margin:0 16px 16px}.form-row{display:flex;flex-direction:column;gap:16px}}.my-school-card{background:linear-gradient(135deg,var(--ocean-50) 0%,var(--palm-50) 100%);border:2px solid var(--ocean-200);border-radius:var(--radius-lg);padding:20px}.my-school-card--clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.my-school-card--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.my-school-card__header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.my-school-card__icon{font-size:28px}.my-school-card__title{font-size:18px;font-weight:600;color:var(--ocean-700)}.my-school-card__content{display:flex;flex-direction:column;gap:8px}.my-school-card__name{font-size:20px;font-weight:700;color:var(--text)}.my-school-card__info{display:flex;flex-wrap:wrap;gap:12px}.my-school-card__timezone{font-size:14px;color:var(--text-secondary)}.my-school-card__footer{margin-top:16px;padding-top:12px;border-top:1px solid var(--ocean-200);text-align:center}.my-school-card__hint{font-size:12px;color:var(--ocean-500);font-weight:500}.multi-select-actions{display:flex;gap:16px;padding:12px 16px;border-bottom:1px solid var(--border);background:#fff;position:sticky;top:0;z-index:1}.multi-select-actions .link-subtle{background:none;border:none;color:var(--primary);font-size:13px;font-weight:500;cursor:pointer;padding:0;transition:opacity .2s}.multi-select-actions .link-subtle:hover{opacity:.7}.multi-select-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .2s}.multi-select-item:last-child{border-bottom:none}.multi-select-item:hover{background:var(--ocean-50)}.multi-select-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.multi-select-item__name{font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multi-select-item__email{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){.multi-select-item{flex-wrap:wrap}.multi-select-item__name{flex:none;width:calc(100% - 30px)}.multi-select-item__email{flex:none;width:calc(100% - 30px);margin-left:30px;margin-top:-4px}}.terms-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1917d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;padding:24px;z-index:2000;overflow-y:auto}.terms-modal{background:#fff;border-radius:var(--radius-lg);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modalIn .3s ease}.terms-modal .modal__header{padding:24px 24px 0;border-bottom:none}.terms-modal .modal__header h2{font-size:24px;font-weight:700;color:var(--text);text-align:center}.terms-modal .modal__content{padding:16px 24px;overflow-y:auto;flex:1}.terms-content{display:flex;flex-direction:column;gap:20px}.terms-text{background:var(--warm-50);border-radius:var(--radius);padding:20px;max-height:400px;overflow-y:auto;font-size:14px;line-height:1.6;color:var(--text)}.terms-text h3{font-size:16px;font-weight:700;text-align:center;margin-bottom:16px;color:var(--ocean-700)}.terms-text h4{font-size:14px;font-weight:600;margin:16px 0 8px;color:var(--ocean-600)}.terms-text p{margin-bottom:12px}.terms-text ul{margin-left:20px;margin-bottom:12px}.terms-text ul li{margin-bottom:6px}.terms-text .terms-final{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);text-align:center}.terms-checkbox{display:flex;align-items:center;gap:12px;padding:16px;background:var(--ocean-50);border-radius:var(--radius);cursor:pointer;transition:background .2s}.terms-checkbox:hover{background:var(--ocean-100)}.terms-checkbox input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary);cursor:pointer}.terms-checkbox span{font-size:14px;font-weight:500;color:var(--text)}.terms-modal .modal__actions{padding:16px 24px 24px;border-top:1px solid var(--border)}.terms-modal .btn--full{width:100%;padding:14px 20px;font-size:16px;font-weight:600}.terms-modal .btn--full:disabled{background:var(--warm-300);cursor:not-allowed;opacity:.7}@media (max-width: 768px){.terms-modal-overlay{padding:0;align-items:stretch}.terms-modal{max-width:none;border-radius:0;max-height:none;height:100%}.terms-text{max-height:none}.terms-modal .modal__content{flex:1;overflow-y:auto}}.profile-screen{padding:20px 0 0}.profile-card-vibrant{background:linear-gradient(135deg,#0891b2,#0e7490)!important;border-radius:16px;padding:24px;margin:0 8px 16px;box-shadow:0 4px 12px #00000026;position:relative;text-align:center;color:#fff}.profile-badge-role{position:absolute!important;top:16px;right:16px;border:1.5px solid white!important;background:transparent!important;color:#fff!important;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 12px;border-radius:12px;text-transform:uppercase}.profile-avatar-vibrant{width:64px;height:64px;background:#ffffff26;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 12px;box-shadow:0 4px 12px #00000026}.profile-name-vibrant{font-size:22px;font-weight:700;color:#fff;margin:0 0 4px;line-height:1.2}.profile-email-vibrant{font-size:14px;font-weight:400;color:#fffc;margin:0 0 16px}.profile-edit-button-vibrant{background:transparent!important;border:1.5px solid white!important;color:#fff!important;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.profile-edit-button-vibrant:active{background:#fff3!important}.subscription-section-vibrant{margin:0 8px 16px}.settings-section-vibrant{background:#fff;padding:0 20px 40px;margin-top:8px}.settings-title-vibrant{font-size:22px;font-weight:600;color:#1f2937;margin:0 0 28px;padding-top:28px;letter-spacing:-.3px}.settings-category-vibrant{display:block;font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;margin:32px 0 8px}.settings-category-vibrant:first-of-type{margin-top:0}.settings-item-vibrant{display:flex;justify-content:space-between;align-items:center;width:100%;min-height:52px;font-size:16px;font-weight:400;color:#374151;background:transparent;border:none;cursor:pointer;text-align:left;transition:background-color .15s ease,opacity .15s ease;border-radius:8px;margin:0 -8px;padding:14px 8px}.chevron-vibrant{font-size:18px;color:#d1d5db;font-weight:300;flex-shrink:0;margin-left:auto;transition:color .15s ease}.settings-item-vibrant:hover .chevron-vibrant{color:#9ca3af}.settings-divider-vibrant{display:none}.settings-divider-strong-vibrant{height:1px;background:#f3f4f6;margin:40px 0 16px}.settings-item-danger-vibrant{color:#dc2626!important;font-weight:500;margin-top:8px}.settings-item-danger-vibrant .chevron-vibrant{color:#fca5a5}.my-subscription-card-vibrant{border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.my-subscription-card-vibrant__header{background:linear-gradient(135deg,#0891b2,#0e7490);padding:16px 20px;display:flex;justify-content:space-between;align-items:center}.my-subscription-card-vibrant__plan{display:flex;flex-direction:column;gap:2px}.my-subscription-card-vibrant__plan-prefix{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:#ffffffb3}.my-subscription-card-vibrant__plan-name{font-size:18px;font-weight:600;color:#fff;margin:0}.status-badge-vibrant{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-badge-vibrant.success{background:#22c55e33;color:#22c55e}.status-badge-vibrant.warning{background:#f9731633;color:#f97316}.status-badge-vibrant.danger{background:#ef444433;color:#ef4444}.status-badge-vibrant.muted{background:#9ca3af33;color:#9ca3af}.my-subscription-card-vibrant__body{background:#fff;padding:16px 20px}.my-subscription-card-vibrant__label{display:block;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin-bottom:4px}.my-subscription-card-vibrant__value{display:block;font-size:15px;font-weight:600;color:#1f2937}.my-subscription-card-vibrant__value.unlimited{color:#0891b2}.my-subscription-card-vibrant__value.warning{color:#f97316}.my-subscription-card-vibrant__checkins{margin-bottom:12px}.my-subscription-card-vibrant__progress{height:10px;background:#0ea5e926;border-radius:5px;overflow:hidden;margin-top:8px}.my-subscription-card-vibrant__progress-bar{height:100%;background:linear-gradient(90deg,#0891b2,#22c55e);border-radius:5px;transition:width .4s ease}.my-subscription-card-vibrant__validity-divider{height:1px;background:#00000014;margin:16px 0}.my-subscription-card-vibrant__validity{display:flex;flex-direction:column}.my-subscription-card-vibrant__pending-info{display:flex;flex-direction:column;gap:16px}.my-subscription-card-vibrant__detail{display:flex;flex-direction:column}.my-subscription-card-vibrant__alerts{padding:0 20px 16px;background:#fff}.my-subscription-card-vibrant__alert{padding:12px 16px;border-radius:8px;font-size:13px;font-weight:500;margin-bottom:8px}.my-subscription-card-vibrant__alert:last-child{margin-bottom:0}.my-subscription-card-vibrant__alert.warning{background:#fef3c7;color:#92400e}.my-subscription-card-vibrant__alert.danger{background:#fee2e2;color:#991b1b}.my-subscription-card-vibrant__alert.info{background:#dbeafe;color:#1e40af}.my-subscription-card-vibrant.empty{background:#fff;padding:24px 20px;text-align:center}.my-subscription-card-vibrant.loading{background:#fff;padding:24px 20px}.avatar-upload{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 0}.avatar-upload__preview{position:relative;width:100px;height:100px;border-radius:var(--radius-full);overflow:hidden;background:var(--warm-100);border:3px solid var(--ocean-200);transition:all .2s ease}.avatar-upload__preview:hover{border-color:var(--ocean-400);transform:scale(1.02)}.avatar-upload__image{width:100%;height:100%;object-fit:cover}.avatar-upload__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--warm-400);background:linear-gradient(135deg,var(--warm-100),var(--warm-200))}.avatar-upload__camera-overlay{position:absolute;bottom:0;left:0;right:0;height:32px;background:linear-gradient(transparent,#0009);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.avatar-upload__preview:hover .avatar-upload__camera-overlay{opacity:1}.avatar-upload__camera-overlay svg{color:#fff}.avatar-upload__loading{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:500}.avatar-upload__actions{display:flex;gap:8px}.avatar-upload__button{padding:8px 16px;font-size:13px;font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;transition:all .2s ease}.avatar-upload__button:hover:not(:disabled){background:var(--warm-50);border-color:var(--ocean-400);color:var(--ocean-600)}.avatar-upload__button:disabled{opacity:.5;cursor:not-allowed}.avatar-upload__button--danger{color:var(--error);border-color:var(--error-light)}.avatar-upload__button--danger:hover:not(:disabled){background:var(--error-light);border-color:var(--error);color:var(--error)}.avatar-upload__error{color:var(--error);font-size:12px;margin-top:4px}.avatar-upload__hint{color:var(--text-secondary);font-size:11px;text-align:center}.user-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar--fallback{background:linear-gradient(135deg,#ffffff26,#ffffff0d)}.user-avatar--sm{width:32px;height:32px;font-size:16px}.user-avatar--md{width:44px;height:44px;font-size:22px}.user-avatar--lg{width:64px;height:64px;font-size:32px}.user-avatar--xl{width:100px;height:100px;font-size:50px}.profile-avatar-vibrant.user-avatar{margin:0 auto 12px;box-shadow:0 4px 12px #00000026;border:3px solid rgba(255,255,255,.2)}
