/* ═══════════════════════════════════
   ARIARICOMMS — shared.css
   key:#a18679  sub:#f5b641  bg:#ffffff
═══════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&family=Noto+Sans+KR:wght@300;400;500&display=swap');

:root {
  --bg:      #ffffff;
  --bg2:     #f9f6f4;
  --bg3:     #f2ede9;
  --key:     #a18679;
  --key2:    #8c6f63;
  --sub:     #f5b641;
  --sub2:    #e0a332;
  --dark:    #1a1410;
  --mid:     #5a4d47;
  --gray:    #9e9189;
  --gray2:   #c5bdb9;
  --line:    rgba(161,134,121,0.15);
  --line2:   rgba(161,134,121,0.28);
  --nav-h:   64px;
  --ease:    cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; }
body {
  font-family:'DM Sans','Noto Sans KR',sans-serif;
  background:var(--bg); color:var(--dark);
  overflow-x:hidden; cursor:none;
  -webkit-font-smoothing:antialiased;
  animation:pageIn .4s var(--ease-out) both;
}
a { text-decoration:none; color:inherit; }
button { cursor:none; border:none; background:none; font-family:inherit; color:inherit; }
img { display:block; object-fit:cover; }

/* ── CURSOR ── */
#cursor { position:fixed; top:0; left:0; pointer-events:none; z-index:9999; }
#cursor-dot  { position:absolute; width:7px; height:7px; border-radius:50%; background:var(--key); transform:translate(-50%,-50%); transition:width .2s var(--ease),height .2s var(--ease); }
#cursor-ring { position:absolute; width:32px; height:32px; border-radius:50%; border:1.5px solid var(--key); opacity:.5; transform:translate(-50%,-50%); transition:width .3s var(--ease),height .3s var(--ease),opacity .3s; }
body.c-hover #cursor-dot  { width:10px; height:10px; background:var(--sub); }
body.c-hover #cursor-ring { width:46px; height:46px; opacity:.35; border-color:var(--sub); }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; width:100%; height:var(--nav-h); z-index:800;
  display:flex; align-items:center; justify-content:space-between; padding:0 52px;
  transition:background .4s var(--ease), border-bottom .4s, box-shadow .4s;
}
nav.scrolled {
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 24px rgba(161,134,121,.08);
}
.nav-logo { display:flex; align-items:center; height:32px; }
.nav-logo img { height:100%; width:auto; max-width:160px; display:block; transition:opacity .25s; object-fit:contain; }
.nav-logo:hover img { opacity:.72; }
.nav-links { display:flex; align-items:center; gap:36px; }
.nav-links a, .nav-links button.nav-link {
  font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; font-weight:500;
  color:var(--mid); position:relative; padding-bottom:3px; transition:color .25s;
  background:none; border:none; font-family:inherit;
}
.nav-links a::after, .nav-links button.nav-link::after {
  content:''; position:absolute; bottom:0; left:0; width:0; height:1.5px;
  background:var(--sub); transition:width .3s var(--ease);
}
.nav-links a:hover, .nav-links button.nav-link:hover { color:var(--dark); }
.nav-links a:hover::after, .nav-links button.nav-link:hover::after { width:100%; }
.nav-links a.active, .nav-links button.nav-link.active { color:var(--dark); }
.nav-links a.active::after, .nav-links button.nav-link.active::after { width:100%; }
.nav-admin-btn {
  font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gray);
  padding:5px 12px; border:1px solid var(--line2); border-radius:2px;
  transition:color .25s, border-color .25s;
}
.nav-admin-btn:hover { color:var(--key); border-color:var(--key); }
.nav-admin-btn.is-admin { color:var(--sub2); border-color:var(--sub2); }

/* ── PAGE FADE ── */
@keyframes pageIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes scanLine { 0%{left:-100%} 100%{left:100%} }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal.visible { opacity:1; transform:none; }

/* ── FOOTER ── */
.site-footer { border-top:1px solid var(--line); padding:18px 52px; }
.footer-copy { font-size:.62rem; letter-spacing:.09em; color:var(--gray); }

