@import url(https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;500;600;700;900&display=swap);*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(180deg,#8b0000,#c8102e 50%,#dc143c);background-attachment:fixed;font-family:"Noto Serif SC",Microsoft YaHei,SimSun,serif,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;position:relative}body:before{background-image:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 0,#00000008 4px),radial-gradient(circle at 20% 50%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 50%,#ffd7001a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:20px}@media (max-width:768px){.container{padding:10px}}.btn{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s}.btn-primary{background:linear-gradient(135deg,#c8102e,#dc143c);border:2px solid gold;box-shadow:0 4px 15px #c8102e66,inset 0 1px 0 #fff3;color:#fff;font-weight:600;letter-spacing:1px;overflow:hidden;position:relative}.btn-primary:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.btn-primary:hover:before{left:100%}.btn-primary:hover{background:linear-gradient(135deg,#dc143c,#ff1744);box-shadow:0 6px 20px #c8102e99,0 0 10px #ffd7004d;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#8b0000,brown);border:2px solid #ffd70080;box-shadow:0 4px 15px #8b00004d;color:#fff;font-weight:600;letter-spacing:1px}.btn-secondary:hover{background:linear-gradient(135deg,brown,#c8102e);border-color:gold;box-shadow:0 6px 20px #8b000080;transform:translateY(-2px)}.card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 4px 15px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;margin-bottom:20px;padding:24px}.input{background:#fffffff2;border:2px solid #c8102e4d;border-radius:8px;font-size:16px;padding:12px;transition:all .3s;width:100%}.input:focus{background:#fff;border-color:#c8102e;box-shadow:0 0 0 3px #c8102e1a;outline:none}.top-bar{display:none}.top-bar-mobile{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(180deg,#8b0000f2,#c8102ef2);border-bottom:2px solid #ffd7004d;box-shadow:0 2px 10px #0003;padding:10px 0;position:-webkit-sticky;position:sticky;top:0;z-index:1001}.top-bar-content{align-items:center;display:flex;justify-content:flex-end;margin:0 auto;max-width:1200px;padding:0 20px}.btn-login,.btn-logout{border-radius:6px;display:inline-block;font-size:14px;font-weight:600;letter-spacing:1px;padding:8px 20px;text-decoration:none;transition:all .3s}.btn-login{background:linear-gradient(135deg,#c8102e,#dc143c);border:2px solid gold;box-shadow:0 2px 10px #c8102e66;color:#fff}.btn-login:hover{background:linear-gradient(135deg,#dc143c,#ff1744);box-shadow:0 4px 15px #c8102e99,0 0 10px #ffd7004d;transform:translateY(-2px)}.btn-logout{background:linear-gradient(135deg,#8b0000,brown);border:2px solid #ffd70080;box-shadow:0 2px 10px #8b00004d;color:#fff;cursor:pointer}.btn-logout:hover{background:linear-gradient(135deg,brown,#c8102e);border-color:gold;box-shadow:0 4px 15px #8b000080;transform:translateY(-2px)}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(180deg,#8b0000fa,#c8102efa);box-shadow:0 4px 20px #0000004d,inset 0 1px 0 #ffd70033;z-index:1000}.navbar-desktop{border-bottom:3px solid gold;padding:20px 0;position:-webkit-sticky;position:sticky;top:0}.btn-desktop{margin-left:10px}.navbar-content{flex-wrap:wrap;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.navbar-content,.navbar-right{align-items:center;display:flex}.navbar-right{gap:20px}.navbar-logo{color:gold;font-size:28px;font-weight:900;letter-spacing:2px;padding-left:40px;position:relative;text-shadow:2px 2px 4px #00000080,0 0 10px #ffd70080}.navbar-logo:before{color:gold;content:"★";font-size:24px;left:0;position:absolute;text-shadow:0 0 10px #ffd700cc;top:50%;transform:translateY(-50%)}.navbar-links{align-items:center;display:flex;flex-wrap:wrap;gap:20px;list-style:none}.navbar-link{border-radius:4px;color:#ffffffe6;font-weight:600;letter-spacing:1px;padding:8px 16px;position:relative;text-decoration:none;transition:all .3s}.navbar-link:after{background:gold;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .3s;width:0}.navbar-link:hover{background:#ffd7001a;color:gold}.navbar-link:hover:after{width:80%}.navbar-link.active{background:#ffd70026;color:gold}.navbar-link.active:after{background:gold;box-shadow:0 0 10px #ffd700cc;width:80%}.navbar-mobile{display:none}@media (max-width:768px){.top-bar-mobile{display:block!important;padding:8px 0}.top-bar-content{padding:0 15px}.btn-login,.btn-logout{font-size:13px;padding:6px 16px}.navbar-desktop{display:none!important}.navbar-mobile{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(180deg,#8b0000fa,#c8102efa)!important;border-bottom:none!important;border-top:3px solid gold;bottom:0!important;box-shadow:0 -4px 20px #0000004d,inset 0 1px 0 #ffd70033;display:block!important;left:0!important;margin:0;padding:0;position:fixed!important;right:0!important;top:auto!important;z-index:1000}.navbar-mobile-links{align-items:center;display:flex;height:65px;justify-content:space-around;list-style:none;margin:0;padding:0}.navbar-mobile-link{align-items:center;border-radius:8px;color:#ffffffb3;display:flex;flex:1 1;flex-direction:column;height:100%;justify-content:center;padding:8px 12px;position:relative;text-decoration:none;transition:all .3s}.navbar-mobile-link .navbar-icon{filter:drop-shadow(0 0 3px rgba(255,215,0,.3));height:24px;margin-bottom:4px;transition:all .3s;width:24px}.navbar-mobile-link .navbar-text{font-size:12px;font-weight:600;letter-spacing:.5px}.navbar-mobile-link:hover{background:#ffd7001a;color:gold}.navbar-mobile-link:hover .navbar-icon{filter:drop-shadow(0 0 8px rgba(255,215,0,.6));transform:scale(1.2)}.navbar-mobile-link.active{background:#ffd70026;color:gold}.navbar-mobile-link.active:before{background:gold;box-shadow:0 0 10px #ffd700cc;content:"";height:3px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:40px}.navbar-mobile-link.active .navbar-icon{filter:drop-shadow(0 0 10px rgba(255,215,0,.9));transform:scale(1.2)}.navbar-desktop .navbar-content{flex-direction:column;gap:12px}.navbar-desktop .navbar-links{gap:12px;justify-content:center}.navbar-desktop .navbar-logo{font-size:20px}}.login-container{align-items:center;background:linear-gradient(180deg,#8b0000,#c8102e 50%,#dc143c);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-container:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#ffd7001a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 10px 40px #0000004d,0 0 0 3px gold,inset 0 1px 0 #ffffffe6;max-width:420px;padding:50px 40px;position:relative;width:100%;z-index:1}.login-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);border-radius:8px 8px 0 0;content:"";height:5px;left:0;position:absolute;right:0;top:0}.login-title{color:#c8102e;font-size:32px;font-weight:900;letter-spacing:3px;margin-bottom:12px;padding-bottom:15px;position:relative;text-align:center;text-shadow:2px 2px 4px #0000001a}.login-title:after{background:linear-gradient(90deg,#0000,gold,#0000);bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:80px}.login-subtitle{color:#666;font-size:20px;font-weight:500;margin-bottom:30px;text-align:center}.login-form{display:flex;flex-direction:column;gap:20px}select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23C8102E' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;font-family:inherit;padding-right:40px}select.input option{background:#fff;padding:8px}.error-message{background:#fee;border-radius:8px;color:#c33;font-size:14px;padding:12px;text-align:center}.link-button{background:none;border:none;color:#c8102e;cursor:pointer;font-size:inherit;font-weight:600;margin-left:4px;text-decoration:underline;transition:color .3s}.link-button:hover{color:#dc143c;text-shadow:0 0 5px #dc143c80}.login-switch{color:#666;margin-top:20px;text-align:center}@media (max-width:768px){.login-card{padding:30px 20px}.login-title{font-size:20px}.login-subtitle{font-size:18px}}.home-container{margin:0 auto;max-width:1200px;padding:40px 20px}.hero-section{margin-bottom:60px;padding:60px 20px;text-align:center}.hero-title{color:gold;font-size:56px;font-weight:900;letter-spacing:4px;margin-bottom:25px;padding-bottom:20px;position:relative;text-shadow:3px 3px 6px #00000080,0 0 20px #ffd70080,0 0 40px #ffd7004d}.hero-title:after{background:linear-gradient(90deg,#0000,gold,#0000);bottom:0;box-shadow:0 0 10px #ffd700cc;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:200px}.hero-subtitle{color:#fffffff2;font-size:28px;font-weight:500;letter-spacing:2px;margin-top:15px;text-shadow:2px 2px 4px #0006}.features-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:60px}.feature-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 4px 15px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;color:#333;overflow:hidden;padding:40px 30px;position:relative;text-align:center;text-decoration:none;transition:all .3s}.feature-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);content:"";height:4px;left:0;position:absolute;right:0;top:0}.feature-card:hover{border-color:#c8102e;box-shadow:0 15px 35px #0000004d,0 0 0 3px gold,0 0 20px #ffd70066;transform:translateY(-10px) scale(1.02)}.feature-icon{font-size:64px;margin-bottom:20px}.feature-card h2{color:#c8102e;font-size:26px;font-weight:700;letter-spacing:1px;margin-bottom:15px;text-shadow:1px 1px 2px #0000001a}.feature-card p{color:#666;font-size:16px;line-height:1.6}.intro-section{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 10px 30px #0003,0 0 0 3px gold,inset 0 1px 0 #ffffffe6;padding:50px 40px;position:relative;text-align:center}.intro-section:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);border-radius:8px 8px 0 0;content:"";height:5px;left:0;position:absolute;right:0;top:0}.intro-section h2{color:#c8102e;font-size:36px;font-weight:900;letter-spacing:2px;margin-bottom:25px;padding-bottom:15px;position:relative;text-shadow:2px 2px 4px #0000001a}.intro-section h2:after{background:linear-gradient(90deg,#0000,gold,#0000);bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:150px}.intro-section p{color:#666;font-size:18px;line-height:1.8;margin:0 auto;max-width:800px}@media (max-width:768px){.hero-title{font-size:32px}.hero-subtitle{font-size:18px}.features-grid{gap:20px;grid-template-columns:1fr}.intro-section{padding:30px 20px}.intro-section h2{font-size:24px}.intro-section p{font-size:16px}}.map-container{border:2px solid #c8102e33;border-radius:12px;box-shadow:0 4px 15px #0003;height:500px;margin:0;overflow:hidden;padding:0;width:100%}@media (max-width:768px){.map-container{height:400px}}.heroes-container{margin:0 auto;max-width:1200px;padding:40px 20px}.heroes-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(4,1fr);margin-bottom:40px}.hero-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 4px 15px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;cursor:pointer;overflow:hidden;padding:25px 20px;position:relative;text-align:center;transition:all .3s}.hero-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);content:"";height:3px;left:0;position:absolute;right:0;top:0}.hero-card:hover{border-color:#c8102e;box-shadow:0 15px 35px #0000004d,0 0 0 3px gold,0 0 20px #ffd70066;transform:translateY(-10px) scale(1.05)}.hero-image{border-radius:8px;height:250px;margin-bottom:16px;object-fit:cover;width:100%}.hero-name{color:#c8102e;font-size:22px;font-weight:700;letter-spacing:1px;margin-top:10px;text-shadow:1px 1px 2px #0000001a}.modal-content{max-width:900px}.modal-select-mode{padding:40px 20px;text-align:center}.mode-selection{flex-wrap:wrap;gap:30px;margin-top:40px}.mode-button,.mode-selection{display:flex;justify-content:center}.mode-button{align-items:center;background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:3px solid gold;border-radius:16px;box-shadow:0 4px 15px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;cursor:pointer;flex-direction:column;gap:15px;min-width:180px;padding:40px 50px;transition:all .3s}.mode-button:hover{background:linear-gradient(135deg,#fff,#fffaf0);box-shadow:0 8px 25px #0000004d,0 0 0 3px gold,0 0 20px #ffd70066;transform:translateY(-5px) scale(1.05)}.mode-icon{font-size:48px;line-height:1}.mode-text{color:#c8102e;font-size:20px;font-weight:700;letter-spacing:2px}.modal-story-content{background:#fffffff2;border:2px solid #ffd7004d;border-radius:12px;box-shadow:0 4px 15px #0000001a;font-size:16px;line-height:1.8;margin:30px 0;max-height:400px;overflow-y:auto;padding:30px;text-align:left;white-space:pre-wrap}.modal-hero-info{margin-bottom:30px;text-align:center}.modal-hero-image-wrapper{border-radius:12px;box-shadow:0 8px 25px #0000004d;margin:0 auto 20px;max-width:400px;overflow:hidden;position:relative;width:100%}.modal-hero-image{border-radius:12px;display:block;height:auto;width:100%}.danmaku-overlay{border-radius:12px;bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0}.modal-hero-name{color:#333;font-size:32px;margin-bottom:16px}.modal-hero-description{color:#666;font-size:16px;line-height:1.6;margin-bottom:20px}.modal-audio{margin:0 auto;max-width:500px;width:100%}.danmaku-container{border-top:2px solid #c8102e33;margin-top:20px;padding-top:20px}.danmaku-item{align-items:center;animation:danmakuScroll linear infinite;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(135deg,#c8102ed9,#dc143cd9);border:2px solid #ffd700cc;border-radius:25px;box-shadow:0 3px 10px #0009,0 0 15px #ffd70080,inset 0 1px 0 #ffffff4d;display:flex;gap:8px;min-width:120px;padding:8px 16px;position:absolute;white-space:nowrap;z-index:10}.danmaku-content{color:gold;font-size:18px;font-weight:700;letter-spacing:1.5px;text-shadow:2px 2px 6px #000,-1px -1px 2px #000c,0 0 15px #ffd700e6,0 0 25px #c8102ecc}.danmaku-user-info{align-items:center;color:#ffffffe6;display:flex;font-size:14px;font-weight:500;gap:4px;letter-spacing:.5px;text-shadow:1px 1px 3px #000c,0 0 5px #ffffff4d}.danmaku-separator{color:#fff9;font-weight:300;margin:0 4px}.danmaku-class{color:#fffffff2}.danmaku-dot{color:#fff9;margin:0 2px}.danmaku-username{color:#fffffff2}@keyframes danmakuScroll{0%{opacity:0;transform:translateX(calc(100% + 20px))}2%{opacity:1}98%{opacity:1}to{opacity:0;transform:translateX(calc(-100% - 20px))}}.danmaku-form{display:flex;gap:12px}.danmaku-input{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:14px;padding:12px}.danmaku-input:focus{border-color:#c8102e;box-shadow:0 0 0 3px #c8102e1a;outline:none}@media (max-width:768px){.heroes-grid{gap:20px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.hero-image{height:200px}.modal-content{padding:20px}.modal-hero-name{font-size:24px}.modal-select-mode{padding:30px 15px}.mode-selection{gap:20px;margin-top:30px}.mode-button{min-width:140px;padding:30px 40px}.mode-icon{font-size:40px}.mode-text{font-size:18px}.modal-story-content{font-size:14px;margin:20px 0;max-height:300px;padding:20px}.danmaku-form{flex-direction:column}}.footprints-section{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:16px;box-shadow:0 10px 40px #0003,0 0 0 3px gold,inset 0 1px 0 #ffffffe6;margin-top:60px;padding:40px 20px}.footprints-title{color:#c8102e;font-size:36px;font-weight:900;letter-spacing:3px;margin-bottom:30px;padding-bottom:15px;position:relative;text-align:center;text-shadow:2px 2px 4px #0000001a}.footprints-title:after{background:linear-gradient(90deg,#0000,gold,#0000);bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:150px}.footprints-map-container{margin-top:30px}.footprints-info{background:#fffffff2;border:2px solid #ffd7004d;border-radius:12px;box-shadow:0 4px 15px #0000001a;max-height:500px;overflow-y:auto;padding:20px}.footprints-info-title{border-bottom:2px solid #c8102e33;color:#c8102e;font-size:20px;font-weight:700;margin-bottom:20px;padding-bottom:10px;text-align:center}.footprints-list{list-style:none;margin:0;padding:0}.footprint-item{background:#fffaf080;border-left:4px solid #c8102e;border-radius:8px;margin-bottom:20px;padding:15px;transition:all .3s}.footprint-item:hover{background:#fffaf0cc;box-shadow:0 2px 8px #0000001a;transform:translateX(5px)}.footprint-name{color:#c8102e;display:block;font-size:16px;font-weight:700;margin-bottom:6px}.footprint-address{color:#666;display:block;font-size:13px;margin-bottom:8px}.footprint-description{color:#333;font-size:13px;line-height:1.6;margin:0}@media (max-width:768px){.footprints-section{margin-top:40px;padding:20px 15px}.footprints-title{font-size:24px;margin-bottom:20px}.footprints-map-container{gap:20px;grid-template-columns:1fr}.footprints-map{height:400px}.footprints-info{max-height:400px}.footprint-item{padding:12px}.footprint-name{font-size:15px}.footprint-address,.footprint-description{font-size:12px}}.quiz-container{margin:0 auto;max-width:900px;padding:40px 20px}.page-title:after{width:250px}.quiz-progress{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 4px 15px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;margin-bottom:25px;padding:25px;position:relative}.quiz-progress:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);border-radius:8px 8px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.quiz-progress span{color:#333;display:block;font-weight:500;margin-bottom:10px}.progress-bar{background:#e0e0e0;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#c8102e,#dc143c 50%,gold);box-shadow:0 0 10px #ffd70080;height:100%;overflow:hidden;position:relative;transition:width .3s}.progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.question-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 8px 25px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;padding:35px;position:relative;touch-action:pan-y}.question-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);border-radius:8px 8px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.question-number{color:#667eea;font-size:18px;font-weight:600}.review-badge{border-radius:20px;font-size:14px;font-weight:500;padding:6px 12px}.review-badge.correct{background:#d4edda;color:#155724}.review-badge.incorrect{background:#f8d7da;color:#721c24}.question-text{color:#333;font-size:24px;line-height:1.6;margin-bottom:30px}.options{display:flex;flex-direction:column;gap:16px;margin-bottom:30px}.option-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;font-size:16px;padding:16px 20px;text-align:left;transition:all .3s}.option-btn:hover:not(:disabled){background:#f8f9ff;border-color:#667eea}.option-btn.selected{background:#f0f4ff;border-color:#667eea}.option-btn.correct{animation:correctPulse .5s ease;background:#d4edda;border-color:#28a745}.option-btn.incorrect{animation:incorrectShake .5s ease;background:#f8d7da;border-color:#dc3545}.option-btn.correct-answer{background:#d4edda;border-color:#28a745;border-width:3px}@keyframes correctPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes incorrectShake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.answer-icon{border-radius:6px;font-size:18px;font-weight:700;margin-left:auto;padding:4px 8px}.correct-icon{background:#28a7451a;color:#28a745}.incorrect-icon{background:#dc35451a;color:#dc3545}.correct-answer-icon{background:#28a7451a;color:#28a745;font-size:14px}.option-btn:disabled{cursor:not-allowed}.option-label{color:#667eea;font-weight:600;margin-right:12px;min-width:30px}.option-text{color:#333;flex:1 1}.question-nav{display:flex;gap:12px;justify-content:space-between;margin-bottom:20px}.swipe-hint{color:#999;font-size:14px;text-align:center}.result-modal{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:3000}.result-content{background:#fff;border-radius:16px;max-width:400px;padding:40px;text-align:center;width:100%}.failure-animation,.success-animation{animation:bounce .5s;font-size:64px;margin-bottom:20px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.result-content h2{color:#333;font-size:32px;margin-bottom:16px}.result-content.success h2{color:#28a745}.result-content.failure h2{color:#dc3545}.result-content p{color:#666;font-size:18px;margin-bottom:12px}.hint{color:#999;font-size:14px;margin-bottom:20px}.completion-message{color:#667eea;font-size:20px;font-weight:600;margin-top:20px}@media (max-width:768px){.question-text{font-size:20px}.option-btn{font-size:15px;padding:14px 16px}.question-nav{flex-direction:column}.question-nav button{width:100%}.result-content{padding:30px 20px}}.workshop-container{margin:0 auto;max-width:1200px;padding:40px 20px}.page-title{margin-bottom:50px}.workshops-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.workshop-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 4px 15px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;cursor:pointer;overflow:hidden;padding:35px 30px;position:relative;text-align:center;transition:all .3s}.workshop-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);content:"";height:4px;left:0;position:absolute;right:0;top:0}.workshop-card:hover{border-color:#c8102e;box-shadow:0 15px 35px #0000004d,0 0 0 3px gold,0 0 20px #ffd70066;transform:translateY(-10px) scale(1.02)}.workshop-card.active{background:linear-gradient(135deg,#fffaf0fa,#fff0e6fa);border:3px solid #c8102e;box-shadow:0 8px 25px #c8102e4d,0 0 0 3px gold,0 0 25px #ffd70080}.workshop-icon{font-size:64px;margin-bottom:16px}.workshop-card h2{color:#c8102e;font-size:26px;font-weight:700;letter-spacing:1px;margin-bottom:15px;text-shadow:1px 1px 2px #0000001a}.workshop-card p{color:#666;font-size:14px;line-height:1.6;margin-bottom:20px}.works-section{background:#fff;border-radius:16px;margin-top:30px;padding:30px}.section-title{color:#333;font-size:28px;margin-bottom:24px;text-align:center}.works-bento-grid{grid-gap:20px;display:grid;gap:20px;grid-auto-flow:dense;grid-auto-rows:minmax(250px,auto);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.work-bento-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e26;border-radius:16px;box-shadow:0 4px 15px #0000001a,0 0 0 1px #ffd70033;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.work-bento-card:hover{border-color:#c8102e4d;box-shadow:0 8px 25px #00000026,0 0 0 2px #ffd70066;transform:translateY(-5px)}.work-bento-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);content:"";height:3px;left:0;position:absolute;right:0;top:0}.work-bento-card-small{grid-column:span 1;grid-row:span 1;min-height:250px}.work-bento-card-medium{grid-column:span 1;grid-row:span 2;min-height:350px}.work-bento-card-large{grid-column:span 2;grid-row:span 2;min-height:450px}.work-bento-header{align-items:center;border-bottom:2px solid #c8102e26;display:flex;flex-shrink:0;gap:12px;margin-bottom:15px;padding-bottom:12px}.work-bento-type{flex-shrink:0;font-size:24px}.work-bento-title{color:#c8102e;flex:1 1;font-size:18px;font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-bento-content{display:flex;flex:1 1;flex-direction:column;margin-bottom:15px;min-height:0;overflow:hidden}.work-bento-image{border-radius:12px;flex:1 1;height:100%;min-height:200px;object-fit:cover;width:100%}.work-bento-video{background:linear-gradient(135deg,#c8102e0d,#ffd7000d);border:2px dashed #c8102e33;border-radius:12px;display:flex;flex-direction:column;gap:15px;height:100%;justify-content:space-between;min-height:150px;padding:20px}.work-bento-video-content{align-items:flex-start;display:flex;flex:1 1;justify-content:center;overflow:hidden}.work-bento-video-text{background:#fffffff2;border:1px solid #c8102e1a;border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#333;font-size:14px;line-height:1.8;margin:0;max-height:150px;overflow-y:auto;padding:15px;text-align:left;width:100%;word-break:break-word}.work-bento-video-actions{display:flex;flex-shrink:0;gap:10px;justify-content:center}.btn-copy-video{align-items:center;background:linear-gradient(135deg,#c8102e,#dc143c);border:none;border-radius:8px;box-shadow:0 2px 8px #c8102e4d;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .3s;width:100%}.btn-copy-video:hover{box-shadow:0 4px 12px #c8102e66;transform:translateY(-2px)}.btn-copy-video:active{transform:translateY(0)}.work-bento-audio{flex-shrink:0;margin:auto 0;width:100%}.work-bento-text{background:#ffffff80;border-radius:8px;color:#666;flex:1 1;font-size:15px;line-height:1.8;margin:0;overflow-y:auto;padding:10px}.work-bento-meta{align-items:center;border-top:2px solid #c8102e26;color:#999;display:flex;flex-shrink:0;font-size:12px;justify-content:space-between;margin-top:auto;padding-top:12px}.work-bento-author{color:#c8102e;font-weight:500}.work-bento-date{color:#999}.empty-works{color:#999;font-size:18px;padding:60px 20px;text-align:center}.modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.modal-content{background:#fff;border-radius:16px;max-height:90vh;max-width:600px;overflow-y:auto;padding:30px;position:relative;width:100%}.modal-close{align-items:center;background:#f0f0f0;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;position:absolute;right:15px;top:15px;transition:background .3s;width:40px}.modal-close:hover{background:#e0e0e0}.modal-content h2{color:#333;font-size:24px;margin-bottom:24px}.upload-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:#333;font-weight:500}.form-group small{color:#999;font-size:12px}.form-group textarea{min-height:100px;resize:vertical}@media (max-width:768px){.workshops-grid{gap:15px;grid-template-columns:repeat(2,1fr)}.workshop-card{padding:20px 15px}.workshop-icon{font-size:48px;margin-bottom:12px}.workshop-card h2{font-size:20px;margin-bottom:10px}.workshop-card p{font-size:12px;margin-bottom:15px}.works-bento-grid{gap:12px;grid-auto-rows:minmax(200px,auto);grid-template-columns:repeat(2,1fr)}.work-bento-card{padding:15px}.work-bento-card-large{grid-column:span 2;grid-row:span 2;min-height:280px}.work-bento-card-medium{grid-column:span 1;grid-row:span 2;min-height:220px}.work-bento-card-small{grid-column:span 1;grid-row:span 1;min-height:200px}.work-bento-title{font-size:14px}.work-bento-type{font-size:20px}.work-bento-text{font-size:13px;padding:8px}.work-bento-video-text{font-size:12px;max-height:100px;padding:12px}.btn-copy-video{font-size:13px;padding:10px 16px}.work-bento-meta{font-size:11px}.modal-content{padding:20px}}@media (min-width:769px) and (max-width:1024px){.works-bento-grid{grid-template-columns:repeat(3,1fr)}.work-bento-card-large{grid-column:span 2;grid-row:span 2}}@media (min-width:1025px){.works-bento-grid{grid-template-columns:repeat(4,1fr)}.work-bento-card-large{grid-column:span 2;grid-row:span 2}}.profile-container{margin:0 auto;max-width:600px;padding:40px 20px}.page-title:after{width:150px}.profile-card{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:8px;box-shadow:0 8px 25px #0003,0 0 0 2px gold,inset 0 1px 0 #ffffffe6;padding:40px;position:relative}.profile-card:before{background:linear-gradient(90deg,#c8102e,gold 50%,#c8102e);border-radius:8px 8px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.profile-header{border-bottom:2px solid #c8102e1a;margin-bottom:30px;padding-bottom:30px;text-align:center}.profile-avatar{align-items:center;background:linear-gradient(135deg,#c8102e,#dc143c);border:3px solid gold;border-radius:50%;box-shadow:0 4px 15px #c8102e66;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.profile-avatar svg{height:50px;width:50px}.profile-email{color:#666;font-size:18px;font-weight:500}.profile-form{gap:24px}.form-group,.profile-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#c8102e;font-size:16px;font-weight:600;letter-spacing:.5px}.form-hint{color:#999;font-size:12px;margin-top:-4px}.message{animation:slideDown .3s ease-out;border-radius:8px;font-weight:500;margin-bottom:20px;padding:12px 16px;text-align:center}.message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-actions{border-top:2px solid #c8102e1a;margin-top:30px;padding-top:30px;text-align:center}.btn-logout-profile{background:linear-gradient(135deg,#8b0000,brown);border:2px solid #ffd70080;border-radius:8px;box-shadow:0 2px 10px #8b00004d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;letter-spacing:1px;max-width:300px;padding:12px 30px;transition:all .3s;width:100%}.btn-logout-profile:hover{background:linear-gradient(135deg,brown,#c8102e);border-color:gold;box-shadow:0 4px 15px #8b000080;transform:translateY(-2px)}@media (max-width:768px){.profile-container{padding:30px 15px}.profile-card{padding:30px 20px}.page-title{font-size:32px;margin-bottom:30px}.btn-logout-profile{max-width:100%}}.admin-container{margin:0 auto;max-width:1200px;padding:40px 20px}.page-title{color:gold;font-size:42px;font-weight:900;letter-spacing:3px;margin-bottom:40px;padding-bottom:20px;position:relative;text-align:center;text-shadow:3px 3px 6px #00000080,0 0 20px #ffd70080}.page-title:after{background:linear-gradient(90deg,#0000,gold,#0000);bottom:0;box-shadow:0 0 10px #ffd700cc;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:200px}.admin-tabs{border-bottom:2px solid #c8102e33;display:flex;gap:20px;margin-bottom:30px}.admin-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;position:relative;top:2px;transition:all .3s}.admin-tab:hover{color:#c8102e}.admin-tab.active{border-bottom-color:gold;color:#c8102e}.admin-filters{display:flex;gap:15px;margin-bottom:20px}.filter-select{background:#fff;border:2px solid #c8102e4d;border-radius:8px;cursor:pointer;font-size:14px;padding:10px 15px;transition:all .3s}.filter-select:focus{border-color:#c8102e;box-shadow:0 0 0 3px #c8102e1a;outline:none}.empty-state,.loading{color:#666;font-size:18px;padding:60px 20px;text-align:center}.works-list{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.work-item{background:linear-gradient(135deg,#fffffffa,#fffaf0fa);border:2px solid #c8102e33;border-radius:12px;box-shadow:0 4px 15px #0000001a,0 0 0 2px #ffd7004d;padding:25px}.work-header{margin-bottom:15px}.work-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:10px}.work-title{color:#c8102e;font-size:20px;font-weight:700;margin:0}.status-badge{border-radius:12px;font-size:12px;font-weight:600;padding:4px 12px}.status-badge.status-pending{background:#fff3cd;color:#856404}.status-badge.status-approved{background:#d4edda;color:#155724}.status-badge.status-rejected{background:#f8d7da;color:#721c24}.work-meta{color:#666;display:flex;flex-wrap:wrap;font-size:14px;gap:15px}.work-type{color:#c8102e;font-weight:600}.work-author{color:#333}.work-date,.work-email{color:#999}.work-content{background:#fffc;border:1px solid #c8102e1a;border-radius:8px;margin:20px 0;padding:15px}.work-image{border-radius:8px;max-height:300px;max-width:100%}.work-audio{width:100%}.work-video-link{color:#c8102e;text-decoration:none;word-break:break-all}.work-video-link:hover{text-decoration:underline}.work-text{line-height:1.8;margin:0;white-space:pre-wrap;word-break:break-word}.work-actions{display:flex;gap:10px;margin-top:15px}.btn-approve{background:linear-gradient(135deg,#28a745,#20c997);border:2px solid #28a745;color:#fff}.btn-approve:hover{background:linear-gradient(135deg,#20c997,#28a745);box-shadow:0 4px 15px #28a74566}.btn-reject{background:linear-gradient(135deg,#dc3545,#c82333);border:2px solid #dc3545;color:#fff}.btn-reject:hover{background:linear-gradient(135deg,#c82333,#dc3545);box-shadow:0 4px 15px #dc354566}.btn-show{background:linear-gradient(135deg,#c8102e,#dc143c);border:2px solid gold;color:#fff}.btn-show:hover{box-shadow:0 4px 15px #c8102e66}.btn-hide{background:linear-gradient(135deg,#8b0000,brown);border:2px solid #ffd70080;color:#fff}.btn-hide:hover{box-shadow:0 4px 15px #8b000066}.pagination{align-items:center;display:flex;gap:20px;justify-content:center;margin-top:30px}.page-info{color:#666;font-weight:600}@media (max-width:768px){.admin-container{padding:30px 15px}.page-title{font-size:32px;margin-bottom:30px}.admin-tabs{flex-direction:column;gap:0}.admin-tab{border-bottom:1px solid #c8102e1a;text-align:left;width:100%}.work-title-row{align-items:flex-start;flex-direction:column}.work-meta{gap:8px}.work-actions,.work-meta{flex-direction:column}.work-actions .btn{width:100%}}.App{min-height:100vh;padding-bottom:0}@media (max-width:768px){.App{padding-bottom:65px}}
/*# sourceMappingURL=main.78d25abe.css.map*/