@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary:#f97316;--primary-hover:#ea580c;--secondary:#16a34a;--background:#f8fafc;--surface:#fff;--surface-hover:#f1f5f9;--text-main:#0f172a;--text-muted:#64748b;--border:#e2e8f0;--danger:#ef4444}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--background);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Outfit,sans-serif}.glass-panel{-webkit-backdrop-filter:blur(24px);background:#ffffffb3;border:1px solid #fff9;border-radius:20px;box-shadow:0 20px 40px -10px #0000001a,inset 0 0 0 1px #fffc}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative;overflow:hidden}.bg-orb-1,.bg-orb-2{filter:blur(80px);z-index:0;border-radius:50%;animation:10s ease-in-out infinite alternate float;position:absolute}.bg-orb-1{background:#f9731640;width:400px;height:400px;top:-100px;left:-100px}.bg-orb-2{background:#22c55e33;width:500px;height:500px;animation-delay:-5s;bottom:-150px;right:-100px}@keyframes float{0%{transform:translate(0)scale(1)}to{transform:translate(30px,50px)scale(1.1)}}h1,h2,h3{letter-spacing:-.025em;font-weight:700}h1.gradient-text{background:linear-gradient(135deg, var(--secondary), #4ade80);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}input{border:1px solid var(--border);width:100%;color:var(--text-main);background-color:#ffffffb3;border-radius:10px;padding:.85rem 1.2rem;font-family:inherit;font-size:1rem;transition:all .3s}input:focus{border-color:var(--primary);background-color:#fff;outline:none;box-shadow:0 0 0 4px #f9731626}button.primary-btn{background:linear-gradient(135deg, var(--primary), #f59e0b);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.85rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 20px -5px #f9731666}button.primary-btn:before{content:"";background:linear-gradient(90deg,#0000,#ffffff40,#0000);width:50%;height:100%;transition:all .5s;position:absolute;top:0;left:-100%;transform:skew(-20deg)}button.primary-btn:hover{transform:translateY(-2px);box-shadow:0 15px 25px -5px #f9731680}button.primary-btn:hover:before{left:150%}button.primary-btn:active{transform:translateY(1px);box-shadow:0 5px 10px -5px #f9731666}.loader{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:24px;height:24px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#1e293bcc;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:relative}.nav-brand{color:#3b82f6;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;display:flex}.change-password-btn{background:linear-gradient(135deg, var(--primary) 0%, #f59e0b 100%);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s;display:flex;box-shadow:0 4px 6px -1px #f9731633}.change-password-btn:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #f973164d}.logout-btn{background:linear-gradient(135deg, var(--danger) 0%, #fca5a5 100%);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s;display:flex;box-shadow:0 4px 6px -1px #ef444433}.logout-btn:hover{color:#fff;transform:translateY(-2px);box-shadow:0 10px 15px -3px #ef44444d}.login-wrapper{text-align:center;z-index:1;width:100%;max-width:420px;padding:3rem 2.5rem;position:relative}.login-icon{background:linear-gradient(135deg, var(--primary), #f59e0b);border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.5rem;animation:3s infinite alternate pulse-glow;display:flex;box-shadow:0 10px 25px -5px #f9731680}@keyframes pulse-glow{0%{transform:translateY(0);box-shadow:0 10px 25px -5px #f9731666}to{transform:translateY(-3px);box-shadow:0 15px 35px -5px #f97316b3}}.login-form{text-align:left;flex-direction:column;gap:1rem;margin-top:2rem;display:flex}.form-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.error-message{color:#dc2626;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.timesheet-container{width:100%;max-width:1000px;margin:0 auto}.student-info{margin-bottom:2rem;padding:1.5rem}.student-info-text{flex:1;min-width:0}.student-info h2{margin-bottom:.5rem;font-size:1.5rem}.student-info p{color:var(--text-muted);align-items:center;gap:.5rem;display:flex}.course-grid{gap:1.5rem;display:grid}.course-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffc;border:1px solid #fff;border-radius:16px;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;animation:.6s cubic-bezier(.16,1,.3,1) backwards slideUpFade;overflow:hidden;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000006}@keyframes slideUpFade{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.course-card:hover{border-color:#f973164d;transform:translateY(-6px);box-shadow:0 25px 30px -10px #0000001a}.course-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(90deg,#ffffff80,#f8fafccc);border-bottom:1px solid #0000;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.course-card.expanded .course-header{border-bottom-color:var(--border)}.course-header:hover{background:linear-gradient(90deg,#ffffffbf,#f8fafcf2)}.course-header-left{flex-direction:column;gap:.25rem;display:flex}.course-header-right{align-items:center;gap:1.25rem;display:flex}.course-toggle-arrow{color:var(--text-muted);background:#00000008;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .3s cubic-bezier(.4,0,.2,1),background-color .2s,color .2s;display:flex}.course-header:hover .course-toggle-arrow{color:var(--primary);background:#f973161a}.course-toggle-arrow.rotated{transform:rotate(180deg)}.course-content-wrapper{opacity:0;max-height:0;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s;overflow:hidden}.course-content-wrapper.expanded{opacity:1;max-height:20000px}.course-title{color:var(--text-main);align-items:center;gap:.6rem;font-size:1.35rem;font-weight:700;display:flex}.course-badges{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.course-id-badge{color:var(--primary);background:#f973161a;border:1px solid #f9731633;border-radius:99px;padding:.35rem 1rem;font-size:.85rem;font-weight:600}.course-receipt-badge{color:var(--text-muted);margin-top:.25rem;margin-left:30px;font-size:.95rem;font-weight:400;display:block}.course-progress-badge{color:var(--secondary);background:#10b9811a;border:1px solid #10b98133;border-radius:99px;padding:.35rem 1rem;font-size:.85rem;font-weight:600}.session-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;padding:1rem;display:grid}.session-item{background:#0f172a80;border:1px solid #ffffff08;border-radius:10px;padding:1.25rem;position:relative;overflow:hidden}.session-item:before{content:"";background:var(--primary);opacity:.7;width:4px;height:100%;position:absolute;top:0;left:0}.session-item.completed:before{background:var(--secondary)}.session-item.cancelled:before{background:var(--danger)}.session-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.session-date{color:var(--text-main);align-items:center;gap:.5rem;font-weight:600;display:flex}.session-status{text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:600}.status-completed{color:#059669;background:#10b98126;border:1px solid #10b9814d}.status-pending{color:#d97706;background:#f59e0b26;border:1px solid #f59e0b4d}.status-cancelled{color:#dc2626;background:#ef444426;border:1px solid #ef44444d}.session-detail{color:var(--text-muted);align-items:flex-start;gap:.75rem;margin-bottom:.75rem;font-size:.9rem;display:flex}.detail-icon{color:var(--primary);flex-shrink:0;margin-top:.125rem}.comment-box{border-left:2px solid var(--text-muted);background:#ffffff08;border-radius:6px;margin-top:.5rem;padding:.75rem}.comment-title{text-transform:uppercase;color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem;font-weight:600}.comment-text{color:#e2e8f0;font-size:.9rem;line-height:1.4}.empty-state{text-align:center;color:var(--text-muted);padding:3rem}.empty-icon{color:var(--border);margin:0 auto 1rem}.table-responsive{width:100%;padding:0 1.5rem 1.5rem;overflow-x:auto}.timesheet-table{border-collapse:collapse;text-align:left;width:100%;font-size:.95rem}.timesheet-table th{color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;background-color:#f8fafc;padding:1.25rem 1rem;font-size:.9rem;font-weight:700}.timesheet-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:1.25rem 1rem}.timesheet-table tbody tr{transition:background-color .2s}.timesheet-table tbody tr:hover{background-color:#f1f5f999}.col-index{color:var(--primary);width:5%;font-weight:700}.col-datetime div,.col-teacher div{white-space:nowrap;color:var(--text-main);align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.col-status{white-space:nowrap}.col-comment{min-width:250px}.col-teacher-inline,.mobile-col-label{display:none}.mobile-only{display:none!important}.col-comment .comment-text{border-left:3px solid var(--primary);background:#fff;border-radius:8px;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;padding:.85rem;display:flex;box-shadow:0 1px 3px #0000000d}.col-comment .comment-text:last-child{margin-bottom:0}.col-comment .comment-text span{color:var(--text-main);line-height:1.4}.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{border-radius:6px}@media (width<=768px){td.mobile-only{display:flex!important}th.desktop-only,td.desktop-only{display:none!important}.timesheet-table thead{display:none}.course-content-wrapper{transition:none!important}.timesheet-table,.timesheet-table tbody,.timesheet-table tr,.timesheet-table td{width:100%;display:block}.timesheet-table tr{border:1px solid var(--border);background:#fff6;border-radius:12px;margin-bottom:1.5rem;padding:1rem;box-shadow:0 4px 6px -1px #0000000d}.timesheet-table td{border-bottom:1px dashed var(--border);text-align:right;justify-content:space-between;align-items:flex-start;padding:.75rem 0;display:flex}.timesheet-table td:last-child{text-align:left;border-bottom:none;flex-direction:column;align-items:flex-start}.timesheet-table td:before{content:attr(data-label);color:var(--text-muted);text-align:left;margin-right:1rem;font-weight:600}.col-datetime:before{display:none}.mobile-col-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:block}.mobile-col-label-right{text-align:right}.col-datetime,.col-teacher{flex-direction:row;justify-content:space-between;align-items:flex-start}.col-teacher{display:none!important}.col-teacher-inline{color:var(--text-main);flex-direction:column;align-items:flex-start;gap:.2rem;font-size:.95rem;display:flex}.col-datetime-info{flex-direction:column;align-items:flex-end;gap:.1rem;display:flex}.col-datetime div,.col-teacher div{margin-bottom:.1rem}.col-comment .comment-text{width:100%;margin-top:.5rem}.main-content{padding:1rem}.login-wrapper{max-width:95vw;padding:2rem 1.25rem}.bg-orb-1,.bg-orb-2{transform:scale(.6)}.navbar{flex-direction:column;gap:1rem;padding:1rem}.navbar>div:last-child{z-index:101;justify-content:center;gap:12px;width:100%;display:flex;position:relative}.change-password-btn,.logout-btn{z-index:101;flex:1;justify-content:center;min-height:44px;position:relative}.student-info{text-align:center;gap:1.25rem;flex-direction:column-reverse!important}.student-info p{justify-content:center}.student-info h2{white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:1.25rem;overflow:hidden}.student-info-text{width:100%}.student-info-avatar{width:70px!important;height:70px!important;margin-left:0!important}.course-header{flex-direction:column;align-items:flex-start}.course-header-left{width:100%}.course-header-right{justify-content:space-between;align-items:center;width:100%;margin-top:.5rem}.course-title{white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:clamp(.85rem,4vw,1.2rem);overflow:hidden}.course-title svg{flex-shrink:0}.course-badges{flex-flow:wrap;align-items:flex-start;width:auto;margin-top:0}}.modal-overlay{z-index:1000;background-color:#00000073;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{-webkit-backdrop-filter:blur(24px);background:#fffffff7;border:1px solid #fffc;border-radius:20px;width:90%;max-width:450px;max-height:90vh;padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto;box-shadow:0 25px 50px -12px #00000026,inset 0 0 0 1px #ffffffe6}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{align-items:center;gap:12px;display:flex}.modal-title h2{color:#0f172a;letter-spacing:-.025em;margin:0;font-size:20px;font-weight:700}.modal-close{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.modal-close:hover{color:#0f172a;background-color:#f1f5f9}.change-password-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#64748b;font-size:14px;font-weight:500}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{color:#0f172a;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;width:100%;padding:10px 40px 10px 12px;font-family:inherit;font-size:14px;transition:all .2s}.password-input-wrapper input::placeholder{color:#94a3b8}.password-input-wrapper input:focus{background-color:#fff;border-color:#f97316;outline:none;box-shadow:0 0 0 3px #f973161f}.toggle-password{color:#94a3b8;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:12px}.toggle-password:hover{color:#f97316}.alert{border-radius:8px;margin:0;padding:12px 14px;font-size:14px;animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{color:#dc2626;background-color:#ef444414;border:1px solid #ef444433}.alert-success{color:#059669;background-color:#10b98114;border:1px solid #10b98133}.form-actions{gap:12px;margin-top:8px;display:flex}.btn-cancel,.btn-submit{cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-cancel{color:#475569;background-color:#f1f5f9;border:1px solid #e2e8f0}.btn-cancel:hover:not(:disabled){color:#0f172a;background-color:#e2e8f0;border-color:#cbd5e1}.btn-submit{color:#fff;background:linear-gradient(135deg,#f97316 0%,#f59e0b 100%);box-shadow:0 4px 12px -2px #f9731659}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px -4px #f9731666}.btn-submit:active:not(:disabled){transform:translateY(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.loader{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.modal-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (width<=600px){.modal-content{border-radius:16px;padding:24px}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}
