/* static/css/app.css — 여러 정적 페이지(index/upload/complete/browse/mypages)가 공유하는
   디자인 토큰과 컴포넌트(리셋·헤더·버튼·레이아웃 유틸·카드 그리드·뷰어/복사·푸터·토스트·
   법적 고지 모달). 페이지 전용 스타일(업로드 폼, 둘러보기 툴바, 마이페이지 리스트, 홈
   히어로 등)은 각 페이지 자신의 <style> 블록에 남긴다. */

/* Pretendard 가변폰트(자체 호스팅) — 라틴+한글을 한 폰트로 통일. 외부 CDN 의존 없음. */
@font-face{
  font-family:'Pretendard';
  src:url('/fonts/PretendardVariable.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
}

/* ===========================================================================
   Uber 스타일 흑백 디자인 시스템 — 화이트 캔버스 + 잉크 블랙 듀엣.
   두 번째 강조색 없음 · pill 999px 시그니처 · 카드 16px · Pretendard(라틴+한글).
   JS가 theme(Paper/Studio)에 맞춰 아래 변수를 덮어쓴다.
   ========================================================================= */
:root{
  --font:'Pretendard',system-ui,-apple-system,sans-serif;
  --bg:#FFFFFF; --panel:#FFFFFF; --panel2:#F3F3F3; --ink:#000000; --muted:#5E5E5E; --mute:#AFAFAF;
  --line:rgba(0,0,0,.12); --softline:rgba(0,0,0,.07); --lineStrong:rgba(0,0,0,.22);
  --shadow:rgba(0,0,0,.16) 0 4px 16px 0;
  --accent:#000000; --accentSoft:#EFEFEF; --accentInk:#FFFFFF;
  --heroSize:clamp(28px,3.4vw,44px);
}
*{box-sizing:border-box}
body{margin:0;min-height:100vh;background:var(--bg);color:var(--ink);
  font-family:var(--font);-webkit-font-smoothing:antialiased}
#app{display:flex;flex-direction:column;min-height:100vh}
main{flex:1}
::selection{background:rgba(0,0,0,.12)}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,.22);border-radius:8px;border:3px solid transparent;background-clip:content-box}
a{color:var(--accent)}
button{font-family:inherit}
input::placeholder,textarea::placeholder{color:var(--mute)}

/* ---- 헤더 ---- */
.header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:14px clamp(20px,5vw,56px);background:var(--bg);
  border-bottom:1px solid var(--softline);backdrop-filter:saturate(1.2) blur(8px)}
.logo{display:flex;align-items:center;gap:11px;background:none;border:0;cursor:pointer;padding:0;text-decoration:none}
.logo-mark{display:grid;place-items:center;width:32px;height:32px;border-radius:8px;
  background:var(--accent);color:var(--accentInk)}
.logo-text{font:700 19px/1 var(--font);color:var(--ink)}
.logo-text b{color:var(--accent);font-weight:700}
.nav{display:flex;align-items:center;gap:6px}
.nav-link{background:none;border:0;cursor:pointer;padding:8px 12px;font:500 15px/1 var(--font);color:var(--muted);text-decoration:none;transition:color .15s}
.nav-link:hover{color:var(--ink)}
.nav-link.active{color:var(--ink);font-weight:700}
.lang{background:var(--accentSoft);border:0;border-radius:999px;cursor:pointer;padding:9px 14px;
  font:500 13px/1 var(--font);color:var(--ink);transition:filter .15s}
.lang:hover{filter:brightness(.95)}
.header-actions{display:flex;align-items:center;gap:6px}
.menu-toggle{display:none;align-items:center;justify-content:center;width:42px;height:42px;
  border:0;border-radius:11px;background:none;cursor:pointer;color:var(--ink);transition:background .15s}
.menu-toggle:hover{background:var(--accentSoft)}
.menu-toggle .ico-close{display:none}

