/* /change/art/art_components.php — 공유 header.php 위에 얹는 갤러리아이 전용 컴포넌트 CSS (색상은 header가 주입하는 --accent-gold(art=vibrant orange)를 그대로 사용) */ .art-brand { text-align:center; margin-bottom:18px; } .art-name { font-weight:900; font-size:1.4rem; color:var(--accent-gold); letter-spacing:-0.5px; } .art-name small { display:block; font-size:.78rem; font-weight:600; color:var(--text-muted); margin-top:2px; letter-spacing:0; } .legal-notice { background:rgba(234,88,12,.08); border:1px dashed var(--accent-gold); border-radius:10px; padding:14px 16px; font-size:.82rem; color:var(--text-main); line-height:1.55; margin:18px 0; } .legal-notice b { color:var(--accent-gold); } .art-bank { background:var(--highlight-bg); border:1px dashed var(--accent-gold); border-radius:12px; padding:18px; text-align:center; margin:15px 0; } .vip-banner { background:var(--accent-gold); color:#fff; text-align:center; padding:12px; font-weight:bold; font-size:.95rem; border-radius:8px; margin-bottom:14px; } .vip-banner a { color:#fff; text-decoration:underline; margin-left:12px; font-size:.85rem; } /* 아트 스타일 선택 칩 */ .style-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(100px,1fr)); gap:8px; margin-bottom:6px; } .style-chip { cursor:pointer; border:2px solid var(--input-border); background:var(--input-bg); color:var(--text-main); border-radius:10px; padding:12px 6px; text-align:center; font-weight:700; font-size:.82rem; transition:.15s; user-select:none; } .style-chip:hover { border-color:var(--accent-gold); } .style-chip.active { border-color:var(--accent-gold); background:var(--highlight-bg); color:var(--accent-gold); box-shadow:0 2px 8px rgba(0,0,0,.15); } /* 갤러리 선택 칩 */ .gallery-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:8px; margin-bottom:8px; } @media (min-width:480px) { .gallery-grid { grid-template-columns:repeat(4,1fr); } } .gallery-chip { cursor:pointer; border:2px solid var(--input-border); background:var(--input-bg); color:var(--text-main); border-radius:10px; padding:12px 6px; text-align:center; font-weight:700; font-size:.78rem; transition:.15s; user-select:none; } .gallery-chip:hover { border-color:var(--accent-gold); } .gallery-chip.active { border-color:var(--accent-gold); background:var(--highlight-bg); color:var(--accent-gold); box-shadow:0 2px 8px rgba(0,0,0,.15); } /* 기본 정보 입력 그리드 */ .info-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px 10px; } .field-cell { display:flex; flex-direction:column; gap:4px; } .field-cell.full { grid-column:1 / -1; } .field-label { font-size:.8rem; font-weight:700; color:var(--text-muted); padding-left:2px; } /* 크레딧 잔량 배지 + 충전 박스 */ .credit-badge { background:var(--highlight-bg); border:1px solid var(--accent-gold); border-radius:10px; padding:12px 14px; text-align:center; font-weight:700; color:var(--text-main); margin-bottom:12px; } .credit-badge span { color:var(--accent-gold); font-weight:800; } .charge-box { background:var(--bg-container); border:1px solid var(--border-color); border-radius:12px; padding:18px; margin-bottom:14px; } .pkg-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:8px; margin-bottom:6px; } @media (min-width:480px) { .pkg-grid { grid-template-columns:repeat(4,1fr); } } .pkg-chip { cursor:pointer; border:2px solid var(--input-border); background:var(--input-bg); border-radius:10px; padding:12px 6px; text-align:center; transition:.15s; user-select:none; position:relative; } .pkg-chip:hover { border-color:var(--accent-gold); } .pkg-chip.active { border-color:var(--accent-gold); background:var(--highlight-bg); box-shadow:0 2px 8px rgba(0,0,0,.15); } .pkg-chip .c { font-weight:800; font-size:1.05rem; color:var(--accent-gold); } .pkg-chip .a { font-size:.82rem; color:var(--text-main); font-weight:700; margin-top:2px; } .pkg-chip .u { font-size:.68rem; color:var(--text-muted); margin-top:2px; } .pkg-chip .badge-off { position:absolute; top:-8px; right:-6px; background:#e74c3c; color:#fff; font-size:.62rem; font-weight:800; padding:2px 6px; border-radius:10px; } .lock-overlay { text-align:center; background:var(--highlight-bg); border:1px dashed var(--accent-gold); border-radius:10px; padding:16px; margin-top:12px; } .lock-overlay b { color:var(--accent-gold); } /* 비포&애프터 슬라이더 (낙서 ↔ 명화) */ .comparison-slider { position:relative; width:100%; max-width:480px; margin:0 auto 16px; overflow:hidden; border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.5); background:#0a0a12; aspect-ratio:4/3; } .comparison-slider img { position:absolute; inset:0; width:100%; height:100%; object-fit:contain; pointer-events:none; background:#111; } .comparison-slider .img-after { clip-path:polygon(50% 0,100% 0,100% 100%,50% 100%); } .comparison-slider .slider-input { position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; z-index:10; } .comparison-slider .slider-line { position:absolute; top:0; left:50%; width:4px; height:100%; background:#fff; z-index:5; transform:translateX(-50%); pointer-events:none; box-shadow:0 0 10px rgba(0,0,0,.5); } .comparison-slider .slider-handle { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:40px; height:40px; background:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:bold; color:#333; box-shadow:0 2px 6px rgba(0,0,0,.4); z-index:6; } .comparison-slider .slider-labels { position:absolute; bottom:14px; width:100%; display:flex; justify-content:space-between; padding:0 16px; box-sizing:border-box; z-index:4; pointer-events:none; } .comparison-slider .label { background:rgba(0,0,0,.7); color:#fff; padding:5px 12px; border-radius:20px; font-size:.8rem; font-weight:bold; border:1px solid rgba(255,255,255,.2); } /* 갤러리씬 추가 출력 박스 */ .gallery-scene-box { border:2px solid var(--accent-gold); border-radius:12px; overflow:hidden; margin:16px 0; box-shadow:0 8px 24px rgba(0,0,0,.3); } .gallery-scene-box img { width:100%; display:block; } .gallery-scene-label { background:var(--accent-gold); color:#fff; text-align:center; padding:8px; font-weight:800; font-size:.85rem; } /* 리포트(마크다운 렌더) 영역 */ .report-box { background:var(--bg-container); border:1px solid var(--border-color); border-radius:12px; padding:20px 18px; margin:18px 0; text-align:left; line-height:1.7; font-size:.92rem; color:var(--text-main); } .report-box h2 { color:var(--accent-gold); font-size:1.08rem; font-weight:800; margin:18px 0 10px; border-bottom:1px solid var(--border-color); padding-bottom:6px; } .report-box h2:first-child { margin-top:0; } .report-box blockquote { border-left:3px solid var(--accent-gold); margin:10px 0; padding:6px 14px; background:var(--highlight-bg); border-radius:0 8px 8px 0; color:var(--text-main); } .report-box ul { padding-left:20px; margin:6px 0; } .report-box ol { padding-left:20px; margin:6px 0; } .report-box code { background:var(--input-bg); padding:1px 5px; border-radius:4px; } /* VIP 수익 구조 카드 */ .profit-card { background:var(--bg-container); border:1px solid var(--border-color); border-radius:12px; padding:20px; margin-bottom:14px; } .profit-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px dashed var(--border-color); font-size:.95rem; color:var(--text-muted); } .profit-row:last-child { border-bottom:none; } .profit-row b { color:var(--text-main); } .profit-row .hi { color:var(--accent-gold); font-weight:800; font-size:1.25rem; } /* 업로드 이미지 쌍 프리뷰 */ .upload-pair { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; } .upload-pair .upload-slot { border:2px dashed var(--input-border); border-radius:10px; padding:14px; text-align:center; font-size:.82rem; color:var(--text-muted); cursor:pointer; transition:.15s; } .upload-pair .upload-slot:hover { border-color:var(--accent-gold); } .upload-pair .upload-slot img { max-width:100%; border-radius:6px; margin-top:8px; display:none; } .upload-pair .upload-slot.has-img { border-color:var(--accent-gold); background:var(--highlight-bg); }