/* ============================================================
   MOA GONGU — 메인 스타일시트 v3.1
   컬러: 선명한 붉은색 계열 / 완전 반응형
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700;900&family=Playfair+Display:wght@700&display=swap');

:root {
  --primary:      #D42B2B;
  --primary-dk:   #B01F1F;
  --primary-lt:   #FEF0F0;
  --primary-mid:  #E85050;
  --accent:       #FF6B4A;
  --accent-lt:    #FFF3F0;
  --dark:         #1A0A0A;
  --brown-1:      #2C1515;
  --brown-2:      #6B3535;
  --gray-1:       #4A3232;
  --gray-2:       #8A6A6A;
  --gray-3:       #B8A0A0;
  --gray-4:       #E8D8D8;
  --gray-5:       #F5EEEE;
  --gray-6:       #FBF7F7;
  --white:        #FFFFFF;
  --success:      #16A34A;
  --warning:      #D97706;
  --info:         #2563EB;
  --danger:       #DC2626;
  --shadow-sm:    0 1px 4px rgba(180,0,0,.08);
  --shadow-md:    0 4px 20px rgba(180,0,0,.10);
  --shadow-lg:    0 8px 40px rgba(180,0,0,.14);
  --shadow-xl:    0 16px 56px rgba(180,0,0,.18);
  --radius-xs:    6px;
  --radius-sm:    10px;
  --radius-md:    16px;
  --radius-lg:    24px;
  --radius-xl:    32px;
  --radius-full:  9999px;
  --ease:         cubic-bezier(.25,.46,.45,.94);
  --duration:     .22s;
  /* 모바일 네비 높이 */
  --nav-h:        68px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Noto Sans KR',-apple-system,sans-serif;color:var(--dark);background:var(--white);font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}

/* ── 컨테이너 ── */
.mg-container{max-width:1200px;margin:0 auto;padding:0 20px}
.mg-container-sm{max-width:880px;margin:0 auto;padding:0 20px}

/* ═══════════════════════════════════
   헤더
═══════════════════════════════════ */
.mg-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-4);box-shadow:0 1px 0 rgba(212,43,43,.08)}
.mg-header-inner{display:flex;align-items:center;height:var(--nav-h);gap:16px;max-width:1200px;margin:0 auto;padding:0 20px}
.mg-logo{font-size:20px;font-weight:900;color:var(--primary);letter-spacing:-1px;flex-shrink:0;line-height:1}
.mg-logo span{color:var(--brown-1);font-weight:500;font-size:16px}
.mg-header-search{flex:1;max-width:440px;display:flex;align-items:center;border:1.5px solid var(--gray-4);border-radius:var(--radius-full);padding:7px 7px 7px 16px;gap:10px;transition:all var(--duration) var(--ease);background:var(--gray-6)}
.mg-header-search:hover,.mg-header-search:focus-within{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(212,43,43,.12)}
.mg-header-search input{border:none;outline:none;flex:1;font-family:inherit;font-size:14px;color:var(--dark);background:transparent;min-width:0}
.mg-header-search input::placeholder{color:var(--gray-3)}
.mg-header-search-btn{width:34px;height:34px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;flex-shrink:0;border:none;cursor:pointer;transition:background var(--duration)}
.mg-header-search-btn:hover{background:var(--primary-dk)}
.mg-header-nav{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}
.mg-header-nav a{padding:8px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--gray-1);transition:all var(--duration);white-space:nowrap}
.mg-header-nav a:hover{background:var(--gray-5);color:var(--dark)}
.mg-header-nav .btn-host{background:var(--primary);color:var(--white);border-radius:var(--radius-full);padding:9px 18px;font-weight:700}
.mg-header-nav .btn-host:hover{background:var(--primary-dk)}
.mg-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px;z-index:1100}
.mg-hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .25s}

