*{box-sizing:border-box;margin:0;padding:0}:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-weight:400;line-height:1.5}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}#root{width:100%;min-height:100vh}button,input{font-family:inherit}.app{background:url(/assets/bg-mobile.png) 50%/cover no-repeat fixed;min-height:100vh;position:relative;overflow-x:hidden}.background-overlay{z-index:0;pointer-events:none;background:radial-gradient(circle at top,#e6f3ffcc 0%,#b3d9ff99 100%);width:100%;height:100%;position:fixed;top:0;left:0}.header{z-index:10;background:#fff;border-radius:40px;justify-content:space-between;align-items:center;max-width:1400px;margin:20px auto 0;padding:1rem 1.5rem;display:flex;position:relative;box-shadow:0 0 0 3px #0053df26,0 0 15px #0053df1a}.logo-container{background:0 0;align-items:center;gap:.5rem;padding:0;display:flex}.logo-img{object-fit:contain;width:auto;height:48px}.logo-desktop{display:block}.logo-mobile{display:none}.logo-text{color:#333;letter-spacing:.05em;font-size:1.25rem;font-weight:700}.header-buttons{gap:.75rem;display:flex}.btn-search,.btn-login,.btn-register{cursor:pointer;letter-spacing:.05em;border:none;border-radius:12px;align-items:center;gap:.5rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.btn-search-form{color:#4a90e2;cursor:pointer;letter-spacing:.05em;white-space:nowrap;background:#fff;border:2px solid #4a90e2;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;margin-left:auto;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .3s;display:inline-flex}.btn-search-form:hover{background:#f0f7ff;transform:translateY(-2px);box-shadow:0 4px 12px #4a90e24d}.btn-search-form svg{flex-shrink:0;width:16px;height:16px}.btn-login{color:#fff;background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);box-shadow:0 4px 12px #4a90e24d}.btn-login:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4a90e266}.btn-register{color:#4a90e2;background:#fff;border:2px solid #4a90e2}.btn-register:hover{background:#f0f7ff;transform:translateY(-2px)}.main-content{z-index:10;flex-direction:column;align-items:center;gap:2rem;max-width:1400px;margin:0 auto;padding:2rem 1.5rem;display:flex;position:relative}.btn-logout-top{color:#f449;cursor:pointer;z-index:20;opacity:.7;background:#fffc;border:1px solid #f446;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:.5rem;transition:all .3s;display:flex;position:absolute;top:0;right:1.5rem}.btn-logout-top:hover{color:#f44;opacity:1;background:#fff5f5f2;border-color:#f44c;transform:translateY(-1px)}.btn-logout-top svg{flex-shrink:0;width:20px;height:20px}.title-banner{text-align:center;z-index:5;justify-content:center;align-items:center;width:100%;margin:1rem 0;display:flex;position:relative}.banner-image{object-fit:contain;max-width:100%;height:auto;display:block}.banner-desktop{display:none}.banner-mobile{display:block}.countdown-label{color:#fff;letter-spacing:.05em;font-size:clamp(.875rem,2vw,1.125rem);font-weight:600}.countdown-time{color:#fff;letter-spacing:.1em;font-family:Courier New,monospace;font-size:clamp(1.125rem,3vw,1.5rem);font-weight:700}.form-container{z-index:5;background:#fff;border:3px solid #4a90e2;border-radius:24px;width:100%;max-width:600px;padding:60px 0 0;position:relative;overflow:visible;box-shadow:0 8px 32px #00000026}.form-title-wrapper{z-index:1;background:0 0;justify-content:center;align-items:center;margin:0;display:flex;position:absolute;top:-15px;left:50%;transform:translate(-50%)}.form-title-background{object-fit:contain;z-index:0;width:auto;height:auto;max-height:120px;display:block;position:relative}.form-title-bg-desktop{display:block}.form-title-bg-mobile{display:none}.form-title-content{z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.form-title-text{color:#fff;letter-spacing:.1em;text-shadow:2px 2px 4px #00000080;text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;width:100%;font-size:clamp(1.125rem,2.5vw,1.5rem);font-weight:700;display:flex}.form-title-text>span{text-shadow:2px 2px 4px #00000080}.form-content-wrapper{padding:2rem}.prediction-form{flex-direction:column;gap:1.5rem;padding:2rem;display:flex}.input-group{align-items:stretch;gap:.75rem;display:flex}.input-wrapper{background:#fff;border:2px solid #4a90e2;border-radius:12px;flex:1;align-items:center;padding:.75rem 1rem;display:flex;position:relative}.input-icon{flex-shrink:0;margin-right:.75rem}.input-field{color:#333;background:0 0;border:none;outline:none;flex:1;font-size:1rem}.input-field::placeholder{color:#999}.btn-history{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);border:none;border-radius:12px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .3s}.btn-history:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4a90e24d}.date-info{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;font-size:1rem;display:flex}.date-label{color:#666}.date-value{color:#4a90e2;font-weight:600}.instruction-text{color:#333;text-align:center;margin:0;font-size:1.125rem;font-weight:600}.number-inputs{justify-content:center;gap:1rem;display:flex}.number-input{text-align:center;color:#4a90e2;border:3px solid #4a90e2;border-radius:16px;outline:none;width:80px;height:80px;font-size:2rem;font-weight:700;transition:all .3s}.number-input:focus{border-color:#357abd;transform:scale(1.05);box-shadow:0 0 0 4px #4a90e233}.number-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.number-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.number-input{-moz-appearance:textfield}.btn-submit{color:#fff;letter-spacing:.05em;cursor:pointer;background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);border:none;border-radius:16px;width:100%;padding:1rem 2rem;font-size:1.125rem;font-weight:700;transition:all .3s;box-shadow:0 4px 16px #4a90e24d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.btn-submit:active{transform:translateY(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.verify-form-wrapper{width:100%}.prediction-form{padding:2rem}.verify-actions{gap:1rem;margin-top:1rem;display:flex}.btn-cancel{color:#4a90e2;letter-spacing:.05em;cursor:pointer;background:#fff;border:2px solid #4a90e2;border-radius:16px;flex:1;padding:1rem 2rem;font-size:1.125rem;font-weight:700;transition:all .3s}.btn-cancel:hover{background:#f0f7ff;transform:translateY(-2px)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed;transform:none}.user-info{background:linear-gradient(135deg,#e6f3ff 0%,#f0f7ff 100%);border:2px solid #4a90e2;border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;font-size:1rem;display:flex}.user-info-left{flex:1;align-items:center;gap:.5rem;display:flex}.user-label{color:#666;font-weight:500}.user-value{color:#4a90e2;font-weight:700}.btn-logout{color:#f44;cursor:pointer;background:#fff;border:2px solid #f44;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:.5rem;transition:all .3s;display:flex}.btn-logout:hover{background:#fff5f5;transform:translateY(-2px);box-shadow:0 4px 12px #ff44444d}.btn-logout svg{flex-shrink:0;width:18px;height:18px}.remaining-text{text-align:center;color:#666;margin:0;padding-top:.5rem;font-size:.875rem}.remaining-text strong{color:#4a90e2;font-size:1rem}.model-container{z-index:9999;pointer-events:none;display:none;position:fixed;bottom:0;left:calc(50% - 600px)}.model-image{object-fit:contain;filter:drop-shadow(0 -4px 20px #0000004d);width:auto;max-height:600px}@media (max-width:1023px){.countdown-container{clip-path:polygon(0 0,calc(100% - 20px) 0,100% 100%,20px 100%);background:linear-gradient(135deg,#87ceeb 0%,#4a90e2 100%);border-radius:12px;padding:.875rem 2rem;box-shadow:0 4px 16px #4a90e24d}.countdown-wrapper{min-width:auto;min-height:auto}.countdown-background{display:none}.countdown-content{padding:0;position:static}}@media (min-width:1024px){.app{background-image:url(/assets/bg-pc.png)}.main-content{flex-direction:column;justify-content:flex-start;align-items:center;padding:3rem 2rem;position:relative}.form-container{z-index:10;width:100%;max-width:500px;margin:2rem auto 0;position:relative}.model-container{display:block}.title-banner{width:100%;max-width:900px;margin-bottom:2rem;position:relative}.banner-desktop{display:block}.banner-mobile{display:none}.form-container{padding-top:40px}.form-title-background{max-height:140px}.form-title-text{font-size:1.5rem}.countdown-label,.countdown-time{font-size:1.125rem}}@media (max-width:768px){.header{padding:.75rem 1rem}.logo-text{font-size:1rem}.btn-login,.btn-register{padding:.5rem 1rem;font-size:.75rem}.main-content{gap:1.5rem;padding:1.5rem 1rem}.form-container{border-radius:20px;padding:1.5rem}.input-group{flex-direction:column}.number-input{width:70px;height:70px;font-size:1.75rem}.form-container{padding-top:50px}.logo-desktop{display:none}.logo-mobile{display:block}.form-title-bg-desktop{display:none}.form-title-bg-mobile{display:block}.form-title-wrapper{top:-10px}.form-title-background{max-height:100px}.form-title-text{font-size:1rem}.countdown-label,.countdown-time{font-size:.875rem}.prediction-form{padding:1.5rem}.user-info{flex-direction:row;align-items:stretch;gap:.75rem}.btn-logout{width:36px;height:36px}.date-info{flex-direction:row;align-items:flex-start;gap:.75rem}.btn-search-form{justify-content:center;width:100%;margin-left:0}.btn-logout-top{width:36px;height:36px;top:.5rem;right:1rem}.btn-logout-top svg{width:18px;height:18px}}@media (max-width:480px){.header-buttons{gap:.5rem}.btn-login,.btn-register{padding:.5rem .875rem;font-size:.7rem}.logo-container{padding:.4rem .75rem}.logo-img{width:unset;height:auto}.logo-text{font-size:.875rem}.form-container{padding:1.25rem}.number-input{width:60px;height:60px;font-size:1.5rem}.instruction-text{font-size:1rem}}.history-modal-overlay{z-index:10000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.history-modal{background:#fff;border-radius:24px;flex-direction:column;width:100%;max-width:800px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 8px 32px #0000004d}.history-modal-header{background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);border-bottom:2px solid #e0e0e0;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.history-modal-title{color:#fff;letter-spacing:.05em;margin:0;font-size:1.5rem;font-weight:700}.history-modal-close{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:2rem;font-weight:300;line-height:1;transition:all .3s;display:flex}.history-modal-close:hover{background:#fff3;transform:rotate(90deg)}.history-modal-content{flex:1;padding:2rem;overflow-y:auto}.history-filters{background:#f5f7fa;border-radius:12px;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;display:flex}.filter-group{flex-direction:column;gap:.75rem;display:flex}.filter-label{color:#333;font-size:.95rem;font-weight:600}.filter-options{flex-wrap:wrap;gap:1.5rem;display:flex}.filter-option{cursor:pointer;color:#555;align-items:center;gap:.5rem;font-size:.95rem;display:flex}.filter-option input[type=radio]{cursor:pointer;accent-color:#4a90e2;width:18px;height:18px}.filter-input{border:2px solid #4a90e2;border-radius:8px;outline:none;width:100%;max-width:400px;padding:.75rem 1rem;font-size:1rem;transition:all .3s}.filter-input:focus{border-color:#357abd;box-shadow:0 0 0 3px #4a90e233}.history-table-container{border:2px solid #e0e0e0;border-radius:12px;overflow-x:auto}.history-table{border-collapse:collapse;background:#fff;width:100%}.history-table thead{background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%)}.history-table th{text-align:left;color:#fff;letter-spacing:.05em;white-space:nowrap;padding:1rem;font-size:.95rem;font-weight:600}.history-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background .2s}.history-table tbody tr:hover{background:#f5f7fa}.history-table tbody tr:last-child{border-bottom:none}.history-table td{color:#333;padding:1rem;font-size:.95rem}.no-data{text-align:center;color:#999;font-style:italic;padding:2rem!important}@media (max-width:768px){.history-modal{max-width:95%;max-height:95vh}.history-modal-header{padding:1rem 1.5rem}.history-modal-title{font-size:1.25rem}.history-modal-content{padding:1.5rem}.history-filters{padding:1rem}.filter-options{flex-direction:column;gap:.75rem}.history-table th,.history-table td{padding:.75rem .5rem;font-size:.875rem}}
