*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#fff;background:#0a0a0a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{background:linear-gradient(135deg,#0a0a0a 0%,#1a1a1a 100%);min-height:100vh;padding:2rem}.login-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#111;border:1px solid #222;border-radius:16px;width:100%;max-width:420px;padding:3rem;box-shadow:0 20px 60px #00000080}.login-title{background:linear-gradient(135deg,#fff 0%,#888 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.login-subtitle{color:#666;margin-bottom:2rem;font-size:.95rem}.login-form{flex-direction:column;gap:1.5rem;display:flex}.input-group{flex-direction:column;gap:.5rem;display:flex}.input-group label{color:#999;font-size:.875rem;font-weight:500}.input-group input{color:#fff;background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:.875rem 1rem;font-size:1rem;transition:all .2s}.input-group input:focus{background:#222;border-color:#fff;outline:none}.input-group input::placeholder{color:#555}.input-group input:disabled{opacity:.5;cursor:not-allowed}.error-message{color:#f66;background:#2a1515;border:1px solid #422;border-radius:8px;padding:.875rem;font-size:.875rem}.login-btn{color:#000;cursor:pointer;background:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.login-btn:hover:not(:disabled){background:#e0e0e0;transform:translateY(-1px);box-shadow:0 4px 12px #fff3}.login-btn:disabled{opacity:.6;cursor:not-allowed}.spinner{border:2px solid #333;border-top-color:#000;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;color:#555;margin-top:2rem;font-size:.75rem}.about-link{color:#888;cursor:pointer;text-align:center;background:0 0;border:none;width:100%;margin-top:1.5rem;padding:0;font-size:.875rem;text-decoration:underline;transition:color .2s}.about-link:hover{color:#fff}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:#111;border:1px solid #222;border-radius:16px;width:100%;max-width:600px;max-height:90vh;animation:.2s ease-out modalSlideIn;overflow-y:auto;box-shadow:0 20px 60px #000000b3}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.modal-close{color:#888;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:2rem;line-height:1;transition:all .2s;display:flex}.modal-close:hover{color:#fff;background:#1a1a1a}.modal-body{padding:2rem}.about-section{margin-bottom:2rem}.about-section:last-child{margin-bottom:0}.about-section h3{color:#fff;margin-bottom:.75rem;font-size:1.125rem;font-weight:600}.about-section p{color:#999;margin-bottom:.75rem;line-height:1.6}.about-section p:last-child{margin-bottom:0}.about-section strong{color:#fff;font-weight:600}.about-section ul{margin:.75rem 0 0;padding:0;list-style:none}.about-section ul li{color:#999;padding-left:1.5rem;line-height:1.8;position:relative}.about-section ul li:before{content:"→";color:#fff;position:absolute;left:0}.container{max-width:1400px;margin:0 auto}.header{border-bottom:1px solid #222;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1.5rem;display:flex}.header h1{margin-bottom:.25rem;font-size:2rem;font-weight:700}.student-id{color:#666;font-size:.875rem}.header-actions{align-items:center;gap:.75rem;display:flex}.share-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.share-btn:hover{background:#222;border-color:#444}.share-icon{font-size:1rem}.refresh-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.refresh-btn:hover:not(:disabled){background:#222;border-color:#444}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-icon{font-size:1.25rem;transition:transform .3s;display:inline-block}.refresh-btn:hover:not(:disabled) .refresh-icon{transform:rotate(180deg)}.logout-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s}.logout-btn:hover{background:#222;border-color:#444}.stats-grid{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-bottom:3rem;display:flex}.stats-grid>.stat-card{flex:320px;max-width:400px}.stat-card{background:#111;border:1px solid #222;border-radius:12px;padding:1.5rem;transition:all .2s}.stat-card:hover{border-color:#333;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.stat-header{margin-bottom:1.5rem}.stat-header h3{margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.4}.module-code{color:#666;font-family:Courier New,monospace;font-size:.75rem}.attendance-circle{width:160px;height:160px;margin:0 auto 1.5rem;position:relative}.attendance-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.attendance-progress{stroke-dashoffset:282.7px;animation:.8s ease-out forwards fillCircle}@keyframes fillCircle{0%{stroke-dashoffset:282.7px}to{stroke-dashoffset:0}}.attendance-text{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.attendance-percent{font-size:2rem;font-weight:700}.stat-details{flex-direction:column;gap:.75rem;display:flex}.check-punch-btn-desktop{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:8px;width:100%;margin-top:.5rem;padding:.75rem;font-size:.875rem;font-weight:600;transition:all .2s}.check-punch-btn-desktop:hover:not(:disabled){background:#222;border-color:#444;transform:translateY(-1px)}.check-punch-btn-desktop:disabled{opacity:.6;cursor:not-allowed}.stat-row{background:#1a1a1a;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.stat-row span:first-child{color:#999;font-size:.875rem}.stat-value{color:#fff;font-weight:600}.stat-row.warning{background:#2a1515;border:1px solid #422}.stat-row.warning .stat-value{color:#f66}.stat-row.success{background:#152a1a;border:1px solid #242}.stat-row.success .stat-value{color:#0f8}.stat-row.danger{background:#3a1515;border:1px solid #522;animation:2s infinite pulse}.stat-row.danger span:first-child{color:#f44;font-weight:600}.stat-row.danger .stat-value{color:#f66}.stat-row.info{background:#1a1f2a;border:1px solid #2a3444}.stat-row.info .stat-value{color:#8af}@keyframes pulse{0%,to{border-color:#522}50%{border-color:#722}}.summary{background:#111;border:1px solid #222;border-radius:12px;padding:2rem}.summary h2{margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;display:grid}.summary-item{background:#1a1a1a;border-radius:8px;flex-direction:column;gap:.5rem;padding:1.25rem;display:flex}.summary-label{color:#666;font-size:.875rem;font-weight:500}.summary-value{font-size:2rem;font-weight:700}.mobile-summary{margin-bottom:2rem}.summary-title{margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.mobile-cards{flex-direction:column;gap:1rem;display:flex}.mobile-card{cursor:pointer;background:#111;border:1px solid #222;border-radius:12px;padding:1.25rem;transition:all .2s}.mobile-card:active{transform:scale(.98)}.mobile-card:hover{background:#151515;border-color:#333}.mobile-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.mobile-card-header h3{margin-bottom:.25rem;font-size:1rem;font-weight:600}.module-code-mobile{color:#666;font-family:Courier New,monospace;font-size:.75rem}.attendance-badge{border-radius:8px;padding:.5rem .875rem;font-size:1.125rem;font-weight:700}.mobile-card-content{flex-direction:column;gap:.75rem;display:flex}.quick-stat{background:#1a1a1a;border-radius:8px;justify-content:space-between;padding:.75rem;display:flex}.quick-label{color:#999;font-size:.875rem}.quick-value{color:#fff;font-weight:600}.danger-text{color:#f66;background:#2a1515;border:1px solid #422}.warning-text{color:#fa6;background:#2a1f15;border:1px solid #432}.success-text{color:#0f8;background:#152a1a;border:1px solid #242}.mobile-card-footer{border-top:1px solid #222;justify-content:space-between;align-items:center;margin-top:.5rem;padding-top:.75rem;display:flex}.check-punch-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.check-punch-btn:hover{background:#222;border-color:#444}.check-punch-btn:disabled{opacity:.6;cursor:not-allowed}.details-link{color:#666;font-size:.875rem;font-weight:500}.mobile-detail{animation:.2s ease-out slideIn}.mobile-detail-header{margin-bottom:1.5rem}.back-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s}.back-btn:hover{background:#222;border-color:#444}.mobile-detail-card{max-width:100%}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.punch-details-overlay{z-index:1000;background:#000c;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.punch-details-modal{background:#111;border:1px solid #222;border-radius:12px;flex-direction:column;width:100%;max-width:500px;max-height:80vh;animation:.3s ease-out slideUp;display:flex}.punch-header{border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.punch-header h3{margin:0;font-size:1.125rem;font-weight:600}.close-btn{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.5rem;transition:all .2s;display:flex}.close-btn:hover{color:#fff;background:#222}.punch-list{flex-direction:column;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.punch-item{background:#1a1a1a;border:1px solid #222;border-radius:8px;padding:.875rem}.punch-date-time{border-bottom:1px solid #222;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;display:flex}.punch-date{color:#fff;font-size:.875rem;font-weight:600}.punch-time{color:#666;font-size:.875rem}.punch-info{flex-direction:column;gap:.5rem;display:flex}.punch-status-row{justify-content:space-between;align-items:center;display:flex}.punch-status{border-radius:4px;padding:.25rem .625rem;font-size:.75rem;font-weight:600}.punch-status.present{color:#0f8;background:#152a1a}.punch-status.absent{color:#f66;background:#2a1515}.punch-in-time{color:#999;font-size:.875rem}.punch-details-row{justify-content:space-between;font-size:.875rem;display:flex}.faculty-name{color:#ccc}.classroom{color:#888}.session-mode{color:#666;background:#222;border-radius:4px;align-self:flex-start;padding:.25rem .5rem;font-size:.75rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.app{padding:1rem}.login-card{padding:2rem}.login-title{font-size:2rem}.header{flex-direction:column;align-items:flex-start;gap:1rem}.stats-grid,.summary-stats{grid-template-columns:1fr}}