/* 모바일 네비 드로어 */
.mg-nav-drawer{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:999}
.mg-nav-drawer.open{display:block}
.mg-nav-drawer-inner{background:#fff;padding:20px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 32px rgba(0,0,0,.15)}
.mg-nav-drawer-inner a{display:block;padding:13px 16px;font-size:15px;font-weight:500;color:var(--dark);border-radius:var(--radius-sm);transition:background .15s}
.mg-nav-drawer-inner a:hover{background:var(--gray-5)}
.mg-nav-drawer-inner .btn-host{background:var(--primary);color:#fff;text-align:center;font-weight:700;border-radius:var(--radius-sm);margin-top:6px}
/* 검색 (드로어 안) */
.mg-nav-drawer-search{display:flex;align-items:center;border:1.5px solid var(--gray-4);border-radius:var(--radius-full);padding:10px 16px;gap:10px;margin-bottom:8px;background:var(--gray-6)}
.mg-nav-drawer-search input{border:none;outline:none;flex:1;font-family:inherit;font-size:15px;background:transparent;color:var(--dark)}

/* ═══════════════════════════════════
   히어로
═══════════════════════════════════ */
.mg-hero{position:relative;min-height:520px;background:linear-gradient(150deg,#1A0A0A 0%,#5C0A0A 35%,#A01818 65%,#D42B2B 100%);display:flex;align-items:center;overflow:hidden}
.mg-hero::before{content:'';position:absolute;inset:0;background:url('../img/hero_bg.jpg') center/cover no-repeat;opacity:.15;mix-blend-mode:luminosity}
.mg-hero::after{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,74,.20) 0%,transparent 70%);top:-220px;right:-120px;pointer-events:none}
.mg-hero-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:72px 20px;width:100%}
.mg-hero h1{font-family:'Playfair Display','Noto Serif KR',serif;font-size:clamp(26px,4.5vw,52px);font-weight:700;color:#fff;line-height:1.2;margin-bottom:12px;letter-spacing:-.5px}
.mg-hero h1 em{color:var(--accent);font-style:normal}
.mg-hero p{font-size:clamp(14px,2vw,17px);color:rgba(255,255,255,.80);margin-bottom:36px;font-weight:300}
.mg-hero-search{background:#fff;border-radius:var(--radius-md);padding:10px;display:flex;gap:0;box-shadow:var(--shadow-xl);max-width:820px;border:1px solid rgba(212,43,43,.10)}
.mg-hs-item{flex:1;padding:10px 18px;border-right:1px solid var(--gray-4);cursor:pointer;min-width:0}
.mg-hs-item:last-of-type{border-right:none}
.mg-hs-item label{display:block;font-size:10px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px;white-space:nowrap}
.mg-hs-item input,.mg-hs-item select{width:100%;border:none;outline:none;font-family:inherit;font-size:14px;color:var(--dark);background:transparent;cursor:pointer;font-weight:500;min-width:0}
.mg-hs-btn{background:linear-gradient(135deg,var(--primary),var(--primary-mid));color:#fff;border:none;border-radius:var(--radius-sm);padding:0 28px;font-size:15px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all var(--duration);box-shadow:0 3px 12px rgba(212,43,43,.35);flex-shrink:0}
.mg-hs-btn:hover{background:linear-gradient(135deg,var(--primary-dk),var(--primary));box-shadow:0 5px 18px rgba(212,43,43,.45)}

/* ═══════════════════════════════════
   카테고리 탭
═══════════════════════════════════ */
.mg-category-bar{border-bottom:1px solid var(--gray-4);position:sticky;top:var(--nav-h);z-index:100;background:var(--white);box-shadow:0 2px 8px rgba(180,0,0,.04)}
.mg-category-inner{display:flex;overflow-x:auto;max-width:1200px;margin:0 auto;padding:0 20px;scrollbar-width:none}
.mg-category-inner::-webkit-scrollbar{display:none}
.mg-cat-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 18px;cursor:pointer;border-bottom:2.5px solid transparent;white-space:nowrap;transition:all var(--duration);font-size:12px;font-weight:500;color:var(--gray-2);text-decoration:none;flex-shrink:0}
.mg-cat-item .cat-ico{font-size:22px;transition:transform var(--duration)}
.mg-cat-item:hover{color:var(--primary)}
.mg-cat-item:hover .cat-ico{transform:scale(1.12)}
.mg-cat-item.active{color:var(--primary);font-weight:700;border-bottom-color:var(--primary)}

/* ═══════════════════════════════════
   섹션
═══════════════════════════════════ */
.mg-section{padding:56px 0}
.mg-section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:12px;flex-wrap:wrap}
.mg-section-title{font-size:clamp(18px,3vw,24px);font-weight:700;color:var(--dark);line-height:1.2}
.mg-section-title em{color:var(--primary);font-style:normal}
.mg-section-more{font-size:13px;font-weight:600;color:var(--primary);padding-bottom:2px;border-bottom:1.5px solid var(--primary);transition:opacity var(--duration);white-space:nowrap}
.mg-section-more:hover{opacity:.75}

/* ═══════════════════════════════════
   숙소 카드
═══════════════════════════════════ */
.mg-host-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
.mg-host-card{border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease);background:var(--white)}
.mg-host-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.mg-card-thumb{position:relative;height:200px;overflow:hidden;background:var(--gray-5);border-radius:var(--radius-md)}
.mg-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.mg-host-card:hover .mg-card-thumb img{transform:scale(1.06)}
.mg-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:56px;background:var(--gray-5)}
.mg-card-wish{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.92);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;border:none;transition:transform .15s;box-shadow:var(--shadow-sm)}
.mg-card-wish:hover{transform:scale(1.2)}
.mg-card-badge{position:absolute;top:10px;left:10px;background:var(--dark);color:#fff;font-size:10px;font-weight:700;padding:4px 10px;border-radius:var(--radius-xs)}
.mg-card-badge.featured{background:linear-gradient(135deg,var(--primary),var(--accent))}
.mg-card-body{padding:12px 2px 0}
.mg-card-location{font-size:12px;color:var(--gray-2);margin-bottom:4px}
.mg-card-name{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mg-card-rating{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;color:var(--dark);margin-bottom:6px}
.mg-card-rating .star{color:var(--primary)}
.mg-card-price{font-size:16px;font-weight:800;color:var(--dark)}
.mg-card-price span{font-weight:400;color:var(--gray-2);font-size:13px}

/* ═══════════════════════════════════
   필터
═══════════════════════════════════ */
.mg-filter-bar{display:flex;align-items:center;gap:8px;padding:14px 0;flex-wrap:wrap}
.mg-filter-btn{padding:8px 16px;border:1.5px solid var(--gray-4);border-radius:var(--radius-full);font-size:13px;font-weight:600;cursor:pointer;background:var(--white);transition:all var(--duration);white-space:nowrap;color:var(--gray-1)}
.mg-filter-btn:hover{border-color:var(--primary);color:var(--primary)}
.mg-filter-btn.active{background:var(--primary);color:var(--white);border-color:var(--primary)}

/* ═══════════════════════════════════
   숙소 상세
═══════════════════════════════════ */
.mg-detail-images{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:320px 0;gap:6px;border-radius:var(--radius-md);overflow:hidden;margin-bottom:32px}
.mg-detail-images .main-img{grid-row:span 2;height:320px}
.mg-detail-images img{width:100%;height:100%;object-fit:cover}
.mg-detail-grid{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.mg-detail-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--dark);margin-bottom:8px}
.mg-detail-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:14px;color:var(--gray-2);margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--gray-4)}
.mg-section-subtitle{font-size:17px;font-weight:700;margin-bottom:12px;color:var(--dark)}
.mg-amenity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.mg-amenity-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--gray-1);padding:8px 0}

