.app{min-height:100vh;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-bottom:80px}.app-content{animation:fadeIn .3s ease-in;position:relative;width:100%;min-height:calc(100vh - 80px);overflow-x:hidden;-webkit-overflow-scrolling:touch;contain:layout style paint}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rating-view,.profile-view{padding:20px 16px 100px;background:linear-gradient(to bottom,#f8f9fa,#fff);min-height:calc(100vh - 200px);animation:slideUp .3s ease-out;position:relative;width:100%;max-width:100%;box-sizing:border-box;contain:layout style paint;-webkit-overflow-scrolling:touch;overflow-x:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-header{margin-bottom:24px;text-align:center}.profile-title{font-size:28px;font-weight:800;color:#1a1a1a;margin:0;letter-spacing:-.5px}.profile-content{display:flex;flex-direction:column;gap:24px}.profile-avatar-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:0 8px 32px #667eea4d;position:relative;overflow:hidden}.profile-avatar-section:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:shimmer 3s ease-in-out infinite}.profile-avatar{width:120px;height:120px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:800;color:#667eea;box-shadow:0 8px 24px #0003;border:4px solid rgba(255,255,255,.3);position:relative;z-index:1;transition:all .3s ease;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-avatar:hover{transform:scale(1.05);box-shadow:0 12px 32px #0000004d}.profile-main-info{text-align:center;position:relative;z-index:1}.profile-name{font-size:24px;font-weight:700;color:#fff;margin:0 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.profile-group{font-size:16px;color:#ffffffe6;margin:0;font-weight:500}.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.profile-stat-card{background:#fff;border-radius:20px;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 4px 16px #00000014;transition:all .3s ease;border:2px solid transparent}.profile-stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#667eea}.stat-card-icon{font-size:32px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.stat-card-content{text-align:center}.stat-card-value{font-size:28px;font-weight:800;color:#1a1a1a;line-height:1;margin-bottom:6px;letter-spacing:-.5px}.stat-card-label{font-size:13px;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@keyframes shimmer{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(30px,30px) rotate(180deg)}}.rating-view h2{font-size:24px;font-weight:700;margin-bottom:20px;color:#333}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}.loading-container p{color:#333;font-size:16px;margin-top:16px}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #ff6b35;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.error-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:#f5f5f5}.error-content{background:#fff;border-radius:16px;padding:32px;max-width:600px;width:100%;box-shadow:0 4px 12px #0000001a}.error-content h2{color:#d32f2f;font-size:24px;margin-bottom:16px;text-align:center}.error-message{color:#333;font-size:16px;margin-bottom:24px;padding:16px;background:#ffebee;border-radius:8px;border-left:4px solid #d32f2f}.error-main{font-weight:600;margin-bottom:12px}.error-details{margin-top:12px;padding-top:12px;border-top:1px solid rgba(211,47,47,.2)}.error-line{margin-bottom:8px;font-size:14px;line-height:1.6;color:#555}.error-bullet{display:block;font-family:monospace;white-space:pre}.error-help{margin-top:24px}.error-help p{color:#666;font-size:14px;margin-bottom:12px;font-weight:600}.error-help ul{margin-left:20px;margin-bottom:16px;color:#666;font-size:14px}.error-help li{margin-bottom:8px}.error-note{margin-top:16px;padding:12px;background:#e3f2fd;border-radius:8px;color:#1976d2;font-size:13px;line-height:1.5}.bottom-navigation{position:fixed;bottom:20px;left:16px;right:16px;background:linear-gradient(135deg,#fffffffa,#fffffff2);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid rgba(255,255,255,.8);border-radius:28px;display:flex;justify-content:space-around;align-items:center;padding:14px 8px calc(14px + env(safe-area-inset-bottom,0px));z-index:1000;box-shadow:0 -4px 24px #00000014,0 -2px 8px #0000000a,inset 0 1px #ffffffe6;min-height:72px;max-width:calc(100% - 32px);margin:0 auto}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:none;border:none;cursor:pointer;padding:10px 8px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:64px;border-radius:20px;margin:0 2px}.nav-tab:active{transform:scale(.96);background:#ff6b3514}.nav-tab.active{background:linear-gradient(135deg,#ff6b351f,#ff8c4214)}.nav-icon{font-size:26px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-tab.active .nav-icon{transform:scale(1.15);background:linear-gradient(135deg,#ff6b3533,#ff8c4226);box-shadow:0 2px 8px #ff6b3533;animation:iconBounce .4s cubic-bezier(.68,-.55,.265,1.55)}@keyframes iconBounce{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1.2)}}.nav-label{font-size:11px;font-weight:500;color:#8e8e93;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.nav-tab.active .nav-label{color:#ff6b35;font-weight:600;animation:labelFadeIn .3s ease-out}@keyframes labelFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.nav-indicator{position:absolute;top:4px;left:50%;transform:translate(-50%);width:40px;height:4px;background:linear-gradient(90deg,#ff6b35,#ff8c42,#ff6b35);border-radius:2px;box-shadow:0 2px 6px #ff6b3566;animation:indicatorSlide .3s cubic-bezier(.4,0,.2,1)}@keyframes indicatorSlide{0%{width:0;opacity:0}to{width:40px;opacity:1}}@media (hover: hover){.nav-tab:hover:not(.active){background:#00000008}.nav-tab:hover:not(.active) .nav-icon{transform:scale(1.08);background:#fffc}.nav-tab:hover:not(.active) .nav-label{color:#666}}@supports (padding: max(0px)){.bottom-navigation{padding-bottom:max(8px,env(safe-area-inset-bottom))}}.header{background:linear-gradient(135deg,#ff6b35,#ff8c42,#ffa366);padding:20px 16px 24px;position:relative;overflow:hidden;color:#fff;box-shadow:0 4px 12px #ff6b354d}.back-button{background:#fff3;border:none;color:#fff;font-size:24px;width:40px;height:40px;border-radius:50%;cursor:pointer;margin-bottom:12px;display:flex;align-items:center;justify-content:center;transition:background .2s}.back-button:hover{background:#ffffff4d}.header-content{position:relative;z-index:2}.header-title{font-size:28px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.header-group{font-size:14px;opacity:.9;margin-bottom:16px;font-weight:500}.header-stats{display:flex;gap:12px;flex-wrap:wrap}.stat-badge{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;border:1px solid rgba(255,255,255,.3)}.header-decoration{position:absolute;right:16px;top:20px;z-index:1;opacity:.3}.decoration-icon{font-size:60px;margin-bottom:8px}.decoration-stars{display:flex;gap:4px;font-size:16px}.not-found-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px);padding:40px 20px;background:linear-gradient(to bottom,#f8f9fa,#fff)}.not-found-content{text-align:center;max-width:500px;width:100%;animation:fadeInUp .6s ease-out}.not-found-icon{font-size:120px;margin-bottom:24px;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.not-found-title{font-size:72px;font-weight:900;background:linear-gradient(135deg,#ff6b35,#f7931e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 16px;letter-spacing:-2px}.not-found-subtitle{font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 16px;letter-spacing:-.5px}.not-found-description{font-size:16px;color:#666;line-height:1.6;margin:0 0 32px}.not-found-button{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none;padding:16px 32px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #ff6b354d}.not-found-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3566}.not-found-button:active{transform:translateY(0)}.rating-container{padding:20px 16px 100px;animation:fadeIn .3s ease-in;position:relative;width:100%;max-width:100%;box-sizing:border-box;contain:layout style paint;-webkit-overflow-scrolling:touch;overflow-x:hidden}.rating-header{margin-bottom:20px}.rating-title{font-size:24px;font-weight:700;color:#333;margin-bottom:8px}.rating-group{font-size:14px;color:#333;font-weight:500}.rating-empty{text-align:center;padding:60px 20px;color:#333;animation:fadeIn .5s ease-out}.empty-icon{font-size:80px;margin-bottom:24px;opacity:.5;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.empty-title{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 12px}.empty-description{font-size:16px;color:#666;line-height:1.6;margin:0}.rating-tabs{display:flex;gap:12px;margin-bottom:20px;background:#fff;padding:4px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.rating-tab{flex:1;padding:12px;border:none;background:transparent;border-radius:8px;font-size:14px;font-weight:600;color:#333;cursor:pointer;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.rating-tab:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ff6b351a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.rating-tab:hover:before{width:300px;height:300px}.rating-tab.active{background:linear-gradient(135deg,#ff6b35,#ff8c42);color:#fff;box-shadow:0 4px 12px #ff6b3566;transform:scale(1.03);animation:tabActive .4s cubic-bezier(.34,1.56,.64,1)}@keyframes tabActive{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1.03)}}.rating-list{display:flex;flex-direction:column;gap:12px}.rating-item{background:#fff;border-radius:16px;padding:16px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000001a;transition:all .4s cubic-bezier(.34,1.56,.64,1);animation:slideInLeft .5s cubic-bezier(.34,1.56,.64,1) both;position:relative;overflow:hidden}.rating-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.rating-item:hover:before{left:100%}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.rating-item:hover{transform:translate(6px) scale(1.01);box-shadow:0 6px 20px #0000002e}.rating-item.current{background:linear-gradient(135deg,#ff6b3526,#ff8c4226);border:2px solid #ff6b35;box-shadow:0 4px 16px #ff6b3533;transform:scale(1.02)}.rating-item.top-three{background:linear-gradient(135deg,#ffd7000d,#ffd7001a);border:1px solid rgba(255,215,0,.3)}.rating-position{display:flex;flex-direction:column;align-items:center;min-width:70px;position:relative}.position-medal{font-size:32px;margin-bottom:4px;animation:medalBounce .6s ease-out}@keyframes medalBounce{0%{transform:scale(0) rotate(-180deg);opacity:0}50%{transform:scale(1.3) rotate(10deg)}70%{transform:scale(.95) rotate(-5deg)}to{transform:scale(1) rotate(0);opacity:1}}.position-number{font-size:32px;font-weight:700;line-height:1;transition:all .3s cubic-bezier(.34,1.56,.64,1);animation:numberPop .5s ease-out both}@keyframes numberPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.position-label{font-size:11px;color:#000;text-transform:uppercase;margin-top:4px;font-weight:500}.rating-info{flex:1;display:flex;flex-direction:column;gap:8px}.rating-name{font-size:17px;font-weight:600;color:#000;margin-bottom:8px}.you-indicator{color:#ff6b35;font-weight:700;font-size:14px}.rating-details{display:flex;flex-direction:column;gap:8px}.rating-stats{display:flex;flex-direction:column;gap:6px}.stat-detail{display:flex;align-items:center;gap:8px;font-size:14px;color:#000;font-weight:500}.stat-icon{font-size:16px}.stat-text{display:flex;align-items:center;gap:6px;color:#333}.stat-label{color:#000;font-weight:500}.stat-text{color:#000}.stat-text strong{color:#000;font-weight:700;font-size:16px}.perfect-badge,.excellent-badge{background:linear-gradient(135deg,#4caf501a,#4caf5033);color:#2e7d32;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;margin-top:4px;animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 2px 8px #4caf5033}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #4caf504d}}.current-badge{background:linear-gradient(135deg,#ff6b35,#ff8c42);color:#fff;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.loading-spinner-small{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #ff6b35;border-radius:50%;animation:spin 1s linear infinite;margin:20px auto}.loading-text{color:#000!important;font-weight:600;text-align:center;margin-top:12px;font-size:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.student-not-found-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px);padding:40px 20px;background:linear-gradient(to bottom,#f8f9fa,#fff)}.student-not-found-content{text-align:center;max-width:600px;width:100%;background:#fff;border-radius:24px;padding:48px 32px;box-shadow:0 8px 32px #0000001a;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.student-not-found-icon{font-size:100px;margin-bottom:24px;animation:pulse 2s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.student-not-found-title{font-size:32px;font-weight:800;color:#1a1a1a;margin:0 0 16px;letter-spacing:-.5px}.student-not-found-description{font-size:18px;color:#666;line-height:1.6;margin:0 0 32px}.student-not-found-error{background:#ffebee;border-left:4px solid #d32f2f;border-radius:8px;padding:16px;margin-bottom:32px;text-align:left}.error-text{color:#c62828;font-size:14px;margin:0;line-height:1.5;word-break:break-word}.student-not-found-help{text-align:left;background:#f7f7f9;border-radius:12px;padding:24px;margin-top:24px}.student-not-found-help h3{font-size:18px;font-weight:700;color:#1a1a1a;margin:0 0 16px}.student-not-found-help ul{list-style:none;padding:0;margin:0}.student-not-found-help li{font-size:15px;color:#4b5563;line-height:1.8;margin-bottom:12px;padding-left:24px;position:relative}.student-not-found-help li:before{content:"✓";position:absolute;left:0;color:#ff6b35;font-weight:700;font-size:18px}.retry-button{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ff6b354d;margin-top:8px}.retry-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b3566}.retry-button:active{transform:translateY(0)}.subject-detail{padding:20px 16px;background:#f5f5f5;min-height:calc(100vh - 200px)}.subject-detail-header{margin-bottom:24px}.subject-header-badge{background:linear-gradient(135deg,#fff5ed,#ffe7d6);padding:20px;border-radius:16px;margin-bottom:20px;box-shadow:0 4px 12px #ff6b3526;display:flex;align-items:center;gap:12px;border:1px solid rgba(255,107,53,.2)}.subject-icon{font-size:32px}.subject-name{font-size:24px;font-weight:700;margin:0;color:#1a1a1a}.subject-stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.summary-card{background:#fff;padding:16px;border-radius:12px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #0000000d;border:2px solid #f0f0f0;transition:all .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#ff6b35}.summary-icon{font-size:24px;flex-shrink:0}.summary-content{display:flex;flex-direction:column;gap:4px;flex:1}.summary-label{font-size:12px;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:22px;font-weight:700;color:#333}.attendance-value{color:#0f5132}.absence-value{color:#a94442}.grades-list{margin-top:24px}.grades-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;background:#fff;padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000000d}.grades-title{font-size:20px;font-weight:700;margin:0;color:#333}.grades-count{font-size:13px;color:#666;font-weight:500;background:#f5f5f5;padding:6px 12px;border-radius:8px}.grades-items{display:flex;flex-direction:column;gap:10px}.grade-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-radius:12px;border-left:4px solid #e0e0e0;box-shadow:0 2px 8px #0000000d;transition:all .2s}.grade-item:hover{transform:translate(4px);box-shadow:0 4px 12px #0000001a}.grade-item.excellent{border-left-color:#4caf50}.grade-item.good{border-left-color:#2196f3}.grade-item.satisfactory{border-left-color:#ffc107}.grade-item.bad{border-left-color:#f44336}.grade-item.absence{border-left-color:#ff5722}.grade-item-left{display:flex;align-items:center;gap:10px}.grade-date-icon{font-size:18px;opacity:.6}.grade-date{font-size:15px;color:#333;font-weight:600}.grade-value{font-size:18px;font-weight:700;padding:8px 16px;border-radius:10px;min-width:60px;text-align:center}.grade-value.excellent{background:#e8f5e9;color:#1b5e20}.grade-value.good{background:#e3f2fd;color:#1565c0}.grade-value.satisfactory{background:#ffc107;color:#333}.grade-value.bad{background:#ffebee;color:#c62828}.grade-value.absence{background:#fff3e0;color:#d84315}.grade-value.empty{color:#999}.no-grades{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.no-grades-icon{font-size:64px;margin-bottom:16px;opacity:.5}.no-grades p{color:#666;font-size:16px;margin:0;font-weight:500}.loading,.error{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;color:#666;font-size:16px}.error{color:#d32f2f;background:#ffebee}.subjects-container{padding:20px 16px 100px;background:#fff;min-height:calc(100vh - 200px);position:relative;width:100%;max-width:100%;box-sizing:border-box;contain:layout style paint;-webkit-overflow-scrolling:touch;overflow-x:hidden}.subjects-scroll{margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch}.subjects-scroll::-webkit-scrollbar{display:none}.subjects-horizontal{display:flex;gap:12px;padding-bottom:8px}.subject-chip{background:#f5f5f5;padding:10px 16px;border-radius:20px;font-size:14px;font-weight:500;color:#333;border:1px solid #e0e0e0}.subjects-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:40px}.subject-card{background:#fff;border-radius:16px;padding:20px;color:#1a1a1a!important;position:relative;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 14px #00000014;animation:cardSlideIn .4s ease-out both;border:1px solid rgba(0,0,0,.05)}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.subject-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 20px #0000001f}.subject-card:active{transform:translateY(-2px) scale(1.01);transition:all .1s}.subject-card.disabled{background:#f0f0f0!important;color:#999!important;cursor:not-allowed!important;opacity:.6;position:relative}.subject-card.disabled:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000000d;border-radius:16px;pointer-events:none}.subject-card.disabled:hover{transform:none!important;box-shadow:0 4px 12px #0000001a!important}.subject-card.disabled .subject-card-title,.subject-card.disabled .stat-label,.subject-card.disabled .stat-value{color:#999!important}.subject-card-locked{position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:24px;opacity:.5}.subject-card.has-final-grade{border:3px solid rgba(255,107,53,.2);box-shadow:0 6px 20px #ff6b3526}.subject-card-header{margin-bottom:16px}.subject-card-title{font-size:18px;font-weight:700;margin-bottom:8px;line-height:1.3;color:#1a1a1a!important;display:flex;align-items:center;gap:8px}.subject-emoji{font-size:24px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.subject-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;opacity:1!important;font-weight:500;color:#4b5563!important}.stat-value{font-size:18px;font-weight:700;color:#111827!important}.stat-value.grade{color:#0f5132!important}.stat-value.absence{color:#a94442!important}.stat-value.attendance{color:#0f5132!important;font-size:20px}.subject-card-arrow{position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:24px;opacity:1!important;color:#111827!important}.calendar-button{width:100%;background:linear-gradient(135deg,#ff6b35,#f7931e);color:#1a1a1a;border:none;padding:16px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #ff6b354d}.calendar-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ff6b3566}.calendar-button:active{transform:translateY(0)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;margin:0;padding:0}#root{width:100%;min-height:100vh}
