/* ===== Reset & Base ===== */ *, *::before, *::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', 'Pretendard', 'Noto Sans KR', sans-serif;color:#1a1a1a;background:#fafafa;line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}main{flex:1}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{border:none;background:none;cursor:pointer;font:inherit}/* ===== Nav ===== */ .portal-nav{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #eee}.nav-inner{max-width:1200px;margin:0 auto;padding:0 16px;height:56px;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:6px}.nav-logo-text{font-size:1.25rem;font-weight:700;color:#7B1FA2}.nav-badge{font-size:0.7rem;font-weight:600;color:#7B1FA2;background:#F3E5F5;padding:2px 8px;border-radius:10px}.btn-icon{padding:8px;border-radius:8px;color:#666}.btn-icon:hover{background:#f5f5f5}/* ===== Footer ===== */ .portal-footer{background:#fff;color:#999;padding:28px 16px 32px;margin-top:auto;border-top:1px solid #eee}.footer-inner{max-width:1200px;margin:0 auto}.footer-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px}.footer-brand{display:flex;align-items:center;gap:8px}.footer-links{display:flex;gap:16px}.footer-links a{font-size:0.75rem;color:#555;font-weight:500;text-decoration:none}.footer-links a:hover{color:#222}.footer-info{font-size:0.7rem;color:#bbb;line-height:1.8}.footer-info span{white-space:nowrap}.footer-info .sep{margin:0 6px;color:#ddd}/* ===== Common ===== */ .container{max-width:1200px;margin:0 auto;padding:0 16px}.section-title{font-size:1.25rem;font-weight:700;margin-bottom:16px}.tag{font-size:0.75rem;font-weight:500;color:#7B1FA2;background:#F3E5F5;padding:3px 10px;border-radius:12px;white-space:nowrap}.feature{font-size:0.75rem;color:#666;background:#f0f0f0;padding:2px 8px;border-radius:4px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#2DB400;color:#fff;font-weight:600;padding:12px 24px;border-radius:8px;font-size:0.95rem;transition:background 0.2s}.btn-primary:hover{background:#269900}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid #ddd;color:#333;font-weight:500;padding:10px 20px;border-radius:8px;font-size:0.9rem;transition:all 0.2s}.btn-outline:hover{border-color:#7B1FA2;color:#7B1FA2}.empty-state{text-align:center;padding:80px 16px;color:#999}.empty-state > svg{margin-bottom:16px}/* ===== Branch Card Grid ===== */ .branch-grid{display:grid;gap:20px;grid-template-columns:1fr}.branch-card{display:block;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.08);transition:box-shadow 0.2s, transform 0.2s}.branch-card:hover{box-shadow:0 4px 12px rgba(0,0,0,0.12);transform:translateY(-2px)}.card-image{position:relative;overflow:hidden;background:#f5f5f5}.card-image::before{content:'';display:block;padding-top:62.5%;/* 16:10 */}.card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.card-image-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.card-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.card-tags{position:absolute;bottom:8px;left:8px;display:flex;gap:4px}.card-body{padding:14px 16px}.card-title{font-size:1rem;font-weight:700;margin-bottom:4px}.card-region{font-size:0.8rem;color:#888;margin-bottom:6px}.card-desc{font-size:0.85rem;color:#666;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{display:flex;align-items:center;gap:12px;margin-bottom:6px}.card-rating{display:flex;align-items:center;gap:3px;font-size:0.85rem;font-weight:600}.review-count{font-weight:400;color:#999;font-size:0.8rem}.card-price{font-size:0.85rem;font-weight:600;color:#7B1FA2}.card-features{display:flex;gap:6px;flex-wrap:wrap}/* ===== Filters ===== */ .filter-bar{display:flex;gap:8px;flex-wrap:wrap;padding:16px 0;overflow-x:auto}.filter-chip{font-size:0.85rem;padding:7px 16px;border:1px solid #ddd;border-radius:20px;background:#fff;color:#555;cursor:pointer;white-space:nowrap;transition:all 0.2s}@media (hover:hover){.filter-chip:hover{border-color:#7B1FA2;color:#7B1FA2;background:#F3E5F5}}.filter-chip.active{border-color:#7B1FA2;color:#7B1FA2;background:#F3E5F5}/* ===== Review Cards ===== */ .review-card{background:#fff;border-radius:10px;padding:16px;border:1px solid #eee}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.review-author{display:flex;flex-direction:column}.author-name{font-weight:600;font-size:0.9rem}.review-date{font-size:0.75rem;color:#999}.review-rating{display:flex;gap:1px}.review-content{font-size:0.9rem;color:#333;line-height:1.6;margin-bottom:8px}.review-images{display:flex;gap:8px;overflow-x:auto;margin-bottom:8px}.review-images img{width:80px;height:80px;object-fit:cover;border-radius:8px;flex-shrink:0}.owner-reply{background:#f8f8f8;border-radius:8px;padding:12px;margin-top:8px}.reply-label{font-size:0.8rem;font-weight:600;color:#7B1FA2;display:block;margin-bottom:4px}.owner-reply p{font-size:0.85rem;color:#555}/* ===== Search ===== */ .search-section{padding:24px 0}.search-box{display:flex;align-items:center;gap:8px;background:#fff;border:2px solid #eee;border-radius:12px;padding:10px 16px;transition:border-color 0.2s}.search-box:focus-within{border-color:#7B1FA2}.search-box input{flex:1;border:none;outline:none;font-size:1rem;background:transparent}.search-box input::placeholder{color:#bbb}/* ===== Responsive ===== */ @media (max-width:767px){.nav-user-name{display:none}.page-detail .portal-footer{display:none}}@media (min-width:768px){.branch-grid{grid-template-columns:repeat(2, 1fr)}}@media (min-width:1024px){.branch-grid{grid-template-columns:repeat(3, 1fr)}}