/*******************************************************************************
 * 일잘하는 사람들 — 반응형 웹 v2
 * Mobile-first · Top GNB · Wide Card Layout
 ******************************************************************************/
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css');

:root {
    --primary: #4F46E5;
    --primary-dark: #3730A3;
    --primary-light: #EEF2FF;
    --primary-50: #E0E7FF;
    --primary-hover: #4338CA;
    --primary-glow: rgba(79, 70, 229, 0.12);
    --accent: #06B6D4; --accent-light: #ECFEFF;
    --success: #10B981; --success-light: #ECFDF5;
    --warning: #F59E0B; --warning-light: #FFFBEB;
    --danger: #EF4444; --danger-light: #FEF2F2;
    --text-primary: #0F172A; --text-secondary: #475569;
    --text-tertiary: #94A3B8; --text-disabled: #CBD5E1;
    --bg-primary: #FFFFFF; --bg-secondary: #F8FAFC;
    --bg-tertiary: #F1F5F9; --bg-page: #F8FAFC;
    --border: #E2E8F0; --border-light: #F1F5F9;
    --radius-sm: 8px; --radius-md: 12px; --radius-lg: 16px;
    --radius-xl: 20px; --radius-2xl: 24px; --radius-full: 9999px;
    --shadow-xs: 0 1px 2px rgba(15,23,42,0.04);
    --shadow-sm: 0 1px 3px rgba(15,23,42,0.06), 0 1px 2px rgba(15,23,42,0.04);
    --shadow-md: 0 4px 6px -1px rgba(15,23,42,0.06), 0 2px 4px -2px rgba(15,23,42,0.04);
    --shadow-lg: 0 10px 15px -3px rgba(15,23,42,0.06), 0 4px 6px -4px rgba(15,23,42,0.03);
    --shadow-card: 0 1px 3px rgba(15,23,42,0.04), 0 1px 2px rgba(15,23,42,0.02);
    --shadow-card-hover: 0 8px 25px -5px rgba(15,23,42,0.1), 0 4px 10px -4px rgba(15,23,42,0.04);
    --header-h: 60px; --gnb-h: 72px;
    --content-max: 1080px; --page-max: 1280px;
    --ease-out: cubic-bezier(0.16,1,0.3,1);
    --transition-fast: 0.15s ease;
    --transition-normal: 0.25s var(--ease-out);
    --transition-slow: 0.4s var(--ease-out);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Pretendard Variable','Pretendard',-apple-system,BlinkMacSystemFont,'Noto Sans KR',sans-serif;font-size:15px;line-height:1.6;color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;overflow-x:hidden;letter-spacing:-0.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none;background:none}
.hidden{display:none!important}
.scroll-h{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.scroll-h::-webkit-scrollbar{display:none}
::selection{background:var(--primary-50);color:var(--primary-dark)}

/* ── App Container ── */
.app-container{padding-bottom:76px;min-height:100vh}
body.has-action-bar .app-container{padding-bottom:136px}

/* ── Mobile Header ── */
.app-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,0.6)}
.header-main{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);padding:0 16px}
.header-logo{font-size:19px;font-weight:800;color:var(--primary);letter-spacing:-0.5px;display:flex;align-items:baseline;gap:2px}
.header-logo span{font-weight:500;color:var(--text-secondary);font-size:17px}
.header-title{font-size:16px;font-weight:700;position:absolute;left:50%;transform:translateX(-50%);white-space:nowrap}
.header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-fast);position:relative;cursor:pointer}
.header-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}
.header-back{color:var(--text-primary)}
.header-actions{display:flex;gap:2px;align-items:center}
.badge-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-primary)}

/* ── PC GNB (hidden mobile) ── */
.pc-gnb{display:none}

/* ── Search Bar ── */
.search-bar-wrap{padding:0 16px 12px}
.search-bar{display:flex;align-items:center;gap:10px;padding:0 16px;height:46px;background:var(--bg-tertiary);border-radius:var(--radius-full);border:1.5px solid transparent;transition:all var(--transition-normal)}
.search-bar:focus-within{background:var(--bg-primary);border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}
.search-icon{color:var(--text-disabled);flex-shrink:0;display:flex}
.search-bar input{flex:1;height:100%;background:none;font-size:15px}
.search-bar input::placeholder{color:var(--text-disabled)}

/* ── Bottom Nav ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:200;background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(226,232,240,0.6);padding-bottom:env(safe-area-inset-bottom,0)}
.bottom-nav-inner{display:flex;height:58px}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:10px;font-weight:500;color:var(--text-tertiary);transition:color var(--transition-fast);position:relative;cursor:pointer}
.nav-item.active{color:var(--primary);font-weight:700}
.nav-item .nav-icon{display:flex}
.nav-center-btn{color:var(--primary)!important;font-weight:700!important}
.nav-center-btn .nav-icon{background:var(--primary);color:white!important;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:-20px;box-shadow:0 4px 14px rgba(79,70,229,0.35)}
.nav-badge{position:absolute;top:2px;right:calc(50% - 22px);min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;color:white;background:var(--danger);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:1}

/* ── Sections ── */
.section{padding:16px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-title{font-size:18px;font-weight:800;color:var(--text-primary);letter-spacing:-0.02em}
.section-more{font-size:13px;color:var(--text-tertiary);font-weight:500;transition:color var(--transition-fast)}
.section-more:hover{color:var(--primary)}
.section-divider{height:6px;background:var(--bg-tertiary)}

/* ── Banner ── */
.banner-wrap{position:relative;padding:12px 16px}
.banner{display:block;border-radius:var(--radius-xl);padding:24px 20px;color:#fff;position:relative;overflow:hidden;min-height:130px}
a.banner,a.banner *{color:#fff}
.banner::after{content:'';position:absolute;right:-30px;top:-30px;width:160px;height:160px;background:rgba(255,255,255,0.08);border-radius:50%}
.banner-slide{display:flex;flex-direction:column;position:relative;z-index:1}
.banner-tag{display:inline-block;padding:4px 12px;font-size:11px;font-weight:700;background:rgba(255,255,255,0.2);backdrop-filter:blur(4px);border-radius:var(--radius-full);margin-bottom:14px;width:fit-content;letter-spacing:0.3px}
.banner-title{font-size:24px;font-weight:800;line-height:1.3;margin-bottom:6px;letter-spacing:-0.02em}
.banner-desc{font-size:14px;opacity:0.85;font-weight:400}

/* ── Category ── */
.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.category-item{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;padding:2px 0}
.category-icon{width:50px;height:50px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}
.category-item:hover .category-icon{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,0.08)}
.category-name{font-size:12px;font-weight:600;color:var(--text-secondary);text-align:center}

/* ── Chips ── */
.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;padding:7px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}
.chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.chip.active{background:var(--primary);color:white;border-color:var(--primary);box-shadow:0 2px 8px rgba(79,70,229,0.25)}

/* ── Cards ── */
.card{background:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden}
.card-shadow{box-shadow:var(--shadow-card)}
.card-elevated{box-shadow:var(--shadow-card);transition:all var(--transition-normal)}
.card-elevated:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}

