:root{--cream-base: #F5F0EB;--cream-soft: #FAF7F4;--sand: #E8DDD4;--olive-point: #6B8E7F;--olive-dark: #5A7D6E;--olive-light: #8CA89D;--deep-charcoal: #1A1410;--charcoal-soft: #6B5C4E;--charcoal-muted: #9E8C7E;--white: #FFFFFF;--shadow-sm: 0 2px 8px rgba(107, 142, 127, .1);--shadow-md: 0 8px 24px rgba(107, 142, 127, .15);--shadow-lg: 0 20px 48px rgba(107, 142, 127, .2);--shadow-cta: 0 10px 25px rgba(107, 142, 127, .4);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--mono: "DM Mono", monospace}.vibe-popup-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.vibe-popup-card{background:#f5f0eb;border-radius:24px;padding:32px 24px;max-width:400px;width:90%;text-align:center;animation:slideUp .4s ease}.vibe-popup-eyebrow{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.18em;color:#9c9189;text-transform:uppercase;margin-bottom:20px}.vibe-popup-photos{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px}.vibe-photo{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid rgba(0,0,0,.1)}.vibe-separator{font-family:"DM Serif Display",serif;font-size:24px;color:#6b8e7f}.vibe-popup-name{font-family:"DM Serif Display",serif;font-size:22px;color:#1c1917;margin-bottom:8px}.vibe-popup-desc{font-size:13px;color:#9c9189;margin-bottom:24px}.vibe-popup-btn{width:100%;padding:14px;background:#1c1917;color:#fff;border:none;border-radius:50px;font-family:"DM Serif Display",serif;font-size:16px;cursor:pointer}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--cream-base);color:var(--deep-charcoal);font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased;position:relative}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(var(--deep-charcoal) .5px,transparent .5px);background-size:24px 24px;opacity:.05;pointer-events:none;z-index:0}.app-shell{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;padding-bottom:80px}.topbar{width:100%;max-width:640px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:32px 24px 0}.topbar h1{font-family:"DM Serif Display",serif;font-size:1.5rem;font-weight:400;letter-spacing:-.02em;color:var(--deep-charcoal);cursor:pointer;transition:opacity .2s}.topbar h1:hover{opacity:.7}.header-right{display:flex;align-items:center;gap:16px}.credits-badge{background:linear-gradient(135deg,gold,orange);color:#1a1410;padding:8px 16px;border-radius:20px;font-size:.875rem;font-weight:600;box-shadow:0 2px 8px #ffd7004d;white-space:nowrap}.lang-selector{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.lang-label{font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;color:var(--charcoal-muted);opacity:.5;font-weight:600}.topbar select{border:none;background:transparent;color:var(--charcoal-soft);font-size:.75rem;font-weight:500;padding:0;cursor:pointer;outline:none;font-family:inherit;opacity:.7}.panel{width:100%;max-width:640px;margin:40px auto 0;padding:0 24px;display:flex;flex-direction:column;gap:24px}.intro-panel{justify-content:center;padding-top:40px}.intro-eyebrow{font-size:.625rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--charcoal-soft);opacity:.6;border-left:2px solid var(--olive-point);padding-left:12px;margin-bottom:16px;animation:fadeSlideIn .6s ease-out}.intro-title{font-family:"DM Serif Display",serif;font-size:clamp(1.875rem,5vw,3rem);font-weight:400;line-height:1.15;color:var(--deep-charcoal);margin-bottom:12px;animation:fadeSlideIn .8s ease-out .1s both}.intro-panel .hero-title{font-family:"DM Serif Display","Noto Serif KR",serif;font-size:clamp(38px,9vw,52px);font-weight:400;line-height:1.12;letter-spacing:-.02em;color:#1c1917;margin-bottom:18px;font-family:"DM Serif Display","Noto Serif KR",serif!important}.hero-title-accent{color:#6b8e7f;font-style:normal}.hero-eyebrow{font-family:DM Mono,monospace;font-size:9px;letter-spacing:.22em;color:#6b8e7f;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}.hero-eyebrow:before{content:"";width:18px;height:1px;background:#6b8e7f;display:block}.intro-body{font-size:.875rem;font-weight:400;color:var(--charcoal-soft);line-height:1.65;max-width:360px;margin-bottom:24px;animation:fadeSlideIn .8s ease-out .2s both}.intro-body-line{display:block}.intro-body-line-second{white-space:nowrap;font-size:.8125rem;letter-spacing:-.01em}@media(max-width:390px){.intro-body-line-second{font-size:.75rem}}.intro-disclaimer{font-size:.6875rem;color:var(--charcoal-muted);opacity:.6;text-align:center;max-width:360px;margin-bottom:24px;line-height:1.5;animation:fadeSlideIn .8s ease-out .25s both}.result-disclaimer{font-size:.6875rem;color:var(--charcoal-muted);opacity:.6;text-align:center;max-width:360px;margin:24px auto;line-height:1.5}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.decorative-frame{position:relative;width:100%;height:176px;border:1px solid rgba(26,20,16,.1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:32px;animation:fadeSlideIn .8s ease-out .3s both}.decorative-frame:before{content:"";position:absolute;inset:16px;border:1px solid rgba(26,20,16,.05);pointer-events:none}.decorative-frame svg{opacity:.2;width:100px;height:100px;animation:gentleRotate 20s linear infinite}@keyframes gentleRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tries-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffff80;border:1px solid rgba(26,20,16,.05);border-radius:var(--radius-full);padding:6px 16px;font-size:.75rem;font-weight:500;color:var(--deep-charcoal);margin-bottom:24px;animation:fadeSlideIn .8s ease-out .4s both}.tries-badge strong{color:var(--olive-point);font-weight:700}.daily-counter{background:#ffffff8f;border:1px solid rgba(26,20,16,.08);border-radius:14px;padding:10px 12px;margin-bottom:14px}.daily-counter-line{font-size:.8rem;color:var(--deep-charcoal);line-height:1.4;white-space:pre-line}.daily-counter-boost{margin-top:6px;font-size:.72rem;color:var(--olive-dark);font-weight:600}.status-wrap{margin-top:18px}.status-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 4px}.tries-wrap{display:flex;align-items:center;gap:8px}.tries-label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:#9c9189;text-transform:uppercase}.tries-dots{display:flex;gap:4px}.try-dot{width:6px;height:6px;border-radius:50%;background:#6b8e7f}.try-dot.used{background:#0000001a}.tries-count{font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:#9c9189}.early-wrap{position:relative;border:1px solid rgba(107,142,127,.2);border-radius:12px;padding:12px 14px;background:#6b8e7f0d;overflow:hidden}.early-wrap:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2.5px;background:#6b8e7f;border-radius:2px 0 0 2px}.early-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}.early-badge{display:flex;align-items:center;gap:5px}.early-dot{width:5px;height:5px;border-radius:50%;background:#6b8e7f;animation:pulse 2s ease infinite}.early-badge-text{font-family:var(--mono);font-size:9px;letter-spacing:.16em;color:#6b8e7f;text-transform:uppercase}.early-dday{font-family:"DM Serif Display",serif;font-size:13px;font-weight:500;color:#1c1917}.early-dday span{color:#6b8e7f}.early-msg{font-family:var(--mono);font-size:10px;line-height:1.7;color:#9c9189;letter-spacing:.04em}.early-msg strong{color:#1c1917;font-weight:500}.early-timeline{display:flex;align-items:center;margin-top:10px}.timeline-item{flex:1;text-align:center}.timeline-label{font-family:var(--mono);font-size:8px;letter-spacing:.1em;color:#9c9189;text-transform:uppercase;display:block;margin-bottom:4px}.timeline-val{font-family:var(--mono);font-size:12px;font-weight:400;color:#1c1917;display:block;letter-spacing:.04em}.timeline-val.active{color:#6b8e7f}.timeline-arrow{font-size:9px;color:#0003;padding:12px 4px 0}.progress-row{display:flex;align-items:center;gap:8px;margin-top:10px}.progress-bar{flex:1;height:2px;background:#00000012;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#6b8e7f,#8faf9f);border-radius:2px;transition:width 1s linear}.progress-timer{font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:#9c9189;min-width:80px;text-align:right}.btn-primary{display:block;width:100%;padding:20px 32px;background:var(--olive-point);color:var(--white);border:none;border-radius:var(--radius-xl);font-family:inherit;font-size:1.125rem;font-weight:700;letter-spacing:-.01em;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-cta);animation:fadeSlideIn .8s ease-out .5s both}.btn-primary:hover{background:var(--olive-dark);transform:translateY(-3px);box-shadow:0 15px 40px #6b8e7f80}.btn-primary:active{transform:translateY(-1px) scale(.98)}.filters-card{background:#ffffff4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(26,20,16,.05);border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:16px}.filter-row{display:flex;align-items:center;justify-content:space-between}.filter-label{font-size:.875rem;color:var(--charcoal-muted);font-weight:500}.filter-select{border:1px solid var(--sand);border-radius:var(--radius-full);background:var(--white);color:var(--deep-charcoal);font-size:.875rem;padding:8px 16px;outline:none;cursor:pointer;font-family:inherit;transition:border-color .2s;font-weight:500}.filter-select:focus{border-color:var(--olive-point)}.filter-value-display{font-size:.875rem;font-weight:600;color:var(--deep-charcoal);padding:8px 16px;background:#6b8e7f1a;border-radius:var(--radius-full);border:1px solid rgba(107,142,127,.2)}.camera-wrap{position:relative;width:100%;aspect-ratio:3 / 4;border-radius:var(--radius-lg);overflow:hidden;background:var(--deep-charcoal);box-shadow:var(--shadow-lg);border:1px solid rgba(26,20,16,.1)}.camera{width:100%;height:100%;object-fit:cover;display:block}.camera-overlay{position:absolute;inset:0;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.05);pointer-events:none}.camera-guide{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:55%;aspect-ratio:3 / 4;border:2px solid rgba(255,255,255,.2);border-radius:50%/60%;pointer-events:none}.app-shell.camera-mode{width:100%;height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:#000;padding:0}.camera-page{position:relative;flex:1;min-height:0;overflow:hidden;background:#000}.camera-stage{position:relative;width:100%;height:100%;overflow:hidden}.camera-full{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.camera-back-btn{position:absolute;top:calc(4px + env(safe-area-inset-top));left:8px;z-index:20;height:48px;padding:0 12px;border:0;background:transparent;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer}.camera-mirror-btn{position:absolute;top:calc(4px + env(safe-area-inset-top));right:8px;z-index:20;height:36px;padding:0 12px;border:1px solid rgba(255,255,255,.5);border-radius:999px;background:#00000073;color:#fff;font-size:.82rem;font-weight:600;cursor:pointer}.camera-guide-centered{top:44%;left:50%;transform:translate(-50%,-50%);width:60%;aspect-ratio:3 / 4;border:2px solid rgba(255,255,255,.6);border-radius:50%}.camera-bottom-overlay{position:absolute;left:0;right:0;bottom:0;z-index:10;background:linear-gradient(transparent,#000000bf);padding:20px 20px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:10px}.camera-liveness-kicker{font-size:10px;color:#fff9;letter-spacing:.14em;text-transform:uppercase;margin:0}.camera-liveness-message{font-size:17px;color:#fff;font-weight:600;line-height:1.35;margin:0}.camera-liveness-note{font-size:12px;color:#ffffffd9;margin:0;line-height:1.35}.camera-btn{width:100%;border-radius:50px;border:1px solid transparent;padding:13px;font-size:.95rem;font-weight:600;cursor:pointer}.camera-btn-outline{border:1.5px solid rgba(255,255,255,.5);background:transparent;color:#fff}.camera-btn-primary{padding:15px;background:#6b8e7f;color:#fff;border-color:#6b8e7f}.camera-btn-primary:disabled{opacity:.5;border-color:#6b8e7f;color:#fff}.capture-transition-overlay{position:absolute;inset:0;z-index:14;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;background:#0000008c;padding:24px}.capture-transition-overlay h3{margin:0;color:#fff;font-size:1.1rem;font-weight:700}.angle-step-sheet{z-index:12;background:linear-gradient(transparent,#000000d1)}.preview-modal{position:absolute;z-index:16;left:16px;right:16px;bottom:140px;border-radius:18px;background:#000000c7;border:1px solid rgba(255,255,255,.2);padding:14px}.preview-photo{width:100%;max-height:46vh;object-fit:cover;border-radius:12px}.preview-caption{margin:12px 0 10px;color:#fff;font-size:.9rem;text-align:center}.preview-actions{display:flex;gap:10px}.angle-capture-screen{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:80px 20px calc(80px + env(safe-area-inset-bottom));z-index:15}.direction-arrow-container{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:40px}.direction-arrow{font-size:120px;font-weight:200;color:#fff;text-shadow:0 0 40px rgba(107,142,127,.8);animation:arrowPulse 1.5s ease-in-out infinite;line-height:1}@keyframes arrowPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.7}}.direction-text{font-size:20px;font-weight:600;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6);margin:0;white-space:nowrap}.manual-capture-btn{width:calc(100% - 40px);max-width:320px;padding:16px;background:#6b8e7f;border:none;border-radius:50px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 20px #6b8e7f66}.manual-capture-btn:active{transform:scale(.98);box-shadow:0 2px 10px #6b8e7f4d}.front-photo-note{color:#ffffffeb}.liveness-box{background:#ffffff4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(26,20,16,.05);border-radius:var(--radius-md);padding:18px 20px;transition:all .3s}.liveness-box.ok{background:#8ca89d26;border-color:var(--olive-light)}.liveness-box strong{display:block;font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;color:var(--charcoal-muted);margin-bottom:8px;font-weight:700}.liveness-challenge{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:1.125rem;font-weight:600;color:var(--deep-charcoal);margin:6px 0;letter-spacing:-.01em}.liveness-note{font-size:.8125rem;color:var(--charcoal-muted);margin-top:6px;font-weight:400}.liveness-note.ok{color:var(--olive-dark);font-weight:600}.actions{display:flex;flex-direction:column;gap:10px}.capture-controls-mobile{display:none}.capture-controls-desktop{display:contents}.btn{width:100%;padding:14px 20px;border:1px solid var(--sand);border-radius:var(--radius-full);background:#ffffff80;color:var(--deep-charcoal);font-family:inherit;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);text-align:center}.btn:hover:not(:disabled){background:var(--white);border-color:var(--olive-point);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-dark{background:var(--olive-point);color:var(--white);border-color:var(--olive-point);box-shadow:var(--shadow-cta)}.btn-dark:hover:not(:disabled){background:var(--olive-dark);border-color:var(--olive-dark);box-shadow:0 12px 32px #6b8e7f80;transform:translateY(-3px)}.btn-light-outline{background:#ffffffb8;border-color:#6b8e7fa6;color:var(--deep-charcoal)}.btn-light-outline:hover:not(:disabled){background:#fff;border-color:var(--olive-point);color:var(--deep-charcoal)}.btn-capture-primary{background:#6b8e7f;border-color:#6b8e7f}.btn-capture-primary:disabled{opacity:.6;color:#fff;border-color:#6b8e7f}.btn-ghost{background:transparent;color:var(--charcoal-muted);border-color:transparent;font-size:.875rem;font-weight:500}.btn-ghost:hover:not(:disabled){color:var(--deep-charcoal);background:transparent;border-color:transparent;box-shadow:none}.analyze-panel{align-items:center;text-align:center;padding-top:80px;gap:32px}.analyze-visual{position:relative;width:180px;height:180px}.analyze-ring{position:absolute;inset:0;border-radius:50%;border:2px solid transparent;border-top-color:var(--olive-point);animation:spin 1.4s linear infinite}.analyze-ring:nth-child(2){inset:14px;border-top-color:transparent;border-right-color:var(--olive-light);animation-duration:2s;animation-direction:reverse}.analyze-ring:nth-child(3){inset:28px;border-top-color:var(--olive-dark);animation-duration:2.6s}.analyze-dot{position:absolute;inset:42px;border-radius:50%;background:radial-gradient(circle,var(--olive-light) 0%,var(--olive-point) 100%);animation:pulse 2s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}.analyze-title{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:1.625rem;font-weight:600;color:var(--deep-charcoal);letter-spacing:-.02em}.analyze-hint{font-size:.875rem;color:var(--charcoal-muted);letter-spacing:.01em;line-height:1.6;font-weight:400}.result-header{text-align:center;padding-top:12px}.result-eyebrow{font-size:.625rem;letter-spacing:.2em;text-transform:uppercase;color:var(--charcoal-muted);margin-bottom:10px;font-weight:700;opacity:.6}.result-title{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:1.5rem;font-weight:600;color:var(--deep-charcoal);line-height:1.3;letter-spacing:-.02em}.my-selfie-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.my-selfie{width:90px;height:90px;border-radius:50%;object-fit:cover;border:3px solid var(--sand);box-shadow:var(--shadow-sm)}.my-nickname{font-size:.8125rem;color:var(--charcoal-muted);letter-spacing:.03em;font-weight:500}.match-label{font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;color:var(--charcoal-muted);margin-bottom:12px;font-weight:700;opacity:.6}.cards{display:flex;flex-direction:column;gap:12px}.featured-match{border-radius:16px;overflow:hidden;border:1px solid rgba(26,20,16,.08);box-shadow:var(--shadow-md);background:#fff}.featured-match img{width:100%;aspect-ratio:4 / 5;object-fit:cover;display:block}.featured-match-caption{padding:10px 14px;font-size:.95rem;font-weight:600;color:var(--deep-charcoal)}.card-item{background:var(--white);border:1px solid rgba(26,20,16,.08);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);opacity:0;animation:cardAppear .5s ease-out forwards}.card-item:nth-child(1){animation-delay:.1s}.card-item:nth-child(2){animation-delay:.2s}.card-item:nth-child(3){animation-delay:.3s}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.card-photo{position:relative;width:88px;height:110px;flex-shrink:0}.card-photo img{width:100%;height:100%;object-fit:cover;display:block}.card-photo.blurred img{filter:blur(14px) saturate(.6);transform:scale(1.08)}.card-info{flex:1;padding:16px 20px}.card-nickname{font-size:.9375rem;font-weight:600;color:var(--deep-charcoal);margin-bottom:4px}.card-meta{font-size:.75rem;color:var(--charcoal-muted);letter-spacing:.02em;font-weight:400}.pill{display:inline-block;font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-full);font-weight:600;margin-top:8px}.pill-clear{background:var(--olive-point);color:var(--white)}.pill-blur{background:var(--sand);color:var(--charcoal-muted)}.compat-note{text-align:center;padding:16px;background:#ffffff4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-md);border:1px solid rgba(26,20,16,.05)}.compat-score{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:2rem;font-weight:700;color:var(--olive-dark);letter-spacing:-.03em}.compat-label{font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;color:var(--charcoal-muted);margin-top:4px;font-weight:700;opacity:.6}.error{background:#fff8f799;border:1px solid rgba(162,54,32,.2);border-radius:var(--radius-md);padding:20px;color:#8a3a2a;font-size:.9375rem;text-align:center;line-height:1.6;font-weight:400}.modal-backdrop{position:fixed;inset:0;background:#1a141080;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:640px;background:var(--cream-soft);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-md) var(--radius-md);padding:32px 28px 40px;box-shadow:0 -20px 60px #6b8e7f33;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal h3{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:1.4rem;font-weight:700;margin-bottom:24px;color:var(--deep-charcoal);letter-spacing:-.02em}.modal label{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;font-size:.875rem;color:var(--charcoal-soft);line-height:1.5;cursor:pointer;font-weight:400}.modal input[type=checkbox]{width:18px;height:18px;flex-shrink:0;margin-top:2px;accent-color:var(--olive-point);cursor:pointer}.modal .btn-dark{margin-top:8px}.status{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--deep-charcoal);color:var(--white);padding:10px 22px;border-radius:var(--radius-full);font-size:.8125rem;letter-spacing:.02em;box-shadow:var(--shadow-md);white-space:nowrap;z-index:50;animation:fadeIn .2s ease;font-weight:500}.app-footer{width:100%;text-align:center;padding:32px 24px;margin-top:auto;position:relative}.footer-disclaimer{font-size:.6875rem;color:var(--charcoal-muted);opacity:.6;margin-bottom:16px;line-height:1.6}.footer-text{font-size:.625rem;text-transform:uppercase;letter-spacing:.2em;color:var(--charcoal-muted);opacity:.4;font-weight:400}.payment-box{background:linear-gradient(135deg,#6b8e7f,#8ba897);border-radius:16px;padding:32px 24px;margin:32px 0;text-align:center;color:#fff;box-shadow:0 4px 16px #6b8e7f33}.payment-title{font-size:1.25rem;font-weight:600;margin-bottom:8px;color:#fff}.payment-price{font-size:2.5rem;font-weight:700;margin-bottom:12px;color:#fff;letter-spacing:-.02em}.payment-description{font-size:.875rem;opacity:.9;margin-bottom:24px;line-height:1.6}.payment-btn{background:#fff;color:#6b8e7f;font-weight:600;padding:14px 32px;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;max-width:300px}.payment-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.payment-note{margin-top:16px;font-size:.75rem;opacity:.7;font-style:italic}.card-locked{transition:transform .2s}.card-locked:hover{transform:scale(1.02)}.unlock-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#6b8e7fe6;opacity:0;transition:opacity .3s;border-radius:12px}.card-locked:hover .unlock-overlay{opacity:1}.unlock-icon{font-size:2.5rem;margin-bottom:8px}.unlock-text{font-size:.875rem;font-weight:600;color:#fff}.purchase-modal{max-width:480px;padding:0;overflow:hidden}.payment-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0}.payment-modal{width:100%;max-height:88dvh;overflow-y:auto;border-radius:24px 24px 0 0;background:#fff;padding:24px 20px 32px;padding-bottom:calc(32px + env(safe-area-inset-bottom))}.payment-modal:before{content:"";display:block;width:40px;height:4px;background:#ddd;border-radius:2px;margin:0 auto 20px}.modal-close-btn{position:absolute;top:16px;right:16px;background:#fff3;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10}.modal-close-btn:hover{background:#ffffff4d}.purchase-header{background:linear-gradient(135deg,#6b8e7f,#8ba897);padding:40px 32px 32px;text-align:center;color:#fff}.purchase-icon{font-size:3rem;margin-bottom:16px}.purchase-modal-title{font-size:1.75rem;font-weight:700;margin:0;color:#fff}.purchase-content{padding:0}.purchase-price-section{text-align:center;margin-bottom:32px}.purchase-price-tag{font-size:3rem;font-weight:700;color:#6b8e7f;margin-bottom:8px;letter-spacing:-.02em}.purchase-price-desc{font-size:.875rem;color:#6b5c4e}.purchase-benefit{background:#fff8e7;border-radius:12px;padding:14px;margin-bottom:16px;border-left:4px solid #6B8E7F}.purchase-benefit-title{font-size:1rem;font-weight:600;color:#1a1410;margin-bottom:8px}.purchase-benefit-desc{font-size:.875rem;color:#3d3530;line-height:1.6;margin:0;white-space:pre-line}.purchase-features{margin-bottom:16px;display:flex;flex-direction:column;gap:10px}.purchase-feature-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #F5F0EB;font-size:.9375rem;color:#3d3530}.purchase-feature-item:last-child{border-bottom:none}.purchase-feature-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#d4e8d4;color:#2d5f2d;font-weight:600;flex-shrink:0}.purchase-checkout-btn{width:100%;padding:16px;font-size:1.125rem;font-weight:600;background:#6b8e7f;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s;margin-bottom:16px}.purchase-checkout-btn:hover{background:#5a7a6d;transform:translateY(-2px);box-shadow:0 4px 12px #6b8e7f4d}.purchase-note{text-align:center;font-size:.75rem;color:#999;font-style:italic}.trust-badges{display:flex;flex-direction:column;gap:6px;margin-top:0;padding:12px 16px;background:#f5f9f7;border-radius:12px;border:1px solid rgba(107,142,127,.15)}.trust-badge{font-size:11px;color:#5a7d6e;font-weight:500;letter-spacing:.01em;line-height:1.4}.purchase-email-block{background:#fff8e7;border-radius:12px;border-left:4px solid #6B8E7F;padding:12px;margin-bottom:16px}.purchase-email-input{width:100%;padding:12px 14px;border:1px solid #E5DDD5;border-radius:10px;font-size:.95rem;margin:8px 0}.purchase-email-input:focus{outline:none;border-color:#6b8e7f}.admin-secret-btn{position:absolute;bottom:8px;right:8px;background:transparent;border:none;font-size:1.25rem;opacity:.15;cursor:pointer;padding:4px;transition:opacity .2s}.admin-secret-btn:hover{opacity:.4}.admin-password-modal{max-width:400px;padding:0;text-align:center}.admin-password-content{padding:40px 32px 32px}.admin-password-icon{font-size:3rem;margin-bottom:16px}.admin-password-title{font-size:1.5rem;font-weight:700;margin-bottom:8px;color:#1a1410}.admin-password-subtitle{font-size:.875rem;color:#6b5c4e;margin-bottom:24px}.admin-password-input{width:100%;padding:14px 16px;border:2px solid #E5DDD5;border-radius:8px;font-size:1.125rem;text-align:center;letter-spacing:.5em;font-weight:600;transition:border-color .2s}.admin-password-input:focus{outline:none;border-color:#6b8e7f}.admin-password-error{color:#dc3545;font-size:.875rem;margin-top:12px;margin-bottom:0}.admin-panel{position:fixed;bottom:20px;right:20px;width:450px;max-width:calc(100vw - 40px);max-height:calc(100vh - 40px);background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;z-index:1000;animation:slideInUp .3s ease-out;display:flex;flex-direction:column;overflow:hidden}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.admin-panel-header{background:linear-gradient(135deg,#6b8e7f,#8ba897);padding:16px 20px;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center}.admin-panel-header h3{margin:0;color:#fff;font-size:1.125rem;font-weight:600}.admin-panel-close{background:#fff3;border:none;width:32px;height:32px;border-radius:50%;font-size:1.5rem;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.admin-panel-close:hover{background:#ffffff4d}.admin-panel-content{padding:20px;overflow-y:auto;flex:1}.admin-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.admin-stat-item{background:#f5f0eb;padding:12px;border-radius:8px;display:flex;flex-direction:column;gap:4px}.admin-stat-label{font-size:.75rem;color:#6b5c4e}.admin-stat-value{font-size:1.25rem;font-weight:700;color:#6b8e7f}.admin-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.admin-actions .btn{width:100%;padding:10px 16px;font-size:.875rem}.admin-info{background:#fff8e7;border-radius:8px;padding:12px;font-size:.75rem}.admin-info-item{margin:0 0 6px;color:#3d3530}.admin-info-item:last-child{margin-bottom:0}.btn-warning{background:#ffc107;color:#1a1410}.btn-warning:hover{background:#e0a800}.admin-profiles-section{margin-top:20px;padding-top:20px;border-top:1px solid #E5DDD5}.admin-profiles-title{font-size:1rem;font-weight:600;margin-bottom:16px;color:#1a1410}.admin-profiles-empty{text-align:center;padding:40px 20px;color:#6b5c4e;font-size:.875rem}.admin-profiles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-height:400px;overflow-y:auto;padding:4px}.admin-profile-card{background:#f5f0eb;border-radius:8px;overflow:hidden;transition:transform .2s}.admin-profile-card:hover{transform:scale(1.02)}.admin-profile-image{width:100%;aspect-ratio:1;object-fit:cover;display:block}.admin-profile-info{padding:8px}.admin-profile-name{font-size:.875rem;font-weight:600;color:#1a1410;margin-bottom:4px}.admin-profile-meta{font-size:.6875rem;color:#6b5c4e;margin-bottom:2px}.admin-profile-status{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.625rem;font-weight:600;margin-top:4px}.admin-profile-status.active{background:#d4e8d4;color:#2d5f2d}.admin-profile-status.expired{background:#f8d7da;color:#721c24}.admin-profile-delete{margin-top:8px;width:100%;border:1px solid #dc3545;background:#fff;color:#dc3545;border-radius:8px;padding:6px 8px;font-size:.75rem;font-weight:600;cursor:pointer}.admin-profile-delete:hover{background:#dc3545;color:#fff}.btn-secondary{background:#e8ddd4;color:#1a1410;border-color:#d8c9bc}.btn-secondary:hover:not(:disabled){background:#dfd1c5;border-color:#ccb9a9}.btn-danger{background:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover:not(:disabled){background:#c82333;border-color:#bd2130}@media(max-width:480px){.topbar{padding:20px 16px 0}.panel{padding:0 16px;gap:20px}.intro-panel{padding-top:32px}.intro-title{font-size:clamp(1.75rem,5vw,2.5rem)}}@media(max-width:768px){.app-shell.capture-mode{height:100dvh;display:flex;flex-direction:column;overflow:hidden;padding-bottom:env(safe-area-inset-bottom)}.app-shell.capture-mode .topbar{max-width:100%;padding:16px;flex-shrink:0}.capture-panel{max-width:100%}.app-shell.capture-mode .capture-panel{margin-top:0;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;padding:0 16px calc(16px + env(safe-area-inset-bottom));gap:12px}.app-shell.capture-mode .filters-card{flex-shrink:0}.app-shell.capture-mode .camera-wrap{position:relative;flex:1;min-height:0;aspect-ratio:auto;border-radius:20px;overflow:hidden}.app-shell.capture-mode .camera{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}.app-shell.capture-mode .camera-guide{top:36%;transform:translate(-50%,-65%);width:42%}.app-shell.capture-mode .capture-controls-desktop{display:none}.app-shell.capture-mode .capture-controls-mobile{position:absolute;left:0;right:0;bottom:0;display:flex;flex-direction:column;gap:8px;padding:16px;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.6) 100%);z-index:3}.app-shell.capture-mode .capture-controls-mobile .liveness-box{background:#00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.35);height:auto;padding:10px 14px;border-radius:14px}.app-shell.capture-mode .capture-controls-mobile .liveness-box strong{font-size:16px;line-height:1.25;letter-spacing:0;text-transform:none;margin-bottom:4px}.app-shell.capture-mode .capture-controls-mobile .liveness-challenge{margin:2px 0;font-size:14px;line-height:1.3}.app-shell.capture-mode .capture-controls-mobile .liveness-box strong,.app-shell.capture-mode .capture-controls-mobile .liveness-challenge,.app-shell.capture-mode .capture-controls-mobile .liveness-note{color:#fff}.app-shell.capture-mode .capture-controls-mobile .liveness-note{margin-top:2px;font-size:12px;line-height:1.35}.app-shell.capture-mode .capture-controls-mobile .actions{gap:8px}.app-shell.capture-mode .capture-controls-mobile .btn{width:100%;border-radius:50px;padding:12px 16px;font-size:14px}.app-shell.capture-mode .capture-controls-mobile .btn-light-outline{background:#ffffff14;border-color:#ffffffbf;color:#fff}.app-shell.capture-mode .capture-controls-mobile .btn-light-outline:hover:not(:disabled){background:#ffffff2e;border-color:#fff;color:#fff}}
