  @font-face{
    font-family:'GmarketSansLight';
    src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansLight.woff') format('woff');
    font-weight:300;font-display:swap;
  }
  @font-face{
    font-family:'GmarketSansMedium';
    src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansMedium.woff') format('woff');
    font-weight:500;font-display:swap;
  }
  @font-face{
    font-family:'GmarketSansBold';
    src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansBold.woff') format('woff');
    font-weight:700;font-display:swap;
  }
  :root{
    --neon:#1fff8f;
    --neon-deep:#0fae63;
    --bg:#f1f3ee;
    --ink:#15201a;
    --muted:#6f7a72;
    --line:#dfe3da;
    --on-accent:#15201a;   /* 하이라이트색 버튼 위 글씨(자동 흰/검) */
    --on-bg:#15201a;       /* 배경 위 글씨(자동 흰/검) */
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html,body{height:100%}
  body{
    font-family:'Pretendard',-apple-system,sans-serif;
    background:var(--bg);color:var(--ink);
    min-height:100dvh;overflow:hidden;
  }
  .screen{
    position:fixed;inset:0;display:none;
    flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:60px 40px;
  }
  .screen.active{display:flex;animation:fadein .4s ease}
  @keyframes fadein{from{opacity:0}to{opacity:1}}
  /* 네온은 깔끔한 단색 테두리만 (발광·일렁임 없음) */
  .neon{
    position:fixed;inset:0;border:18px solid var(--neon);
    pointer-events:none;z-index:1;
  }

  /* 필름 프레임: JS가 화면 크기를 읽어 균일 격자로 구멍을 배치 */
  .filmframe{position:fixed;inset:0;z-index:2;pointer-events:none}
  .filmframe i{position:absolute;background:var(--bg);border-radius:3px}
  .inner{position:relative;z-index:2;width:100%;max-width:460px}

  .start-tagline{font-family:'GmarketSansMedium',sans-serif;font-size:26px;font-weight:500;letter-spacing:3px;text-indent:3px;color:var(--neon-deep);text-align:center;text-transform:uppercase;margin-bottom:10px;opacity:1}
  .about-link{display:block;margin-top:24px;font-size:12px;color:var(--muted);text-decoration:none;opacity:.6;letter-spacing:.5px;transition:opacity .15s}
  .about-link:hover{opacity:1;color:var(--neon-deep)}
  .title{
    font-family:'GmarketSansBold',sans-serif;
    font-weight:700;
    font-size:clamp(58px,17vw,98px);
    line-height:.95;letter-spacing:-3px;
    color:var(--on-bg);display:inline-block;
    background:linear-gradient(180deg,transparent 58%,var(--neon) 58%);
    padding:0 6px;margin:0;
  }
  .title-en{font-weight:700;font-size:13px;letter-spacing:6px;text-transform:uppercase;color:var(--muted);margin-top:14px}
  .brand-rule{width:62px;height:3px;background:var(--neon-deep);border-radius:2px;margin:16px auto 0}
  /* 컬렉션 진입 시: 인생웹컷 헤더는 작게 — 브랜드명이 주인공 */
  #screen-start.brandmode .start-tagline{font-size:16px;letter-spacing:2px;margin-bottom:6px}
  #screen-start.brandmode .title{font-size:clamp(38px,11vw,60px);letter-spacing:-2px}
  .brand-name{font-weight:900;font-size:38px;letter-spacing:-1px;margin-top:12px;color:var(--on-bg);max-width:340px;margin-left:auto;margin-right:auto;line-height:1.1;white-space:nowrap;text-align:center}
  .brand-sub{font-weight:700;font-size:15px;color:var(--on-bg);margin:12px auto 0;max-width:300px;line-height:1.5;opacity:.9;text-align:center}
  /* 마스코트 본체 색을 하이라이트(--neon)에 연동 — 기본값은 원래 초록과 동일 */
  .mascot rect[fill="#1fff8f"]{fill:var(--neon)}
  .mascot rect[fill="#0fae63"]{fill:var(--neon-deep)}
  .mascot{position:relative;display:block;width:-moz-fit-content;width:fit-content;margin:30px auto 30px;animation:hop 1.1s ease-in-out infinite}
  .mascot svg{image-rendering:pixelated;filter:drop-shadow(0 4px 0 color-mix(in srgb, var(--neon-deep) 24%, transparent));overflow:visible}
  /* 컬렉션 로고: 캐릭터는 가운데(코·입 기준), 왼손=로고 스트립 / 오른손=기존 스트립(양손) */
  .logo-strip{display:none}
  /* 로고 모드: hop 애니메이션 transform이 translateX를 덮어쓰므로 키프레임에 가로 이동 포함 */
  .mascot.has-logo{animation-name:hop-logo}
  @keyframes hop-logo{0%,100%{transform:translate(15px,0)}50%{transform:translate(15px,-12px)}}
  .mascot.has-logo .logo-strip{display:flex;flex-direction:column;align-items:center;
    position:absolute;left:-44px;top:6px;width:66px;padding:6px 6px 7px;background:#fff;border-radius:6px;
    box-shadow:0 6px 16px rgba(0,0,0,.18);transform:rotate(-11deg);z-index:3}
  .logo-strip img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:3px;display:block;background:#f1f3ee}
  .logo-strip .ls-cap{font-family:'GmarketSansMedium','Pretendard',sans-serif;font-weight:500;font-size:9px;color:var(--strip-text,#15201a);letter-spacing:.2px;margin-top:6px;display:flex;align-items:center;justify-content:center;width:100%}
  @keyframes hop{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
  /* 눈 깜빡임: 가끔 위아래로 납작해짐 */
  .mascot .eye{transform-box:fill-box;transform-origin:center;animation:blink 3.4s infinite}
  @keyframes blink{0%,92%,100%{transform:scaleY(1)}95%{transform:scaleY(.1)}}
  /* 렌즈 반짝임: 위치 이동하며 깜빡 */
  .mascot .glint{transform-box:fill-box;animation:glint 2.6s ease-in-out infinite}
  @keyframes glint{
    0%,100%{transform:translate(0,0);opacity:.9}
    40%{transform:translate(2px,1px);opacity:.3}
    50%{transform:translate(2px,1px);opacity:1}
    70%{transform:translate(0,0);opacity:.5}
  }
  /* 셔터 버튼 눌림 + 그 자리 플래시 번쩍 */
  .mascot .shutter{transform-box:fill-box;transform-origin:center;animation:shpress 3.2s ease-in-out infinite}
  @keyframes shpress{0%,72%{transform:translateY(0)}79%,86%{transform:translateY(0.9px)}93%,100%{transform:translateY(0)}}
  .mascot .shflash{opacity:0;animation:shflash 3.2s ease-in-out infinite}
  @keyframes shflash{0%,74%{opacity:0}80%{opacity:.9}90%{opacity:0}100%{opacity:0}}
  .guide{font-weight:500;font-size:clamp(15px,4.2vw,18px);color:var(--muted);line-height:1.7;margin:34px auto 30px;max-width:300px}
  .guide b{color:var(--ink);font-weight:700}

  .btn{
    font-family:'Pretendard',sans-serif;font-weight:800;font-size:21px;letter-spacing:1px;
    color:var(--on-accent);background:var(--neon);border:none;border-radius:50px;
    padding:17px 56px;cursor:pointer;
    box-shadow:0 5px 0 var(--neon-deep),0 0 18px color-mix(in srgb,var(--neon) 60%,transparent);
    transition:transform .12s,box-shadow .12s,opacity .2s;-webkit-tap-highlight-color:transparent;
  }
  .btn:hover{transform:translateY(-2px);box-shadow:0 7px 0 var(--neon-deep),0 0 30px color-mix(in srgb,var(--neon) 80%,transparent)}
  .btn:active{transform:translateY(3px);box-shadow:0 2px 0 var(--neon-deep)}
  .btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
  .btn.ghost{background:transparent;color:var(--muted);box-shadow:inset 0 0 0 2px var(--line);font-weight:700;font-size:16px;padding:13px 30px}
  .btn.ghost:hover{transform:none;color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
  .btn.ghost:active{transform:translateY(1px)}

  .step-head{margin-bottom:20px}
  .step-eyebrow{font-weight:700;font-size:12px;letter-spacing:4px;color:var(--neon-deep);text-transform:uppercase}
  .step-title{font-weight:900;font-size:clamp(26px,7vw,34px);letter-spacing:-1px;margin-top:6px;color:var(--on-bg)}
  .step-sub{font-weight:500;font-size:14px;color:var(--muted);margin-top:6px}
  .step-sub b{color:var(--ink);font-weight:700}
  .nav-row{display:flex;gap:12px;justify-content:center;align-items:center;margin-top:30px}

  .cut-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 auto;max-width:360px}
  .cut-card .preview{flex-direction:column}
  .cut-big{font-weight:900;font-size:32px;line-height:1;color:var(--ink);margin-bottom:8px}
  .cut-big span{font-size:.5em;font-weight:800;margin-left:2px}
  .cut-mini{display:inline-grid;gap:3px;align-content:center;justify-content:center}
  .cut-mini i{display:block;width:7px;height:7px;background:var(--line);border-radius:2px}
  .cut-card.sel .cut-mini i{background:var(--neon)}

  /* 레이아웃(템플릿) / 디자인 공용 격자 */
  .pick-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:0 auto;max-width:320px}
  /* 템플릿 갤러리(그룹 칩 + 카드) */
  .tpl-chips{display:flex;gap:7px;justify-content:center;overflow-x:auto;max-width:340px;margin:0 auto 12px;padding:2px;scrollbar-width:none}
  .tpl-chips::-webkit-scrollbar{display:none}
  .tpl-chips button{flex:0 0 auto;font-family:inherit;font-weight:700;font-size:13px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:20px;padding:7px 14px;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .tpl-chips button.on{background:var(--neon);border-color:var(--neon)}
  .tpl-gallery-wrap{position:relative;max-width:360px;margin:0 auto}
  .tpl-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-height:48vh;overflow-y:auto;padding:16px}
  .scroll-fade{position:absolute;left:0;right:0;bottom:0;height:36px;pointer-events:none;border-radius:0 0 16px 16px;background:linear-gradient(color-mix(in srgb, var(--bg), transparent 100%), var(--bg))}
  .btn:disabled,.btn[disabled]{opacity:.4;cursor:not-allowed;box-shadow:0 5px 0 var(--neon-deep);transform:none;filter:grayscale(.3)}
  @media(min-width:520px){ .tpl-gallery-wrap{max-width:580px} .tpl-gallery{grid-template-columns:repeat(3,1fr)} .tpl-chips{max-width:580px} }
  .pick-grid.cols3{grid-template-columns:repeat(3,1fr);max-width:380px}
  .pick{position:relative;cursor:pointer;border-radius:14px;overflow:hidden;background:#fff;border:2px solid var(--line);transition:border-color .15s,transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}
  .pick:hover{transform:translateY(-3px)}
  .pick.sel{border-color:var(--neon);box-shadow:0 0 0 3px color-mix(in srgb,var(--neon) 35%,transparent),0 0 16px color-mix(in srgb,var(--neon) 45%,transparent)}
  .pick .preview{position:relative;display:flex;align-items:center;justify-content:center;padding:14px 10px;height:140px;box-sizing:border-box;overflow:hidden}
  /* 선택된 카드에만 "크게 보기" 반투명 버튼 */
  .pick .zoom{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:none;align-items:center;gap:5px;background:rgba(15,20,16,.6);color:#fff;border:none;border-radius:30px;padding:8px 14px;font-family:inherit;font-size:11px;font-weight:700;cursor:pointer;z-index:4;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(2px);box-shadow:0 2px 10px rgba(0,0,0,.25)}
  .pick.sel .zoom{display:inline-flex}
  .pick .zoom:active{transform:translate(-50%,-50%) scale(.94)}
  /* 템플릿 크게 보기 모달 */
  .tpl-modal-card{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:92vw}
  .tpl-modal-name{font-weight:800;font-size:15px;color:#fff;text-align:center;text-shadow:0 1px 6px rgba(0,0,0,.4)}
  #tplModalBody{display:flex;align-items:center;justify-content:center}
  #tplModal .modal-cancel{color:#fff;background:rgba(255,255,255,.16);border-radius:30px;padding:10px 28px}
  .pick .preview canvas{box-shadow:0 1px 5px rgba(0,0,0,.12);border-radius:0}   /* 스트립과 카드 배경색 같아도 구분되게 옅은 그림자 */
  .pick .name{font-weight:600;font-size:11px;color:var(--muted);padding:6px 4px 9px;border-top:1px solid var(--line)}
  .pick.sel .name{color:var(--ink)}
  .pick .rec{position:absolute;top:6px;right:6px;z-index:3;background:var(--neon);color:var(--ink);font-weight:800;font-size:9px;letter-spacing:.5px;padding:3px 7px;border-radius:20px;box-shadow:0 1px 4px rgba(0,0,0,.15)}

  /* 디자인 캐러셀: 한 페이지 2×2, 좌우로 넘겨보기 */
  .carousel{position:relative;max-width:320px;margin:0 auto}
  .carousel-track{display:flex;align-items:flex-start;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .carousel-track::-webkit-scrollbar{display:none}
  .design-page{flex:0 0 100%;scroll-snap-align:start;display:grid;grid-template-columns:repeat(2,1fr);align-content:start;gap:12px;padding:4px 2px}
  .carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:32px;height:32px;border-radius:50%;border:none;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.18);font-size:18px;font-weight:800;line-height:1;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}
  .carousel-btn.prev{left:-12px}
  .carousel-btn.next{right:-12px}
  .carousel-btn:active{transform:translateY(-50%) scale(.92)}
  .carousel-btn:disabled{opacity:0;pointer-events:none}

  /* 프레임 미니 프리뷰 (하단에 브랜딩 텍스트 포함) */
  .frame{display:flex;flex-direction:column;align-items:center;padding:4px 4px 0;border-radius:3px;background:#15201a}
  .frame-cells{display:grid;gap:3px}
  .frame-cells i{display:block;border-radius:2px;background:#fff}
  .frame-brand{font-family:'GmarketSansLight','Pretendard',sans-serif;font-weight:300;letter-spacing:.3px;line-height:1;color:#eafff4;white-space:nowrap;display:flex;align-items:center;justify-content:center}
  .frame[data-bg="film"]{background:#e8e2d4}
  .frame[data-bg="film"] .frame-cells i{background:#fff}
  .frame[data-bg="film"] .frame-brand{color:#6b6253}
  .frame[data-bg="mint"]{background:#bdeed3}
  .frame[data-bg="mint"] .frame-brand{color:#1d6b46}
  .frame[data-bg="warm"]{background:#ffd9bd}
  .frame[data-bg="warm"] .frame-brand{color:#8a5326}
  .frame[data-bg="dark"]{background:#0c0f0d}
  .frame[data-bg="dark"] .frame-cells i{background:#2a322c}
  .frame[data-bg="dark"] .frame-brand{color:#cfe9da}
  .frame[data-bg="mono"]{background:#4a534d}
  .frame[data-bg="mono"] .frame-cells i{background:#e8ece8}
  .frame[data-bg="mono"] .frame-brand{color:#eef2ee}
  .frame[data-bg="classic"] .frame-brand{color:#eafff4}

  .sound{margin:22px auto 0;max-width:360px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px 18px}
  .sound-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
  .sound-label{font-weight:700;font-size:15px;text-align:left}
  .sound-label small{display:block;font-weight:500;font-size:12px;color:var(--muted);margin-top:2px}
  .toggle{position:relative;width:50px;height:30px;flex:none;cursor:pointer}
  .toggle input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;margin:0}
  .toggle .track{position:absolute;inset:0;background:var(--line);border-radius:30px;transition:background .2s}
  .toggle .knob{position:absolute;top:3px;left:3px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
  .toggle input:checked + .track{background:var(--neon)}
  .toggle input:checked + .track + .knob{transform:translateX(20px)}

  #screen-cam{padding:0;justify-content:flex-start}
  .cam-wrap{position:relative;z-index:2;width:100%;max-width:520px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;padding:26px 34px 30px}
  .cam-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
  .cam-top .back{background:none;border:none;font-family:inherit;font-weight:700;font-size:15px;color:var(--muted);cursor:pointer}
  .cam-top .count{font-weight:800;font-size:15px}
  .cam-top .count b{color:var(--neon-deep)}
  .cam-top-end{display:flex;flex-direction:row;align-items:center;gap:10px}
  /* 카메라 컷 카운터 + 방향 전환 한 줄 */
  .cam-meta-row{max-width:440px;width:100%;display:flex;justify-content:space-between;align-items:center}
  .cam-flip{display:flex;flex-direction:row;align-items:center;gap:4px;padding:3px 9px 3px 6px;
    border-radius:14px;background:#fff;border:1px solid var(--line);
    color:var(--ink);cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none}
  .cam-flip:active{opacity:.7}
  .cam-flip img{width:15px;height:15px;display:block;object-fit:contain}
  .cam-flip-lbl{font-size:11px;font-weight:600;color:#15201a;line-height:1;letter-spacing:-.3px}
  .cam-top-end .opt{display:flex;align-items:center;gap:7px;font-weight:700;font-size:12px;color:var(--muted)}
  .cam-top-end .toggle{width:40px;height:22px}
  .cam-top-end .toggle .knob{width:16px;height:16px}
  .cam-top-end .toggle input:checked + .track + .knob{transform:translateX(18px)}
  #beautyOpt{position:relative}
  #beautyPopup{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.22);padding:6px;z-index:200;min-width:114px;flex-direction:column;gap:2px}
  #beautyPopup.open{display:flex!important}
  .bpreset{font-family:inherit;font-size:13px;font-weight:700;color:var(--ink);background:none;border:none;border-radius:9px;padding:9px 12px;cursor:pointer;text-align:left;white-space:nowrap;width:100%}
  .bpreset:hover{background:var(--bg)}
  .bpreset.active{background:var(--neon);color:var(--ink)}

  .cam-caption{min-height:24px;font-weight:700;font-size:16px;color:var(--on-bg);transition:opacity .2s}
  .cam-caption small{display:block;font-weight:500;font-size:12px;color:var(--muted);margin-top:1px}

  .cam-stage{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
  .video-box{position:relative;width:100%;max-width:440px;aspect-ratio:3 / 4;max-height:58vh;overflow:hidden;background:#0c0f0d;box-shadow:0 0 0 2px #15201a;display:flex;align-items:center;justify-content:center}
  #video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);transition:transform .25s}
  /* 뽀샤시 효과 ON: 화면 왜곡 없이 화사하게 (밝기 ↑·은은한 블룸·살짝 파스텔 톤) */
  .video-box.beauty #video{transform:scaleX(-1);
    filter:brightness(1.03) contrast(.99) saturate(.98);}
  /* 뽀샤시 ①: 라이브 화면 밝은 부분만 살짝 떠서 screen 블렌드 → 또렷한 소프트 글로우(흐릿 X) */
  .glow{position:absolute;inset:0;pointer-events:none;z-index:1;display:none;
    -webkit-backdrop-filter:blur(2.5px) brightness(1.08);
    backdrop-filter:blur(2.5px) brightness(1.08);
    mix-blend-mode:screen;opacity:.3}
  .video-box.beauty .glow{display:block}
  /* 뽀샤시 ②: 이마·볼 쪽 하이라이트만 화사하게 (전체 들뜸 없이) */
  .soft{position:absolute;inset:0;pointer-events:none;z-index:2;display:none;
    background:
      radial-gradient(110% 80% at 50% 22%, rgba(255,255,255,.18), rgba(255,255,255,0) 55%),
      radial-gradient(130% 110% at 50% 110%, rgba(255,250,245,.08), rgba(255,255,255,0) 50%);
    mix-blend-mode:screen;}
  .video-box.beauty .soft{display:block}
  .cam-count{font-weight:800;font-size:15px}
  .cam-count b{color:var(--neon-deep)}
  .cam-overlay{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:26px;color:#dfe7e1;text-align:center;background:rgba(10,14,12,.55)}
  .cam-overlay p{font-weight:600;font-size:15px;line-height:1.6;max-width:320px}
  .cam-overlay.hidden{display:none}
  /* 카운트다운: 얼굴을 가리지 않게 투명하게 위쪽에 표시 */
  .countdown{position:absolute;inset:0;z-index:2;display:none;align-items:flex-start;justify-content:center}
  .countdown.on{display:flex}
  .countdown b{margin-top:7%;font-weight:800;font-size:78px;line-height:1;
    color:rgba(255,255,255,.9);text-shadow:0 2px 14px rgba(0,0,0,.45);animation:cd .9s ease forwards}
  /* 각 숫자: 팡 나타났다 살짝 커지며 완전히 사라짐 → 다음 숫자가 깔끔히 등장 */
  @keyframes cd{0%{transform:scale(.6);opacity:0}18%{transform:scale(1);opacity:.95}68%{transform:scale(1);opacity:.95}100%{transform:scale(1.12);opacity:0}}
  .flash{position:absolute;inset:0;z-index:4;background:#fff;opacity:0;pointer-events:none}
  .flash.fire{animation:flash .4s ease}
  @keyframes flash{0%{opacity:0}10%{opacity:.95}100%{opacity:0}}

  /* 찍은 사진을 카메라 영역에 덮어 잠시 정지 (사진첩처럼: 흰 테두리, 검정선 없음) */
  .snapshot{position:absolute;inset:0;z-index:7;display:none;background:#fff;border:6px solid #fff;box-sizing:border-box}
  .snapshot.on{display:block;animation:snappop 1.3s ease forwards}
  /* 마지막 컷: 사진을 그대로 유지(페이드아웃 X) → 카메라 꺼질 때 검정화면 안 보이게 */
  .snapshot.on.hold{animation:snappophold 1.3s ease forwards}
  .snapshot img{width:100%;height:100%;object-fit:cover;display:block}
  /* 스냅샷 동안엔 카메라 테두리(검정선) 숨김 → 사진만 깔끔하게 */
  .video-box.snapping{box-shadow:none}
  @keyframes snappop{0%{opacity:0;transform:scale(1.07)}8%{opacity:1;transform:scale(1)}84%{opacity:1;transform:scale(1)}100%{opacity:0}}
  @keyframes snappophold{0%{opacity:0;transform:scale(1.07)}8%{opacity:1;transform:scale(1)}100%{opacity:1;transform:scale(1)}}

  .progress{display:flex;gap:9px;justify-content:center;margin-top:0;flex-wrap:wrap}
  .progress .dot{width:12px;height:12px;border-radius:50%;background:var(--line);transition:background .2s,transform .2s}
  .progress .dot.done{background:var(--neon);transform:scale(1.1)}
  .progress .dot.now{box-shadow:0 0 0 3px color-mix(in srgb,var(--neon) 40%,transparent)}

  .cam-actions{margin-top:16px;display:flex;justify-content:center}

  /* 결과 화면은 한 화면에서 끝 (스크롤 없음) */
  #screen-result{justify-content:center;overflow:hidden}
  .result-title{font-weight:900;font-size:clamp(24px,6.5vw,30px);letter-spacing:-1px;margin-bottom:16px}
  .result-preview{margin:0 auto;display:flex;justify-content:center}
  .result-preview img,.result-preview video{max-width:100%;max-height:52vh;width:auto;height:auto;border-radius:0;box-shadow:0 2px 8px rgba(0,0,0,.10)}
  /* 사진 / 움짤 전환 칩 */
  .view-toggle{display:none;justify-content:center;gap:4px;width:max-content;margin:0 auto 14px;background:#fff;border:1px solid var(--line);border-radius:30px;padding:3px}
  .view-toggle button{font-family:inherit;font-weight:700;font-size:12px;color:var(--muted);background:none;border:none;border-radius:24px;padding:5px 13px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}
  .view-toggle button.on{background:var(--neon);color:var(--on-accent)}
  /* 움짤 합성 중/실패 안내 (사진 미리보기와 비슷한 영역 차지) */
  .movie-making{flex-direction:column;align-items:center;justify-content:center;gap:14px;
    width:min(80vw,300px);height:40vh;color:var(--muted);font-weight:600;font-size:15px;
    background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.10)}
  .result-actions{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:22px}
  .result-actions .btn{width:100%;max-width:300px}
  .result-sub{display:flex;gap:10px;width:100%;max-width:300px}
  .result-sub .btn{flex:1;padding-left:0;padding-right:0}
  .result-loading{display:none;flex-direction:column;align-items:center;gap:14px;margin:0 auto;color:var(--muted);font-weight:600;font-size:15px}

  /* 저장 선택 모달 */
  .modal{position:fixed;inset:0;z-index:20;display:none;align-items:center;justify-content:center;background:rgba(10,14,12,.55);padding:30px}
  .modal.on{display:flex;animation:fadein .2s ease}
  .modal-card{width:100%;max-width:300px;background:#fff;border-radius:20px;padding:18px;display:flex;flex-direction:column;gap:10px;box-shadow:0 20px 50px rgba(0,0,0,.3)}
  .modal-title{font-weight:800;font-size:17px;text-align:center;margin:4px 0 6px}
  .save-group{display:flex;flex-direction:column;gap:8px}
  .save-head{font-weight:800;font-size:12px;color:var(--muted);letter-spacing:.5px;text-align:left;padding:2px 2px 0}
  .save-opt{font-family:inherit;font-weight:700;font-size:15px;color:var(--ink);background:var(--bg);border:none;border-radius:12px;padding:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .save-opt:active{background:var(--line)}
  .save-opt small{display:block;font-weight:500;font-size:11px;color:var(--muted);margin-top:2px}
  .modal-cancel{font-family:inherit;font-weight:700;font-size:14px;color:var(--muted);background:none;border:none;padding:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .result-loading.on{display:flex}
  .spinner{width:38px;height:38px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--neon-deep);animation:spin .8s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}

  @media (prefers-reduced-motion:reduce){
    .screen.active,.countdown b{animation:none}
    .mascot{animation:none}
    .mascot .eye,.mascot .glint,.mascot .shutter,.mascot .shflash{animation:none}
  }
