@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700;800&display=swap";:root{--background: #ffffff;--foreground: #1a1a2e;--card: #ffffff;--card-foreground: #1a1a2e;--primary: #1e3a5f;--primary-foreground: #ffffff;--primary-light: #2d5a8e;--primary-lighter: #e8eef6;--secondary: #f1f5f9;--secondary-foreground: #1e3a5f;--muted: #f8fafc;--muted-foreground: #64748b;--accent: #f1f5f9;--accent-foreground: #1e3a5f;--destructive: #ef4444;--destructive-foreground: #ffffff;--border: #e2e8f0;--input: #e2e8f0;--ring: #1e3a5f;--radius: .5rem;--success: #22c55e;--success-foreground: #ffffff;--warning: #f59e0b;--warning-foreground: #ffffff;--info: #3b82f6;--info-foreground: #ffffff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f8fafc;color:var(--foreground);min-height:100vh;-webkit-font-smoothing:antialiased;font-size:15px}a{text-decoration:none;color:inherit}.app{min-height:100vh;display:flex;flex-direction:column}.floating-card{box-shadow:0 2px 12px #1e3a5f14;transition:box-shadow .2s,transform .2s}.floating-card:hover{box-shadow:0 4px 20px #1e3a5f1f}.navbar{background:var(--primary);color:var(--primary-foreground);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:50;box-shadow:0 2px 12px #1e3a5f33}.navbar h1{font-size:14px;font-weight:700;color:#fff;letter-spacing:-.02em}.navbar .nav-right{display:flex;align-items:center;gap:12px;font-size:14px;color:#fffc}.navbar button{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);padding:6px 14px;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:all .15s}.navbar button:hover{background:#ffffff40}.content{flex:1;padding:24px 24px 80px;max-width:1200px;margin:0 auto;width:100%}.card{background:var(--card);border-radius:var(--radius);padding:24px;margin-bottom:16px;border:1px solid var(--border);box-shadow:0 1px 4px #0000000a}.card h2{font-size:18px;font-weight:700;margin-bottom:16px;color:var(--primary);letter-spacing:-.02em}.card h3{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--primary)}.greeting-card{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:var(--radius);padding:28px 24px;margin-bottom:16px;border:none;box-shadow:0 4px 16px #1e3a5f40}.greeting-card h2{color:#fff;font-size:22px;font-weight:800;margin-bottom:6px}.greeting-card p{color:#ffffffd9;font-size:15px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.grid-card{background:var(--card);border-radius:var(--radius);padding:20px;border:1px solid var(--border);cursor:pointer;transition:all .2s;border-left:3px solid var(--primary);box-shadow:0 1px 6px #1e3a5f0f}.grid-card:hover{background:var(--primary-lighter);border-color:var(--primary-light);box-shadow:0 4px 16px #1e3a5f1f;transform:translateY(-1px)}.grid-card .title{font-size:15px;font-weight:600;color:var(--foreground)}.grid-card .count{font-size:13px;color:var(--muted-foreground);margin-top:4px}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}th{background:var(--primary-lighter);font-weight:600;color:var(--primary);font-size:13px}tr:hover{background:var(--muted)}tr:last-child td{border-bottom:none}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{background:#dce4ee}th.sortable .sort-icon{margin-left:4px;font-size:10px;opacity:.5}th.sortable.active .sort-icon{opacity:1}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:var(--primary)}input,select,textarea{width:100%;padding:9px 12px;border:1px solid var(--input);border-radius:var(--radius);font-size:15px;font-family:inherit;transition:all .15s;background:var(--background);color:var(--foreground);line-height:1.5}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1e3a5f1a}input::placeholder,textarea::placeholder{color:var(--muted-foreground);opacity:.6}textarea{min-height:100px;resize:vertical}select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:36px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius);border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap;line-height:1.25;box-shadow:0 1px 3px #0000000f}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary);color:var(--primary-foreground);box-shadow:0 2px 6px #1e3a5f33}.btn-primary:hover{background:var(--primary-light);box-shadow:0 3px 10px #1e3a5f40}.btn-success{background:var(--success);color:var(--success-foreground)}.btn-success:hover{opacity:.9}.btn-danger{background:var(--destructive);color:var(--destructive-foreground)}.btn-danger:hover{opacity:.9}.btn-secondary{background:var(--secondary);color:var(--secondary-foreground);border:1px solid var(--border)}.btn-secondary:hover{background:var(--primary-lighter)}.btn-outline{background:transparent;color:var(--primary);border:1px solid var(--border);box-shadow:none}.btn-outline:hover{background:var(--primary-lighter);border-color:var(--primary)}.btn-ghost{background:transparent;color:var(--primary);box-shadow:none}.btn-ghost:hover{background:var(--primary-lighter)}.btn-sm{padding:5px 10px;font-size:13px;border-radius:calc(var(--radius) - 2px)}.btn-group{display:flex;gap:8px;margin-top:16px}.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:14px;display:flex;align-items:center;gap:8px}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted-foreground);margin-bottom:20px}.breadcrumb a{color:var(--primary);cursor:pointer;transition:color .15s}.breadcrumb a:hover{color:var(--primary-light);text-decoration:underline}.breadcrumb span{color:var(--foreground);font-weight:600}.notice-card{border-left:3px solid var(--primary);padding:14px 16px;background:var(--muted);border-radius:0 var(--radius) var(--radius) 0;margin-bottom:10px;transition:all .15s;box-shadow:0 1px 3px #00000008}.notice-card:hover{background:var(--primary-lighter);box-shadow:0 2px 6px #1e3a5f14}.notice-card .notice-title{font-weight:600;font-size:15px;color:var(--foreground);margin-bottom:4px}.notice-card .notice-date{font-size:13px;color:var(--muted-foreground);margin-bottom:6px}.notice-card .notice-content{font-size:14px;color:var(--muted-foreground);line-height:1.6;white-space:pre-wrap}.review-card{background:var(--muted);border-radius:var(--radius);padding:16px;margin-bottom:10px;border:1px solid var(--border);box-shadow:0 1px 3px #00000008}.review-card.best{border-color:var(--warning);background:#fffbeb;box-shadow:0 2px 8px #f59e0b1a}.review-card .review-content{font-size:15px;line-height:1.7;color:var(--foreground);margin-bottom:8px}.review-card .review-meta{font-size:13px;color:var(--muted-foreground);display:flex;justify-content:space-between;align-items:center}.review-card .best-badge{background:var(--warning);color:#fff;padding:2px 8px;border-radius:9999px;font-size:12px;font-weight:600}.review-rolling-container{overflow:hidden;height:140px;position:relative}.review-rolling-track{transition:transform .6s cubic-bezier(.4,0,.2,1)}.review-rolling-item{height:140px;display:flex;align-items:center;padding:4px 0}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes floatDrift0{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(15px,-20px) rotate(1deg)}50%{transform:translate(-10px,15px) rotate(-.5deg)}75%{transform:translate(20px,10px) rotate(.8deg)}}@keyframes floatDrift1{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-20px,12px) rotate(-1deg)}50%{transform:translate(12px,-18px) rotate(.5deg)}75%{transform:translate(-8px,-10px) rotate(-.8deg)}}@keyframes floatDrift2{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(10px,18px) rotate(.7deg)}50%{transform:translate(-15px,-8px) rotate(-1deg)}75%{transform:translate(18px,-15px) rotate(.3deg)}}@keyframes floatDrift3{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-12px,-15px) rotate(-.5deg)}50%{transform:translate(20px,10px) rotate(1.2deg)}75%{transform:translate(-18px,18px) rotate(-.7deg)}}.floating-bg-img{box-shadow:0 8px 32px #0000004d}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e8eef6);padding:24px}.auth-layout{display:flex;gap:32px;align-items:stretch;max-width:900px;width:100%}.auth-card{background:var(--card);border-radius:calc(var(--radius) + 4px);padding:48px;flex:1;border:1px solid var(--border)}.auth-card h1{text-align:center;color:var(--primary);margin-bottom:4px;font-size:22px;font-weight:800;line-height:1.4}.auth-card .subtitle{text-align:center;color:var(--muted-foreground);margin-bottom:28px;font-size:15px}.auth-card .btn{width:100%;justify-content:center;padding:12px;font-size:16px}.auth-card .switch-link{text-align:center;margin-top:20px;font-size:14px;color:var(--muted-foreground)}.auth-card .switch-link a{color:var(--primary);cursor:pointer;font-weight:600}.auth-card .switch-link a:hover{text-decoration:underline}.profile-card{background:var(--card);border-radius:calc(var(--radius) + 4px);padding:36px 28px;width:300px;min-width:280px;border:1px solid var(--border);text-align:center;display:flex;flex-direction:column;align-items:center}.profile-photo{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid var(--primary-lighter);margin-bottom:16px;box-shadow:0 4px 16px #1e3a5f1f}.profile-photo img{width:100%;height:100%;object-fit:cover}.profile-placeholder{width:100%;height:100%;background:var(--primary-lighter);display:flex;align-items:center;justify-content:center}.profile-name{font-size:20px;font-weight:800;color:var(--primary);margin-bottom:12px}.profile-divider{width:40px;height:3px;background:var(--primary);border-radius:2px;margin-bottom:16px}.profile-info{font-size:14px;color:var(--foreground);line-height:1.8;text-align:center}.profile-info .profile-section-title{font-weight:700;color:var(--primary);font-size:15px;margin-bottom:4px}.tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--border)}.tab{padding:10px 18px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:600;color:var(--muted-foreground);font-family:inherit;transition:all .15s;border-bottom:2px solid transparent;margin-bottom:-2px}.tab:hover{color:var(--primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.bottom-tab-bar{position:fixed;bottom:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;height:56px;z-index:100}.bottom-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;cursor:pointer;color:var(--muted-foreground);font-family:inherit;background:none;border:none;flex:1;transition:color .15s}.bottom-tab:hover{color:var(--primary-light)}.bottom-tab.active{color:var(--primary)}.bottom-tab svg{width:20px;height:20px}.bottom-tab.active svg{stroke-width:2.5}.bottom-tab .tab-label{font-size:10px;font-weight:500;letter-spacing:.02em}.bottom-tab.active .tab-label{font-weight:700}.score-input{width:80px;padding:6px 8px;text-align:center}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:12px;font-weight:600;line-height:1.5;white-space:nowrap}.badge-default{background:var(--secondary);color:var(--secondary-foreground)}.badge-primary{background:var(--primary);color:var(--primary-foreground)}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fef2f2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.badge-purple{background:#f3e8ff;color:#6b21a8}.stat-card{display:flex;flex-direction:column;align-items:center;padding:16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--card)}.stat-card .stat-label{font-size:13px;color:var(--muted-foreground);margin-bottom:4px;font-weight:500}.stat-card .stat-value{font-size:22px;font-weight:700;color:var(--primary);letter-spacing:-.02em}.stat-card .stat-unit{font-size:14px;font-weight:400;color:var(--muted-foreground);margin-left:2px}@media(max-width:768px){.content{padding:16px 16px 80px}.form-row,.card-grid{grid-template-columns:1fr}table{font-size:13px}th,td{padding:8px 6px}.tabs{overflow-x:auto}.tab{white-space:nowrap}.navbar{padding:0 16px}.navbar h1{font-size:13px}.auth-layout{flex-direction:column}.profile-card{width:100%;min-width:auto}.auth-card{padding:28px}}
