*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:system-ui,sans-serif}body{line-height:1.5;-webkit-font-smoothing:antialiased;background:#fff;color:#111}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}:root{--primary: #6a1e55;--accent: #ff4081;--background: #f9f9f9;--text-color: #111;--radius: 10px;--transition: .3s ease-in-out}body{background-color:var(--background);color:var(--text-color);line-height:1.5;font-size:16px}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent)}button{background-color:var(--primary);color:#fff;padding:10px 16px;border:none;border-radius:var(--radius);cursor:pointer;transition:background-color var(--transition)}button:hover{background-color:var(--accent)}.flex-center{display:flex;justify-content:center;align-items:center}.container{max-width:1200px;margin:0 auto;padding:0 20px}.hidden{display:none!important}.icon-loader{position:relative;width:80px;height:80px;margin:auto}.icon-frame{position:absolute;width:100%;height:100%;object-fit:contain;opacity:0;transform:scale(.85) rotateY(0);transition:all .6s ease-in-out}.icon-frame.visible{opacity:1;transform:scale(1) rotateY(360deg);z-index:1}.layout-wrapper{position:relative;height:100dvh;width:100vw;overflow:hidden}.dashboard-container{display:flex;flex-direction:column;height:100dvh;width:100vw;background:#f9f9f9;overflow:hidden;position:relative}@media (min-width: 769px){.dashboard-container{flex-direction:row}}.sidebar{width:250px;background:#6A1E55;color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:30px 20px;flex-shrink:0}.sidebar-title{font-size:1.8rem;margin-bottom:30px}.sidebar-nav{display:flex;flex-direction:column;gap:15px}.sidebar-nav a{color:#fff;text-decoration:none;font-size:1.1rem;transition:color .3s}.sidebar-nav a:hover{color:#ffcce5}.topbar{height:70px;background:white;padding:0 30px;display:flex;align-items:center;justify-content:flex-end;border-bottom:1px solid #e0e0e0;flex-shrink:0}.user-info{display:flex;align-items:center;color:#000;gap:12px;font-size:1rem}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;box-shadow:0 0 5px #0003;cursor:pointer}.main-content{flex:1 1 auto;overflow-y:auto;min-height:0;padding:30px 30px 100px;box-sizing:border-box;-webkit-overflow-scrolling:touch}.content{padding:30px;flex-grow:1;color:#000}.dashboard-loading{height:100vh;display:flex;justify-content:center;align-items:center;font-size:1.5rem}.logout-button{background:white;color:#6a1e55;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:700;margin-top:20px;transition:background .2s,color .2s}.logout-button:hover{background:#ffcce5;color:#541442}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:10}.modal{background:white;padding:30px;color:#000;border-radius:12px;width:400px;max-width:90%;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal h2{margin-bottom:20px}.modal input,.modal select{width:100%;padding:12px;margin-bottom:15px;border:1px solid #ccc;border-radius:8px}.avatar-picker-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:20px 0}.avatar-picker-grid img{width:60px;height:60px;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:transform .2s,border-color .2s}.avatar-picker-grid img:hover{transform:scale(1.05)}.modal-buttons{display:flex;justify-content:space-between}.modal-buttons button{padding:10px 20px;border:none;background:#6A1E55;color:#fff;border-radius:8px;cursor:pointer}.modal-buttons button:hover{background:#541442}.toast{position:fixed;top:20px;right:20px;background:#6A1E55;color:#fff;padding:15px 20px;border-radius:8px;box-shadow:0 4px 12px #0003;animation:fadeSlideIn .4s ease-out;z-index:9999;font-size:1rem}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.bottom-nav{display:none}@media (max-width: 768px){.sidebar{display:none}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;height:60px;background:#6A1E55;display:flex;justify-content:space-around;align-items:center;z-index:999}.nav-icon{color:#fff;font-size:1.6rem;text-decoration:none;transition:transform .2s ease}.nav-icon:hover{transform:scale(1.1)}.main-content{padding:20px 20px 100px;min-height:0}.bottom-nav .badge{position:absolute;top:-6px;right:-6px;background:#FF3B30;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:999px;font-weight:700;line-height:1;z-index:10;animation:pulse 1.5s infinite ease-in-out}}.logout-mobile{background:none;border:none;padding:0;margin:0;cursor:pointer}.logout-mobile svg{stroke:#fff;width:26px;height:26px;transition:transform .2s ease}.logout-mobile:hover svg{transform:scale(1.1)}.burger{display:none;background:none;border:none;font-size:1.8rem;margin-right:15px;cursor:pointer;color:#6a1e55}@media (max-width: 768px){.burger{display:block}.mobile-sidebar{position:fixed;top:0;left:0;width:250px;height:100%;background:#6A1E55;color:#fff;padding:30px 20px;z-index:999;transform:translate(-100%);transition:transform .3s ease}.mobile-sidebar.open{transform:translate(0)}.mobile-sidebar .sidebar-nav{display:flex;flex-direction:column;gap:15px;margin-top:20px}.mobile-sidebar .sidebar-nav a{color:#fff;text-decoration:none;font-size:1.1rem}.mobile-sidebar .logout-button{margin-top:30px;width:100%;padding:12px;background:white;color:#6a1e55;border-radius:8px;font-weight:700;cursor:pointer;border:none}.close-sidebar{position:absolute;top:15px;right:15px;background:none;border:none;font-size:1.5rem;color:#fff;cursor:pointer}}@media (min-width: 769px){.mobile-sidebar{display:none!important}}.main-loader-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;background:#fff;color:#444}.loader-label{margin-top:12px;font-size:.95rem;color:#6a1e55}.sidebar-inbox-link{position:relative;display:inline-flex;align-items:center;gap:6px}.sidebar-inbox-link .badge{position:absolute;top:-6px;right:-12px;background:#FF3B30;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:999px;font-weight:700;line-height:1;z-index:10;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.nav-submenu{margin-top:10px;padding-left:15px;display:flex;flex-direction:column;gap:8px}.nav-submenu a{color:#fffc;font-size:.95rem;padding:6px 10px;border-radius:6px;transition:background .2s ease;text-decoration:none}.nav-submenu a:hover{background:rgba(255,255,255,.1)}.nav-submenu.disabled{opacity:.6;font-style:italic;pointer-events:none}.nav-submenu a.active{background:#ffffff22;font-weight:700}body,html,#root{height:100%;margin:0;padding:0}.landing-container{min-height:100vh;width:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#3B1C32,#6A1E55);background-size:400% 400%;animation:gradientShift 15s ease infinite;text-align:center;padding:20px;box-sizing:border-box}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.landing-header{width:100%;max-width:720px;margin:0 auto;padding:20px}.landing-header h1{font-size:clamp(2rem,6vw,3rem);color:#fff;margin-bottom:1rem}.landing-header p{font-size:clamp(1.1rem,4vw,1.5rem);color:#e0e0e0;margin-bottom:2rem}.cta-button,.install-button{display:inline-block;background:#fff;color:#6a1e55;padding:12px 24px;border-radius:25px;font-weight:700;text-decoration:none;border:none;font-size:1rem;transition:background .3s;margin:8px;min-width:180px}.cta-button:hover,.install-button:hover{background-color:#f0f0f0}@media (min-width: 768px){.landing-container{padding:60px 40px}.landing-header{padding:40px}.cta-button,.install-button{font-size:1.1rem;padding:14px 28px}}.page-auth{height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#3B1C32 0%,#6A1E55 100%);padding:20px;box-sizing:border-box;font-family:Inter,sans-serif}.auth-container{width:100%;max-width:450px;min-height:580px;background:#fff;padding:60px 40px;border-radius:20px;box-shadow:0 10px 30px #00000026;text-align:center;animation:slideIn .6s ease-out forwards;opacity:0;transform:translateY(30px)}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-container h2{font-size:clamp(1.6rem,5vw,2rem);color:#6a1e55;margin-bottom:30px}.auth-container input,.auth-container select{width:100%;padding:16px;margin:14px 0;background:#f8f8f8;color:#000;border:1px solid #ccc;border-radius:10px;font-size:1rem;box-sizing:border-box;transition:border-color .3s,box-shadow .3s}.auth-container input:focus,.auth-container select:focus{outline:none;border-color:#6a1e55;box-shadow:0 0 0 3px #6a1e5540}.password-strength{text-align:left;font-size:.9rem;color:#6a1e55;margin-bottom:10px}.avatar-grid{display:flex;flex-wrap:wrap;justify-content:center;margin:20px 0 30px}.avatar-grid img{width:70px;height:70px;margin:6px;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:transform .2s,border-color .3s}.avatar-grid img:hover{border-color:#6a1e55;transform:scale(1.05)}.selected-avatar{border:2px solid #6A1E55;transform:scale(1.1)}.auth-container button{width:100%;padding:16px;background-color:#6a1e55;color:#fff;font-weight:700;font-size:1rem;border:none;border-radius:12px;cursor:pointer;margin-top:10px;transition:background-color .3s,transform .2s;line-height:1.2}.auth-container button:hover{background-color:#541442;transform:translateY(-2px)}.auth-container button:disabled{opacity:.7;cursor:not-allowed}.button-spinner{display:inline-block;width:18px;height:18px;border:3px solid #fff;border-radius:50%;border-top-color:transparent;animation:spin .6s linear infinite;vertical-align:middle;margin-right:10px}@keyframes spin{to{transform:rotate(360deg)}}.auth-container p{margin-top:22px;font-size:.95rem}.auth-container a{color:#6a1e55;text-decoration:none;font-weight:700}.auth-container a:hover{text-decoration:underline}.error{color:red;font-size:.9rem;margin-top:10px}.success{color:green;font-size:.9rem;margin-top:10px}@media (min-width: 768px){.auth-container{padding:70px 50px;min-height:620px}}.page-auth.forgot .auth-container{min-height:400px;padding:50px 30px}.dynamics-page{padding:30px;max-width:800px;margin:auto;color:#111}h1,h2{color:#6a1e55;margin-bottom:20px}.search-section{display:flex;gap:10px;margin-bottom:30px}.search-section input{flex:1;padding:12px;border-radius:10px;border:1px solid #ccc;background:#f8f8f8;font-size:1rem}.search-section button{background:#6A1E55;color:#fff;border:none;padding:12px 20px;border-radius:10px;cursor:pointer;transition:background .2s}.search-section button:hover{background:#541442}.search-results,.request-item,.search-result-item{background:#fff;border:1px solid #ddd;padding:15px 20px;border-radius:12px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center}.request-buttons{display:flex;gap:10px}.request-buttons button,.search-result-item button{padding:8px 16px;border:none;border-radius:8px;font-weight:700;cursor:pointer;font-size:.9rem;transition:background .2s}.search-result-item span{flex:1 1 auto;font-size:1rem;font-weight:500;color:#333;margin-right:10px}.search-result-item{flex-wrap:wrap;gap:10px}.request-buttons button:first-of-type{background:#4CAF50;color:#fff}.request-buttons button:last-of-type{background:#f44336;color:#fff}.search-result-item button{background:#6A1E55;color:#fff}.search-result-item button:disabled{background:#ccc;cursor:not-allowed}.cancel{background:#999!important}.toast{position:fixed;bottom:30px;right:30px;background:#6A1E55;color:#fff;padding:14px 20px;border-radius:10px;box-shadow:0 4px 14px #00000026;font-size:1rem;z-index:999}.no-dynamics{padding:20px;border:1px dashed #bbb;border-radius:12px;text-align:center;color:#555;background:#fafafa;margin-bottom:20px}.view-link{margin-left:auto;color:#6a1e55;text-decoration:none;font-weight:700}.view-link:hover{text-decoration:underline}.end-button{margin-left:10px;background-color:#ffe0e0;border:none;color:#a10000;padding:5px 10px;border-radius:6px;font-size:.85rem;cursor:pointer}.end-button:hover{background-color:#fcc}.dynamic-detail-page{padding:30px}.dynamic-header{display:flex;flex-direction:column;gap:10px;margin-bottom:30px}.back-button{background:none;border:none;color:#6a1e55;font-size:1rem;cursor:pointer}.status-label{font-weight:700;color:#444}.dynamic-section{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 6px #0000000d}.status-pill{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:capitalize;background-color:#eee;color:#333;margin-top:10px}.status-pill.accepted{background-color:#d1f9da;color:#267a3e}.status-pill.pending{background-color:#fff6cc;color:#8a6d00}.status-pill.rejected{background-color:#ffe0e0;color:#a10000}.back-button{background:none;border:none;color:#6a1e55;font-weight:600;font-size:.95rem;padding:6px 0;cursor:pointer;display:inline-flex;align-items:center;transition:color .2s ease;margin-bottom:10px}.back-button:hover{color:#922b6c;text-decoration:underline}.dynamic-header{margin-bottom:20px}.header-top{display:flex;align-items:center;justify-content:space-between;gap:20px}.dynamic-section,.dynamic-rules,.dynamic-tasks,.dynamic-sessions{margin-top:30px;padding:20px;background:#fff;border-radius:10px;box-shadow:0 1px 4px #0000000d}.dynamic-section h2{margin-bottom:10px}.rule-list,.task-list,.session-list{margin-top:20px}.rules-container{padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000014}.rule-list{list-style:none;padding:0;margin:20px 0}.rule-item{padding:10px 15px;margin-bottom:10px;border:1px solid #ccc;border-radius:8px;background:#fafafa}.rule-tags{margin-top:6px;display:flex;gap:10px}.tag{display:inline-block;padding:3px 8px;border-radius:6px;font-size:.8rem;color:#fff}.tag.reward{background:#4caf50}.tag.punish{background:#f44336}.tag.points{background:#2196f3}.rule-form{margin-top:30px;display:flex;flex-direction:column;gap:10px}.rule-form input[type=text],.rule-form input[type=number],.rule-form select{padding:10px;border-radius:8px;border:1px solid #ccc}.rule-form label{font-size:.95rem}.rule-form button{padding:10px;border:none;background:#6A1E55;color:#fff;border-radius:8px;cursor:pointer}.inbox-page{max-width:700px;margin:40px auto;padding:0 20px;color:#111}.inbox-page h1{color:#6a1e55;margin-bottom:30px}.inbox-empty{text-align:center;color:#666;background:#f9f9f9;padding:30px;border-radius:12px;border:1px dashed #ccc}.inbox-item{background:white;border:1px solid #ddd;padding:20px;border-radius:12px;margin-bottom:15px;transition:background .2s}.inbox-item.read{background:#f4f4f4;opacity:.7}.inbox-item .message{font-size:1rem;margin-bottom:10px}.inbox-item .meta{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#666}.inbox-item button{padding:6px 12px;font-size:.85rem;border:none;background:#6A1E55;color:#fff;border-radius:8px;cursor:pointer}.badge{background:red;color:#fff;font-size:.75rem;padding:2px 6px;border-radius:50%;position:absolute;top:-5px;right:-5px}.task-form{display:flex;flex-direction:column;gap:16px;background:#fff;padding:30px;border-radius:16px;box-shadow:0 2px 8px #0000000d;margin-bottom:40px}.task-form h3{font-size:1.3rem;color:#333}.task-form input[type=text],.task-form input[type=number],.task-form input[type=datetime-local],.task-form textarea,.task-form select{padding:14px;border-radius:12px;border:1px solid #ccc;font-size:1rem;background:#f8f8f8;transition:border-color .2s,background-color .2s}.task-form input:focus,.task-form textarea:focus,.task-form select:focus{border-color:#6a1e55;background-color:#fff;outline:none}.task-form textarea{resize:vertical;min-height:100px}.task-form label{font-size:.95rem;color:#333;font-weight:500}.task-form button{background:#6A1E55;color:#fff;padding:14px;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .3s}.task-form button:hover{background:#912f73}.task-list{padding-top:20px}.task-list h3{font-size:1.3rem;margin-bottom:20px;color:#333}.task-list ul{list-style:none;padding:0;margin:0}.task-card{border:1px solid #e0e0e0;background:#fff;padding:24px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 6px #0000000a}.task-card strong{font-size:1.1rem;color:#222;display:block;margin-bottom:5px}.task-card .task-status{margin-top:6px}.task-card .task-status span{font-weight:600;text-transform:capitalize}.task-card .status-pending span{color:#666}.task-card .status-submitted span{color:#d49b00}.task-card .status-completed span{color:#2e7d32}.task-card .status-late span{color:#c62828}.task-card .task-badges{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.task-card .badge{position:relative!important;display:inline-block;padding:5px 10px;border-radius:8px;font-size:.85rem;font-weight:500;background:#eee;color:#333}.task-card .badge-points{background:#e3f2fd;color:#0277bd}.task-card .badge-reward{background:#e8f5e9;color:#2e7d32}.task-card .badge-punishment{background:#fff3e0;color:#ef6c00}.task-card .badge-evidence{background:#f3e5f5;color:#6a1b9a}.task-actions{margin-top:16px}.task-actions input[type=file]{display:block;margin-bottom:10px}.task-actions button{margin-top:10px;margin-right:10px;background:#6A1E55;color:#fff;padding:10px 16px;border:none;border-radius:10px;font-size:.9rem;cursor:pointer;transition:background .3s}.task-actions button:hover{background:#912f73}.evidence-list{padding-left:20px;margin-top:10px}.evidence-list li{margin-bottom:6px;font-size:.95rem}.evidence-list a{color:#6a1e55;font-weight:500;text-decoration:underline}.evidence-list a:hover{color:#912f73}