/* ── MODAL ── */
.modal-overlay {
  position:fixed; inset:0; z-index:2000;
  background:rgba(26,20,16,.5); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; padding:24px;
  transition:opacity .32s var(--ease);
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal-box {
  background:var(--bg); border:1px solid var(--line2);
  box-shadow:0 24px 80px rgba(26,20,16,.18);
  width:100%; max-width:880px; max-height:88vh; overflow-y:auto;
  transform:translateY(20px); transition:transform .32s var(--ease);
}
.modal-overlay.open .modal-box { transform:translateY(0); }
.modal-topbar { position:sticky; top:0; z-index:5; background:var(--bg); border-bottom:1px solid var(--line); padding:13px 20px; display:flex; justify-content:flex-end; }
.modal-close-btn { display:flex; align-items:center; gap:6px; font-size:.63rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gray); transition:color .25s; }
.modal-close-btn:hover { color:var(--dark); }
.modal-close-btn svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:2; }
.modal-body { padding:32px 40px 40px; }
.modal-cats { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:14px; }
.modal-cat { padding:3px 10px; font-size:.6rem; letter-spacing:.13em; text-transform:uppercase; color:var(--key); border:1px solid var(--line2); background:var(--bg2); border-radius:1px; }
.modal-title { font-family:'Cormorant Garamond',serif; font-size:clamp(1.6rem,3.5vw,2.7rem); font-weight:300; line-height:1.15; margin-bottom:8px; color:var(--dark); }
.modal-client { font-size:.8rem; color:var(--mid); margin-bottom:24px; display:flex; align-items:center; gap:8px; }
.modal-client::before { content:''; width:16px; height:1px; background:var(--gray2); flex-shrink:0; }
.modal-divider { border:none; border-top:1px solid var(--line); margin-bottom:20px; }
.modal-desc { font-size:.86rem; color:var(--mid); line-height:1.85; margin-bottom:30px; white-space:pre-wrap; }
.modal-gallery { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.modal-gallery img { aspect-ratio:16/9; object-fit:cover; border:1px solid var(--line); width:100%; }
.gallery-ph { aspect-ratio:16/9; background:var(--bg3); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-style:italic; font-size:.85rem; color:var(--gray2); border:1px solid var(--line); }
.modal-actions { display:none; gap:10px; margin-top:24px; padding-top:18px; border-top:1px solid var(--line); }
.modal-actions.on { display:flex; }
.btn-edit { padding:8px 18px; border:1px solid var(--line2); font-size:.67rem; letter-spacing:.12em; text-transform:uppercase; color:var(--dark); font-family:'DM Sans',sans-serif; border-radius:2px; transition:all .25s; background:var(--bg); }
.btn-edit:hover { border-color:var(--key); color:var(--key); }
.btn-delete { padding:8px 18px; border:1px solid var(--line2); font-size:.67rem; letter-spacing:.12em; text-transform:uppercase; color:var(--key); font-family:'DM Sans',sans-serif; border-radius:2px; transition:all .25s; background:var(--bg); }
.btn-delete:hover { background:var(--bg3); }

/* ── ADMIN FORM ── */
.admin-overlay { position:fixed; inset:0; z-index:3000; background:rgba(26,20,16,.45); backdrop-filter:blur(8px); display:flex; align-items:flex-start; justify-content:center; opacity:0; pointer-events:none; transition:opacity .3s var(--ease); padding:24px; overflow-y:auto; }
.admin-overlay.open { opacity:1; pointer-events:all; }
.admin-panel { background:var(--bg); border:1px solid var(--line2); box-shadow:0 24px 80px rgba(26,20,16,.14); width:100%; max-width:680px; margin:auto; transform:translateY(18px); transition:transform .3s var(--ease); }
.admin-overlay.open .admin-panel { transform:translateY(0); }
.admin-header { padding:18px 26px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; }
.admin-header h2 { font-family:'Cormorant Garamond',serif; font-weight:400; font-size:1.3rem; color:var(--dark); }
.admin-close-x { display:flex; align-items:center; gap:5px; font-size:.63rem; letter-spacing:.15em; text-transform:uppercase; color:var(--gray); transition:color .25s; }
.admin-close-x:hover { color:var(--dark); }
.admin-close-x svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:2; }
.admin-form { padding:24px 26px; display:flex; flex-direction:column; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); }
.form-input, .form-textarea { width:100%; background:var(--bg2); border:1px solid var(--line2); color:var(--dark); padding:10px 13px; font-family:'DM Sans','Noto Sans KR',sans-serif; font-size:.86rem; outline:none; border-radius:2px; transition:border-color .25s; }
.form-input:focus, .form-textarea:focus { border-color:var(--key); background:var(--bg); }
.form-textarea { resize:vertical; line-height:1.65; min-height:88px; }
.form-hint { font-size:.7rem; color:var(--gray); margin-top:2px; }
.form-cats { display:flex; flex-wrap:wrap; gap:7px; }
.form-cat-btn { padding:5px 12px; border:1px solid var(--line2); border-radius:2px; font-size:.65rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mid); transition:all .2s; font-family:'DM Sans',sans-serif; background:var(--bg); }
.form-cat-btn.sel { background:var(--key); border-color:var(--key); color:#fff; }
.form-actions { display:flex; gap:10px; justify-content:flex-end; padding-top:6px; border-top:1px solid var(--line); }
.btn-cancel { padding:9px 20px; border:1px solid var(--line2); font-size:.67rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mid); font-family:'DM Sans',sans-serif; border-radius:2px; transition:all .25s; background:var(--bg); }
.btn-cancel:hover { border-color:var(--key); color:var(--dark); }
.btn-save { padding:9px 22px; background:var(--key); font-size:.67rem; letter-spacing:.12em; text-transform:uppercase; color:#fff; font-family:'DM Sans',sans-serif; border-radius:2px; transition:background .25s; }
.btn-save:hover { background:var(--sub); }

/* ── LOGIN ── */
.login-overlay { position:fixed; inset:0; z-index:4000; background:rgba(26,20,16,.45); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .3s var(--ease); }
.login-overlay.open { opacity:1; pointer-events:all; }
.login-box { background:var(--bg); border:1px solid var(--line2); box-shadow:0 24px 80px rgba(26,20,16,.16); width:100%; max-width:360px; padding:40px 36px; text-align:center; }
.login-logo { font-family:'Cormorant Garamond',serif; font-size:1.18rem; font-weight:600; letter-spacing:.15em; margin-bottom:5px; color:var(--dark); }
.login-logo span { color:var(--key); }
.login-sub { font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); margin-bottom:26px; }
.login-error { font-size:.72rem; color:var(--key); margin-bottom:8px; display:none; }
.login-error.show { display:block; }
.btn-login { width:100%; padding:11px; background:var(--key); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:#fff; font-family:'DM Sans',sans-serif; border-radius:2px; transition:background .25s; margin-bottom:14px; }
.btn-login:hover { background:var(--sub); }
.login-close { font-size:.64rem; letter-spacing:.15em; text-transform:uppercase; color:var(--gray); transition:color .25s; }
.login-close:hover { color:var(--dark); }

/* ── TOAST ── */
.toast { position:fixed; bottom:24px; right:24px; z-index:5000; padding:11px 16px; background:var(--bg); border:1px solid var(--line2); box-shadow:0 4px 20px rgba(26,20,16,.1); font-size:.76rem; color:var(--dark); display:flex; align-items:center; gap:9px; transform:translateY(14px); opacity:0; transition:all .3s var(--ease); pointer-events:none; }
.toast.show { transform:translateY(0); opacity:1; }
.toast-dot { width:5px; height:5px; border-radius:50%; background:var(--sub); flex-shrink:0; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--gray2); border-radius:2px; }

/* ── RESPONSIVE ── */
@media (max-width:860px) {
  nav { padding:0 24px; }
  .nav-links { gap:18px; }
  .site-footer { padding-left:24px; padding-right:24px; }
  .modal-body { padding:22px; }
}
@media (max-width:600px) {
  .modal-gallery { grid-template-columns:1fr; }
}