/* ── Request Cards ── */
.request-card{display:block;padding:14px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border-light);transition:all var(--transition-normal)}
.request-card:hover{background:var(--bg-secondary)}
.request-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.request-category{font-size:12px;color:var(--primary);font-weight:600}
.request-title{font-size:15px;font-weight:700;margin-bottom:10px;line-height:1.45;letter-spacing:-0.01em}
.request-bottom{display:flex;align-items:center;gap:12px}
.request-budget{font-size:13px;color:var(--text-secondary);font-weight:600}
.request-bids{font-size:12px;color:var(--text-tertiary)}

/* ── Status ── */
.status-badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;border-radius:var(--radius-full);letter-spacing:0.2px}
.status-waiting{background:var(--warning-light);color:#B45309}
.status-matched{background:var(--success-light);color:#047857}
.status-progress{background:#EFF6FF;color:#1D4ED8}
.status-complete{background:var(--bg-tertiary);color:var(--text-tertiary)}
.status-cancelled{background:var(--danger-light);color:var(--danger)}
.status-draft{background:var(--bg-tertiary);color:var(--text-disabled)}

/* ── Expert Cards ── */
.expert-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border-light);transition:all var(--transition-normal);cursor:pointer}
.expert-card:hover{background:var(--bg-secondary)}
.expert-avatar{width:50px;height:50px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0}
.expert-avatar.colored{color:white}
.expert-info{flex:1;min-width:0}
.expert-top{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.expert-name{font-size:15px;font-weight:700;letter-spacing:-0.01em}
.expert-badge{display:inline-flex;align-items:center;padding:2px 7px;font-size:10px;font-weight:800;border-radius:5px;letter-spacing:0.5px}
.badge-top{background:#FEF3C7;color:#B45309}
.badge-pro{background:var(--primary-light);color:var(--primary)}
.badge-new{background:var(--success-light);color:#047857}
.expert-sub{font-size:13px;color:var(--text-tertiary);margin-bottom:5px}
.expert-desc{font-size:13px;color:var(--text-secondary);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}
.expert-meta{display:flex;align-items:center;gap:10px;font-size:12px}
.expert-rating{color:var(--warning);font-weight:600}
.expert-rating span{color:var(--text-primary)}
.expert-reviews{color:var(--text-tertiary)}
.expert-price{color:var(--primary);font-weight:700;margin-left:auto}

/* ── Profile ── */
.profile-header{text-align:center;padding:36px 20px 28px}
.profile-avatar-lg{width:84px;height:84px;border-radius:var(--radius-xl);font-size:34px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 6px 20px rgba(79,70,229,0.3)}
.profile-name{font-size:24px;font-weight:800;letter-spacing:-0.02em}
.profile-sub{font-size:14px;color:var(--text-tertiary)}
.profile-stats{display:flex;justify-content:center;gap:36px;margin-top:24px}
.profile-stat{text-align:center}
.profile-stat-num{font-size:22px;font-weight:800;letter-spacing:-0.02em}
.profile-stat-label{font-size:12px;color:var(--text-tertiary);margin-top:2px;font-weight:500}

/* ── Tabs ── */
.tab-bar{display:flex;background:var(--bg-primary);border-bottom:1px solid var(--border-light);overflow-x:auto;scrollbar-width:none}
.tab-bar::-webkit-scrollbar{display:none}
.tab-item{flex:1;text-align:center;padding:14px 12px;font-size:14px;font-weight:600;color:var(--text-tertiary);cursor:pointer;border-bottom:2.5px solid transparent;transition:all var(--transition-fast);white-space:nowrap}
.tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}
.tab-item:hover{color:var(--text-primary)}

/* ── Toggle ── */
.toggle-group{display:inline-flex;background:var(--bg-tertiary);border-radius:var(--radius-full);padding:3px}
.toggle-item{padding:6px 14px;font-size:13px;font-weight:600;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast)}
.toggle-item.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}

/* ── Forms ── */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}
.required{color:var(--danger)}
.form-input{width:100%;padding:13px 16px;font-size:15px;background:var(--bg-primary);border:1.5px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-normal)}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394A3B8' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 5.646a.5.5 0 01.708 0L8 8.293l2.646-2.647a.5.5 0 01.708.708l-3 3a.5.5 0 01-.708 0l-3-3a.5.5 0 010-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
.form-textarea{min-height:130px;resize:vertical;line-height:1.65}
.form-helper{font-size:12px;color:var(--text-tertiary);margin-top:6px}

/* ── Buttons ── */
/* 기본값 안전망: .btn 단독 사용 시에도 최소한 보이도록 (modifier 미지정 대비) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 22px;font-size:14px;font-weight:700;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;letter-spacing:-0.01em;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}
.btn:hover{background:var(--bg-tertiary)}
.btn-primary{background:var(--primary);color:white;box-shadow:0 1px 3px rgba(79,70,229,0.25)}
.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 14px rgba(79,70,229,0.3);transform:translateY(-1px)}
.btn-outline{background:var(--bg-primary);color:var(--primary);border:1.5px solid var(--primary)}
.btn-outline:hover{background:var(--primary-light)}
.btn-sm{padding:8px 16px;font-size:13px}
.btn-lg{padding:15px 28px;font-size:15px;border-radius:var(--radius-lg)}
.btn-full{width:100%}

/* ── Fixed Bottom Bar ── */
.fixed-bottom-bar{position:fixed;bottom:0;left:0;right:0;z-index:150;background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(226,232,240,0.6);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0))}
.fixed-bottom-bar .inner{display:flex;gap:10px}

/* ── Step ── */
.step-indicator{display:flex;align-items:center;justify-content:center;padding:24px 24px 16px;gap:0}
.step{display:flex;flex-direction:column;align-items:center;gap:6px}
.step-circle{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:var(--bg-tertiary);color:var(--text-tertiary)}
.step.active .step-circle{background:var(--primary);color:white;box-shadow:0 2px 8px rgba(79,70,229,0.3)}
.step-label{font-size:11px;color:var(--text-tertiary)}
.step.active .step-label{color:var(--primary);font-weight:600}
.step-line{flex:1;height:2px;background:var(--border);margin:0 8px;margin-bottom:20px;max-width:60px}

