*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#B8952A;--gold-light:#D4AF55;--black:#0A0A0A;
  --dark:#111214;--mid:#1C1E22;--steel:#2A2D34;--white:#F7F4EE;
}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans KR',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;cursor:none}
.cursor{width:8px;height:8px;background:var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(184,149,42,.5);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .15s}
/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 60px;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(to bottom,rgba(10,10,10,.97),transparent);transition:background .4s}
nav.scrolled{background:rgba(10,10,10,.98);border-bottom:1px solid rgba(184,149,42,.15)}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;cursor:none}
.nav-logo img{width:48px;height:48px;object-fit:contain;filter:none}
.nav-logo-ko{font-family:'Noto Serif KR',serif;font-size:13px;font-weight:600;color:var(--white);letter-spacing:2px}
.nav-logo-en{font-family:'Cormorant Garamond',serif;font-size:11px;font-weight:300;color:var(--gold);letter-spacing:3px;text-transform:uppercase}
.nav-links{display:flex;gap:32px}
.nav-links a{font-size:11px;font-weight:300;letter-spacing:2px;text-transform:uppercase;color:rgba(247,244,238,.6);text-decoration:none;position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:.5px;background:var(--gold);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--gold-light)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);border:1px solid rgba(184,149,42,.4);padding:9px 20px;text-decoration:none;transition:all .3s}
.nav-cta:hover{background:var(--gold);color:var(--black)}
/* FOOTER */
footer{background:var(--dark);padding:48px 60px;border-top:1px solid rgba(184,149,42,.1)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.footer-logo{display:flex;align-items:center;gap:12px;text-decoration:none;cursor:none}
.footer-logo img{width:40px;height:40px;object-fit:contain;filter:none}
.footer-copy{font-size:11px;font-weight:300;color:rgba(247,244,238,.3)}
.footer-cert{display:flex;gap:8px;flex-wrap:wrap}
.cert-badge{font-size:9px;letter-spacing:1px;color:rgba(247,244,238,.3);border:1px solid rgba(184,149,42,.1);padding:4px 9px}
/* FLOATING */
.floating-contact{position:fixed;right:26px;bottom:26px;z-index:50;display:flex;flex-direction:column;gap:8px}
.float-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:17px;text-decoration:none;transition:all .3s;cursor:none}
.float-btn.phone{background:rgba(184,149,42,.12);border:1px solid rgba(184,149,42,.3);color:var(--gold)}
.float-btn.phone:hover{background:var(--gold);color:var(--black)}
.float-btn.mail{background:var(--gold);color:var(--black)}
.float-btn.mail:hover{background:var(--gold-light)}
/* UTIL */
section{padding:100px 60px}
.section-eyebrow{font-family:'Cormorant Garamond',serif;font-size:12px;letter-spacing:5px;color:var(--gold);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:14px}
.section-eyebrow::before{content:'';width:30px;height:.5px;background:var(--gold)}
.section-title{font-family:'Noto Serif KR',serif;font-size:clamp(26px,3.5vw,44px);font-weight:300;line-height:1.3;margin-bottom:16px}
.section-title em{font-style:italic;color:var(--gold-light);font-family:'Cormorant Garamond',serif;font-size:1.1em}
.section-sub{font-size:14px;font-weight:300;line-height:1.9;color:rgba(247,244,238,.55);max-width:580px}
.gold-line{width:50px;height:1px;background:var(--gold);margin:22px 0}
.btn-primary{background:var(--gold);color:var(--black);padding:14px 32px;text-decoration:none;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:500;transition:all .3s;display:inline-block}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(247,244,238,.25);color:var(--white);padding:14px 32px;text-decoration:none;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:300;transition:all .3s;display:inline-block}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .7s,transform .7s}
.fade-up.visible{opacity:1;transform:translateY(0)}
@media(max-width:900px){
  nav{padding:16px 20px} .nav-links{display:none}
  section{padding:70px 20px} footer{padding:36px 20px}
  body{cursor:auto} .cursor,.cursor-ring{display:none}
}

/* ══ 모바일 전체 개선 ══════════════════════════════ */
@media(max-width:768px){
  /* 네비 */
  nav { padding: 12px 16px !important; }
  .nav-logo img { width: 40px !important; height: 40px !important; }
  .nav-logo-ko { font-size: 12px !important; letter-spacing: 1px !important; }
  .nav-logo-en { font-size: 10px !important; }
  .nav-cta { padding: 7px 12px !important; font-size: 10px !important; }

  /* 전체 버튼 터치 최적화 */
  button, a[href], .tag-filter, .tb-btn, .cat-btn, .tab-btn {
    min-height: 44px !important;
    -webkit-tap-highlight-color: rgba(184,149,42,.2) !important;
    touch-action: manipulation !important;
  }

  /* 섹션 패딩 */
  section { padding: 60px 16px !important; }

  /* 퀵 그리드 */
  .quick-grid { grid-template-columns: repeat(2,1fr) !important; gap: 3px !important; }
  .quick-card { aspect-ratio: unset !important; min-height: 160px !important; }
  .quick-title { font-size: 14px !important; color: #f0ece4 !important; }
  .quick-num { color: #B8952A !important; }

  /* 앱 배너 */
  .app-top-banner {
    padding: 10px 14px !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
  }
  .app-banner-text { font-size: 11px !important; }
  .app-banner-text span { display: none !important; }
  .app-install-btn { 
    padding: 8px 14px !important; 
    font-size: 11px !important;
    white-space: nowrap !important;
    min-height: 36px !important;
  }
  .app-banner-close { 
    min-width: 36px !important; 
    min-height: 36px !important;
    font-size: 22px !important;
  }
  body.banner-visible nav { top: 45px !important; }

  /* 플로팅 버튼 */
  .floating-contact { right: 14px !important; bottom: 14px !important; }
  .float-btn { width: 50px !important; height: 50px !important; font-size: 20px !important; }

  /* 폼 */
  .form-row { grid-template-columns: 1fr !important; }

  /* 테이블 */
  .rec-table th:nth-child(3),
  .rec-table td:nth-child(3) { display: none !important; }

  /* 모달 */
  .modal-box, .write-box, .detail-box, .edit-box, .lock-box {
    width: 96vw !important;
    padding: 22px 16px !important;
    margin: 8px auto !important;
  }

  /* 잠금화면 */
  .lock-screen { padding: 20px !important; }
  .lock-input { font-size: 18px !important; padding: 14px !important; }
  .lock-btn { padding: 16px !important; font-size: 14px !important; }

  /* 페이지 히어로 */
  .page-hero { height: 28vh !important; padding: 0 16px 30px !important; }
  .page-hero-title { font-size: clamp(24px,7vw,40px) !important; }

  /* 푸터 */
  footer { padding: 32px 16px !important; }
  .footer-inner { flex-direction: column !important; gap: 16px !important; text-align: center !important; }
}
