design: 글래스모피즘 디자인 전면 적용
- 관리자 페이지: 사이드바/카드/모달/폼 유리 효과 - 로그인 페이지: 유리 카드 + 강화된 배경 효과 - 비주얼 매퍼: 유리 패널 + 스텝카드 - 공개 페이지(목록/랜딩): 유리 카드 + 애니메이션 그라데이션 배경 - 전체 backdrop-filter blur + 반투명 배경 + 애니메이션 오브
This commit is contained in:
+35
-31
@@ -314,42 +314,44 @@ ${adsenseScript}
|
||||
<script type="application/ld+json">${jsonLdData}</script>
|
||||
<link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🎯</text></svg>">
|
||||
<style>
|
||||
:root{--primary:#6c5ce7;--primary-light:#a29bfe;--bg:#0a0a1a;--bg-card:#12122a;--bg-card-hover:#1a1a3e;--text:#e0e0ee;--text-muted:#7878aa;--accent:#00cec9;--gold:#ffd700;--silver:#c0c0c0;--bronze:#cd7f32;--danger:#ff6b6b;--border:#1e1e44;--star:#f9ca24}
|
||||
:root{--primary:#6c5ce7;--primary-light:#a29bfe;--bg:#080b16;--bg-card:#12122a;--bg-card-hover:#1a1a3e;--text:#e0e0ee;--text-muted:#7878aa;--accent:#00cec9;--gold:#ffd700;--silver:#c0c0c0;--bronze:#cd7f32;--danger:#ff6b6b;--border:#1e1e44;--star:#f9ca24}
|
||||
*{margin:0;padding:0;box-sizing:border-box}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}
|
||||
.header{background:linear-gradient(135deg,#0a0a2e 0%,#1a0a3e 50%,#0a1a3e 100%);padding:2.5rem 1rem 2rem;text-align:center;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
|
||||
.header h1{font-size:1.8rem;font-weight:800;color:#fff;position:relative;z-index:1}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;position:relative;overflow-x:hidden}
|
||||
body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;background:radial-gradient(600px circle at 20% 20%,rgba(108,92,231,.12),transparent 50%),radial-gradient(500px circle at 80% 60%,rgba(0,206,201,.08),transparent 50%),radial-gradient(400px circle at 50% 80%,rgba(139,92,246,.06),transparent 50%);animation:bgShift 15s ease-in-out infinite alternate;pointer-events:none}
|
||||
@keyframes bgShift{0%{transform:translate(0,0) scale(1)}50%{transform:translate(-20px,15px) scale(1.05)}100%{transform:translate(15px,-10px) scale(1)}}
|
||||
.header{background:rgba(10,10,30,.5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:2.5rem 1rem 2rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.08);position:relative;z-index:1}
|
||||
.header h1{font-size:1.8rem;font-weight:800;color:#fff}
|
||||
.version-badge{display:inline-block;background:var(--accent);color:#000;font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:12px;margin-left:.5rem;vertical-align:middle}
|
||||
.sub-info{color:var(--text-muted);font-size:.82rem;margin-top:.6rem;position:relative;z-index:1}
|
||||
.stats-row{display:inline-flex;gap:1rem;margin-top:1rem;position:relative;z-index:1;flex-wrap:wrap;justify-content:center}
|
||||
.stat-chip{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:.35rem .9rem;border-radius:20px;font-size:.75rem;color:var(--accent)}
|
||||
.container{max-width:960px;margin:0 auto;padding:1.5rem 1rem}
|
||||
.ad-box{background:var(--bg-card);border:1px dashed var(--border);border-radius:10px;padding:.8rem;margin:1.2rem 0;text-align:center;min-height:100px}
|
||||
.sub-info{color:var(--text-muted);font-size:.82rem;margin-top:.6rem}
|
||||
.stats-row{display:inline-flex;gap:1rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}
|
||||
.stat-chip{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);padding:.35rem .9rem;border-radius:20px;font-size:.75rem;color:var(--accent)}
|
||||
.container{max-width:960px;margin:0 auto;padding:1.5rem 1rem;position:relative;z-index:1}
|
||||
.ad-box{background:rgba(255,255,255,.03);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px dashed rgba(255,255,255,.08);border-radius:12px;padding:.8rem;margin:1.2rem 0;text-align:center;min-height:100px}
|
||||
.ad-box .ad-label{font-size:.65rem;color:var(--text-muted);margin-bottom:.3rem;text-transform:uppercase;letter-spacing:1px}
|
||||
.section-header{display:flex;align-items:center;gap:.6rem;margin:1.8rem 0 1rem;padding-bottom:.6rem;border-bottom:2px solid var(--border)}
|
||||
.section-header{display:flex;align-items:center;gap:.6rem;margin:1.8rem 0 1rem;padding-bottom:.6rem;border-bottom:2px solid rgba(255,255,255,.08)}
|
||||
.section-header h2{font-size:1.15rem;font-weight:700;color:#fff}
|
||||
.badge{background:var(--primary);color:#fff;font-size:.7rem;padding:.15rem .5rem;border-radius:10px}
|
||||
.badge{background:rgba(108,92,231,.3);backdrop-filter:blur(4px);color:#fff;font-size:.7rem;padding:.15rem .5rem;border-radius:10px;border:1px solid rgba(108,92,231,.3)}
|
||||
.rank-list{display:flex;flex-direction:column;gap:.6rem}
|
||||
.rank-card{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1rem 1.2rem;transition:all .2s;text-decoration:none;color:inherit}
|
||||
.rank-card:hover{background:var(--bg-card-hover);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 25px rgba(108,92,231,.15)}
|
||||
.rank-card{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:1rem;background:rgba(255,255,255,.04);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1rem 1.2rem;transition:all .25s;text-decoration:none;color:inherit;box-shadow:0 4px 20px rgba(0,0,0,.2)}
|
||||
.rank-card:hover{background:rgba(255,255,255,.08);border-color:rgba(108,92,231,.4);transform:translateY(-2px);box-shadow:0 8px 30px rgba(108,92,231,.2)}
|
||||
.rank-card.inactive{opacity:.45;border-style:dashed}
|
||||
.rank-num{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;background:var(--border);color:var(--text-muted);flex-shrink:0}
|
||||
.rank-num.r1{background:linear-gradient(135deg,#ffd700,#f0c800);color:#1a1a00;box-shadow:0 4px 15px rgba(255,215,0,.3)}
|
||||
.rank-num.r2{background:linear-gradient(135deg,#e0e0e0,#b0b0b0);color:#1a1a1a;box-shadow:0 4px 12px rgba(192,192,192,.2)}
|
||||
.rank-num.r3{background:linear-gradient(135deg,#cd7f32,#b06820);color:#fff;box-shadow:0 4px 12px rgba(205,127,50,.2)}
|
||||
.rank-num{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text-muted);flex-shrink:0}
|
||||
.rank-num.r1{background:linear-gradient(135deg,#ffd700,#f0c800);color:#1a1a00;border:none;box-shadow:0 4px 15px rgba(255,215,0,.3)}
|
||||
.rank-num.r2{background:linear-gradient(135deg,#e0e0e0,#b0b0b0);color:#1a1a1a;border:none;box-shadow:0 4px 12px rgba(192,192,192,.2)}
|
||||
.rank-num.r3{background:linear-gradient(135deg,#cd7f32,#b06820);color:#fff;border:none;box-shadow:0 4px 12px rgba(205,127,50,.2)}
|
||||
.rank-body{min-width:0}
|
||||
.rank-name{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.2rem}
|
||||
.rank-card.inactive .rank-name{text-decoration:line-through;color:var(--text-muted)}
|
||||
.rank-url{font-size:.78rem;color:var(--accent);word-break:break-all;opacity:.85}
|
||||
.rank-features{display:inline-flex;align-items:center;gap:.3rem;margin-top:.3rem}
|
||||
.feature-tag{background:rgba(108,92,231,.15);color:var(--primary-light);font-size:.7rem;padding:.15rem .5rem;border-radius:6px;font-weight:600}
|
||||
.feature-tag{background:rgba(108,92,231,.12);border:1px solid rgba(108,92,231,.2);color:var(--primary-light);font-size:.7rem;padding:.15rem .5rem;border-radius:6px;font-weight:600}
|
||||
.stars{color:var(--star);font-size:.8rem;letter-spacing:1px}
|
||||
.rank-arrow{color:var(--text-muted);font-size:1.3rem;transition:all .2s;flex-shrink:0}
|
||||
.rank-card:hover .rank-arrow{color:var(--accent);transform:translateX(3px)}
|
||||
.notice-box{background:linear-gradient(135deg,rgba(255,107,107,.08),rgba(255,107,107,.03));border:1px solid rgba(255,107,107,.2);border-radius:12px;padding:1.2rem 1.5rem;margin:1.5rem 0;font-size:.85rem;line-height:1.7}
|
||||
.notice-box{background:rgba(255,107,107,.06);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,107,107,.15);border-radius:14px;padding:1.2rem 1.5rem;margin:1.5rem 0;font-size:.85rem;line-height:1.7}
|
||||
.notice-box h3{color:var(--danger);font-size:.9rem;margin-bottom:.5rem}
|
||||
.notice-box p{color:var(--text-muted)}
|
||||
.footer{text-align:center;padding:2rem 1rem;margin-top:2rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.75rem}
|
||||
.footer{text-align:center;padding:2rem 1rem;margin-top:2rem;border-top:1px solid rgba(255,255,255,.08);color:var(--text-muted);font-size:.75rem;position:relative;z-index:1}
|
||||
.footer a{color:var(--primary-light);text-decoration:none}
|
||||
@media(max-width:640px){.header h1{font-size:1.3rem}.version-badge{display:block;margin:.5rem auto 0;width:fit-content}.rank-card{grid-template-columns:40px 1fr auto;padding:.8rem;gap:.7rem}.rank-num{width:40px;height:40px;font-size:.95rem;border-radius:10px}.rank-name{font-size:.95rem}}
|
||||
</style>
|
||||
@@ -437,15 +439,17 @@ ${adsenseScript}
|
||||
<script type="application/ld+json">${jsonLdData}</script>
|
||||
<link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>📄</text></svg>">
|
||||
<style>
|
||||
:root{--primary:#6c5ce7;--primary-light:#a29bfe;--bg:#0f0f23;--bg-card:#1a1a2e;--text:#e0e0ee;--text-muted:#8888aa;--accent:#00cec9;--border:#2a2a4a}
|
||||
:root{--primary:#6c5ce7;--primary-light:#a29bfe;--bg:#080b16;--bg-card:#1a1a2e;--text:#e0e0ee;--text-muted:#8888aa;--accent:#00cec9;--border:#2a2a4a}
|
||||
*{margin:0;padding:0;box-sizing:border-box}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);line-height:1.8;min-height:100vh}
|
||||
.lp-header{background:linear-gradient(135deg,#0a0a2e 0%,#1a0a3e 50%,#0a1a3e 100%);padding:2.5rem 1rem 2rem;text-align:center;border-bottom:1px solid var(--border)}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);line-height:1.8;min-height:100vh;position:relative;overflow-x:hidden}
|
||||
body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;background:radial-gradient(600px circle at 30% 25%,rgba(108,92,231,.12),transparent 50%),radial-gradient(500px circle at 70% 70%,rgba(0,206,201,.08),transparent 50%),radial-gradient(400px circle at 50% 50%,rgba(139,92,246,.06),transparent 50%);animation:bgShift 15s ease-in-out infinite alternate;pointer-events:none}
|
||||
@keyframes bgShift{0%{transform:translate(0,0) scale(1)}50%{transform:translate(-20px,15px) scale(1.05)}100%{transform:translate(15px,-10px) scale(1)}}
|
||||
.lp-header{background:rgba(10,10,30,.5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:2.5rem 1rem 2rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.08);position:relative;z-index:1}
|
||||
.lp-header h1{font-size:1.6rem;font-weight:800;color:#fff}
|
||||
.lp-header .sub{color:var(--text-muted);font-size:.8rem;margin-top:.5rem}
|
||||
.lp-container{max-width:900px;margin:0 auto;padding:2rem 1rem}
|
||||
.lp-content{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:2rem;margin:1rem 0;font-size:.95rem;line-height:1.9;word-break:keep-all}
|
||||
.lp-content img{max-width:100%;height:auto;border-radius:8px;margin:1rem 0}
|
||||
.lp-container{max-width:900px;margin:0 auto;padding:2rem 1rem;position:relative;z-index:1}
|
||||
.lp-content{background:rgba(255,255,255,.04);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:2rem;margin:1rem 0;font-size:.95rem;line-height:1.9;word-break:keep-all;box-shadow:0 8px 32px rgba(0,0,0,.3)}
|
||||
.lp-content img{max-width:100%;height:auto;border-radius:10px;margin:1rem 0}
|
||||
.lp-content h1,.lp-content h2,.lp-content h3{color:#fff;margin:1.5rem 0 .8rem;font-weight:700}
|
||||
.lp-content h1{font-size:1.5rem}.lp-content h2{font-size:1.25rem}.lp-content h3{font-size:1.1rem}
|
||||
.lp-content p{margin:.8rem 0;color:var(--text)}
|
||||
@@ -453,11 +457,11 @@ body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans
|
||||
.lp-content ul,.lp-content ol{margin:.8rem 0 .8rem 1.5rem}
|
||||
.lp-content li{margin:.3rem 0}
|
||||
.lp-content table{width:100%;border-collapse:collapse;margin:1rem 0}
|
||||
.lp-content th,.lp-content td{border:1px solid var(--border);padding:.6rem .8rem;text-align:left}
|
||||
.lp-content th{background:rgba(108,92,231,.15);color:#fff}
|
||||
.lp-content blockquote{border-left:3px solid var(--primary);padding:.5rem 1rem;margin:1rem 0;background:rgba(108,92,231,.05);border-radius:0 8px 8px 0}
|
||||
.ad-box{background:var(--bg-card);border:1px dashed var(--border);border-radius:10px;padding:.8rem;margin:1.2rem 0;text-align:center;min-height:100px}
|
||||
.lp-footer{text-align:center;padding:2rem 1rem;margin-top:2rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.75rem}
|
||||
.lp-content th,.lp-content td{border:1px solid rgba(255,255,255,.08);padding:.6rem .8rem;text-align:left}
|
||||
.lp-content th{background:rgba(108,92,231,.1);color:#fff}
|
||||
.lp-content blockquote{border-left:3px solid var(--primary);padding:.5rem 1rem;margin:1rem 0;background:rgba(108,92,231,.06);backdrop-filter:blur(6px);border-radius:0 10px 10px 0}
|
||||
.ad-box{background:rgba(255,255,255,.03);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px dashed rgba(255,255,255,.08);border-radius:12px;padding:.8rem;margin:1.2rem 0;text-align:center;min-height:100px}
|
||||
.lp-footer{text-align:center;padding:2rem 1rem;margin-top:2rem;border-top:1px solid rgba(255,255,255,.08);color:var(--text-muted);font-size:.75rem;position:relative;z-index:1}
|
||||
@media(max-width:640px){.lp-header h1{font-size:1.3rem}.lp-content{padding:1.2rem}}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
+34
-30
@@ -5,51 +5,54 @@
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title><%= typeof pageTitle !== 'undefined' ? pageTitle : 'Crawl Manager' %></title>
|
||||
<style>
|
||||
:root{--bg:#111827;--bg2:#1f2937;--bg3:#374151;--text:#f9fafb;--muted:#9ca3af;--primary:#6366f1;--primary-hover:#818cf8;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--border:#374151;--radius:8px}
|
||||
:root{--bg:#0a0e1a;--bg2:#1f2937;--bg3:#374151;--text:#f9fafb;--muted:#9ca3af;--primary:#6366f1;--primary-hover:#818cf8;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--border:#374151;--radius:12px;--glass-bg:rgba(255,255,255,.05);--glass-bg-hover:rgba(255,255,255,.08);--glass-border:rgba(255,255,255,.1);--glass-border-hover:rgba(255,255,255,.18);--glass-blur:blur(12px);--glass-blur-heavy:blur(20px);--glass-shadow:0 8px 32px rgba(0,0,0,.3)}
|
||||
*{margin:0;padding:0;box-sizing:border-box}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;position:relative;overflow-x:hidden}
|
||||
body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;background:radial-gradient(600px circle at 20% 30%,rgba(99,102,241,.12),transparent 50%),radial-gradient(500px circle at 80% 70%,rgba(6,182,212,.08),transparent 50%),radial-gradient(400px circle at 50% 50%,rgba(139,92,246,.06),transparent 50%);animation:bgShift 15s ease-in-out infinite alternate;pointer-events:none}
|
||||
@keyframes bgShift{0%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,20px) scale(1.05)}100%{transform:translate(20px,-15px) scale(1)}}
|
||||
|
||||
/* 사이드바 */
|
||||
.sidebar{width:220px;background:var(--bg2);border-right:1px solid var(--border);padding:1.5rem 0;flex-shrink:0;position:fixed;top:0;left:0;height:100vh;overflow-y:auto}
|
||||
.sidebar .logo{padding:0 1.2rem 1.5rem;font-size:1.1rem;font-weight:700;color:var(--primary);border-bottom:1px solid var(--border);margin-bottom:1rem}
|
||||
.sidebar nav a{display:flex;align-items:center;gap:.6rem;padding:.7rem 1.2rem;color:var(--muted);text-decoration:none;font-size:.88rem;transition:all .15s}
|
||||
.sidebar nav a:hover,.sidebar nav a.active{color:var(--text);background:var(--bg3)}
|
||||
.sidebar nav a.active{border-left:3px solid var(--primary)}
|
||||
.sidebar{width:220px;background:rgba(15,20,35,.75);backdrop-filter:var(--glass-blur-heavy);-webkit-backdrop-filter:var(--glass-blur-heavy);border-right:1px solid var(--glass-border);padding:1.5rem 0;flex-shrink:0;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:2}
|
||||
.sidebar .logo{padding:0 1.2rem 1.5rem;font-size:1.1rem;font-weight:700;color:var(--primary);border-bottom:1px solid var(--glass-border);margin-bottom:1rem}
|
||||
.sidebar nav a{display:flex;align-items:center;gap:.6rem;padding:.7rem 1.2rem;color:var(--muted);text-decoration:none;font-size:.88rem;transition:all .2s;border-left:3px solid transparent}
|
||||
.sidebar nav a:hover{color:var(--text);background:rgba(255,255,255,.05)}
|
||||
.sidebar nav a.active{color:var(--text);background:rgba(99,102,241,.1);border-left:3px solid var(--primary)}
|
||||
|
||||
/* 메인 */
|
||||
.main{margin-left:220px;flex:1;min-height:100vh}
|
||||
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:.8rem 1.5rem;display:flex;justify-content:space-between;align-items:center}
|
||||
.main{margin-left:220px;flex:1;min-height:100vh;position:relative;z-index:1}
|
||||
.topbar{background:rgba(15,20,35,.6);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);padding:.8rem 1.5rem;display:flex;justify-content:space-between;align-items:center}
|
||||
.topbar h1{font-size:1.1rem;font-weight:600}
|
||||
.content{padding:1.5rem}
|
||||
|
||||
/* 카드 */
|
||||
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;margin-bottom:1rem}
|
||||
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}
|
||||
.card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.2rem;margin-bottom:1rem;box-shadow:var(--glass-shadow);transition:all .2s}
|
||||
.card:hover{border-color:var(--glass-border-hover)}
|
||||
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid var(--glass-border)}
|
||||
.card-header h2{font-size:1rem;font-weight:600}
|
||||
|
||||
/* 버튼 */
|
||||
.btn{padding:.5rem 1rem;border:none;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:.4rem}
|
||||
.btn-primary{background:var(--primary);color:#fff}
|
||||
.btn-primary:hover{background:var(--primary-hover)}
|
||||
.btn-danger{background:var(--danger);color:#fff}
|
||||
.btn-danger:hover{opacity:.8}
|
||||
.btn-success{background:var(--success);color:#fff}
|
||||
.btn-warning{background:var(--warning);color:#000}
|
||||
.btn{padding:.5rem 1rem;border:none;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem}
|
||||
.btn-primary{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;box-shadow:0 4px 15px rgba(99,102,241,.3)}
|
||||
.btn-primary:hover{background:linear-gradient(135deg,var(--primary-hover),#8b5cf6);transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,.4)}
|
||||
.btn-danger{background:linear-gradient(135deg,var(--danger),#dc2626);color:#fff}
|
||||
.btn-danger:hover{opacity:.9;transform:translateY(-1px)}
|
||||
.btn-success{background:linear-gradient(135deg,var(--success),#16a34a);color:#fff}
|
||||
.btn-warning{background:linear-gradient(135deg,var(--warning),#d97706);color:#000}
|
||||
.btn-sm{padding:.35rem .7rem;font-size:.78rem}
|
||||
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
|
||||
.btn-outline:hover{background:var(--bg3)}
|
||||
.btn-outline{background:rgba(255,255,255,.03);border:1px solid var(--glass-border);color:var(--text)}
|
||||
.btn-outline:hover{background:rgba(255,255,255,.08);border-color:var(--glass-border-hover)}
|
||||
|
||||
/* 테이블 */
|
||||
table{width:100%;border-collapse:collapse}
|
||||
th,td{padding:.6rem .8rem;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}
|
||||
th,td{padding:.6rem .8rem;text-align:left;border-bottom:1px solid var(--glass-border);font-size:.85rem}
|
||||
th{color:var(--muted);font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px}
|
||||
tr:hover td{background:rgba(255,255,255,.02)}
|
||||
tr:hover td{background:rgba(255,255,255,.04)}
|
||||
|
||||
/* 폼 */
|
||||
.form-group{margin-bottom:1rem}
|
||||
.form-group label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.3rem;font-weight:500}
|
||||
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.55rem .8rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.88rem;font-family:inherit}
|
||||
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}
|
||||
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.55rem .8rem;background:rgba(0,0,0,.3);border:1px solid var(--glass-border);border-radius:var(--radius);color:var(--text);font-size:.88rem;font-family:inherit;transition:all .2s}
|
||||
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.15);background:rgba(0,0,0,.4)}
|
||||
.form-group textarea{resize:vertical;min-height:80px;font-family:monospace}
|
||||
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
|
||||
|
||||
@@ -61,9 +64,9 @@ tr:hover td{background:rgba(255,255,255,.02)}
|
||||
.badge-info{background:rgba(99,102,241,.15);color:var(--primary-hover)}
|
||||
|
||||
/* 모달 */
|
||||
.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:100;align-items:center;justify-content:center}
|
||||
.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;align-items:center;justify-content:center}
|
||||
.modal-overlay.active{display:flex}
|
||||
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}
|
||||
.modal{background:rgba(15,20,35,.85);backdrop-filter:var(--glass-blur-heavy);-webkit-backdrop-filter:var(--glass-blur-heavy);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px rgba(0,0,0,.5)}
|
||||
.modal h3{margin-bottom:1rem;font-size:1rem}
|
||||
|
||||
/* 유틸 */
|
||||
@@ -77,19 +80,20 @@ tr:hover td{background:rgba(255,255,255,.02)}
|
||||
|
||||
/* 통계 카드 */
|
||||
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}
|
||||
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
|
||||
.stat-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1rem;transition:all .2s;box-shadow:var(--glass-shadow)}
|
||||
.stat-card:hover{background:var(--glass-bg-hover);transform:translateY(-2px);border-color:var(--glass-border-hover)}
|
||||
.stat-card .number{font-size:1.8rem;font-weight:700}
|
||||
.stat-card .label{color:var(--muted);font-size:.8rem;margin-top:.2rem}
|
||||
|
||||
/* 토스트 */
|
||||
.toast{position:fixed;top:1rem;right:1rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:.8rem 1.2rem;z-index:200;display:none;font-size:.85rem;box-shadow:0 4px 20px rgba(0,0,0,.3)}
|
||||
.toast{position:fixed;top:1rem;right:1rem;background:rgba(15,20,35,.85);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);padding:.8rem 1.2rem;z-index:200;display:none;font-size:.85rem;box-shadow:0 8px 32px rgba(0,0,0,.4)}
|
||||
.toast.show{display:block;animation:slideIn .3s}
|
||||
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
|
||||
|
||||
/* 크론 프리셋 */
|
||||
.cron-presets{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}
|
||||
.cron-presets .preset{padding:.25rem .6rem;background:var(--bg3);border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:.75rem;color:var(--muted)}
|
||||
.cron-presets .preset:hover{border-color:var(--primary);color:var(--text)}
|
||||
.cron-presets .preset{padding:.25rem .6rem;background:rgba(255,255,255,.05);border:1px solid var(--glass-border);border-radius:6px;cursor:pointer;font-size:.75rem;color:var(--muted);transition:all .2s}
|
||||
.cron-presets .preset:hover{border-color:var(--primary);color:var(--text);background:rgba(99,102,241,.1)}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
+12
-12
@@ -5,36 +5,36 @@
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Crawl Manager - 로그인</title>
|
||||
<style>
|
||||
:root{--bg:#0f172a;--card:#1e293b;--border:#334155;--primary:#6366f1;--primary-hover:#818cf8;--text:#f1f5f9;--muted:#94a3b8;--danger:#ef4444;--radius:12px}
|
||||
:root{--bg:#0a0e1a;--card:#1e293b;--border:#334155;--primary:#6366f1;--primary-hover:#818cf8;--text:#f1f5f9;--muted:#94a3b8;--danger:#ef4444;--radius:12px}
|
||||
*{margin:0;padding:0;box-sizing:border-box}
|
||||
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
|
||||
|
||||
/* 배경 애니메이션 */
|
||||
.bg-glow{position:fixed;top:-50%;left:-50%;width:200%;height:200%;z-index:0}
|
||||
.bg-glow::before,.bg-glow::after{content:'';position:absolute;border-radius:50%;filter:blur(80px);opacity:.15}
|
||||
.bg-glow::before{top:20%;left:30%;width:400px;height:400px;background:#6366f1;animation:float 8s ease-in-out infinite}
|
||||
.bg-glow::after{bottom:20%;right:30%;width:350px;height:350px;background:#06b6d4;animation:float 8s ease-in-out infinite reverse}
|
||||
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}
|
||||
.bg-glow::before,.bg-glow::after{content:'';position:absolute;border-radius:50%;filter:blur(100px);opacity:.2}
|
||||
.bg-glow::before{top:20%;left:25%;width:500px;height:500px;background:#6366f1;animation:float 10s ease-in-out infinite}
|
||||
.bg-glow::after{bottom:15%;right:25%;width:450px;height:450px;background:#06b6d4;animation:float 10s ease-in-out infinite reverse}
|
||||
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}
|
||||
|
||||
.login-container{position:relative;z-index:1;width:100%;max-width:420px;padding:1rem}
|
||||
|
||||
.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2.5rem 2rem;box-shadow:0 25px 50px rgba(0,0,0,.3)}
|
||||
.login-card{background:rgba(30,41,59,.45);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2.5rem 2rem;box-shadow:0 25px 60px rgba(0,0,0,.4)}
|
||||
|
||||
.logo{text-align:center;margin-bottom:2rem}
|
||||
.logo .icon{width:56px;height:56px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1rem;box-shadow:0 8px 20px rgba(99,102,241,.3)}
|
||||
.logo .icon{width:56px;height:56px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1rem;box-shadow:0 8px 25px rgba(99,102,241,.4);border:1px solid rgba(255,255,255,.15)}
|
||||
.logo h1{font-size:1.3rem;font-weight:700;letter-spacing:-.5px}
|
||||
.logo p{color:var(--muted);font-size:.82rem;margin-top:.3rem}
|
||||
|
||||
.form-group{margin-bottom:1.2rem}
|
||||
.form-group label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.4rem;font-weight:500}
|
||||
.form-group input{width:100%;padding:.75rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.92rem;transition:border-color .2s;outline:none}
|
||||
.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.15)}
|
||||
.form-group input{width:100%;padding:.75rem 1rem;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);color:var(--text);font-size:.92rem;transition:all .2s;outline:none}
|
||||
.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.2);background:rgba(0,0,0,.4)}
|
||||
.form-group input::placeholder{color:#475569}
|
||||
|
||||
.error-msg{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:8px;padding:.6rem 1rem;margin-bottom:1.2rem;font-size:.82rem;color:var(--danger);display:flex;align-items:center;gap:.5rem}
|
||||
.error-msg{background:rgba(239,68,68,.08);backdrop-filter:blur(8px);border:1px solid rgba(239,68,68,.2);border-radius:10px;padding:.6rem 1rem;margin-bottom:1.2rem;font-size:.82rem;color:var(--danger);display:flex;align-items:center;gap:.5rem}
|
||||
|
||||
.btn-login{width:100%;padding:.8rem;background:linear-gradient(135deg,#6366f1,#7c3aed);border:none;border-radius:var(--radius);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}
|
||||
.btn-login:hover{background:linear-gradient(135deg,#818cf8,#8b5cf6);transform:translateY(-1px);box-shadow:0 8px 20px rgba(99,102,241,.3)}
|
||||
.btn-login{width:100%;padding:.8rem;background:linear-gradient(135deg,#6366f1,#7c3aed);border:none;border-radius:var(--radius);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem;box-shadow:0 4px 15px rgba(99,102,241,.3)}
|
||||
.btn-login:hover{background:linear-gradient(135deg,#818cf8,#8b5cf6);transform:translateY(-2px);box-shadow:0 8px 30px rgba(99,102,241,.4)}
|
||||
.btn-login:active{transform:translateY(0)}
|
||||
|
||||
.footer-text{text-align:center;margin-top:1.5rem;font-size:.75rem;color:#475569}
|
||||
|
||||
@@ -2,22 +2,23 @@
|
||||
|
||||
<style>
|
||||
.mapper-wrap{display:grid;grid-template-columns:1fr 340px;gap:1rem;height:calc(100vh - 120px)}
|
||||
.preview-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
|
||||
.preview-panel .toolbar{padding:.6rem .8rem;border-bottom:1px solid var(--border);display:flex;gap:.5rem;align-items:center;flex-shrink:0}
|
||||
.preview-panel{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--glass-shadow)}
|
||||
.preview-panel .toolbar{padding:.6rem .8rem;border-bottom:1px solid var(--glass-border);display:flex;gap:.5rem;align-items:center;flex-shrink:0;background:rgba(255,255,255,.02)}
|
||||
.preview-panel .toolbar input{flex:1}
|
||||
.preview-panel iframe{flex:1;width:100%;border:none;background:#fff}
|
||||
.config-panel{display:flex;flex-direction:column;gap:.8rem;overflow-y:auto}
|
||||
.step-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
|
||||
.step-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1rem;box-shadow:var(--glass-shadow);transition:all .2s}
|
||||
.step-card:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover)}
|
||||
.step-card h3{font-size:.9rem;margin-bottom:.6rem;color:var(--primary)}
|
||||
.step-card .step-num{display:inline-block;background:var(--primary);color:#fff;width:22px;height:22px;border-radius:50%;text-align:center;line-height:22px;font-size:.75rem;font-weight:700;margin-right:.4rem}
|
||||
.field-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.4rem .6rem;background:var(--bg);border-radius:6px;font-size:.82rem}
|
||||
.step-card .step-num{display:inline-block;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;width:22px;height:22px;border-radius:50%;text-align:center;line-height:22px;font-size:.75rem;font-weight:700;margin-right:.4rem;box-shadow:0 2px 8px rgba(99,102,241,.3)}
|
||||
.field-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.4rem .6rem;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.05);border-radius:8px;font-size:.82rem}
|
||||
.field-row .field-name{width:70px;font-weight:600;flex-shrink:0}
|
||||
.field-row .field-selector{flex:1;color:var(--muted);font-family:monospace;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
||||
.field-row .field-selector.mapped{color:var(--success)}
|
||||
.field-row button{flex-shrink:0}
|
||||
.mapping-active{outline:3px solid var(--primary)!important;animation:pulse .8s infinite}
|
||||
@keyframes pulse{0%,100%{outline-color:var(--primary)}50%{outline-color:var(--success)}}
|
||||
.json-preview{background:var(--bg);padding:.8rem;border-radius:var(--radius);font-size:.72rem;font-family:monospace;white-space:pre-wrap;max-height:200px;overflow:auto;color:var(--success)}
|
||||
.json-preview{background:rgba(0,0,0,.3);border:1px solid var(--glass-border);padding:.8rem;border-radius:var(--radius);font-size:.72rem;font-family:monospace;white-space:pre-wrap;max-height:200px;overflow:auto;color:var(--success)}
|
||||
</style>
|
||||
|
||||
<div class="mapper-wrap">
|
||||
|
||||
Reference in New Issue
Block a user