/* ── Chat ── */
.chat-list-item{display:flex;align-items:center;gap:14px;padding:16px;border-bottom:1px solid var(--border-light);transition:all var(--transition-normal);cursor:pointer}
.chat-list-item:hover{background:var(--bg-secondary)}
.chat-avatar{width:50px;height:50px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}
.chat-content{flex:1;min-width:0}
.chat-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.chat-name{font-size:15px;font-weight:700;letter-spacing:-0.01em}
.chat-time{font-size:12px;color:var(--text-disabled);flex-shrink:0}
.chat-preview{flex:1;font-size:13px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-unread{min-width:20px;height:20px;padding:0 6px;background:var(--primary);color:white;font-size:11px;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}
body.page-chat-room .app-container{padding-bottom:0}
body.page-chat-room .bottom-nav{display:none}
.chat-room{display:flex;flex-direction:column;height:calc(100vh - var(--header-h));height:calc(100dvh - var(--header-h));background:var(--bg-secondary)}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px;-webkit-overflow-scrolling:touch}
.chat-date-divider{text-align:center;padding:14px 0;font-size:12px;color:var(--text-disabled);font-weight:500}
.chat-bubble-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:4px}
.chat-bubble-wrap.mine{align-items:flex-end}
.chat-bubble{max-width:72%;padding:11px 16px;font-size:14px;line-height:1.55;border-radius:20px;word-break:break-word}
.chat-bubble.other{background:var(--bg-primary);border-bottom-left-radius:6px;box-shadow:var(--shadow-xs)}
.chat-bubble.mine{background:var(--primary);color:white;border-bottom-right-radius:6px}
.chat-bubble-time{font-size:11px;color:var(--text-disabled);padding:0 4px}
.chat-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0));background:var(--bg-primary);border-top:1px solid var(--border-light)}
.chat-input{flex:1;height:42px;padding:0 18px;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:14px;transition:all var(--transition-fast)}
.chat-input:focus{background:var(--bg-primary);box-shadow:0 0 0 2px var(--primary-glow)}
.chat-send-btn{width:42px;height:42px;border-radius:50%;background:var(--primary);color:white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}
.chat-send-btn:disabled{background:var(--bg-tertiary);color:var(--text-disabled)}
.chat-send-btn:not(:disabled):hover{background:var(--primary-hover);transform:scale(1.05)}

/* ── Review, Empty, Menu, Star, FAQ ── */
.review-card{padding:18px 0;border-bottom:1px solid var(--border-light)}
.review-card:last-child{border-bottom:none}
.review-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.review-avatar{width:38px;height:38px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:var(--text-tertiary)}
.review-info{flex:1}
.review-name{font-size:14px;font-weight:600}
.review-date{font-size:12px;color:var(--text-disabled)}
.review-stars{color:var(--warning);margin-bottom:8px;display:flex;gap:2px}
.review-text{font-size:14px;color:var(--text-secondary);line-height:1.65}
.empty-state{text-align:center;padding:48px 24px}
.empty-icon{color:var(--text-disabled);margin-bottom:16px}
.empty-title{font-size:17px;font-weight:700;color:var(--text-secondary);margin-bottom:6px}
.empty-desc{font-size:14px;color:var(--text-tertiary)}
.menu-item{display:flex;align-items:center;gap:14px;padding:16px;border-bottom:1px solid var(--border-light);transition:all var(--transition-normal);cursor:pointer}
.menu-item:hover{background:var(--bg-secondary)}
.menu-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.menu-text{flex:1}.menu-arrow{color:var(--text-disabled);flex-shrink:0}
.star-rating{display:flex;gap:4px}.star-rating span{user-select:none}
.faq-item.open .faq-arrow{transform:rotate(90deg)}
.faq-item.open .faq-answer{display:block!important}

/* ═══════════════════════════════════════
   PC (≥ 1024px) — Top GNB
   ═══════════════════════════════════════ */