/* 예약 패널 */
.mg-book-panel{background:var(--white);border-radius:var(--radius-md);border:1.5px solid var(--gray-4);box-shadow:var(--shadow-lg);padding:22px;position:sticky;top:90px}
.mg-book-price{font-size:22px;font-weight:800;margin-bottom:16px;color:var(--dark)}
.mg-book-price span{font-size:15px;font-weight:400;color:var(--gray-2)}
.mg-book-dates{display:grid;grid-template-columns:1fr 1fr;border:1.5px solid var(--gray-4);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:10px}
.mg-book-date-item{padding:12px 12px;cursor:pointer;transition:background var(--duration)}
.mg-book-date-item:hover{background:var(--gray-6)}
.mg-book-date-item:first-child{border-right:1px solid var(--gray-4)}
.mg-book-date-item label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--primary);margin-bottom:3px}
.mg-book-date-item input{border:none;outline:none;width:100%;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;background:transparent}
.mg-book-guests{border:1.5px solid var(--gray-4);border-radius:var(--radius-sm);padding:12px 12px;margin-bottom:14px;cursor:pointer;transition:background var(--duration)}
.mg-book-guests:hover{background:var(--gray-6)}
.mg-book-guests label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--primary);margin-bottom:3px}
.mg-price-breakdown{border-top:1px solid var(--gray-4);padding-top:14px;margin-top:14px}
.mg-price-row{display:flex;justify-content:space-between;font-size:14px;padding:5px 0;color:var(--gray-1)}
.mg-price-total{display:flex;justify-content:space-between;font-size:16px;font-weight:800;padding-top:12px;margin-top:8px;border-top:2px solid var(--dark);color:var(--dark)}
.mg-btn-book{width:100%;padding:15px;background:linear-gradient(135deg,var(--primary),var(--primary-mid));color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:700;cursor:pointer;transition:all var(--duration);margin-top:16px;box-shadow:0 4px 16px rgba(212,43,43,.35)}
.mg-btn-book:hover{background:linear-gradient(135deg,var(--primary-dk),var(--primary));box-shadow:0 6px 24px rgba(212,43,43,.45);transform:translateY(-1px)}

