여기에 **styles.css 전체 수정본(v1.7)** 넣어 쓰면 돼요.
(모바일 우선 네비·햄버거, 버튼 통일, 타이틀/카드제목 그라데이션, 사파리 안전 설정 포함)

```css
/* Aesthmaris — Royal Theme (Deep Navy + Refined Gold) */
/* v1.7 — mobile-first nav fix, unified buttons, safe gradients, Safari guards */

/* ========== Anchor / Scroll ========== */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 72px; /* fixed header 높이와 동일 */
}

/* ========== Theme Vars ========== */
:root{
  --bg:#0f1a35;                 /* deep navy */
  --fg:#d1b169;                 /* refined gold (본문 기본색) */
  --muted:#bfa463;              /* softer gold */

  /* gold gradient */
  --gold-1:#d1b169;             /* light gold */
  --gold-2:#9e7a2f;             /* deep gold */
  --text-grad: linear-gradient(135deg, var(--gold-1), var(--gold-2));

  --btn-fg:#0f1a35;             /* 버튼·active nav 글자색(네이비) */
  --card: rgba(8,14,32,.55);
  --stroke: rgba(255,255,255,.10);
  --radius:14px;
  --shadow: 0 8px 24px rgba(0,0,0,.35);
}

/* ========== Base ========== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  padding-top:72px; /* fixed header 공간 확보 */
  color:var(--fg);
  font:16px/1.65 'Source Sans 3', system-ui, -apple-system, Segoe UI, Roboto, Noto Sans, Helvetica, Arial, sans-serif;
  background:
    radial-gradient(1200px 800px at 20% -10%, rgba(255,255,255,.03), transparent 60%),
    radial-gradient(1000px 700px at 120% 10%, rgba(255,255,255,.02), transparent 55%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.02) 0 2px, transparent 2px 8px),
    var(--bg);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:1120px;margin:0 auto;padding:0 16px}
.shadow{box-shadow:var(--shadow)}

/* ========== Header / Nav ========== */
header{
  position:fixed;
  top:0; left:0; right:0;
  height:72px;
  z-index:9999;
  background:rgba(12,22,46,.85);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid var(--stroke);
  padding-top: env(safe-area-inset-top, 0); /* iOS notch */
}
.nav{display:flex;align-items:center;justify-content:flex-start;height:72px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}

/* --- Mobile-first: 기본은 모바일(가로 메뉴 숨김) --- */
.menu{ display:none !important; }
.hamb{ display:inline-flex !important; padding:10px;border:1px solid var(--stroke);border-radius:10px;background:rgba(255,255,255,.06);color:var(--fg) }

/* 드롭다운 패널 */
.mobile{
  display:none;                 /* JS로 토글 */
  position:fixed;
  top:72px; left:0; right:0;
  z-index:9998;
  background:rgba(12,22,46,.92);
  backdrop-filter:saturate(120%) blur(8px);
  border-top:1px solid var(--stroke);
  padding:8px 12px calc(12px + env(safe-area-inset-bottom, 0));
}
.mobile a{
  display:block;
  padding:12px 14px;
  border-radius:12px;
  margin:6px 0;
  background:rgba(255,255,255,.06);
  color:var(--fg) !important;
  -webkit-text-fill-color: var(--fg) !important; /* Safari */
}

/* --- Desktop 이상: 가로 메뉴 표시 --- */
@media (min-width: 860px){
  .menu{ display:flex !important; align-items:center; gap:28px }
  .hamb{ display:none !important; }
  .mobile{ display:none !important; }
}

.menu a{
  padding:10px 14px;border-radius:999px;opacity:.95;
  transition:background .2s ease,color .2s ease
}
/* 비활성 메뉴에 은은한 그라데이션 글자 */
.menu a:not(.active){
  background: var(--text-grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.menu a:hover{background:rgba(255,255,255,.07)}
.menu a.active{
  background:linear-gradient(135deg,var(--gold-1),var(--gold-2)) !important;
  color:var(--btn-fg) !important;
  -webkit-background-clip: initial !important;
  -webkit-text-fill-color: initial !important;
  box-shadow:0 2px 8px rgba(0,0,0,.35);
}

/* ========== Grids ========== */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
@media(min-width:720px){
  .grid-2{grid-template-columns:1.2fr 1fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
}

/* ========== Hero ========== */
.hero{padding:96px 0}
.art{
  border-radius:var(--radius);
  border:1px solid var(--stroke);
  background:rgba(8,14,32,.6);
  position:relative;
  box-shadow:var(--shadow);
}
.art::before{
  content:"";position:absolute;inset:8px;
  border:1px solid var(--gold-1);
  border-radius:calc(var(--radius) - 8px);
  opacity:.8;pointer-events:none;
}

/* ========== Cards ========== */
.card{
  background:var(--card);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  position:relative;
  color:var(--fg);
  overflow:hidden;
  z-index:1;
}
.card::before{
  content:"";position:absolute;inset:6px;
  border:1px solid var(--gold-1);
  border-radius:calc(var(--radius) - 6px);
  opacity:.7;pointer-events:none;z-index:2;
}
.card > *{position:relative}
.card img{
  display:block;
  width:calc(100% - 12px) !important;
  margin:6px auto 0;
  border-radius:calc(var(--radius) - 6px);
  object-fit:cover;
  position:relative;
  z-index:1;
}
.card img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(212,175,55,0.08), rgba(0,0,0,0.2));
  border-radius:inherit;
  z-index:2;pointer-events:none;
}

/* 카드 제목(볼드 라인) 그라데이션 */
.card [style*="font-weight:700"],
.card div[style*="font-weight:700"]{
  font-family:'Cinzel', serif;
  background:var(--text-grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ========== Typography ========== */
h1,h2,h3{
  font-family:'Cinzel', serif;
  background:var(--text-grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
h1{font-size:40px;line-height:1.1}
h2{font-size:28px}
p, li, label, span, div{color:var(--fg)} /* 본문은 단색 골드(가독성) */
.muted{color:var(--muted)}
.section{padding:48px 0 96px}

/* Section ornament */
.section > .container > h2{
  position:relative;padding-bottom:12px;margin-bottom:28px;
  text-align:center;letter-spacing:1px;
}
.section > .container > h2::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-1),transparent);
  opacity:.8;
}
.section > .container > h2::before{
  content:"✦";position:absolute;bottom:-16px;left:50%;
  transform:translateX(-50%);
  font-size:14px;color:var(--gold-2);opacity:.8;
}

/* Tags */
.tag{
  display:inline-block;border:1px solid var(--stroke);
  border-radius:999px;padding:4px 10px;font-size:12px;margin-right:6px;
  color:var(--fg) !important;
  background:rgba(255,255,255,.04);
}

/* ========== Buttons (통일) ========== */
.btn, .btn.fill{
  display:inline-block;
  padding:12px 18px;
  border-radius:12px;
  font-weight:600;
  text-align:center;
  border:none !important;
  cursor:pointer;
  transition:all .2s ease;

  background:linear-gradient(135deg,var(--gold-1),var(--gold-2)) !important;
  color:var(--btn-fg) !important;
  -webkit-text-fill-color: var(--btn-fg) !important; /* Safari */
  box-shadow:0 2px 8px rgba(0,0,0,.35) !important;
}
.btn:hover{ filter:brightness(1.06); transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }
.btn:focus-visible{
  outline:2px solid rgba(209,177,105,.85);
  outline-offset:2px;
}

/* ========== Forms ========== */
input,textarea{
  width:100%;padding:10px;border-radius:10px;border:1px solid var(--stroke);
  background:rgba(255,255,255,.05) !important;
  color:var(--fg) !important;
  -webkit-text-fill-color: var(--fg) !important;
}
textarea{min-height:120px}

/* ========== Footer ========== */
footer{
  border-top:2px solid var(--gold-2);
  padding:48px 0;
  margin-top:64px;
  text-align:center;
}

/* ========== Section tweaks ========== */
#news { min-height:80vh; }  /* 짧게 스쳐 지나감 방지 */
/* --- Desktop 이상: 가로 메뉴 표시 --- */
@media (min-width: 860px){
  .menu{
    display:flex !important;
    align-items:center;
    gap:28px;
    margin-left:auto;      /* ✅ 이 줄 추가해서 우측 정렬 */
  }
  .hamb{ display:none !important; }
  .mobile{ display:none !important; }
}
/* --- Mobile: push hamburger to the far right --- */
@media (max-width: 859px){
  /* nav는 그대로 플렉스 */
  .nav{ display:flex; align-items:center; }

  /* 햄버거 버튼을 오른쪽 끝으로 */
  .nav .hamb{ margin-left:auto; }

  /* 만약 햄버거가 div로 한번 감싸져 있으면 이 라인이 효과적 */
  .nav > div:last-child{ margin-left:auto; }
}