@media(min-width:1024px){
    :root{--header-h:0px;--gnb-h:72px}
    .app-header{display:none}
    .bottom-nav{display:none!important}
    .pc-gnb{display:flex;position:sticky;top:0;z-index:300;align-items:center;height:var(--gnb-h);padding:0 40px;background:rgba(255,255,255,0.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(226,232,240,0.5)}
    .gnb-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--page-max);margin:0 auto}
    .gnb-logo{font-size:22px;font-weight:900;color:var(--primary);letter-spacing:-0.5px;display:flex;align-items:baseline;gap:3px;transition:opacity var(--transition-fast)}
    .gnb-logo:hover{opacity:0.8}
    .gnb-logo span{font-weight:500;color:var(--text-secondary);font-size:20px}
    .gnb-nav{display:flex;align-items:center;gap:4px}
    .gnb-link{padding:8px 18px;font-size:14px;font-weight:600;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative}
    .gnb-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}
    .gnb-link.active{color:var(--primary)}
    .gnb-link.active::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:20px;height:3px;background:var(--primary);border-radius:2px}
    .gnb-link .gnb-badge{margin-left:4px;padding:1px 6px;font-size:10px;font-weight:700;background:var(--danger);color:white;border-radius:var(--radius-full);line-height:1.5}
    .gnb-actions{display:flex;align-items:center;gap:8px}
    .gnb-btn-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative}
    .gnb-btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}
    .gnb-btn-icon .badge-dot{position:absolute;top:8px;right:8px}
    .gnb-cta{margin-left:8px;padding:10px 22px;font-size:14px;font-weight:700;background:var(--primary);color:white;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;gap:6px;box-shadow:0 1px 3px rgba(79,70,229,0.2)}
    .gnb-cta:hover{background:var(--primary-hover);box-shadow:0 4px 12px rgba(79,70,229,0.3);transform:translateY(-1px)}
    .gnb-admin-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;font-size:12.5px;font-weight:700;color:#fff;background:linear-gradient(135deg,#1F2937,#111827);border-radius:var(--radius-sm);text-decoration:none;letter-spacing:-0.01em;transition:all var(--transition-fast);box-shadow:0 1px 3px rgba(0,0,0,0.15)}
    .gnb-admin-btn:hover{background:linear-gradient(135deg,#374151,#1F2937);transform:translateY(-1px);box-shadow:0 3px 8px rgba(0,0,0,0.2)}
    .header-btn-admin{color:#7C3AED}
    .header-btn-admin:hover{background:#7C3AED15;color:#6D28D9}

    .app-container{padding-bottom:40px;min-height:calc(100vh - var(--gnb-h));max-width:var(--content-max);margin:0 auto}
    body.has-action-bar .app-container{padding-bottom:100px}
    .section{padding:20px 0}
    .search-bar-wrap{padding:0 0 12px}
    .banner-wrap{padding:16px 0}
    .section-divider{height:1px;background:var(--border-light);margin:0}
    .banner{border-radius:var(--radius-2xl);padding:36px 40px;min-height:160px}
    .banner::after{width:240px;height:240px;right:-40px;top:-60px}
    .banner-title{font-size:30px}
    .banner-desc{font-size:15px}
    .category-grid{grid-template-columns:repeat(6,1fr);gap:16px}
    .category-icon{width:58px;height:58px;border-radius:var(--radius-xl)}
    .category-name{font-size:13px}
    .expert-card{padding:16px 20px;border-radius:var(--radius-lg);border-bottom:none;box-shadow:var(--shadow-card);margin-bottom:8px}
    .expert-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
    .expert-avatar{width:52px;height:52px;border-radius:var(--radius-lg)}
    .request-card{padding:16px 20px;border-radius:var(--radius-lg);border-bottom:none;box-shadow:var(--shadow-card);margin-bottom:8px}
    .request-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
    .chat-list-item{padding:16px 24px;border-radius:var(--radius-lg);border-bottom:none;margin-bottom:8px;box-shadow:var(--shadow-card)}
    .chat-list-item:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}
    .menu-item{padding:16px 20px;border-radius:var(--radius-lg);border-bottom:none;margin-bottom:8px;box-shadow:var(--shadow-card)}
    .menu-item:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}
    .fixed-bottom-bar{padding:16px 24px}
    .fixed-bottom-bar .inner{max-width:var(--content-max);margin:0 auto}
    .tab-bar{padding:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
    .tab-item{flex:none;padding:14px 24px;font-size:15px}
    .scroll-h{padding-left:0!important;padding-right:0!important}
    .profile-header{padding:36px 0 28px}
    .profile-avatar-lg{width:96px;height:96px;border-radius:var(--radius-2xl);font-size:38px}
    .profile-name{font-size:26px}
    .profile-stats{gap:48px}
    .profile-stat-num{font-size:24px}
    body.page-chat-room .pc-gnb{display:flex}
    .chat-room{height:calc(100vh - var(--gnb-h))}
    .chat-bubble{max-width:50%}
    .chat-input-bar{padding-bottom:14px}
    .form-input{padding:12px 16px;font-size:15px}
    .form-textarea{min-height:140px}
    .step-indicator{padding:20px 0 14px}
    .step-line{max-width:80px}
}

/* ── Tablet ── */
@media(min-width:768px) and (max-width:1023px){
    .category-grid{grid-template-columns:repeat(5,1fr);gap:14px}
    .category-icon{width:56px;height:56px}
    .banner{padding:28px}
    .banner-title{font-size:24px}
    .section{padding:16px 20px}
    .search-bar-wrap{padding:0 20px 10px}
    .banner-wrap{padding:12px 20px}
    .chat-bubble{max-width:60%}
    .expert-card,.request-card,.chat-list-item,.menu-item{padding-left:20px;padding-right:20px}
}

/* ── Scrollbar, animations ── */
@media(min-width:1024px){
    ::-webkit-scrollbar{width:6px}
    ::-webkit-scrollbar-track{background:transparent}
    ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
    ::-webkit-scrollbar-thumb:hover{background:var(--text-disabled)}
}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeInUp .45s var(--ease-out) both}

/* ═══════════════════════════════════════
   REGISTER PAGE
   ═══════════════════════════════════════ */
body.page-register .app-container{max-width:none;padding-bottom:0}
body.page-register .bottom-nav{display:none}

.register-wrap{min-height:100vh;display:flex;flex-direction:column}
.register-side{display:none}
.register-form-area{flex:1;padding:24px 16px 40px}
.register-form-inner{max-width:480px;margin:0 auto}
.register-mobile-header{margin-bottom:28px}

/* 소셜 버튼 */
.social-register{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:50px;border-radius:var(--radius-md);font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition-normal);border:none;letter-spacing:-0.01em}
.social-kakao{background:#FEE500;color:#3C1E1E}
.social-kakao:hover{background:#FADA0A;box-shadow:0 2px 8px rgba(254,229,0,0.4)}
.social-naver{background:#03C75A;color:#fff}
.social-naver:hover{background:#02B550;box-shadow:0 2px 8px rgba(3,199,90,0.3)}

.register-divider{display:flex;align-items:center;gap:14px;margin:20px 0;color:var(--text-disabled);font-size:13px}
.register-divider::before,.register-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* 가입유형 카드 */
.register-type-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.register-type-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);text-align:center;background:var(--bg-primary)}
.register-type-card:hover{border-color:var(--primary);background:var(--primary-light)}
.register-type-card.active{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 3px var(--primary-glow)}
.register-type-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all var(--transition-normal)}
.register-type-card.active .register-type-icon{background:var(--primary);color:white}
.register-type-name{font-size:15px;font-weight:700;color:var(--text-primary)}
.register-type-desc{font-size:12px;color:var(--text-tertiary)}

/* 폼 2열 */
.form-row{display:flex;gap:12px}
.form-row .form-group{flex:1}

/* 약관 */
.agree-all-wrap{padding:14px 0;border-bottom:1px solid var(--border-light);margin-bottom:12px}
.agree-all-label{font-size:15px;font-weight:700}
.agree-check{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer;font-size:13px;color:var(--text-secondary)}
.agree-check input{display:none}
.agree-check-box{width:20px;height:20px;border:1.5px solid var(--border);border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast);background:var(--bg-primary)}
.agree-check input:checked+.agree-check-box{background:var(--primary);border-color:var(--primary)}
.agree-check input:checked+.agree-check-box::after{content:'✓';color:white;font-size:12px;font-weight:700}
.agree-view{margin-left:auto;font-size:12px;color:var(--text-tertiary);text-decoration:underline;flex-shrink:0}
.agree-list{display:flex;flex-direction:column;gap:2px}
.agree-detail{display:none;padding:10px 14px;margin:4px 0 8px 30px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:12px;color:var(--text-tertiary);line-height:1.6;max-height:120px;overflow-y:auto}

.register-login-link{text-align:center;margin-top:24px;padding:20px 0;font-size:14px;color:var(--text-tertiary);border-top:1px solid var(--border-light)}
.register-login-link a{color:var(--primary);font-weight:700;margin-left:4px}