/* ═══════════════════════════════════
   리뷰
═══════════════════════════════════ */
.mg-review-summary{display:flex;gap:28px;align-items:center;padding:24px;background:var(--gray-6);border-radius:var(--radius-md);margin-bottom:24px;border:1px solid var(--gray-4);flex-wrap:wrap}
.mg-review-score{font-size:56px;font-weight:900;line-height:1;color:var(--primary)}
.mg-rating-bar{display:flex;flex-direction:column;gap:6px;flex:1;min-width:160px}
.mg-rating-row{display:flex;align-items:center;gap:10px;font-size:13px}
.mg-rating-row .bar-track{flex:1;height:4px;background:var(--gray-4);border-radius:2px}
.mg-rating-row .bar-fill{height:100%;background:var(--primary);border-radius:2px}
.mg-review-card{padding:20px 0;border-bottom:1px solid var(--gray-4)}
.mg-review-card:last-child{border-bottom:none}
.mg-review-author{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.mg-review-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.mg-review-stars{color:var(--primary);font-size:13px}

/* ═══════════════════════════════════
   배지
═══════════════════════════════════ */
.mg-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-xs);font-size:11px;font-weight:700;letter-spacing:.2px;white-space:nowrap}
.mg-badge.pending  {background:#FEF3C7;color:#92400E}
.mg-badge.confirmed{background:#D1FAE5;color:#065F46}
.mg-badge.cancelled{background:#FEE2E2;color:#991B1B}
.mg-badge.completed{background:#EDE9FE;color:#4C1D95}
.mg-badge.noshow   {background:#F3F4F6;color:#6B7280}

/* ═══════════════════════════════════
   버튼
═══════════════════════════════════ */
.mg-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:var(--radius-sm);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all var(--duration);text-decoration:none;letter-spacing:.2px}
.mg-btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-mid));color:#fff;box-shadow:0 4px 14px rgba(212,43,43,.30)}
.mg-btn-primary:hover{background:linear-gradient(135deg,var(--primary-dk),var(--primary));transform:translateY(-1px);box-shadow:0 6px 20px rgba(212,43,43,.40)}
.mg-btn-dark{background:var(--dark);color:#fff}
.mg-btn-dark:hover{background:var(--brown-1);color:#fff;transform:translateY(-1px)}
.mg-btn-outline{background:transparent;color:var(--dark);border:1.5px solid var(--gray-4)}
.mg-btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.mg-btn-sm{padding:8px 14px;font-size:13px}
.mg-btn-block{display:flex;width:100%;justify-content:center}

/* ═══════════════════════════════════
   폼
═══════════════════════════════════ */
.mg-form-group{margin-bottom:18px}
.mg-form-group label{display:block;font-size:13px;font-weight:700;color:var(--brown-1);margin-bottom:6px}
.mg-form-group label .req{color:var(--primary);margin-left:2px}
.mg-form-group input,.mg-form-group select,.mg-form-group textarea{width:100%;padding:11px 14px;border:1.5px solid var(--gray-4);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;color:var(--dark);background:var(--gray-6);transition:all var(--duration);outline:none}
.mg-form-group input:focus,.mg-form-group select:focus,.mg-form-group textarea:focus{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(212,43,43,.10)}
.mg-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mg-form-hint{font-size:12px;color:var(--gray-2);margin-top:4px}

/* ═══════════════════════════════════
   페이지네이션
═══════════════════════════════════ */
.mg-pagination{display:flex;justify-content:center;flex-wrap:wrap;gap:5px;margin-top:40px}
.pg-btn{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 6px;border-radius:var(--radius-sm);border:1.5px solid var(--gray-4);font-size:14px;font-weight:600;color:var(--gray-1);text-decoration:none;transition:all var(--duration)}
.pg-btn:hover{border-color:var(--primary);color:var(--primary)}
.pg-btn.active{background:var(--primary);color:var(--white);border-color:var(--primary);box-shadow:0 3px 10px rgba(212,43,43,.30)}

/* ═══════════════════════════════════
   관리자 레이아웃
═══════════════════════════════════ */
.mg-adm-shell{display:flex;min-height:100vh}
.mg-sidebar{width:240px;flex-shrink:0;background:linear-gradient(180deg,#1A0A0A 0%,#2C0E0E 100%);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;transition:transform .3s var(--ease)}
.mg-sidebar-logo{padding:22px 20px 18px;font-size:16px;font-weight:900;color:var(--accent);border-bottom:1px solid rgba(255,255,255,.07);text-decoration:none;display:block;transition:opacity var(--duration)}
.mg-sidebar-logo:hover{opacity:.85}
.mg-sidebar-logo span{color:rgba(255,255,255,.45);font-size:11px;font-weight:400;display:block;margin-top:3px;letter-spacing:.3px}
.mg-nav-section{padding:16px 16px 4px;font-size:10px;font-weight:700;color:rgba(255,255,255,.25);letter-spacing:1.8px;text-transform:uppercase}
.mg-nav a{display:flex;align-items:center;gap:10px;padding:10px 14px;margin:2px 8px;border-radius:var(--radius-xs);color:rgba(255,255,255,.60);text-decoration:none;font-size:13px;font-weight:500;transition:all var(--duration)}
.mg-nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.mg-nav a.active{background:linear-gradient(135deg,var(--primary),var(--primary-mid));color:#fff;font-weight:700;box-shadow:0 3px 10px rgba(212,43,43,.40)}
.mg-nav a .ico{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.mg-nav a .cnt{margin-left:auto;background:var(--warning);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full)}
.mg-sidebar-footer{margin-top:auto;padding:14px;font-size:11px;color:rgba(255,255,255,.20);text-align:center;border-top:1px solid rgba(255,255,255,.06)}
/* 관리자 모바일 토글 */
.mg-adm-toggle{display:none;position:fixed;bottom:20px;left:20px;z-index:1200;width:46px;height:46px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;font-size:20px;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(212,43,43,.4)}
.mg-main{flex:1;min-width:0;display:flex;flex-direction:column;background:#FDF5F5}
.mg-topbar{background:#fff;border-bottom:1px solid var(--gray-4);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 0 rgba(212,43,43,.06)}
.mg-topbar-title{font-size:16px;font-weight:700;color:var(--dark)}
.mg-topbar-right{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--gray-2);flex-wrap:wrap}
.mg-topbar-right a{color:var(--primary);font-weight:600;transition:opacity var(--duration)}
.mg-topbar-right a:hover{opacity:.75}
.mg-content{padding:24px;flex:1}

/* 통계 카드 */
.mg-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.mg-stat-card{background:#fff;border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);border-top:3px solid transparent;transition:transform var(--duration),box-shadow var(--duration)}
.mg-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.mg-stat-card.red   {border-top-color:var(--primary)}
.mg-stat-card.green {border-top-color:var(--success)}
.mg-stat-card.blue  {border-top-color:var(--info)}
.mg-stat-card.orange{border-top-color:var(--warning)}
.mg-stat-ico{font-size:28px;margin-bottom:10px}
.mg-stat-label{font-size:11px;color:var(--gray-2);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.mg-stat-value{font-size:26px;font-weight:900;color:var(--dark);line-height:1}
.mg-stat-sub{font-size:12px;color:var(--gray-2);margin-top:4px}

/* 관리자 테이블 */
.mg-adm-table{width:100%;border-collapse:collapse;background:#fff}
.mg-adm-table th{padding:11px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--gray-2);background:var(--gray-6);border-bottom:2px solid var(--gray-4);white-space:nowrap;text-transform:uppercase;letter-spacing:.4px}
.mg-adm-table td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--gray-5);vertical-align:middle}
.mg-adm-table tr:hover td{background:var(--accent-lt)}
.mg-panel{background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:18px;border:1px solid var(--gray-4)}
.mg-panel-header{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--gray-4);background:var(--gray-6);flex-wrap:wrap;gap:8px}
.mg-panel-header h3{font-size:14px;font-weight:700;color:var(--dark)}
.mg-panel-header a{font-size:13px;color:var(--primary);font-weight:600}
.mg-panel-body{padding:20px}

/* 빠른 실행 */
.mg-quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.mg-quick-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 10px;border-radius:var(--radius-sm);text-decoration:none;background:var(--gray-6);border:1.5px solid var(--gray-4);font-size:12px;font-weight:700;color:var(--gray-1);transition:all var(--duration);cursor:pointer}
.mg-quick-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-2px);box-shadow:0 6px 18px rgba(212,43,43,.30)}
.mg-quick-btn .q-ico{font-size:24px}

/* ═══════════════════════════════════
   푸터
═══════════════════════════════════ */
.mg-footer{background:linear-gradient(180deg,#1A0A0A 0%,#0E0404 100%);color:rgba(255,255,255,.55);padding:52px 0 28px}
.mg-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.mg-footer-logo{font-size:20px;font-weight:900;color:var(--accent);margin-bottom:10px}
.mg-footer-heading{font-size:12px;font-weight:700;color:rgba(255,255,255,.80);margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}
.mg-footer-links{list-style:none}
.mg-footer-links li{margin-bottom:9px}
.mg-footer-links a{font-size:13px;color:rgba(255,255,255,.45);transition:color var(--duration)}
.mg-footer-links a:hover{color:var(--accent)}
.mg-footer-bottom{padding-top:22px;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;font-size:12px;flex-wrap:wrap;gap:8px}

/* ═══════════════════════════════════
   반응형 — 태블릿 (≤1024px)
═══════════════════════════════════ */
@media(max-width:1024px){
  .mg-detail-grid{grid-template-columns:1fr}
  .mg-book-panel{position:static}
  .mg-stat-grid{grid-template-columns:repeat(2,1fr)}
  .mg-quick-grid{grid-template-columns:repeat(4,1fr)}
  .mg-footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .mg-hero-search{max-width:100%}
}

/* ═══════════════════════════════════
   반응형 — 모바일 (≤768px)
═══════════════════════════════════ */
@media(max-width:768px){
  /* 헤더: 검색 숨기고 햄버거 표시 */
  .mg-header-search{display:none}
  .mg-header-nav{display:none}
  .mg-hamburger{display:flex}

  /* 히어로 */
  .mg-hero{min-height:auto}
  .mg-hero-content{padding:48px 20px 40px}
  .mg-hero p{margin-bottom:24px}
  .mg-hero-search{
    flex-direction:column;
    border-radius:var(--radius-sm);
    padding:8px;
    gap:0
  }
  .mg-hs-item{
    border-right:none;
    border-bottom:1px solid var(--gray-4);
    padding:11px 14px
  }
  .mg-hs-item:last-of-type{border-bottom:none}
  .mg-hs-btn{padding:13px;border-radius:var(--radius-xs);margin-top:6px}

  /* 카테고리 탭 */
  .mg-cat-item{padding:10px 14px;font-size:11px}
  .mg-cat-item .cat-ico{font-size:20px}

  /* 카드 그리드 */
  .mg-host-grid{grid-template-columns:repeat(2,1fr);gap:14px}

  /* 섹션 */
  .mg-section{padding:40px 0}
  .mg-section-header{margin-bottom:20px}

  /* 상세 이미지 */
  .mg-detail-images{grid-template-columns:1fr;grid-template-rows:auto;max-height:280px}
  .mg-detail-images .main-img{grid-row:span 1;height:280px}

  /* 관리자 */
  .mg-sidebar{
    position:fixed;left:0;top:0;bottom:0;
    transform:translateX(-100%);
    z-index:1100;
    width:260px;
    height:100vh
  }
  .mg-sidebar.open{transform:translateX(0)}
  .mg-adm-toggle{display:flex}
  .mg-content{padding:14px}
  .mg-topbar{padding:0 16px;height:56px}
  .mg-topbar-title{font-size:15px}

  /* 폼 */
  .mg-form-row{grid-template-columns:1fr}

  /* 통계/빠른실행 */
  .mg-stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .mg-quick-grid{grid-template-columns:repeat(2,1fr)}

  /* 테이블 */
  .mg-adm-table{font-size:12px}
  .mg-adm-table th,.mg-adm-table td{padding:10px 10px}

  /* 패널 */
  .mg-panel-body{padding:14px}
}

/* ═══════════════════════════════════
   반응형 — 소형 모바일 (≤480px)
═══════════════════════════════════ */
@media(max-width:480px){
  :root{--nav-h:60px}

  .mg-container,.mg-container-sm{padding:0 14px}

  /* 로고 */
  .mg-logo{font-size:18px}
  .mg-logo span{font-size:14px}

  /* 히어로 */
  .mg-hero h1{font-size:24px;letter-spacing:-.3px}
  .mg-hero p{font-size:14px}
  .mg-hero-content{padding:36px 14px 32px}

  /* 카드 1열 */
  .mg-host-grid{grid-template-columns:1fr;gap:14px}
  .mg-card-thumb{height:220px}

  /* 섹션 */
  .mg-section{padding:32px 0}
  .mg-section-title{font-size:18px}

  /* 통계 */
  .mg-stat-grid{grid-template-columns:1fr 1fr;gap:8px}
  .mg-stat-value{font-size:22px}
  .mg-stat-card{padding:14px}

  /* 빠른실행 */
  .mg-quick-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .mg-quick-btn{padding:14px 8px}

  /* 푸터 */
  .mg-footer-grid{grid-template-columns:1fr;gap:24px}
  .mg-footer{padding:36px 0 20px}

  /* 페이지네이션 */
  .mg-pagination{gap:3px}
  .pg-btn{min-width:34px;height:34px;font-size:13px}

  /* 예약 날짜 */
  .mg-book-date-item input{font-size:12px}

  /* 테이블 스크롤 */
  .mg-panel>div{overflow-x:auto;-webkit-overflow-scrolling:touch}
}

/* ═══════════════════════════════════
   공통 유틸리티
═══════════════════════════════════ */
/* 관리자 모바일 오버레이 */
.mg-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1050}
.mg-sidebar-overlay.open{display:block}
/* 스크롤 잠금 */
body.no-scroll{overflow:hidden}
