:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.drawing-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.header{text-align:center;color:#fff;margin-bottom:2rem}.header h1{font-size:3rem;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.subtitle{font-size:1.2rem;margin:.5rem 0 0;opacity:.9}.manual-input-area{margin-top:2rem;display:flex;justify-content:center;gap:1rem}.drawing-input{padding:.8rem 1.5rem;font-size:1.2rem;border:2px solid rgba(255,255,255,.5);border-radius:30px;width:300px;background:#ffffffe6;transition:all .3s;text-align:center}.drawing-input:focus{outline:none;border-color:#fff;background:#fff;box-shadow:0 0 0 4px #fff3}.btn-submit{padding:0 2rem;font-size:1rem;font-weight:700;color:#667eea;background:#fff;border:none;border-radius:30px;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #0000001a}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0003}.btn-submit:active{transform:translateY(0)}.btn-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.prize-selector{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}.prize-btn{background:#fff;border:3px solid transparent;border-radius:12px;padding:1rem 2rem;cursor:pointer;transition:all .3s ease;min-width:150px}.prize-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #0003}.prize-btn.active{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.prize-btn.full{opacity:.5;cursor:not-allowed;background:#e0e0e0}.prize-name{font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.prize-count{font-size:.9rem;opacity:.8}.message{max-width:600px;margin:0 auto 2rem;padding:1rem 2rem;border-radius:8px;text-align:center;font-size:1.2rem;font-weight:700;animation:slideDown .3s ease}.message.success{background:#4caf50;color:#fff}.message.error{background:#f44336;color:#fff}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.current-prize-info{background:#fff;max-width:600px;margin:0 auto 2rem;padding:1.5rem;border-radius:12px;text-align:center;box-shadow:0 4px 6px #0000001a}.current-prize-info h2{margin:0 0 .5rem;color:#667eea}.current-prize-info p{margin:0;font-size:1.1rem;color:#666}.winner-list{background:#fff;max-width:1200px;margin:0 auto 2rem;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.winner-list h3{margin:0 0 1.5rem;color:#333;font-size:1.5rem;text-align:center}.empty-message{text-align:center;color:#999;font-size:1.1rem;padding:2rem}.winner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.winner-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f7fafc;border-radius:8px;border-left:4px solid #667eea;transition:all .2s ease;animation:fadeIn .3s ease}.winner-card:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.winner-number{background:#667eea;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.winner-info{flex:1}.winner-name{font-size:1.1rem;font-weight:700;color:#333;margin-bottom:.25rem}.winner-details{font-size:.9rem;color:#666}.hint{text-align:center;color:#fff;margin-top:2rem}.hint p{background:#0003;display:inline-block;padding:.75rem 1.5rem;border-radius:8px;margin:0}.employee-manager{padding:1rem}.actions-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 4px #0000000d}.left-actions{display:flex;gap:.8rem}.search-input{padding:.6rem 1rem;border:1px solid #ddd;border-radius:20px;width:250px;transition:all .3s}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.stats-bar{margin-bottom:1rem;color:#666;font-size:.9rem;font-weight:500}.file-btn{display:flex;align-items:center;cursor:pointer}.table-container{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000000d;overflow:hidden}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.data-table th{background:#f8fafc;color:#4a5568;font-weight:600}.data-table tr:hover{background:#f1f5f9}.data-table tr.selected{background:#eef2ff}.btn-small{padding:.3rem .6rem;font-size:.85rem;margin-right:.5rem;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.btn-edit{background:#edf2f7;color:#2d3748}.btn-edit:hover{background:#cbd5e0}.btn-delete{background:#fff5f5;color:#e53e3e}.btn-delete:hover{background:#fed7d7}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:12px;width:400px;max-width:90%;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.employee-form .form-group{margin-bottom:1rem}.employee-form label{display:block;margin-bottom:.5rem;color:#4a5568;font-weight:500}.employee-form input{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:6px;box-sizing:border-box}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.empty-text{text-align:center;color:#999;padding:2rem}.backend-page{min-height:100vh;background:#f5f7fa;padding:2rem}.container{max-width:1200px;margin:0 auto}.backend-page h1{color:#2d3748;margin:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:0 1rem}.tabs{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center}.tab-btn{background:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;color:#718096;cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #0000000d}.tab-btn:hover{color:#667eea;transform:translateY(-2px)}.tab-btn.active{background:#667eea;color:#fff;box-shadow:0 4px 6px #667eea4d}.section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.section h2{color:#2d3748;margin:0 0 1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0}.import-area{text-align:center;padding:2rem;border:2px dashed #cbd5e0;border-radius:8px}.file-upload-btn{display:inline-block;background:#667eea;color:#fff;padding:.75rem 2rem;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:700}.file-upload-btn:hover{background:#5568d3;transform:translateY(-2px)}.hint-text{margin-top:1rem;color:#718096;font-size:.9rem}.prize-form{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1.5rem;background:#f7fafc;border-radius:8px}.prize-form input{flex:1;padding:.75rem;border:1px solid #cbd5e0;border-radius:6px;font-size:1rem}.prize-form input:focus{outline:none;border-color:#667eea}.prize-list{display:grid;gap:1rem}.prize-item{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#f7fafc;border-radius:8px;border-left:4px solid #667eea}.prize-info h3{margin:0 0 .5rem;color:#2d3748}.prize-info p{margin:0;color:#718096}.prize-actions{display:flex;gap:.5rem}.btn-primary,.btn-secondary,.btn-danger{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-weight:700;transition:all .2s ease}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-secondary{background:#718096;color:#fff}.btn-secondary:hover{background:#4a5568}.btn-danger{background:#f56565;color:#fff}.btn-danger:hover{background:#e53e3e}.btn-small{padding:.25rem .75rem;font-size:.875rem}.winner-table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#f7fafc;padding:1rem;text-align:left;font-weight:600;color:#2d3748;border-bottom:2px solid #e2e8f0}.data-table td{padding:1rem;border-bottom:1px solid #e2e8f0;color:#4a5568}.data-table tbody tr:hover{background:#f7fafc}.empty-message{text-align:center;color:#a0aec0;padding:2rem;font-size:1.1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:12px;max-width:500px;width:90%;text-align:center}.modal-content h2{margin:0 0 1.5rem;color:#2d3748}.qr-code-container{display:flex;justify-content:center;margin-bottom:1.5rem}.share-url{display:flex;gap:.5rem;margin-bottom:1.5rem}.share-url input{flex:1;padding:.75rem;border:1px solid #cbd5e0;border-radius:6px;font-size:.9rem}.share-url input:focus{outline:none;border-color:#667eea}.prize-sub-text{font-size:.85em;color:#718096;margin-left:.5rem}.prize-item-name{font-size:.9em;color:#667eea;font-weight:400;margin-left:.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem;flex:2}@media(max-width:768px){.prize-form{flex-direction:column}.prize-item{flex-direction:column;align-items:flex-start;gap:1rem}.prize-actions{width:100%;justify-content:flex-end}.data-table,.data-table thead,.data-table tbody,.data-table th,.data-table td,.data-table tr{display:block}.data-table thead tr{position:absolute;top:-9999px;left:-9999px}.data-table tr{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:1rem;padding:1rem;border:1px solid #e2e8f0}.data-table td{border:none;padding:.5rem 0;position:relative;padding-left:40%;text-align:right;display:flex;justify-content:space-between;align-items:center}.data-table td:before{content:attr(data-label);font-weight:700;color:#718096;text-align:left}.data-table td:last-child{justify-content:flex-end;padding-left:0}.data-table td:last-child:before{display:none}}.share-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.loading,.error-message{text-align:center;color:#fff;font-size:1.5rem;padding:4rem 2rem}.error-message h2{margin:0 0 1rem}.error-message p{margin:0;opacity:.9}.export-toolbar{text-align:center;margin-bottom:2rem}.export-btn{background:#fff;color:#667eea;border:none;padding:.75rem 2rem;font-size:1rem;border-radius:8px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;font-weight:700}.export-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.prize-list-card{max-width:900px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center}.card-header h1{margin:0;font-size:2.5rem;font-weight:700}.share-prize-item{font-size:.8em;opacity:.9;margin:0 .5rem}.subtitle{margin:.5rem 0 0;font-size:1.2rem;opacity:.9}.card-body{padding:2rem;min-height:200px}.empty-text{text-align:center;color:#999;font-size:1.2rem;padding:3rem 0}.winner-table{width:100%;border-collapse:collapse}.winner-table th{background:#f7fafc;padding:1rem;text-align:left;font-weight:600;color:#2d3748;border-bottom:2px solid #e2e8f0;font-size:1rem}.winner-table td{padding:1rem;border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:.95rem}.winner-table tbody tr:hover{background:#f7fafc}.winner-table tbody tr:last-child td{border-bottom:none}.card-footer{background:#f7fafc;padding:1.5rem;text-align:center;font-size:1.3rem;color:#667eea;font-weight:700}@media(max-width:768px){.share-page{padding:1rem}.card-header{padding:2rem 1rem}.card-header h1{font-size:1.8rem}.winner-table,.winner-table thead,.winner-table tbody,.winner-table th,.winner-table td,.winner-table tr{display:block}.winner-table thead tr{position:absolute;top:-9999px;left:-9999px}.winner-table tr{border:1px solid #e2e8f0;margin-bottom:1rem;border-radius:8px;background:#fff;box-shadow:0 2px 4px #0000000d}.winner-table td{border:none;border-bottom:1px solid #eee;position:relative;padding-left:50%;text-align:right}.winner-table td:before{position:absolute;top:1rem;left:1rem;width:45%;padding-right:10px;white-space:nowrap;text-align:left;font-weight:700;color:#718096}.winner-table td:nth-of-type(1):before{content:"序號"}.winner-table td:nth-of-type(2):before{content:"工號"}.winner-table td:nth-of-type(3):before{content:"姓名"}.winner-table td:nth-of-type(4):before{content:"部門"}}.export-canvas-1920{position:fixed;top:-9999px;left:-9999px;width:1920px;height:1080px;background:linear-gradient(135deg,#667eea,#764ba2);padding:60px;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center}.export-canvas-1920 .prize-list-card{width:100%;height:100%;max-width:100%;box-shadow:none;display:flex;flex-direction:column;border-radius:24px}.export-canvas-1920 .card-header{flex:0 0 auto;padding:40px}.export-canvas-1920 .card-header h1{font-size:3.5rem;margin-bottom:1rem}.export-canvas-1920 .subtitle{font-size:1.8rem}.export-canvas-1920 .card-body{flex:1 1 auto;padding:40px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start}.export-canvas-1920 .winner-table{display:flex;flex-wrap:wrap;align-content:flex-start;border:none}.export-canvas-1920 .winner-table thead{display:none}.export-canvas-1920 .winner-table tbody{display:contents}.export-canvas-1920 .winner-table tr{display:flex;flex:0 0 33.33%;padding:15px;box-sizing:border-box;border-bottom:1px solid #eee;align-items:center;background:transparent}.export-canvas-1920 .winner-table td{border:none;font-size:2.1rem;padding:5px 10px}.export-canvas-1920 .card-footer{flex:0 0 auto;font-size:2rem;padding:30px}.card-footer p{margin:0}.app{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif}body{margin:0;padding:0;background-color:#f0f2f5}.home-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.home-container h1{color:#2c3e50;margin-bottom:3rem;font-size:2.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.entry-cards{display:flex;gap:2rem;padding:1rem}.entry-card{background:#fff;padding:3rem;border-radius:20px;text-decoration:none;color:#2c3e50;text-align:center;transition:all .3s ease;box-shadow:0 10px 20px #0000001a;width:250px;display:flex;flex-direction:column;align-items:center}.entry-card:hover{transform:translateY(-10px);box-shadow:0 15px 30px #0003}.entry-card .icon{font-size:4rem;margin-bottom:1rem}.entry-card h2{margin:.5rem 0;font-size:1.8rem}.entry-card p{color:#7f8c8d;margin:0}.entry-card.drawing{border-bottom:5px solid #667eea}.entry-card.admin{border-bottom:5px solid #764ba2}.access-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d3748,#1a202c);padding:1rem}.gate-card{background:#fff;padding:2.5rem;border-radius:16px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px;text-align:center}.gate-card h1{margin:0 0 .5rem;color:#2d3748;font-size:1.8rem}.gate-card p{color:#718096;margin:0 0 2rem}.gate-card input{width:100%;padding:.8rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1.1rem;margin-bottom:1rem;outline:none;transition:all .2s;box-sizing:border-box}.gate-card input:focus{border-color:#667eea}.gate-card input.error{border-color:#e53e3e;background-color:#fff5f5}.gate-card .error-text{color:#e53e3e;font-size:.9rem;margin-top:-.5rem;margin-bottom:1rem;text-align:left}.gate-card button{width:100%;padding:.8rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:background .2s}.gate-card button:hover{background:#5a67d8}