/* ---- 공통 버튼 (pill 999px · 라벨 weight 500) ---- */
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border-radius:999px;
  font:500 15px/1 var(--font);transition:opacity .15s,background .15s,border-color .15s,color .15s;border:0;text-decoration:none}
.btn-primary{background:var(--accent);color:var(--accentInk);padding:14px 26px}
.btn-primary:hover{opacity:.86}
.btn-ghost{background:var(--panel);color:var(--ink);border:1px solid var(--line);padding:13px 24px}
.btn-ghost:hover{background:var(--accentSoft)}
.btn-sm{padding:13px 22px;font-size:15px}
.btn-up{padding:11px 20px;border-radius:999px;font:500 14px/1 var(--font);background:var(--accent);color:var(--accentInk);text-decoration:none}
.btn-up:hover{opacity:.86}
.btn-ondark{background:#fff;color:#000;border:0;border-radius:999px;padding:14px 26px;cursor:pointer;
  font:500 15px/1 var(--font);white-space:nowrap;transition:opacity .15s;text-decoration:none;display:inline-flex}
.btn-ondark:hover{opacity:.86}
.linkbtn{background:none;border:0;cursor:pointer;color:var(--muted);font:500 14px/1 var(--font);transition:color .15s;text-decoration:none}
.linkbtn:hover{color:var(--ink)}

/* ---- 레이아웃 유틸 ---- */
.section{max-width:1180px;margin:0 auto;padding:clamp(28px,5vw,52px) clamp(20px,5vw,56px) 56px}
.eyebrow{font:500 12px/1 var(--font);letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}
.h2{font-weight:700;font-size:clamp(28px,3.5vw,40px);line-height:1.18;letter-spacing:normal;margin:0;font-feature-settings:"ss01"}
.h1{font-weight:700;font-size:clamp(34px,4.5vw,52px);line-height:1.14;letter-spacing:normal;margin:0;font-feature-settings:"ss01";overflow-wrap:break-word}
.sub{font:400 14px/1.4 var(--font);color:var(--muted);margin-top:6px}
.count{font:500 14px/1 var(--font);color:var(--muted)}