/* ── Register PC ── */
@media(min-width:1024px){
    body.page-register .pc-gnb{display:none}
    .register-wrap{flex-direction:row;min-height:100vh}
    .register-side{display:flex;width:46%;background:linear-gradient(160deg,#4338CA 0%,#4F46E5 40%,#6366F1 100%);color:white;padding:60px 48px;flex-direction:column;justify-content:center;position:sticky;top:0;height:100vh;overflow:hidden}
    .register-side::before{content:'';position:absolute;right:-80px;bottom:-80px;width:320px;height:320px;background:rgba(255,255,255,0.06);border-radius:50%}
    .register-side::after{content:'';position:absolute;left:-40px;top:-40px;width:200px;height:200px;background:rgba(255,255,255,0.04);border-radius:50%}
    .register-side-inner{position:relative;z-index:1;max-width:420px}
    .register-side-badge{display:inline-block;padding:5px 14px;font-size:12px;font-weight:700;background:rgba(255,255,255,0.15);backdrop-filter:blur(4px);border-radius:var(--radius-full);margin-bottom:20px;letter-spacing:0.5px}
    .register-side-title{font-size:32px;font-weight:800;line-height:1.35;margin-bottom:16px;letter-spacing:-0.02em}
    .register-side-desc{font-size:15px;opacity:0.8;line-height:1.65;margin-bottom:36px}
    .register-side-features{display:flex;flex-direction:column;gap:18px;margin-bottom:40px}
    .register-feature{display:flex;align-items:flex-start;gap:14px}
    .register-feature-icon{width:40px;height:40px;border-radius:var(--radius-md);background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .register-feature-title{font-size:14px;font-weight:700;margin-bottom:2px}
    .register-feature-desc{font-size:13px;opacity:0.7}
    .register-side-stats{display:flex;gap:32px;padding-top:28px;border-top:1px solid rgba(255,255,255,0.15)}
    .register-stat-num{font-size:24px;font-weight:800;letter-spacing:-0.02em}
    .register-stat-label{font-size:12px;opacity:0.7;margin-top:2px}

    .register-form-area{flex:1;padding:48px 56px;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto}
    .register-form-inner{max-width:520px;width:100%;padding-top:16px}
    .register-mobile-header{margin-bottom:32px}
    .register-mobile-header h1{font-size:28px}
    .social-register{flex-direction:row;gap:12px}
    .social-btn{flex:1}
    .form-row{gap:16px}
}


/* ═══════════════════════════════════════
   AD BANNER
   ═══════════════════════════════════════ */
.ad-banner-area{padding:12px 16px;display:flex;flex-direction:column;gap:10px}
.ad-banner{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-radius:var(--radius-lg);color:#fff;transition:all var(--transition-normal);overflow:hidden;position:relative}
a.ad-banner,a.ad-banner *{color:#fff}
a.ad-banner .ad-banner-arrow{color:rgba(255,255,255,0.7)}
.ad-banner:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.ad-banner::after{content:'';position:absolute;right:-20px;top:-20px;width:100px;height:100px;background:rgba(255,255,255,0.06);border-radius:50%}
.ad-banner-content{flex:1;min-width:0;position:relative;z-index:1}
.ad-banner-tag{display:inline-block;padding:2px 8px;font-size:10px;font-weight:700;background:rgba(255,255,255,0.2);border-radius:var(--radius-full);margin-bottom:6px;letter-spacing:0.3px}
.ad-banner-title{font-size:15px;font-weight:700;margin-bottom:2px;letter-spacing:-0.01em}
.ad-banner-desc{font-size:12px;opacity:0.8}
.ad-banner-arrow{color:rgba(255,255,255,0.6);flex-shrink:0;position:relative;z-index:1}

@media(min-width:1024px){
    .ad-banner-area{padding:16px 0;flex-direction:row;gap:12px}
    .ad-banner{flex:1;padding:20px 24px;border-radius:var(--radius-xl)}
    .ad-banner::after{width:140px;height:140px;right:-30px;top:-30px}
    .ad-banner-title{font-size:16px}
    .ad-banner-desc{font-size:13px}
}

@media(min-width:768px) and (max-width:1023px){
    .ad-banner-area{padding:12px 24px;flex-direction:row;gap:10px}
    .ad-banner{flex:1}
}

/* ── Tablet register ── */
@media(min-width:768px) and (max-width:1023px){
    .register-form-inner{max-width:520px;margin:0 auto}
    .register-form-area{padding:32px 32px 40px}
    .social-register{flex-direction:row;gap:12px}
    .social-btn{flex:1}
    .form-row{gap:16px}
}

/* ═══════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════ */
body.page-login .app-container{max-width:none;padding-bottom:0}
body.page-login .bottom-nav{display:none}

.login-wrap{min-height:100vh;display:flex;flex-direction:column}
.login-side{display:none}
.login-form-area{flex:1;padding:24px 16px 40px;display:flex;align-items:flex-start;justify-content:center}
.login-form-inner{max-width:420px;width:100%}
.login-header{margin-bottom:28px}
.login-register-link{text-align:center;margin-top:24px;padding:20px 0;font-size:14px;color:var(--text-tertiary);border-top:1px solid var(--border-light)}
.login-register-link a{color:var(--primary);font-weight:700;margin-left:4px}

@media(min-width:1024px){
    body.page-login .pc-gnb{display:none}
    .login-wrap{flex-direction:row;min-height:100vh}
    .login-side{display:flex;width:46%;background:linear-gradient(160deg,#3730A3 0%,#4F46E5 50%,#818CF8 100%);color:white;padding:60px 48px;flex-direction:column;justify-content:center;position:sticky;top:0;height:100vh;overflow:hidden}
    .login-side::before{content:'';position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;background:rgba(255,255,255,0.05);border-radius:50%}
    .login-side::after{content:'';position:absolute;left:-30px;top:-30px;width:180px;height:180px;background:rgba(255,255,255,0.04);border-radius:50%}
    .login-side-inner{position:relative;z-index:1;max-width:400px}
    .login-side-badge{display:inline-block;padding:5px 14px;font-size:12px;font-weight:700;background:rgba(255,255,255,0.15);backdrop-filter:blur(4px);border-radius:var(--radius-full);margin-bottom:20px;letter-spacing:0.5px}
    .login-side-title{font-size:32px;font-weight:800;line-height:1.35;margin-bottom:16px;letter-spacing:-0.02em}
    .login-side-desc{font-size:15px;opacity:0.8;line-height:1.65;margin-bottom:40px}
    .login-side-features{display:flex;gap:28px;padding-top:28px;border-top:1px solid rgba(255,255,255,0.15)}
    .login-feature{text-align:center}
    .login-feature-num{display:block;font-size:24px;font-weight:800;letter-spacing:-0.02em;margin-bottom:2px}
    .login-feature-label{font-size:12px;opacity:0.7}

    .login-form-area{flex:1;padding:48px 56px;display:flex;align-items:center;justify-content:center}
    .login-form-inner{max-width:440px}
    .login-header{margin-bottom:32px}
    .login-header h1{font-size:28px}
}

@media(min-width:768px) and (max-width:1023px){
    .login-form-inner{max-width:440px}
    .login-form-area{padding:40px 32px}
}

/* ── Social buttons: Google & Apple ── */
.social-google{background:#FFFFFF;color:#3C4043;border:1.5px solid var(--border)}
.social-google:hover{background:#F8FAFC;box-shadow:0 2px 8px rgba(0,0,0,0.08)}
.social-apple{background:#000000;color:#FFFFFF}
.social-apple:hover{background:#1a1a1a;box-shadow:0 2px 8px rgba(0,0,0,0.2)}

/* 4-button grid layout */
.social-register.social-4{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:1024px){
    .social-register.social-4{grid-template-columns:1fr 1fr;gap:10px}
}

/* ═══════════════════════════════════════
   PROFILE EDIT PAGE
   ═══════════════════════════════════════ */
.profile-edit-wrap{min-height:100vh}
.profile-edit-side{display:none}
.profile-edit-main{padding:0 0 80px}

/* 섹션 */
.pe-section{padding:20px 16px}
.pe-section+.pe-section{border-top:6px solid var(--bg-tertiary)}
.pe-section-header{margin-bottom:16px}

/* ════════════════════════════════════════════════════════════
   HERO BANNER v3 — 터치 드래그 슬라이드 (translateX 트랙)
   ════════════════════════════════════════════════════════════ */
.mp-hero{
    position:relative;
    margin:12px 16px;
    border-radius:16px;
    overflow:hidden;
    touch-action:pan-y; /* 세로 스크롤은 허용, 가로는 자체 처리 */
    user-select:none;
    -webkit-user-select:none;
    -webkit-tap-highlight-color:transparent;
}
.mp-hero-track{
    display:flex;
    width:100%;
    transition:transform .4s cubic-bezier(.22,.61,.36,1);
    will-change:transform;
}
.mp-hero.is-dragging .mp-hero-track{transition:none}
.mp-hero-slide{
    flex:0 0 100%;
    min-width:0;
    box-sizing:border-box;
    display:flex;flex-direction:column;justify-content:center;
    min-height:140px;padding:24px 22px;
    background:linear-gradient(135deg,var(--from,#7C3AED),var(--to,#6D28D9));
    color:#fff !important;
    text-decoration:none !important;
    overflow:hidden;position:relative;
}
.mp-hero-slide::after{
    content:'';position:absolute;right:-30px;top:-30px;
    width:160px;height:160px;
    background:rgba(255,255,255,0.08);border-radius:50%;
    pointer-events:none;
}
.mp-hero-slide>*{position:relative;z-index:1;color:#fff !important}
.mp-hero-tag{
    display:inline-block;padding:4px 12px;
    font-size:11px;font-weight:700;letter-spacing:0.3px;
    background:rgba(255,255,255,0.22);
    border-radius:999px;margin-bottom:12px;width:fit-content;
}
.mp-hero-title{
    font-size:24px;font-weight:800;line-height:1.3;
    margin:0 0 6px;letter-spacing:-0.02em;
}
.mp-hero-desc{
    font-size:14px;font-weight:400;line-height:1.5;
    margin:0;opacity:0.92;
}
.mp-hero-dots{
    position:absolute;bottom:14px;left:50%;
    transform:translateX(-50%);
    display:flex;gap:6px;z-index:5;
}
.mp-hero-dot{
    width:7px;height:7px;border-radius:999px;
    border:none;padding:0;cursor:pointer;
    background:rgba(255,255,255,0.45);
    transition:background .2s, width .2s;
}
.mp-hero-dot.is-active{
    background:rgba(255,255,255,0.95);
    width:18px;
}
/* 드래그 중에는 링크 클릭 차단 (스와이프와 클릭 구분) */
.mp-hero.is-swiped .mp-hero-slide{pointer-events:none}
@media (min-width:768px){
    .mp-hero{margin:16px 0}
    .mp-hero-slide{padding:36px 40px;min-height:180px;border-radius:0}
    .mp-hero-slide::after{width:240px;height:240px;right:-40px;top:-60px}
    .mp-hero-title{font-size:30px}
    .mp-hero-desc{font-size:15px}
}

/* ════════════════════════════════════════════════════════════
   FEATURE SLIDE — 비교 다이어그램이 있는 풍성한 슬라이드
   ════════════════════════════════════════════════════════════ */
.mp-hero-slide--feature{
    padding:24px 22px 70px;
    min-height:280px;
    align-items:flex-start;
    justify-content:flex-start;
}
.mp-hero-slide--feature::before{
    content:'';position:absolute;left:-20px;bottom:-30px;
    width:120px;height:120px;
    background:rgba(255,255,255,0.06);border-radius:50%;
    pointer-events:none;
}
.mp-feature-inner{
    display:flex;flex-direction:column;gap:18px;
    width:100%;flex:1;
    position:relative;z-index:1;
}
.mp-feature-text{display:flex;flex-direction:column;gap:8px;width:100%}
.mp-feature-text .mp-hero-tag{margin-bottom:8px}
.mp-feature-text .mp-hero-title{font-size:22px;line-height:1.25}
.mp-feature-text .mp-hero-desc{font-size:13px;margin-bottom:12px}

.mp-feature-points{
    list-style:none;margin:6px 0 0;padding:0;
    display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
.mp-feature-points li{
    display:flex;flex-direction:column;align-items:flex-start;gap:6px;
    color:#fff;
}
.mp-feature-ico{
    width:32px;height:32px;border-radius:50%;
    background:rgba(255,255,255,0.22);
    display:flex;align-items:center;justify-content:center;
    color:#fff;flex-shrink:0;
}
.mp-feature-points li strong{
    display:block;font-size:12.5px;font-weight:700;color:#fff;line-height:1.3;
}
.mp-feature-points li small{
    display:none;font-size:11px;color:rgba(255,255,255,0.85);line-height:1.4;
}

.mp-feature-compare{display:none}
.mp-feature-quote{
    position:absolute;left:24px;right:24px;bottom:36px;
    text-align:center;font-size:11.5px;
    color:rgba(255,255,255,0.85);
    line-height:1.5;
}
.mp-feature-quote strong{color:#fff;font-weight:700}
.mp-quote-mark{font-size:14px;font-weight:700;opacity:0.7;margin:0 3px}

@media (min-width:768px){
    .mp-hero-slide--feature{
        padding:34px 36px 76px;
        min-height:360px;
    }
    .mp-feature-inner{flex-direction:row;gap:32px;align-items:center}
    .mp-feature-text{flex:1;max-width:50%}
    .mp-feature-text .mp-hero-title{font-size:30px;line-height:1.25}
    .mp-feature-text .mp-hero-desc{font-size:14.5px}
    .mp-feature-points{gap:14px;margin-top:18px}
    .mp-feature-points li{flex-direction:row;align-items:center;gap:10px}
    .mp-feature-ico{width:36px;height:36px}
    .mp-feature-points li strong{font-size:13.5px}
    .mp-feature-points li small{display:block;margin-top:1px}

    /* ── 비교 다이어그램 ── */
    .mp-feature-compare{
        display:flex;align-items:center;gap:10px;
        flex:0 0 auto;width:48%;max-width:520px;
    }
    .mp-compare-card{
        flex:1;background:#fff;color:#1F2937;
        border-radius:14px;padding:14px 12px 12px;
        text-align:center;
        box-shadow:0 4px 14px rgba(0,0,0,0.08);
    }
    .mp-compare-card--good{background:#EFF6FF}
    .mp-compare-label{
        font-size:12px;font-weight:700;color:#374151;
        margin-bottom:10px;letter-spacing:-0.01em;
    }
    .mp-compare-card--good .mp-compare-label{color:#0E4F94}
    .mp-compare-pill{
        display:inline-block;padding:5px 14px;
        font-size:11.5px;font-weight:700;
        border-radius:7px;background:#E5E7EB;color:#374151;
        margin-bottom:10px;
    }
    .mp-compare-pill--active{background:#0891B2;color:#fff}
    .mp-compare-arrows{
        display:flex;justify-content:center;gap:9px;
        height:34px;align-items:flex-start;margin-bottom:6px;
        position:relative;
    }
    .mp-compare-arrow{
        width:1.5px;height:30px;
        background:repeating-linear-gradient(to bottom,#9CA3AF 0,#9CA3AF 3px,transparent 3px,transparent 6px);
        position:relative;
    }
    .mp-compare-arrow::after{
        content:'';position:absolute;bottom:-2px;left:-3px;
        width:0;height:0;
        border-left:4px solid transparent;
        border-right:4px solid transparent;
        border-top:5px solid #9CA3AF;
    }
    .mp-compare-arrow--solid{
        width:2px;background:#0891B2;
    }
    .mp-compare-arrow--solid::after{border-top-color:#0891B2}
    .mp-compare-row{
        display:flex;justify-content:center;gap:6px;
        margin-bottom:10px;
    }
    .mp-compare-person{
        width:24px;height:24px;border-radius:50%;
        background:#D1D5DB;
        display:flex;align-items:center;justify-content:center;
        color:#fff;
    }
    .mp-compare-shield{
        width:26px;height:26px;border-radius:50%;
        background:#0891B2;
        display:flex;align-items:center;justify-content:center;
        color:#fff;
    }
    .mp-compare-foot{
        font-size:10.5px;color:#6B7280;font-weight:600;
        line-height:1.4;
    }
    .mp-compare-card--good .mp-compare-foot{color:#0891B2}
    .mp-compare-divider{
        flex-shrink:0;color:rgba(255,255,255,0.55);
        display:flex;align-items:center;
    }
}

@media (min-width:1024px){
    .mp-hero-slide--feature{padding:40px 50px 80px;min-height:400px}
    .mp-feature-text .mp-hero-title{font-size:34px}
    .mp-feature-compare{max-width:560px}
    .mp-feature-quote{font-size:13px;bottom:46px}
}

/* ════════════════════════════════════════════════════════════
   FEATURE DIAGRAM VARIANTS — free / experts / escrow
   ════════════════════════════════════════════════════════════ */
@media (min-width:768px){
    /* ─ B. 비용 대조 (free) ─ */
    .mp-cost-list{list-style:none;margin:0 0 6px;padding:0}
    .mp-cost-list li{
        display:flex;justify-content:space-between;align-items:center;
        padding:5px 0;font-size:11.5px;
        border-bottom:1px dashed #E5E7EB;
    }
    .mp-cost-list li:last-child{border-bottom:none}
    .mp-cost-list li span{color:#6B7280;font-weight:500}
    .mp-cost-list li strong{color:#374151;font-weight:700}
    .mp-cost-list--good li strong{color:var(--accent,#10B981);font-weight:800}

    /* ─ C. 전문가 통계 (experts) ─ */
    .mp-feature-compare--stats{
        gap:8px;align-items:stretch;
    }
    .mp-stat-card{
        flex:1;background:#fff;
        border-radius:12px;padding:18px 8px;
        text-align:center;
        box-shadow:0 4px 14px rgba(0,0,0,0.08);
        display:flex;flex-direction:column;justify-content:center;
    }
    .mp-stat-num{
        font-size:26px;font-weight:800;
        letter-spacing:-0.02em;line-height:1;
        color:#6366F1;
    }
    .mp-stat-num sub{
        font-size:14px;font-weight:700;
        margin-left:1px;bottom:0;vertical-align:baseline;
    }
    .mp-stat-label{
        margin-top:6px;
        font-size:11px;font-weight:600;
        color:#6B7280;letter-spacing:-0.01em;
    }

    /* ─ D. 결제 흐름 (escrow) ─ */
    .mp-feature-compare--flow{
        background:#fff;
        border-radius:14px;
        padding:16px 10px;
        gap:2px;
        box-shadow:0 4px 14px rgba(0,0,0,0.08);
    }
    .mp-flow-step{
        flex:1;display:flex;flex-direction:column;
        align-items:center;text-align:center;
        gap:4px;color:#1F2937;
    }
    .mp-flow-ico{
        width:34px;height:34px;border-radius:50%;
        background:#F3F4F6;color:#9CA3AF;
        display:flex;align-items:center;justify-content:center;
        flex-shrink:0;
    }
    .mp-flow-step--active .mp-flow-ico{
        background:#10B981;color:#fff;
        box-shadow:0 0 0 4px rgba(16,185,129,0.15);
    }
    .mp-flow-step strong{
        font-size:11.5px;font-weight:700;
        color:#1F2937;line-height:1.2;
        margin-top:2px;
    }
    .mp-flow-step small{
        font-size:9.5px;font-weight:500;
        color:#6B7280;line-height:1.3;
    }
    .mp-flow-arrow{
        flex-shrink:0;color:#D1D5DB;
        align-self:center;margin-top:-12px;
        display:flex;align-items:center;
    }
}

@media (min-width:1024px){
    .mp-stat-num{font-size:30px}
    .mp-stat-num sub{font-size:15px}
    .mp-stat-label{font-size:12px}
    .mp-flow-step strong{font-size:12.5px}
    .mp-flow-step small{font-size:10.5px}
    .mp-flow-ico{width:38px;height:38px}
    .mp-cost-list li{font-size:12.5px;padding:6px 0}
}

/* ════════════════════════════════════════════════════════════
   PROMO BANNER v2 — 중단·하단 광고 배너
   ════════════════════════════════════════════════════════════ */
.mp-promos{
    display:flex;flex-direction:column;
    gap:10px;padding:12px 16px;
}
.mp-promo{
    display:flex;align-items:center;justify-content:space-between;
    gap:12px;padding:16px 18px;
    border-radius:12px;
    background:linear-gradient(135deg,var(--from,#4F46E5),var(--to,#6366F1));
    color:#fff !important;
    text-decoration:none !important;
    overflow:hidden;position:relative;
    transition:transform .2s, box-shadow .2s;
}
.mp-promo:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,0.12)}
.mp-promo::after{
    content:'';position:absolute;right:-20px;top:-20px;
    width:100px;height:100px;
    background:rgba(255,255,255,0.08);border-radius:50%;
    pointer-events:none;
}
.mp-promo>*{position:relative;z-index:1;color:#fff !important}
.mp-promo-body{flex:1;min-width:0}
.mp-promo-tag{
    display:inline-block;padding:2px 9px;
    font-size:10.5px;font-weight:700;letter-spacing:0.3px;
    background:rgba(255,255,255,0.22);
    border-radius:999px;margin-bottom:6px;
}
.mp-promo-title{
    display:block;
    font-size:15px;font-weight:700;line-height:1.4;
    margin-bottom:2px;letter-spacing:-0.01em;
}
.mp-promo-desc{
    display:block;
    font-size:12.5px;line-height:1.5;
    opacity:0.88;
}
.mp-promo-arrow{
    flex-shrink:0;width:30px;height:30px;border-radius:50%;
    background:rgba(255,255,255,0.18);
    display:flex;align-items:center;justify-content:center;
    color:#fff !important;
}
@media (min-width:768px){
    .mp-promos{flex-direction:row;padding:16px 0;gap:12px}
    .mp-promo{flex:1;padding:20px 24px;border-radius:14px}
    .mp-promo-title{font-size:16px}
    .mp-promo-desc{font-size:13px}
}
.pe-section-title{font-size:17px;font-weight:800;letter-spacing:-0.02em;margin-bottom:4px}
.pe-section-desc{font-size:13px;color:var(--text-tertiary)}

/* 카드 */
.pe-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:20px 16px}

/* 프로필 사진 */
.pe-photo-wrap{display:flex;align-items:center;gap:16px}
.pe-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}
.pe-photo img{width:100%;height:100%;object-fit:cover}
.pe-photo-initial{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;border-radius:50%}
.pe-photo-actions{display:flex;gap:8px;flex-wrap:wrap}

/* 토글 스위치 */
.pe-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--border-light);cursor:pointer}
.pe-toggle-row:last-child{border-bottom:none}
.pe-toggle-input{display:none}
.pe-toggle{width:44px;height:24px;background:var(--border);border-radius:12px;position:relative;transition:background var(--transition-fast);flex-shrink:0}
.pe-toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:white;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}
.pe-toggle-input:checked+.pe-toggle{background:var(--primary)}
.pe-toggle-input:checked+.pe-toggle::after{transform:translateX(20px)}

/* ── PC: 좌우 분할 ── */
@media(min-width:1024px){
    .profile-edit-wrap{display:flex;max-width:var(--content-max);margin:0 auto;gap:0;align-items:flex-start}
    .profile-edit-side{display:block;width:260px;position:sticky;top:calc(var(--gnb-h) + 20px);flex-shrink:0;padding:20px 0}
    .profile-edit-side-inner{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden}

    .pe-profile-card{text-align:center;padding:28px 20px 20px;border-bottom:1px solid var(--border-light)}
    .pe-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;margin:0 auto 12px}
    .pe-name{font-size:16px;font-weight:700}
    .pe-email{font-size:12px;color:var(--text-tertiary);margin-top:2px}

    .pe-side-nav{padding:8px}
    .pe-side-link{display:block;padding:10px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);margin-bottom:2px}
    .pe-side-link:hover{background:var(--bg-secondary);color:var(--text-primary)}
    .pe-side-link.active{background:var(--primary-light);color:var(--primary);font-weight:700}

    .profile-edit-main{flex:1;min-width:0;padding:20px 0 80px 24px}
    .pe-section{padding:0 0 24px}
    .pe-section+.pe-section{border-top:none;padding-top:24px}
    .pe-card{border:1px solid var(--border-light);padding:24px;box-shadow:var(--shadow-xs)}
    .pe-section-title{font-size:18px}
}

/* ── Tablet ── */
@media(min-width:768px) and (max-width:1023px){
    .pe-section{padding:20px}
    .pe-card{padding:24px}
}

/* ═══════════════════════════════════════
   TOAST NOTIFICATION & SPINNER
   ═══════════════════════════════════════ */
.pe-toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-20px);display:flex;align-items:center;gap:10px;padding:14px 24px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;z-index:9999;opacity:0;transition:all .3s var(--ease-out);pointer-events:none;box-shadow:0 12px 32px rgba(0,0,0,0.12);max-width:420px}
.pe-toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.pe-toast.hide{opacity:0;transform:translateX(-50%) translateY(-12px)}
.pe-toast-success{background:#059669;color:white}
.pe-toast-error{background:#DC2626;color:white}
.pe-toast-icon{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}
.pe-toast-msg{line-height:1.4}

@media(min-width:1024px){
    .pe-toast{top:calc(var(--gnb-h) + 16px)}
}

.pe-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,0.3);border-top-color:white;border-radius:50%;animation:pe-spin .6s linear infinite;vertical-align:middle}
@keyframes pe-spin{to{transform:rotate(360deg)}}
