@charset "UTF-8";: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}*{margin:0;box-sizing:border-box;font-family:Pretendard}body{background-color:#fff;color:#111;min-height:100svb}button:focus{outline:none}.desktop-message{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f8f9fa;width:100vw}.desktop-container{display:flex;flex-direction:column;max-width:1200px;width:90%;min-height:80vh}.desktop-header{background-color:#fff;padding:20px;border-radius:12px;margin-bottom:24px;box-shadow:0 4px 12px #0000000d;text-align:center}.desktop-logo{max-width:200px;height:auto}.message-container{background-color:#fff;padding:60px 40px;border-radius:16px;box-shadow:0 8px 24px #0000001a;text-align:center;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.mobile-illustration{margin-bottom:32px}.phone-icon{font-size:72px;display:inline-block}.message-container h2{font-size:32px;font-weight:700;margin-bottom:16px;color:#333}.message-container p{font-size:18px;color:#666;line-height:1.5;margin-bottom:8px;max-width:400px}.qr-placeholder{width:auto;height:auto;margin-top:40px;padding:20px;border:1px dashed #ddd;border-radius:8px}.qr-text{margin-bottom:16px!important;font-size:16px!important;color:#888!important}.qr-code{width:10vw;height:10vw;background:#eee;margin:0 auto;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;color:#999;border:1px solid #ddd}.mobile-container{max-width:430px;min-height:100svb;margin:0 auto;background-color:#fff;color:#111;box-shadow:0 0 10px #0000001a;position:relative;overflow:hidden;width:100vw}@media (max-width: 600px){.mobile-container{max-width:100vw;min-width:0;min-height:0;box-shadow:none;border-radius:0}.home-screen,.fourcut-app,.mbti-app{height:auto;min-height:100vh}}.home-screen,.fourcut-app,.mbti-app{background:#fff;color:#111}.header-container{line-height:0}.header-container img{width:100vw}.logo-container{display:flex;align-items:center}.logo-container h2{font-size:28px;font-weight:700;margin-right:10px}.logo-image{width:40px;height:40px;border-radius:50%;object-fit:cover}.menu-list{padding:32px 24px 21px;flex:1}.menu-list .main-message h1{font-size:24px;font-weight:400;margin-bottom:4px}.menu-list .main-message h2{font-size:24px;font-weight:700}.menu-list .menu-items{display:flex;flex-direction:column;gap:16px;padding-top:24px}.menu-list .menu-items .menu-item{display:flex;background:#fff;align-items:center;padding:14px 16px;background-color:#fff;border-radius:8px;box-shadow:0 0 4px #0000001a;text-decoration:none;border:1px solid #e8e8e8;color:#464c52;position:relative}.menu-list .menu-items .menu-item .emoji{font-size:16px;margin-right:8px}.menu-list .menu-items .menu-item .arrow{position:absolute;right:15px;color:#999}.footer-info{padding:0 20px 20px}.fourcut-header{display:flex;height:56px;padding:16px 20px;justify-content:center;align-items:center;flex-shrink:0;border-bottom:1px solid #eee}.back-button{background:none;border:none;font-size:20px;margin-right:15px;cursor:pointer;min-width:44px;min-height:44px}.header-title{flex:1;text-align:center;font-size:16px}.menu-button{background:none;border:none;font-size:20px;cursor:pointer}.question-title{font-size:18px;font-weight:700;margin-bottom:20px;text-align:center}.options-container{display:flex;flex-wrap:wrap;justify-content:space-between;gap:15px;margin-top:20px}.option-card{width:calc(50% - 10px);background-color:#fff;border:1px solid #eee;border-radius:10px;padding:15px;text-align:center;cursor:pointer;transition:all .3s ease}.option-card.selected{border:2px solid #4caf50;box-shadow:0 0 5px #4caf5080}.option-card img{max-width:100%;height:auto;margin-bottom:10px}.option-card h3{font-size:14px;margin-bottom:5px}.option-card p{font-size:12px;color:#666}.navigation-buttons{display:flex;justify-content:center;padding:20px 0;margin-top:auto}.nav-button{padding:14px 24px;background-color:#4caf50;color:#fff;border:none;border-radius:8px;font-size:18px;cursor:pointer;margin:0 10px;min-width:44px;min-height:44px}.nav-button:disabled{background-color:#ccc;cursor:not-allowed}.question-counter{padding:8px 15px;background-color:#f0f0f0;border-radius:20px;font-size:14px;color:#666}.camera-prep-screen{padding:0;display:flex;flex-direction:column;flex:1}.screen-title{font-size:20px;font-weight:700;margin-bottom:20px;text-align:center}.camera-screen{flex:1;display:flex;flex-direction:column;min-height:100vh}@media (max-width: 600px){.camera-screen{min-height:100vw;width:100vw;padding:0}}.video-container{flex:1;overflow:hidden;position:relative;background-color:#000}.photo-counter{position:absolute;top:15px;right:15px;background-color:#00000080;color:#fff;padding:5px 10px;border-radius:20px;font-size:14px}.photo-thumbnails{display:flex;padding:10px;background-color:#f8f9fa;overflow-x:auto}.thumbnail{width:60px;height:60px;border-radius:5px;overflow:hidden;margin-right:10px;border:2px solid #4caf50}.camera-buttons{padding:15px;text-align:center;background-color:#f8f9fa}.capture-button{padding:12px 30px;background-color:#4caf50;color:#fff;border:none;border-radius:30px;font-size:16px;cursor:pointer}.loading-spinner{display:flex;justify-content:center;align-items:center;height:150px}.spinner{border:4px solid rgba(0,0,0,.1);border-left-color:#4caf50;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-screen{padding:20px;text-align:center;flex:1;display:flex;flex-direction:column}.result-image{max-width:100%;border-radius:10px;margin:20px 0;box-shadow:0 4px 10px #0000001a}.result-type{font-size:48px;font-weight:700;margin:20px 0;color:#4caf50;letter-spacing:5px}.result-title{font-size:18px;margin-bottom:15px;color:#333}.result-description{font-size:16px;line-height:1.6;color:#555;margin-bottom:30px;padding:0 10px}.share-buttons{display:flex;justify-content:center;gap:15px;margin-top:auto;padding-bottom:20px}.share-button{padding:10px 15px;background-color:#f0f0f0;border:none;border-radius:5px;font-size:14px;cursor:pointer;display:flex;align-items:center;text-decoration:none;color:#333}.share-button svg{margin-right:5px}.countdown-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;background-color:#0000004d;z-index:10}.countdown-number{font-size:120px;color:#fff;font-weight:700;text-shadow:2px 2px 8px rgba(0,0,0,.8)}.photo-preview{width:100%;position:relative}.video-container{position:relative;width:100%}.camera-error{background-color:#ffebee;border:1px solid #f44336;color:#d32f2f;padding:20px;border-radius:10px;margin:20px 0;text-align:center}.camera-error .error-icon{font-size:40px;margin-bottom:10px}.camera-error h3{margin-bottom:10px}.camera-error p{font-size:14px;color:#d32f2f}.debug-info{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:10px;margin:10px 0;font-size:12px;text-align:left;max-height:200px;overflow-y:auto}@font-face{font-family:Pretendard;font-weight:100;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Thin.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Thin.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Thin.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:200;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-ExtraLight.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-ExtraLight.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-ExtraLight.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:300;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Light.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Light.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Light.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:400;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Regular.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Regular.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Regular.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:500;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Medium.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Medium.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Medium.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:600;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-SemiBold.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-SemiBold.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-SemiBold.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:700;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Bold.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Bold.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Bold.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:800;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-ExtraBold.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-ExtraBold.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-ExtraBold.otf) format("opentype")}@font-face{font-family:Pretendard;font-weight:900;font-style:normal;font-display:swap;src:url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Black.woff2) format("woff2"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Black.woff) format("woff"),url(https://cdn.jsdelivr.net/gh/fonts-archive/Pretendard/Pretendard-Black.otf) format("opentype")}.voter-tabs{display:flex;width:100%;background:#fff;height:52px}.voter-tabs button{border-radius:0}.voter-tabs .tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;font-size:16px;color:#666;cursor:pointer;transition:all .3s ease}.voter-tabs .tab.active{color:#000;border-bottom:2px solid #1d1b1b;font-weight:500}.voter-tabs .tab:hover:not(.active){color:#333;background:#f8f9fa}.page-header{display:flex;align-items:center;height:56px;padding:0 16px;background-color:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:10;width:100%;position:relative}.page-header .back-button{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:absolute;left:16px}.page-header .back-button .back-arrow{font-size:18px;font-weight:500;color:#333}.page-header .header-title{font-size:16px;font-weight:500;color:#333;width:100%;text-align:center}.cta-button{display:flex;height:48px;align-items:center;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;text-align:center;width:100%;justify-content:center;transition:all .2s ease;color:#13f739}.cta-button.primary{background:#1d1b1b;border:1px solid #d5d5d5}.cta-button.secondary{background-color:#fff;color:#1d1b1b;border:1px solid #d5d5d5}.cta-button:hover{opacity:.9}.cta-button.floating{position:fixed;bottom:0;left:0;z-index:1000;box-shadow:0 -5px 10px #0000000d;border-radius:0;margin-top:0}.app-footer{position:fixed;bottom:0;left:0;width:100%;background:#fff;padding:20px 24px 40px;box-shadow:0 -5px 10px #0000000d;z-index:100;border-radius:14px 14px 0 0}.kakao-logo-container{position:fixed;right:20px;bottom:120px;cursor:pointer;transition:transform .2s ease;z-index:101}.kakao-logo-container:hover{transform:scale(1.05)}.kakao-logo-container:active{transform:scale(.95)}.kakao-footer-logo{width:63px;height:63px;border-radius:100%;box-shadow:0 0 10px #fff6 inset,0 4px 4px #00000040}.new-voter{padding:0;min-height:100vh;width:100%}.new-voter .voter-content{display:flex;flex-direction:column;justify-content:center;align-items:center}.new-voter .voter-header{width:100vw;height:228px;text-align:left;position:relative;padding:32px 24px 0;background-image:url(/images/chamchi_man.png);background-size:cover;background-repeat:no-repeat;background-position:center}.new-voter .voter-header h1{font-size:20px;font-weight:700;margin-bottom:22px}.new-voter .voter-header p{font-size:16px;color:#3a3a3a;line-height:1.5;margin-bottom:18px}.new-voter .voter-header .more-info{display:flex;float:inline-end;gap:4px;align-items:center;background-color:#fff;padding:0 8px 0 12px;height:36px;border-radius:8px;cursor:pointer;box-shadow:0 0 4px #0000001a;border:1px solid #e8e8e8}.new-voter .voter-header .more-info p{margin-bottom:0;font-size:14px;font-weight:500;color:#464c52}.new-voter .voter-header:after{content:"";position:absolute;right:0;top:0;width:120px;height:120px;background-size:contain;background-repeat:no-repeat}.new-voter .voting-method{width:100%;padding:32px 24px}.new-voter .section-title{font-size:20px;font-weight:700;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between}.new-voter .section-title .link{font-size:14px;color:#666;font-weight:400}.new-voter .step-section{background:#fff;border-radius:12px;margin-bottom:24px}.new-voter .step-section .step-header{display:flex;align-items:center;margin-bottom:16px}.new-voter .step-section .step-label{font-size:12px;color:#13f739;font-weight:500;margin-right:8px;padding:4px 8px;background:#1d1b1b;border-radius:6px}.new-voter .step-section .step-title{font-size:14px;font-weight:600}.new-voter .step-section .step-content .info-title{font-size:16px;color:#1db177;font-weight:600;margin-bottom:12px}.new-voter .step-section .step-content ul{list-style:none;padding-left:0;margin-bottom:16px}.new-voter .step-section .step-content ul li{position:relative;padding-left:12px;margin-bottom:8px;font-size:14px;color:#333}.new-voter .step-section .step-content ul li:before{content:"•";position:absolute;left:0;color:#1db177}.new-voter .step-section .step-content .info-note{background:#f8f9fa;padding:16px;border-radius:8px;font-size:14px;color:#666;line-height:1.6}.new-voter .step-section .step-content .button-group{display:flex;justify-content:space-between;align-items:center}.new-voter .step-section .step-content .button-group a{width:calc(50% - 6px)}.new-voter .step-section .step-content .button-group .find-button{flex:1;height:40px;padding:0 8px 0 12px;border:none;font-size:14px;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%;border:1px solid #e8e8e8;background:#fff;box-shadow:0 0 4px #0000001a;color:#464c52}.new-voter .step-section .step-content .voting-cards .voting-card{background:#f8f9fa;border-radius:8px;margin-bottom:12px;overflow:hidden}.new-voter .step-section .step-content .voting-cards .voting-card .card-header{padding:16px;display:flex;align-items:center;background:#fff}.new-voter .step-section .step-content .voting-cards .voting-card .card-header .card-number{color:#1db177;font-weight:600;margin-right:12px;font-size:14px}.new-voter .step-section .step-content .voting-cards .voting-card .card-header .card-title{font-size:15px;font-weight:500;color:#333}.new-voter .step-section .step-content .voting-cards .voting-card .card-content{padding:16px;margin:0}.new-voter .step-section .step-content .voting-cards .voting-card .card-content li{margin-bottom:8px;font-size:14px;color:#666;line-height:1.6}.new-voter .step-section .step-content .voting-cards .voting-card .card-content li:last-child{margin-bottom:0}.new-voter .step-section .step-content .more-info-link{margin-top:16px;font-size:14px;color:#666;text-align:right}.new-voter .step-section .step-content .ballot-criteria-container{margin:-12px 0 12px;background:#f8f9fa;border-radius:8px;padding:0 16px 12px}.new-voter .step-section .step-content .ballot-criteria-link{display:inline-block;font-size:14px;color:#626262;font-weight:500;cursor:pointer;text-decoration:none}.new-voter .divider{height:1px;background-color:#f5f5f5;width:100%;margin:28px 0}.new-voter .voting-caution{padding:20px}.new-voter .voting-caution .warning-list .warning-item{background:#fff5f5;border-radius:8px;padding:16px;margin-bottom:12px;display:flex;align-items:flex-start}.new-voter .voting-caution .warning-list .warning-item .warning-icon{width:20px;height:20px;min-width:20px;background:#ff4d4f;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;margin-right:12px;margin-top:2px}.new-voter .voting-caution .warning-list .warning-item .warning-content{flex:1}.new-voter .voting-caution .warning-list .warning-item .warning-content .warning-title{font-weight:600;margin-bottom:4px;color:#ff4d4f}.new-voter .voting-caution .warning-list .warning-item .warning-content .warning-text{font-size:14px;color:#666;line-height:1.5}.new-voter .voting-caution .warning-list .warning-item .warning-content .warning-text .warning-bullet{position:relative;padding-left:12px;margin-bottom:8px}.new-voter .voting-caution .warning-list .warning-item .warning-content .warning-text .warning-bullet:before{content:"•";position:absolute;left:0;color:#ff4d4f}.new-voter .voting-caution .warning-list .warning-item .warning-content .warning-text .warning-bullet:last-child{margin-bottom:0}.fourcut-container{width:100%;min-height:100vh;background:#fff;color:#111;overflow-y:auto;display:flex;flex-direction:column}.fourcut-content-wrapper{flex:1;display:flex;flex-direction:column;overflow-y:auto}.fourcut-content{padding:0 20px;flex:1;overflow-y:auto}.back-button{background:none;border:none;font-size:20px;cursor:pointer;color:#111}.header-title{margin:0;font-size:18px;color:#111}.question-screen{background-image:url(/images/background/FourCutBackground.png);background-size:cover;background-position:center;background-repeat:no-repeat;padding:0 24px;flex:1;display:flex;flex-direction:column;color:#111}.fourcut-question-title{margin-top:50px;color:#000;font-size:24px;font-weight:400}.fourcut-question-title span{font-weight:700}.four-cut-options-container{display:grid;grid-template-columns:repeat(2,1fr);justify-items:center;gap:20px;margin-top:20px}.four-cut-options-container .option-candidate-name{font-size:18px;font-weight:600;text-align:center}.template-options-container{display:grid;grid-template-columns:repeat(2,1fr);flex-wrap:wrap;justify-content:space-between;gap:15px;margin-top:20px;max-height:calc(100vh - 200px);overflow-y:auto;padding-bottom:20px}.template-options-container:has(>*:only-child){grid-template-columns:1fr;width:150px;margin:20px auto 0}.four-cut-candidate-card{width:100%;height:auto;min-height:150px;border:2px solid #333;border-radius:12px;padding:15px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;background-color:#f9f9f9;box-shadow:0 2px 4px #0000001a}.four-cut-candidate-card.selected{border-color:#111;background:#eee;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.four-cut-candidate-card .option-candidate-name{font-size:18px;font-weight:600;text-align:center;margin-bottom:10px}.four-cut-candidate-card .option-candidate-description{font-size:13px;line-height:1.4;text-align:center;color:#555;margin-top:5px}.template-card{width:100%;border:1px solid #222;background-color:#fff;border-radius:10px;padding:15px;text-align:center;cursor:pointer;transition:all .3s ease;color:#111;flex-shrink:0;max-height:auto;overflow:hidden;display:flex;justify-content:center;align-items:center;flex-direction:column}.template-card.selected{border-color:#111;background:#eee}.template-card img{max-width:100%;height:auto;object-fit:contain}.template-card h3{font-size:14px;margin-bottom:5px}.template-card p{font-size:12px;color:#666}.navigation-buttons{display:flex;justify-content:space-between;margin-top:20px}.nav-button{padding:10px 20px;border:1px solid #111;border-radius:20px;background:#fff;color:#111;cursor:pointer}.nav-button:disabled{background:#ccc;color:#888;border-color:#ccc}.nav-button.primary{background:#111;color:#fff}.nav-button.camera-start-button{width:50vw;height:50px;border-radius:25px;font-weight:600;margin:20px auto;display:flex;justify-content:center;align-items:center}.spinner{border:4px solid #eee;width:36px;height:36px;border-radius:50%;border-left-color:#111;animation:spin 1s linear infinite}.camera-prep-screen{text-align:center}.screen-title{margin-left:20px;margin-bottom:20px;font-size:24px;text-align:left}.four-cut-result-screen-title{margin-left:-20%;margin-bottom:20px;font-size:24px;text-align:left}.instruction-text{margin-top:12px;line-height:1.5;font-size:16px;text-align:left}.template-preview{width:100%;height:auto;margin-bottom:10px;display:flex;justify-content:center;align-items:center}.template-preview img{max-width:100%;height:auto;object-fit:contain}.template-preview-large{margin:0 auto 20px;box-shadow:0 4px 8px #0000001a;background:#eee;width:30%;display:flex;flex-direction:column;align-items:center}.template-preview-large img{max-width:100%;height:auto;object-fit:contain}.template-preview-large p{padding:10px;text-align:center}.camera-screen{width:100%;max-width:375px;min-height:1106px;margin:0 auto;background:#fff;color:#111;position:relative;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.photo-slot{position:absolute;overflow:hidden;background:#222;z-index:2}.photo-slot video,.photo-slot img{position:absolute;width:100%;height:100%;object-fit:cover}.photo-slot video{max-width:100%;max-height:100%}.photo-slot .empty-slot{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffffb3;font-size:16px;background:#22222280}.template-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;pointer-events:none}.countdown-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background-color:#000000b3;z-index:3}.countdown-number{font-size:80px;color:#fff;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.5)}.photo-controls{position:fixed;bottom:0;left:0;right:0;padding:20px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:20;border-top:1px solid rgba(0,0,0,.1)}.photo-counter{font-size:16px;font-weight:600;color:#111;margin-bottom:10px;text-align:center}.photo-thumbnails{display:flex;gap:10px;justify-content:center;margin-top:10px}.thumbnail{width:48px;height:48px;border-radius:8px;overflow:hidden;border:2px solid #111;background:#fff;position:relative}.thumbnail:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;opacity:0;transition:opacity .2s ease}.thumbnail:hover:after{opacity:1}.thumbnail img{width:100%;height:100%;object-fit:cover}.four-cut-result-screen{text-align:center;background:#fff;color:#111;padding:10px;display:flex;flex-direction:column;align-items:center;height:100%}.four-cut-result-screen .event-info{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.four-cut-result-screen .event-info .event-option-wrapper{display:flex;flex-direction:column;gap:10px}.four-cut-result-screen .event-info .event-option-wrapper .event-option{display:flex;align-items:center;gap:10px}.four-cut-result-screen .event-info .event-option-wrapper .event-option .event-option-badge{display:flex;width:54px;height:20px;padding:0 6px;justify-content:center;align-items:center;border-radius:4px;background:#000;color:#13f739;font-size:12px;font-weight:500;line-height:18px}.four-cut-result-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:20px;margin-bottom:10px}.four-cut-result-actions .result-button-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.four-cut-result-actions .result-button{width:28px;height:28px}.final-image-container{width:100%;margin:10px auto;overflow:hidden;display:flex;justify-content:center;align-items:center}.final-image-container img.final-image{max-width:100%;height:auto;object-fit:contain}.result-image{max-width:100%;margin:0 auto 20px;box-shadow:0 4px 8px #2222;border-radius:8px;border:1px solid #111;background:#fff}.share-buttons{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin:20px 0}.share-button{padding:10px 20px;border:1px solid #111;border-radius:20px;background:#fff;color:#111;cursor:pointer;text-decoration:none}.share-button:disabled{background:#ccc;color:#888;border-color:#ccc}.camera-error{text-align:center;padding:20px;border:1px solid #f44336;border-radius:10px;margin:20px;background:#fff;color:#111}.error-icon{font-size:40px;margin-bottom:10px}.camera-error-buttons{display:flex;flex-direction:column;gap:5px;margin-top:20px}.debug-info{background:#f5f5f5;border:1px solid #222;border-radius:4px;padding:10px;margin:10px 0;font-size:12px;text-align:left;max-height:200px;overflow-y:auto;color:#111}.debug-info h4{margin-bottom:10px;color:#333}.debug-info p{margin:5px 0;font-family:monospace}.processing-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:20px;text-align:center;background:#fff;color:#111}.camera-video{width:100%!important;height:100%!important;object-fit:cover!important}.carousel-container{width:100%;display:flex;justify-content:center;align-items:center;position:relative}.fourcut-candidate-carousel{margin-top:94px;position:relative;display:flex;justify-content:center;align-items:center;width:100%;max-width:335px}.candidate-card-wrapper{display:flex;align-items:center;justify-content:center;border:5px solid #0a0a0a;border-radius:28px;box-shadow:0 6px 32px #0000001f;place-self:center;transition:box-shadow .2s,border .2s;margin:0 auto}.candidate-card-frame{background:#fff3;border:none;border-radius:20px;box-shadow:none;padding:32px 24px 24px;display:flex;flex-direction:column;align-items:center;margin:0}.carousel-arrow{position:absolute;margin:0 8px;top:50%;transform:translateY(-50%);z-index:10}.carousel-arrow.left{left:0}.carousel-arrow.right{right:0}@media (max-width: 600px){.carousel-container{width:100%;padding:0 20px}.fourcut-candidate-carousel{display:flex;justify-content:center;align-items:center;width:100%}.candidate-card-wrapper{display:flex;justify-content:center;align-items:center;width:220px;flex:0 0 auto;margin:0 auto;box-shadow:0 0 10px #ffffff80}.candidate-card-wrapper .candidate-info{height:83px;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;border:1px solid rgba(0,140,205,.05);background:#ffffffb3;border-radius:0 0 20px 20px;gap:6px;padding:10.5px 0}.candidate-card-wrapper .candidate-info .candidate-party{display:flex;justify-content:center;align-items:center;height:23px}.candidate-card-wrapper .candidate-info .candidate-party img{height:100%}.candidate-card-wrapper .candidate-info .candidate-name{font-size:18px;font-weight:700;text-align:center;font-size:28px;color:#1d1b1b;line-height:1.2;display:flex;align-items:center;justify-content:center;place-items:anchor-center;gap:6px}.candidate-card-wrapper .candidate-info .candidate-name span{color:#7a7a7a;font-size:16px;font-weight:400}.candidate-card-wrapper .candidate-info .fourcut-candidate-photo{width:100px;height:100px;object-fit:cover;border-radius:0 0 20px 20px}.candidate-card-frame{width:100%;height:294px;padding:8px 0 0;display:flex;flex-direction:column}.candidate-card-frame img{flex:1 1 auto;width:100%;height:calc(100% - 83px);object-fit:contain;display:block}.carousel-arrow{display:flex;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;margin:0;position:absolute;z-index:10}.carousel-arrow.left{left:0}.carousel-arrow.right{right:0}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;padding:24px;border-radius:12px;width:80%;max-width:400px;text-align:center;box-shadow:0 4px 20px #00000026}.modal-content h3{margin-top:0;margin-bottom:16px;font-size:20px;color:#333}.modal-content p{margin-bottom:24px;font-size:16px;line-height:1.5;color:#555}.modal-button{padding:12px 20px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;border:none;margin:0 8px 8px 0;transition:all .2s}.modal-button.primary{background-color:#000;color:#fff}.modal-button:not(.primary){background-color:#f1f1f1;color:#555}.result-actions .result-button.contest{color:#13f739}.custom-footer,.custom-footer .app-footer{padding:20px 24px!important}.kakao-share-template-container{position:fixed;bottom:100px;right:20px;width:63px;height:63px;display:flex;justify-content:center;align-items:center;z-index:100;cursor:pointer;transition:transform .2s ease}.kakao-share-template-container:active{transform:scale(.95)}.kakao-template-share-icon{width:63px;height:63px;border-radius:100%;box-shadow:0 0 10px #fff6 inset,0 4px 4px #00000040}.info-box{background-color:#f5f5f5;border-radius:6px;padding:8px;display:flex;flex-direction:column;margin-top:24px;align-items:flex-start;gap:6px;letter-spacing:.01rem}.info-box .info-box-header{display:flex;align-items:center;gap:4px;align-self:stretch}.info-box .info-box-header img{width:14px;height:14px}.info-box .info-box-header span{font-size:14px;font-weight:500;color:#3177ff}.info-box .info-box-content{padding-left:16px;margin:0;display:flex;flex-direction:column;justify-content:center;align-items:center}.info-box .info-box-content li{margin-bottom:8px;font-size:12px;line-height:1.4;color:#232323;text-align:left}.info-box .info-box-content li::marker{color:#6f7070;font-size:12px;line-height:1}.info-box .info-box-content li:last-child{margin-bottom:0}.info-box h3{font-size:16px;margin-bottom:5px}.info-box p{font-size:14px;color:#666}.mbti-container{width:100%;min-height:100vh;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;display:flex;flex-direction:column}.mbti-content{padding:0;flex:1;display:flex;flex-direction:column}.mbti-question-screen{padding:24px;flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.question-counter{position:absolute;top:16px;right:16px;font-size:14px;font-weight:600;color:#fff;background-color:#222;padding:4px 10px;border-radius:12px}.question-title{font-size:24px;font-weight:700;margin:40px 0 32px;text-align:left;line-height:1.4;word-break:keep-all}.options-container{display:flex;flex-direction:column;gap:12px;margin-top:16px}.option-card{cursor:pointer;transition:all .2s ease;min-height:60px;gap:8px;display:flex;width:100%;height:auto;padding:0 12px;justify-content:space-between;align-items:center;border-radius:8px;border:1px solid #ebebeb;background:#fff;box-shadow:0 0 4px #0000001a}.option-card:hover{border-color:#555}.option-card.selected{border:2px solid #000}.option-card h3{width:80%;text-align:left;font-size:16px;margin:0;color:#000}.option-badge{background-color:#e8f5e9;color:#2e7d32;font-size:12px;font-weight:600;padding:4px 8px;border-radius:4px;display:inline-block;width:fit-content}.navigation-buttons{margin-top:auto;padding:24px 0}.next-button{width:100%;padding:16px;border:none;border-radius:8px;background-color:#000;color:#4caf50;cursor:pointer;font-size:16px;font-weight:600;transition:all .2s ease}.next-button:hover{opacity:.9}.next-button:disabled{background-color:#e0e0e0;cursor:not-allowed}.processing-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:20px;text-align:center}.processing-screen p{margin-top:20px;color:#666}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:20px 0}.spinner{border:4px solid rgba(0,0,0,.1);width:36px;height:36px;border-radius:50%;border-left-color:#4caf50;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.result-screen{text-align:center;padding:0 0 20px;background-image:url(/images/background/MBTIBackground.png);background-size:cover;background-position:center;background-repeat:no-repeat;color:#fff;min-height:100vh;display:flex;flex-direction:column}.result-header{padding:24px 20px;text-align:left}.result-header h2{font-size:16px;font-weight:400;margin:0 0 8px;color:#eee}.result-header h1.result-name{font-size:28px;font-weight:700;margin:0 0 16px}.info-link{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background-color:#ffffff1a;border-radius:8px;margin-top:16px;font-size:14px}.info-link .arrow{font-size:18px}.candidate-cards{display:flex;justify-content:center;align-items:flex-end;gap:16px;padding:0 12px;width:100%;margin:20px 0;position:relative}.candidate-card{width:25vw;height:35vw;flex-shrink:0;border-radius:16px;position:relative;display:flex;flex-direction:column;align-items:center;transition:all .3s ease}.candidate-card.active{width:35vw;height:44vw;z-index:2}.candidate-card .candidate-photo{width:100%;height:70%;object-fit:cover;border-radius:16px 16px 0 0;overflow:hidden}.candidate-card .star-icon{position:absolute;top:-15px;right:-10px;width:30px;height:30px;z-index:3;object-fit:contain}.candidate-card .party-label{width:100%;text-align:center;color:#fff;font-size:10px;padding:2px 0;font-weight:500;background-color:#0003;display:flex;justify-content:center;align-items:center;gap:4px}.candidate-card .party-label img{width:60px}.candidate-card .candidate-name{margin:5px 0 0;font-size:16px;font-weight:700;color:#fff;text-align:center}.candidate-card .candidate-title{font-size:12px;font-weight:400}.match-badge{margin:12px auto;padding:8px 16px;background-color:#4caf50;color:#fff;border-radius:20px;font-size:14px;font-weight:600;width:fit-content}.traits-section{margin-top:32px;padding:0 20px;text-align:left}.traits-section h3{font-size:18px;font-weight:600;margin-bottom:16px}.traits-list{display:flex;gap:10px;flex-wrap:wrap}.trait-badge{padding:10px 20px;background-color:#333;border-radius:50px;font-size:14px;font-weight:500}.match-results{margin-top:32px;padding:0 20px;text-align:left;flex:1}.match-results h3{font-size:18px;font-weight:600;margin-bottom:16px}.candidate-progress{padding:16px;border-radius:12px;border:1px solid #dfdfdf;background:#fff3;box-shadow:0 0 10px #0000000d}.progress-item{display:flex;flex-direction:column;align-items:flex-start;gap:4px;align-self:stretch;margin-bottom:20px}.progress-item:last-child{margin-bottom:0}.progress-item p{font-size:13px;margin:8px 0 0;color:#aaa}.progress-header{display:flex;justify-content:space-between;margin-bottom:8px;font-weight:500}.progress-header span{color:#fff;font-size:16px;font-weight:700;line-height:20px}.progress-bar-container{display:flex;align-items:center;justify-content:center;gap:12px;width:100%}.progress-bar{height:16px;background-color:#0000004d;border-radius:8px;overflow:hidden;width:90%}.progress-percentage{min-width:45px;text-align:right;font-size:14px;color:#fff}.result-actions{padding:20px;display:flex;flex-direction:column;gap:12px}.action-button{padding:16px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer}.action-button.primary{background-color:#4caf50;color:#fff}.action-button.secondary{background-color:#fff;color:#333}.info-icon{position:absolute;top:16px;left:16px;width:24px;height:24px;color:#2196f3}.info-title{font-weight:600;margin-bottom:8px;color:#1976d2}.info-content{color:#555;line-height:1.5;margin-left:16px}@media (max-width: 767px){.question-title{font-size:20px;margin:40px 0 24px}}.progress-fill{height:100%;background-color:#13f739;border-radius:8px;transition:width .3s ease;box-shadow:0 0 8px #13f73980}.progress-fill.secondary{background-color:#fff;box-shadow:0 0 8px #66666680}.mbti-info-box{background:#182135;padding:16px;margin-top:24px}.mbti-info-box .mbti-info-box-header{display:flex;align-items:center;margin-bottom:12px}.mbti-info-box .mbti-info-box-header img{width:20px;height:20px;margin-right:8px}.mbti-info-box .mbti-info-box-header span{font-weight:600;color:#13f739}.mbti-info-box .mbti-info-box-content{padding-left:16px;margin:0}.mbti-info-box .mbti-info-box-content li{margin-bottom:8px;font-size:14px;line-height:1.4;color:#666;text-align:left}.mbti-info-box .mbti-info-box-content li:last-child{margin-bottom:0}