/* ---- 카드 그리드 (홈 트렌딩 · 둘러보기 목록 공유) ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,320px);gap:24px;justify-content:center}
.card{width:320px;text-align:left;padding:0;background:var(--panel);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;cursor:pointer;color:inherit;text-decoration:none;display:block;
  transition:transform .2s cubic-bezier(.2,.7,.2,1),box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-4px);box-shadow:rgba(0,0,0,.14) 0 14px 34px -16px;border-color:var(--lineStrong)}
.preview{position:relative;border-bottom:1px solid var(--softline)}
.rank{position:absolute;top:10px;left:10px;z-index:2;display:grid;place-items:center;min-width:24px;height:24px;
  padding:0 8px;border-radius:999px;background:var(--ink);color:var(--bg);font:700 12px/1 var(--font)}
.thumb{height:240px;overflow:hidden;background:#fff;pointer-events:none}
.thumb iframe{width:1280px;height:960px;border:0;transform:scale(.25);transform-origin:0 0;display:block}
.card-body{padding:15px 16px 16px}
.card-titlerow{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:12px}
.card-title{font:600 15.5px/1.35 var(--font);color:var(--ink);text-wrap:pretty}
.card-time{flex:none;font:500 11px/1 var(--font);color:var(--muted)}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.tag{font:500 11px/1 var(--font);color:var(--ink);background:var(--accentSoft);padding:6px 10px;border-radius:999px}
.card-foot{display:flex;align-items:center;gap:14px;padding-top:13px;border-top:1px solid var(--softline);font:500 12px/1 var(--font);color:var(--muted)}

/* ---- 뷰어 프레임 · 복사 버튼 (완료 · 둘러보기 상세 · 업로드 미리보기 공유) ---- */
.full-frame{width:100%;height:70vh;min-height:420px;border:0;display:block;background:#fff}
.locked-frame{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;padding:24px;background:var(--panel2)}
.locked-frame .lock-ico{font-size:46px;line-height:1}
.locked-frame .lock-title{font:700 19px/1.3 var(--font);color:var(--ink)}
.locked-frame .lock-desc{font:400 14px/1.55 var(--font);color:var(--muted);max-width:360px;margin:4px 0 0;text-wrap:pretty}
.locked-frame .lock-open{margin-top:14px;padding:12px 24px;text-decoration:none}
.viewer-wrap{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel);box-shadow:var(--shadow)}
.viewer-chrome{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--softline);background:var(--panel2)}
.viewer-chrome .url{flex:1;font:500 12px/1 var(--font);color:var(--muted);background:var(--bg);border:1px solid var(--softline);border-radius:999px;padding:8px 14px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.dots{display:flex;gap:6px}
.dots i{width:10px;height:10px;border-radius:50%;background:rgba(0,0,0,.18)}
.copy{display:inline-flex;align-items:center;justify-content:center;padding:11px 22px;border-radius:999px;border:0;background:var(--accent);color:var(--accentInk);font:500 13px/1 var(--font);cursor:pointer;flex:none;transition:opacity .15s;text-decoration:none}
.copy:hover{opacity:.86}
.copy.copy-alt{background:var(--panel);color:var(--ink);border:1px solid var(--line)}
.copy.copy-alt:hover{opacity:1;background:var(--accentSoft)}

/* ---- 푸터 (블랙 밴드) / 토스트 ---- */
.footer{background:#000;color:rgba(255,255,255,.62);padding:clamp(40px,5vw,64px) clamp(20px,5vw,56px) 30px;font:500 13px/1.4 var(--font)}
.footer-inner{max-width:1180px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1.4fr;gap:clamp(28px,4vw,56px)}
.footer-brand{display:flex;flex-direction:column;gap:13px;max-width:320px}
.footer-logo{display:flex;align-items:center;gap:10px}
.footer-logo .logo-mark{background:#fff;color:#000}
.footer-logo .logo-text,.footer-logo .logo-text b{color:#fff}
.footer-tagline{color:rgba(255,255,255,.66);font:500 13px/1.5 var(--font)}
.footer-meta{color:rgba(255,255,255,.42);font:500 12px/1.6 var(--font);letter-spacing:.01em}
.footer-col{display:flex;flex-direction:column;gap:13px}
.footer-col h4{margin:0;color:rgba(255,255,255,.92);font:600 12px/1 var(--font);letter-spacing:.1em;text-transform:uppercase}
.footer-link{align-self:flex-start;background:none;border:0;padding:0;cursor:pointer;color:rgba(255,255,255,.62);font:500 13.5px/1 var(--font);text-decoration:none;transition:color .15s}
.footer-link:hover{color:#fff}
.footer-tags{display:flex;flex-wrap:wrap;gap:8px}
.footer-chip{padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.72);cursor:pointer;font:500 12px/1 var(--font);transition:border-color .15s,color .15s,background .15s;text-decoration:none}
.footer-chip:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.06)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px 24px;flex-wrap:wrap;
  margin-top:clamp(30px,4vw,44px);padding-top:22px;border-top:1px solid rgba(255,255,255,.12)}
.footer-bottom-left{display:flex;flex-direction:column;gap:5px}
.footer-copy{color:rgba(255,255,255,.62)}
.footer-lang{background:rgba(255,255,255,.1);border:0;border-radius:999px;cursor:pointer;padding:9px 16px;color:#fff;font:500 13px/1 var(--font);transition:background .15s}
.footer-lang:hover{background:rgba(255,255,255,.2)}
.footer-legal{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.footer-legal .sep{color:rgba(255,255,255,.3)}
.toast{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:100;background:var(--ink);
  color:var(--bg);padding:13px 24px;border-radius:999px;font:500 14px/1 var(--font);box-shadow:0 12px 30px -8px rgba(0,0,0,.4)}

/* ---- 법적 고지 / 확인 모달 (이용약관 · 권리침해 신고 · 삭제 확인) ---- */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;
  justify-content:center;padding:clamp(16px,5vh,64px) 16px;overflow-y:auto;backdrop-filter:blur(2px)}
.modal{background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:16px;max-width:680px;
  width:100%;box-shadow:0 24px 60px -20px rgba(0,0,0,.5);display:flex;flex-direction:column;overflow:hidden;
  max-height:calc(100vh - clamp(32px,10vh,128px));max-height:calc(100dvh - clamp(32px,10vh,128px))}
.modal-head{flex:none;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px clamp(20px,4vw,32px);border-bottom:1px solid var(--softline);background:var(--bg);border-radius:16px 16px 0 0}
.modal-title{font:700 20px/1.25 var(--font);margin:0}
.modal-close{background:var(--accentSoft);border:0;cursor:pointer;width:34px;height:34px;border-radius:50%;
  font:400 17px/1 var(--font);color:var(--ink);display:grid;place-items:center;flex:none;transition:filter .15s}
.modal-close:hover{filter:brightness(.95)}
.modal-body{padding:clamp(20px,4vw,32px);overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.legal-sec{margin-bottom:22px}
.legal-sec:last-child{margin-bottom:0}
.legal-sec h3{font:700 15px/1.4 var(--font);margin:0 0 8px}
.legal-sec p{margin:0 0 10px;font:400 14.5px/1.7 var(--font);color:var(--muted)}
.legal-sec ul{margin:0 0 10px;padding-left:20px;color:var(--muted);font:400 14.5px/1.7 var(--font)}
.legal-sec li{margin-bottom:5px}
.legal-mail{display:inline-flex;align-items:center;gap:8px;margin:6px 0 4px;background:var(--accent);
  color:var(--accentInk);text-decoration:none;padding:11px 20px;border-radius:999px;font:500 14px/1 var(--font)}
.legal-mail:hover{opacity:.86}
.legal-eff{font:500 12px/1.5 var(--font);color:var(--mute);margin-top:8px;padding-top:14px;border-top:1px solid var(--softline)}

/* ---- 모바일 헤더: 네비게이션 링크를 햄버거(☰) 토글 뒤 드롭다운으로 접는다 ---- */
@media(max-width:600px){
  .header{padding:12px 16px;gap:10px}
  .logo{gap:9px}
  .logo-mark{width:30px;height:30px}
  .logo-text{font-size:17px}
  .menu-toggle{display:flex}
  .menu-toggle[aria-expanded="true"] .ico-menu{display:none}
  .menu-toggle[aria-expanded="true"] .ico-close{display:block}
  .nav{position:absolute;top:calc(100% + 8px);right:16px;flex-direction:column;align-items:stretch;
    gap:4px;min-width:184px;padding:8px;background:var(--bg);border:1px solid var(--line);
    border-radius:14px;box-shadow:var(--shadow);display:none;z-index:60}
  .nav.open{display:flex}
  .nav-link{width:100%;text-align:left;padding:12px 14px;border-radius:9px;font-size:15px}
  .nav-link:hover,.nav-link.active{background:var(--accentSoft);color:var(--ink)}
  .nav .lang{margin-top:4px;padding:11px 14px;font-size:13px}
  .btn-up{white-space:nowrap;padding:10px 16px;font-size:14px}
  .footer-top{grid-template-columns:1fr;gap:30px}
  .footer-brand{max-width:none}
  /* iOS Safari는 16px 미만 입력 필드를 포커스하면 화면을 자동 확대한다. 줌이 틀어지지 않도록 16px로 고정. */
  .search input,.code,.field{font-size:16px}
}
