/* ===== MOBYDICK END — Cinematic Black Luxury ===== */
:root{
  --bg:#0b0b0d; --bg-soft:#121214; --surface:#17171a;
  --line:rgba(240,233,221,.10); --line-strong:rgba(240,233,221,.18);
  --text:#f1ebe0; --muted:#9c968c; --muted-d:#6f6a63;
  --gold:#c6a45c; --gold-soft:#e3cf9b;
  --maxw:1200px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Pretendard","Pretendard Variable",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);background:var(--bg);color:var(--text);
  line-height:1.7;overflow-x:hidden;letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  word-break:keep-all;overflow-wrap:break-word;
}
/* film grain */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img,video,iframe,table{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#0b0b0d}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,2.5rem)}
section{position:relative}

/* ===== Typography ===== */
h1,h2,h3{line-height:1.12;font-weight:600;letter-spacing:-.02em;word-break:keep-all;overflow-wrap:break-word;text-wrap:balance}
/* 한글 줄바꿈: 짧은 카피는 균형, 긴 본문은 고아줄 방지 */
p,li,.info .v,.lead,.svc .desc,.hero h1,.phero h1,.sec-title,.hero .sub,.phero p,.cta-band h2,.cta-band p{text-wrap:pretty}
.info .v{overflow-wrap:anywhere}
.serif{font-family:var(--serif)}
.overline{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.78rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.3rem;
}
.overline::before{content:"";width:34px;height:1px;background:var(--gold);opacity:.7}
.sec-title{font-family:var(--serif);font-size:clamp(2.1rem,4.4vw,3.4rem);font-weight:600;line-height:1.08}
.lead{color:var(--muted);font-size:clamp(1rem,1.4vw,1.12rem);max-width:62ch}

/* ===== Buttons ===== */
.btn,.btn-ghost{
  display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;
  padding:.95rem 1.9rem;border-radius:2px;font-weight:600;font-size:.95rem;
  letter-spacing:.02em;transition:all .35s var(--ease);border:1px solid transparent;
}
.btn{background:var(--gold);color:#0b0b0d}
.btn:hover{background:var(--gold-soft);transform:translateY(-2px);box-shadow:0 14px 36px -12px rgba(198,164,92,.6)}
.btn-ghost{border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn .ar{transition:transform .35s var(--ease)}
.btn:hover .ar,.btn-ghost:hover .ar{transform:translateX(4px)}

/* ===== Header ===== */
.hdr{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s var(--ease)}
.hdr.scrolled{background:rgba(11,11,13,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{height:30px;width:auto;filter:drop-shadow(0 1px 6px rgba(0,0,0,.5))}
.brand .mark{display:inline-block;width:3px;height:30px;border-radius:2px;background:linear-gradient(var(--gold-soft),var(--gold));box-shadow:0 0 12px -2px var(--gold)}
.foot-brand .mark{height:40px}
.brand .logo-h{height:30px;width:auto;filter:drop-shadow(0 1px 6px rgba(0,0,0,.5))}
.foot-brand .logo-h{height:38px}
@media(max-width:640px){.brand .logo-h{height:26px}}
.brand .bt{font-family:var(--serif);font-size:1.45rem;font-weight:700;letter-spacing:.02em;line-height:1}
.brand .bt small{display:block;font-family:var(--sans);font-size:.58rem;letter-spacing:.34em;color:var(--gold);font-weight:600;margin-top:2px}
.nav{display:flex;align-items:center;gap:1.6rem}
.nav a{font-size:.94rem;color:var(--muted);font-weight:500;position:relative;transition:color .3s}
.nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav a:hover,.nav a.active{color:var(--text)}
.nav a.active::after,.nav a:hover::after{width:100%}
.nav .cta{padding:.6rem 1.3rem;border:1px solid var(--gold);color:var(--gold);border-radius:2px}
.nav .cta::after{display:none}
.nav .cta:hover{background:var(--gold);color:#0b0b0d}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--text);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Hero ===== */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,11,13,.72)0%,rgba(11,11,13,.45)45%,rgba(11,11,13,.92)100%),
             radial-gradient(120% 80% at 70% 0%,rgba(198,164,92,.16),transparent 55%)}
.hero-in{padding-top:8rem;padding-bottom:5rem;max-width:880px}
.hero h1{font-family:var(--serif);font-size:clamp(1.85rem,6.2vw,5.4rem);font-weight:600;line-height:1.08;letter-spacing:-.02em;word-break:keep-all}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .sub{margin:1.8rem 0 2.6rem;font-size:clamp(1.05rem,1.8vw,1.3rem);color:#d8d2c7;max-width:46ch;font-weight:300}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--muted);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero-scroll::after{content:"";width:1px;height:46px;background:linear-gradient(var(--gold),transparent);animation:scrolldn 2s infinite}
@keyframes scrolldn{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===== generic section heads ===== */
.sec{padding:clamp(5rem,10vw,8rem) 0}
.sec.soft{background:var(--bg-soft)}
.sec-head{max-width:680px;margin-bottom:clamp(2.5rem,5vw,3.8rem)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .overline{justify-content:center}

/* ===== stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden}
.stat{background:var(--bg);padding:2.2rem 1.4rem;text-align:center}
.stat .num{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:700;color:var(--gold);line-height:1}
.stat .lbl{margin-top:.6rem;font-size:.86rem;color:var(--muted);letter-spacing:.02em}

/* ===== intro split ===== */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split p{color:var(--muted);margin-top:1.3rem;font-size:1.02rem}
.split .figure{position:relative;border-radius:4px;overflow:hidden;border:1px solid var(--line)}
.split .figure img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split .figure::after{content:"";position:absolute;inset:0;box-shadow:inset 0 -80px 80px -40px rgba(11,11,13,.8)}
.tag-badge{position:absolute;left:1.1rem;bottom:1.1rem;z-index:2;font-family:var(--serif);font-size:1.1rem;color:var(--gold-soft);letter-spacing:.04em}

/* ===== feature cards ===== */
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.4rem}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem}
.proc-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.4rem}
@media(max-width:900px){.proc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:480px){.proc-grid{grid-template-columns:1fr 1fr}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:2.2rem 1.9rem;transition:all .4s var(--ease)}
.card:hover{border-color:rgba(198,164,92,.5);transform:translateY(-5px);background:#1c1c20}
.card .ic{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-strong);border-radius:50%;margin-bottom:1.3rem;color:var(--gold)}
.card h3{font-size:1.22rem;margin-bottom:.6rem}
.card p{color:var(--muted);font-size:.96rem}
.card .price{margin-top:1.1rem;font-size:.84rem;color:var(--gold);letter-spacing:.08em;text-transform:uppercase}

/* ===== service rows ===== */
.svc{border-top:1px solid var(--line);padding:clamp(2rem,4vw,3rem) 0;display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:start}
.svc:last-child{border-bottom:1px solid var(--line)}
.svc .no{font-family:var(--serif);font-size:1.5rem;color:var(--gold);font-weight:600;min-width:3ch}
.svc h3{font-size:clamp(1.5rem,3vw,2.1rem);font-family:var(--serif);font-weight:600}
.svc .desc{color:var(--muted);margin-top:.9rem;max-width:60ch}
.svc .chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.1rem}
.svc .chips span{font-size:.8rem;color:var(--muted);border:1px solid var(--line);padding:.3rem .8rem;border-radius:99px}
.svc .pricecol{text-align:right;color:var(--gold);font-weight:600;white-space:nowrap;letter-spacing:.04em}
.svc .pricecol small{display:block;color:var(--muted-d);font-weight:400;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3rem}

/* ===== event insurance ===== */
.ins-list{list-style:none;display:grid;gap:1rem;margin-top:.4rem}
.ins-list li{position:relative;padding-left:1.9rem;color:var(--muted);font-size:.97rem;line-height:1.6}
.ins-list li::before{content:"✓";position:absolute;left:0;top:0;color:var(--gold);font-weight:700}
.ins-list li strong{color:var(--text);font-weight:600}
.ask-box{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:clamp(1.7rem,3.5vw,2.6rem)}
.ask-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem 2rem;margin-top:.4rem}
.ask-grid span{color:var(--text);font-size:.97rem;padding-bottom:.9rem;border-bottom:1px solid var(--line)}
.ask-grid span.full{grid-column:1/-1}
.ask-grid em{color:var(--muted);font-style:normal;font-size:.88rem}
@media(max-width:640px){.ask-grid{grid-template-columns:1fr}}

/* ===== gallery ===== */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.2rem;justify-content:center}
.filters button{background:none;border:1px solid var(--line);color:var(--muted);padding:.55rem 1.3rem;border-radius:99px;cursor:pointer;font-family:var(--sans);font-size:.9rem;transition:all .3s}
.filters button:hover{color:var(--text);border-color:var(--line-strong)}
.filters button.active{background:var(--gold);color:#0b0b0d;border-color:var(--gold)}
.masonry{columns:3;column-gap:14px}
.tile{break-inside:avoid;margin-bottom:14px;position:relative;border-radius:4px;overflow:hidden;cursor:pointer;border:1px solid var(--line);background:var(--surface)}
.tile img{width:100%;transition:transform .6s var(--ease);opacity:0;transition:opacity .6s,transform .6s var(--ease)}
.tile img.loaded{opacity:1}
.tile:hover img{transform:scale(1.05)}
.tile::after{content:attr(data-label);position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .7rem;font-size:.78rem;letter-spacing:.04em;color:var(--gold-soft);
  background:linear-gradient(transparent,rgba(11,11,13,.85));opacity:0;transform:translateY(8px);transition:.4s}
.tile:hover::after{opacity:1;transform:none}

/* lightbox */
.lb{position:fixed;inset:0;z-index:2000;background:rgba(7,7,8,.96);display:none;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.lb.open{display:flex;animation:fade .3s}
.lb img{max-width:92vw;max-height:86vh;border-radius:4px;box-shadow:0 30px 80px -20px #000}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.06);border:1px solid var(--line-strong);color:var(--text);width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:.3s}
.lb-close:hover,.lb-nav:hover{background:var(--gold);color:#0b0b0d;border-color:var(--gold)}
.lb-close{top:1.4rem;right:1.4rem}
.lb-nav.prev{left:1.4rem;top:50%;transform:translateY(-50%)}
.lb-nav.next{right:1.4rem;top:50%;transform:translateY(-50%)}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ===== CTA band ===== */
.cta-band{position:relative;text-align:center;padding:clamp(5rem,9vw,7rem) 0;overflow:hidden}
.cta-band .bgimg{position:absolute;inset:0;z-index:-2}
.cta-band .bgimg img{width:100%;height:100%;object-fit:cover}
.cta-band .bgimg::after{content:"";position:absolute;inset:0;background:rgba(8,8,10,.8)}
.cta-band h2{font-family:var(--serif);font-size:clamp(2rem,4.5vw,3.4rem);font-weight:600;margin-bottom:1rem}
.cta-band p{color:var(--muted);margin-bottom:2.2rem;max-width:50ch;margin-inline:auto}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== contact info cards ===== */
.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.4rem}
.info{background:var(--surface);border:1px solid var(--line);padding:1.9rem;border-radius:4px;min-width:0}
.info .k{display:flex;align-items:center;gap:.5rem;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.info .k svg{width:15px;height:15px;flex:none}
.info .v{font-size:1.05rem}
.info .v a:hover{color:var(--gold)}
.info .v.addr-line{line-height:1.5}
/* PC 전용 줄바꿈 (모바일에선 자동 흐름) */
@media(max-width:640px){br.pc-br{display:none}}
.info .v small{color:var(--muted);font-size:.86rem}

.map-wrap{border:1px solid var(--line);border-radius:4px;overflow:hidden;height:420px;background:#1a1a1d}
.map-wrap iframe{width:100%;height:100%;border:0;filter:invert(.92) hue-rotate(180deg) brightness(.96) contrast(.92)}
.map-links{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem}
.map-links a{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line-strong);color:var(--text);padding:.7rem 1.3rem;border-radius:2px;font-size:.9rem;font-weight:500;transition:all .3s var(--ease)}
.map-links a:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
/* 지도 브랜드 컬러 버튼 */
.map-links a.map-naver,.map-links a.map-kakao,.map-links a.map-google{border:0;font-weight:700}
.map-links a.map-naver{background:#03c75a;color:#fff}
.map-links a.map-naver:hover{background:#04b152;color:#fff;transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(3,199,90,.7)}
.map-links a.map-kakao{background:#fee500;color:#3a1d1d}
.map-links a.map-kakao:hover{background:#ffec3d;color:#3a1d1d;transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(254,229,0,.6)}
.map-links a.map-google{color:#fff;background:linear-gradient(90deg,#4285f4,#9b59b6,#ea4335,#fbbc05,#34a853);background-size:200% 100%}
.map-links a.map-google:hover{color:#fff;transform:translateY(-2px);background-position:100% 0;box-shadow:0 12px 28px -12px rgba(66,133,244,.6)}

/* ===== Contact form ===== */
.form-wrap{display:grid;grid-template-columns:1.55fr .85fr;gap:clamp(1.4rem,3vw,2.4rem);align-items:start}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:clamp(1.6rem,3.5vw,2.6rem)}
.field{margin-bottom:1.3rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.field label{display:block;font-size:.9rem;color:var(--text);margin-bottom:.6rem;font-weight:500}
.req{color:var(--gold)}
.form-card input[type=text],.form-card input[type=tel],.form-card input[type=email],.form-card textarea{
  width:100%;background:#0f0f12;border:1px solid var(--line-strong);border-radius:3px;color:var(--text);
  font-family:var(--sans);font-size:.98rem;padding:.85rem 1rem;transition:border-color .25s,box-shadow .25s}
.form-card input::placeholder,.form-card textarea::placeholder{color:#5f5a53}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(198,164,92,.15)}
.form-card textarea{resize:vertical;min-height:120px;line-height:1.7}
.chip-radios{display:flex;flex-wrap:wrap;gap:.6rem}
.chip-radio{position:relative;cursor:pointer}
.chip-radio input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip-radio span{display:inline-block;padding:.6rem 1.1rem;border:1px solid var(--line-strong);border-radius:99px;color:var(--muted);font-size:.92rem;transition:all .25s var(--ease)}
.chip-radio input:checked+span{background:var(--gold);border-color:var(--gold);color:#0b0b0d;font-weight:600}
.chip-radio:hover span{border-color:var(--gold);color:var(--text)}
.chip-radio input:focus-visible+span{box-shadow:0 0 0 3px rgba(198,164,92,.3)}
.agree{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;color:var(--muted);margin:.4rem 0 1.6rem;cursor:pointer;line-height:1.6}
.agree input{margin-top:.25rem;width:17px;height:17px;accent-color:var(--gold);flex:none}
.agree a{color:var(--gold-soft);text-decoration:underline}
.submit-btn{width:100%;justify-content:center;font-size:1.02rem;padding:1.05rem}
.submit-btn:disabled{opacity:.6;cursor:default;transform:none}
.form-note{margin-top:1rem;font-size:.92rem;text-align:center;min-height:1.2em}
.form-note.ok{color:var(--gold-soft)}
.form-note.err{color:#e3a08c}
.form-aside{background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;padding:clamp(1.6rem,3vw,2.2rem)}
.form-aside h3{font-size:1.4rem;margin-bottom:.7rem}
.aside-lead{color:var(--muted);font-size:.95rem;margin-bottom:1.6rem}
.aside-links{display:flex;flex-direction:column;gap:.9rem;padding-bottom:1.6rem;margin-bottom:1.6rem;border-bottom:1px solid var(--line)}
.aside-links .ic-link{display:flex;align-items:center;gap:.6rem;color:var(--text);font-size:.98rem}
.aside-links .ic-link:hover{color:var(--gold)}
.aside-hours p{color:var(--muted);font-size:.9rem;margin-bottom:.9rem;line-height:1.6}
.aside-hours strong{color:var(--gold);font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
@media(max-width:860px){.form-wrap{grid-template-columns:1fr}}
@media(max-width:560px){.field-row{grid-template-columns:1fr;gap:0}}

/* ===== Aquascaping page (aqua-green accent) ===== */
body.scaping{--gold:#43b88c;--gold-soft:#86dcbb}
.aqua-quote{border-left:3px solid var(--gold);background:var(--surface);padding:1.5rem 1.8rem;border-radius:0 4px 4px 0;margin:2.2rem 0}
.aqua-quote p{font-family:var(--serif);font-size:clamp(1.15rem,2.2vw,1.4rem);line-height:1.55;color:var(--text);font-style:italic}
.aqua-quote cite{display:block;margin-top:.9rem;font-size:.85rem;color:var(--muted);font-style:normal}

/* 헤더 메뉴: 항목이 많아 920px 이하에서 햄버거로 전환 */
@media(max-width:920px){
  .nav{position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;flex-direction:column;justify-content:center;align-items:flex-start;gap:1.6rem;background:rgba(13,13,15,.98);backdrop-filter:blur(16px);padding:2rem 2.2rem;transform:translateX(100%);transition:transform .4s var(--ease);border-left:1px solid var(--line)}
  .nav.open{transform:none}
  .nav a{font-size:1.15rem}
  .nav .cta{padding:.6rem 1.3rem}
  .burger{display:flex;z-index:1001}
}

/* ===== Partners (logo wall) ===== */
.partners{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem}
.partner{background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:1.4rem 1.3rem;min-height:104px;border:1px solid var(--line);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.partner img{max-width:100%;max-height:54px;width:auto;object-fit:contain}
.partner:hover{transform:translateY(-4px);box-shadow:0 16px 34px -18px rgba(0,0,0,.6)}
@media(max-width:900px){.partners{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.partners{grid-template-columns:repeat(2,1fr)}}

/* ===== Notice board ===== */
.notice-list{display:flex;flex-direction:column;gap:.8rem}
.notice-empty{color:var(--muted);text-align:center;padding:3rem 0}
.notice-item{border:1px solid var(--line);border-radius:4px;background:var(--surface);overflow:hidden}
.notice-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:none;border:0;cursor:pointer;padding:1.3rem 1.5rem;text-align:left;color:var(--text);font-family:var(--sans);transition:background .25s}
.notice-head:hover{background:#1c1c20}
.notice-title{font-size:1.05rem;font-weight:600}
.notice-date{font-size:.85rem;color:var(--muted);white-space:nowrap}
.notice-item.open .notice-head{color:var(--gold)}
.notice-body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.notice-inner{padding:0 1.5rem 1.4rem;color:var(--muted);line-height:1.8;border-top:1px solid var(--line);padding-top:1.2rem;margin-top:0}

/* ===== Admin ===== */
.admin-tabs{display:flex;gap:.6rem;margin-bottom:2rem;border-bottom:1px solid var(--line)}
.tab-btn{background:none;border:0;border-bottom:2px solid transparent;color:var(--muted);padding:.9rem 1.2rem;cursor:pointer;font-family:var(--sans);font-size:1rem;font-weight:500;margin-bottom:-1px}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.adm-select{width:100%;background:#0f0f12;border:1px solid var(--line-strong);border-radius:3px;color:var(--text);font-family:var(--sans);font-size:.98rem;padding:.85rem 1rem}
.admin-list{display:flex;flex-direction:column;gap:.7rem}
.admin-row{display:flex;gap:1rem;justify-content:space-between;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:1.1rem 1.3rem}
.ar-main strong{display:block;font-size:1.02rem}
.ar-main .ar-date{font-size:.8rem;color:var(--muted)}
.ar-main p{color:var(--muted);font-size:.9rem;margin-top:.4rem}
.ar-actions{display:flex;gap:.5rem;flex:none}
.mini{background:none;border:1px solid var(--line-strong);color:var(--muted);border-radius:3px;padding:.45rem .8rem;cursor:pointer;font-size:.85rem;font-family:var(--sans)}
.mini:hover{border-color:var(--gold);color:var(--gold)}
.mini.danger:hover{border-color:#e3a08c;color:#e3a08c}
.cat-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.cat-chip{display:inline-flex;align-items:center;gap:.4rem;background:#0f0f12;border:1px solid var(--line-strong);border-radius:99px;padding:.4rem .5rem .4rem .95rem;font-size:.88rem;color:var(--text)}
.cat-chip button{background:none;border:0;color:var(--muted);cursor:pointer;font-size:.8rem;width:20px;height:20px;border-radius:50%;line-height:1}
.cat-chip button:hover{background:rgba(227,160,140,.2);color:#e3a08c}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
.admin-cell{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--surface)}
.admin-cell img{width:100%;aspect-ratio:4/3;object-fit:cover}
.ac-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.6rem .7rem;font-size:.8rem;color:var(--muted)}
.ac-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== Footer ===== */
.foot{background:#08080a;border-top:1px solid var(--line);padding:clamp(3.5rem,7vw,5rem) 0 2.5rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line)}
.foot .brand{margin-bottom:1.2rem}
.foot-col h4{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:.92rem;margin-bottom:.6rem}
.foot-col a:hover{color:var(--text)}
.foot-col a.ic-link{display:flex;align-items:center;gap:.6rem}
.ci{width:16px;height:16px;flex:none;color:var(--gold);opacity:.95}
.legal{padding-top:1.8rem;font-size:.82rem;color:var(--muted-d);line-height:1.9}
.legal .biz{display:flex;flex-wrap:wrap;gap:.4rem 1.3rem;margin-bottom:.8rem}
.legal a{color:var(--muted)}
.legal a:hover{color:var(--gold)}
.legal .credit{margin-top:.5rem;font-size:.8rem;letter-spacing:.06em;color:var(--muted)}
.legal .credit::before{content:"";display:inline-block;width:14px;height:1px;background:var(--gold);vertical-align:middle;margin-right:.5rem;opacity:.8}
.legal .credit a{color:var(--gold-soft);font-weight:600;transition:color .3s}
.legal .credit a:hover{color:var(--gold)}
.legal-nav{margin:.2rem 0 .9rem;font-size:.86rem}
.legal-nav a{color:var(--muted)}
.legal-nav a:hover{color:var(--gold)}
.legal-nav strong{font-weight:600}

/* ===== legal document pages ===== */
.legal-doc{max-width:840px;margin:0 auto}
.legal-doc .updated{color:var(--muted);font-size:.9rem;margin-bottom:2.2rem;padding-bottom:1.3rem;border-bottom:1px solid var(--line)}
.legal-doc h2{font-family:var(--serif);font-size:clamp(1.35rem,2.6vw,1.7rem);font-weight:600;color:var(--text);margin:2.6rem 0 .8rem}
.legal-doc p,.legal-doc li{color:var(--muted);font-size:.98rem;line-height:1.85}
.legal-doc p{margin-bottom:.7rem}
.legal-doc ul{list-style:none;padding:0;margin:.4rem 0 .8rem}
.legal-doc ul li{position:relative;padding-left:1.4rem;margin-bottom:.5rem}
.legal-doc ul li::before{content:"–";position:absolute;left:0;color:var(--gold)}
.legal-doc strong{color:var(--text);font-weight:600}
.legal-doc a{color:var(--gold-soft)}
.legal-doc a:hover{color:var(--gold)}
.legal-doc .doc-foot{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid var(--line);font-size:.86rem;color:var(--muted-d)}

/* ===== reveal anim ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ===== Page hero (subpages) ===== */
.phero{padding:11rem 0 4rem;position:relative;text-align:center;overflow:hidden;border-bottom:1px solid var(--line)}
.phero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(80% 120% at 50% -10%,rgba(198,164,92,.14),transparent 60%)}
.phero h1{font-family:var(--serif);font-size:clamp(2.4rem,6vw,4.2rem);font-weight:600}
.phero p{color:var(--muted);margin-top:1rem;max-width:54ch;margin-inline:auto}
.crumb{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}

/* ===== Responsive ===== */
@media(max-width:900px){
  .grid-3,.info-grid{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:2.5rem}
  .split .figure img{aspect-ratio:16/10}
  .masonry{columns:2}
  .foot-top{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav{position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;flex-direction:column;justify-content:center;align-items:flex-start;gap:1.6rem;background:rgba(13,13,15,.98);backdrop-filter:blur(16px);padding:2rem 2.2rem;transform:translateX(100%);transition:transform .4s var(--ease);border-left:1px solid var(--line)}
  .nav.open{transform:none}
  .nav a{font-size:1.15rem}
  .burger{display:flex;z-index:1001}
  .grid-3,.grid-2,.info-grid,.foot-top{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .svc{grid-template-columns:1fr;gap:.6rem}
  .svc .pricecol{text-align:left;margin-top:.4rem}
  .masonry{columns:1}
  .hero-actions{flex-direction:column}.hero-actions .btn,.hero-actions .btn-ghost{justify-content:center}
  .hero h1{font-size:1.8rem;line-height:1.18}
  .hero .sub{font-size:.98rem;margin:1.3rem 0 2rem}
  .hero .overline{font-size:.68rem;letter-spacing:.2em}
  .hero-in{padding-top:7rem;padding-bottom:4rem}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
