
:root{
  --indigo-abyss:#05071a;--indigo-deep:#0a1228;--indigo:#121d42;--indigo-soft:#1a2756;--indigo-line:#2b3a72;
  --gold:#d6a455;--gold-bright:#f0c878;--gold-dim:#a98140;--teal:#4c9da2;
  --cream:#efe7d8;--cream-dim:#bcb6a8;--cream-faint:#8a8678;
  --display:"Cormorant Garamond",Georgia,serif;--ui:"Jost","Helvetica Neue",sans-serif;--maxw:1320px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--ui);background:var(--indigo-abyss);color:var(--cream);font-weight:300;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
section[id]{scroll-margin-top:84px}
.bg-field{position:fixed;inset:0;z-index:-3;background:
  radial-gradient(120% 90% at 80% -10%, rgba(76,157,162,.16), transparent 55%),
  radial-gradient(90% 80% at 10% 0%, rgba(214,164,85,.10), transparent 50%),
  radial-gradient(140% 120% at 50% 110%, rgba(26,39,86,.6), transparent 60%),
  linear-gradient(180deg, var(--indigo-deep) 0%, var(--indigo-abyss) 100%);}
.bg-grain{position:fixed;inset:0;z-index:-2;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}

/* NAV */
header.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,5vw,64px);transition:padding .4s,background .4s,border-color .4s;border-bottom:1px solid transparent}
header.nav.scrolled{padding:14px clamp(20px,5vw,64px);background:rgba(8,13,30,.8);backdrop-filter:blur(16px);border-bottom:1px solid var(--indigo-line)}
.brand{cursor:pointer;display:flex;align-items:baseline;gap:.55rem;user-select:none}
.brand .b-name{font-family:var(--display);font-weight:500;font-size:1.55rem;letter-spacing:.42em;text-transform:uppercase;color:var(--cream)}
.brand .b-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px var(--gold);transform:translateY(-2px)}
nav.menu{display:flex;align-items:center;gap:clamp(20px,3vw,46px)}
.nav-item{position:relative}
.nav-link{font-family:var(--ui);font-weight:400;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cream-dim);
  background:none;border:none;cursor:pointer;padding:6px 0;transition:color .3s;display:inline-flex;align-items:center;gap:.4rem}
.nav-link:hover,.nav-link.active{color:var(--gold-bright)}
.nav-link::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .35s}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.caret{font-size:.55rem;transition:transform .3s}
.nav-item.open .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 18px);right:0;min-width:240px;background:rgba(11,20,48,.96);backdrop-filter:blur(18px);
  border:1px solid var(--indigo-line);border-radius:2px;padding:10px 0;opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all .3s;box-shadow:0 30px 60px -20px rgba(0,0,0,.7)}
.nav-item.open .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown::before{content:"";position:absolute;top:-1px;right:30px;width:40px;height:1px;background:var(--gold)}
.drop-link{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--ui);font-weight:300;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-dim);padding:11px 26px;transition:all .25s}
.drop-link>span:first-child{flex:1}
.drop-link:hover{color:var(--gold-bright);background:rgba(214,164,85,.07)}
.drop-mini{display:flex;gap:6px;opacity:0}
.editing .drop-link .drop-mini{opacity:.85}
.mini-btn{background:none;border:none;color:var(--cream-faint);cursor:pointer;font-size:.7rem;padding:2px 4px;border-radius:3px;line-height:1}
.mini-btn:hover{color:var(--gold-bright);background:rgba(214,164,85,.12)}
.mini-btn.del:hover{color:#e7886f;background:rgba(231,136,111,.12)}
.drop-add{margin-top:6px;border-top:1px solid var(--indigo-line);padding-top:8px;display:none}
.editing .drop-add{display:block}
.drop-add .drop-link{color:var(--gold)}

main{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px)}

/* HERO with painting background */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;isolation:isolate;overflow:hidden}
#hero .hero-bg{position:absolute;inset:0;z-index:-2;background-image:var(--hero-img);background-size:cover;background-position:center 22%;
  transform:scale(1.04);animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.12)}to{transform:scale(1.0)}}
#hero .hero-veil{position:absolute;inset:0;z-index:-1;background:
  linear-gradient(100deg, rgba(7,12,29,.95) 0%, rgba(7,12,29,.84) 30%, rgba(7,12,29,.5) 62%, rgba(9,16,38,.62) 100%),
  linear-gradient(180deg, rgba(7,12,29,.55) 0%, transparent 22%, transparent 70%, rgba(7,12,29,.9) 100%)}
.hero-inner{padding:120px 0 90px}
.eyebrow{font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:30px;opacity:0;animation:fadeUp .8s .2s both}
.hero-titles{font-family:var(--display);font-weight:300;line-height:.98;font-size:clamp(2.6rem,5.6vw,4.8rem);color:var(--cream);margin-bottom:34px;text-shadow:0 4px 40px rgba(0,0,0,.6)}
.hero-titles .ln{display:block;white-space:nowrap;opacity:0;animation:fadeUp .9s both}
.hero-titles .ln:nth-child(1){animation-delay:.35s}
.hero-titles .ln:nth-child(2){animation-delay:.55s}
.hero-titles .ln:nth-child(3){animation-delay:.75s}
.hero-titles .dot{color:var(--gold)}
.hero-intro{font-family:var(--display);font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:300;line-height:1.5;color:var(--cream-dim);max-width:30em;margin-bottom:42px;
  text-shadow:0 2px 24px rgba(0,0,0,.7);opacity:0;animation:fadeUp .9s .95s both}
.hero-intro b{display:block;margin-top:.55em;color:var(--cream);font-weight:500}
.hero-cta{display:inline-flex;align-items:center;gap:14px;cursor:pointer;background:none;border:none;font-family:var(--ui);font-size:.78rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold-bright);opacity:0;animation:fadeUp .9s 1.15s both;transition:gap .3s}
.hero-cta:hover{gap:24px}
.hero-cta .arr{width:46px;height:1px;background:var(--gold);position:relative}
.hero-cta .arr::after{content:"";position:absolute;right:0;top:-3px;width:7px;height:7px;border-top:1px solid var(--gold);border-right:1px solid var(--gold);transform:rotate(45deg)}
.hero-credit{position:absolute;bottom:26px;right:clamp(20px,5vw,64px);font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--cream-dim);
  z-index:1;text-shadow:0 2px 20px rgba(0,0,0,.8);opacity:0;animation:fadeUp 1s 1.4s both}
.hero-credit em{font-style:normal;font-family:var(--ui);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-left:12px}
/* On wider/landscape screens, hold the hero text in a left column so it never covers the centred figure */
@media (min-width:900px){
  #hero .hero-inner{max-width:min(560px,44vw);margin:0;padding:120px clamp(20px,5vw,64px) 90px}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* SECTION HEADERS */
.cat-section,#about,#contact{padding:90px 0 30px}
.cat-section{border-top:1px solid rgba(43,58,114,.4)}
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;border-bottom:1px solid var(--indigo-line);padding-bottom:34px;margin-bottom:50px}
.sec-head .titles h2{font-family:var(--display);font-weight:300;font-size:clamp(2.6rem,5.5vw,4.4rem);line-height:1;color:var(--cream)}
.sec-head .titles .kicker{font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;display:flex;align-items:center;gap:14px}
.sec-head .titles .kicker::before{content:"";width:34px;height:1px;background:var(--gold)}
.sec-head .count{font-family:var(--display);font-size:1.2rem;color:var(--cream-faint);font-style:italic;white-space:nowrap}
.cat-tools{display:none;gap:10px;align-items:center}
.editing .cat-tools{display:flex}

/* GALLERY */
.gallery{column-count:3;column-gap:26px}
@media(max-width:1000px){.gallery{column-count:2}}
@media(max-width:620px){.gallery{column-count:1}}
.work{position:relative;break-inside:avoid;margin-bottom:26px;cursor:pointer;overflow:hidden;background:var(--indigo);border:1px solid transparent;transition:border-color .4s}
.work img{width:100%;display:block;transition:transform .8s cubic-bezier(.2,.7,.2,1),filter .6s;filter:saturate(.97)}
.work:hover img{transform:scale(1.05);filter:saturate(1.08)}
.work:hover{border-color:var(--gold-dim)}
.work .overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;
  background:linear-gradient(to top,rgba(7,12,29,.92) 0%,rgba(7,12,29,.4) 40%,transparent 75%);opacity:0;transition:opacity .45s}
.work:hover .overlay{opacity:1}
.work .w-title{font-family:var(--display);font-size:1.5rem;font-weight:400;color:var(--cream);line-height:1.1;transform:translateY(10px);transition:transform .45s}
.work:hover .w-title{transform:none}
.work .w-sub{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);margin-top:8px;transform:translateY(10px);transition:transform .5s}
.work:hover .w-sub{transform:none}
.work .w-edit{position:absolute;top:12px;right:12px;display:none;gap:8px;z-index:3}
.editing .work .w-edit{display:flex}
.icon-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--indigo-line);background:rgba(8,13,30,.82);color:var(--cream-dim);
  cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;backdrop-filter:blur(8px);transition:all .25s}
.icon-btn:hover{color:var(--gold-bright);border-color:var(--gold)}
.icon-btn.del:hover{color:#e7886f;border-color:#e7886f}
.add-tile{break-inside:avoid;margin-bottom:26px;border:1px dashed var(--indigo-line);background:rgba(26,39,86,.25);min-height:300px;
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:16px;cursor:pointer;color:var(--cream-faint);transition:all .35s}
.editing .add-tile{display:flex}
.add-tile:hover{border-color:var(--gold);color:var(--gold-bright);background:rgba(214,164,85,.06)}
.add-tile .plus{font-family:var(--display);font-size:3rem;line-height:1;font-weight:300}
.add-tile span{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase}
.empty-note{color:var(--cream-faint);font-family:var(--display);font-style:italic;font-size:1.4rem;padding:30px 0 60px}

/* ABOUT */
#about{border-top:1px solid rgba(43,58,114,.4)}
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,90px);align-items:start;padding-bottom:80px}
.about-photo .frame2{position:relative;line-height:0}
.about-photo img{width:100%;display:block;filter:grayscale(.15) contrast(1.02);box-shadow:0 40px 80px -30px rgba(0,0,0,.8)}
.about-photo .frame2::before{content:"";position:absolute;inset:-12px;border:1px solid var(--gold-dim);opacity:.4}
.about-photo .ph-name{margin-top:34px;font-family:var(--display);font-size:2rem;color:var(--cream)}
.about-photo .ph-role{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:6px}
.about-photo .ph-replace{margin-top:18px;display:none}
.editing .about-photo .ph-replace{display:inline-flex}
.about-bio p{font-family:var(--display);font-size:clamp(1.12rem,1.6vw,1.32rem);line-height:1.72;color:var(--cream-dim);margin-bottom:1.4em;font-weight:300}
.about-bio p:first-child::first-letter{font-size:3.4em;float:left;line-height:.82;padding:.06em .14em 0 0;color:var(--gold);font-weight:400}
.about-bio textarea{width:100%;min-height:460px;background:rgba(8,13,30,.6);border:1px solid var(--indigo-line);color:var(--cream);font-family:var(--display);font-size:1.1rem;line-height:1.7;padding:22px;border-radius:2px}
.bio-edit-note{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-faint);margin-bottom:14px;display:none}
.editing .bio-edit-note{display:block}

/* CONTACT */
#contact{border-top:1px solid rgba(43,58,114,.4)}
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,90px);padding-bottom:80px;align-items:start}
.contact-info .ci-block{margin-bottom:38px}
.contact-info .ci-label{font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.contact-info .ci-val{font-family:var(--display);font-size:1.5rem;color:var(--cream)}
.contact-info .ci-val a{color:var(--cream);text-decoration:none;border-bottom:1px solid var(--gold-dim);transition:color .3s,border-color .3s}
.contact-info .ci-val a:hover{color:var(--gold-bright);border-color:var(--gold-bright)}
.contact-info .ci-small{font-size:1.05rem;font-family:var(--ui);font-weight:300;color:var(--cream-dim);letter-spacing:.04em}
.socials{display:flex;gap:18px;margin-top:8px}
.socials a{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-dim);text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:color .3s}
.socials a:hover{color:var(--gold-bright)}
.socials a::before{content:"";width:18px;height:1px;background:var(--gold);transition:width .3s}
.socials a:hover::before{width:30px}
.ci-edit{display:none;width:100%;background:rgba(8,13,30,.6);border:1px solid var(--indigo-line);color:var(--cream);font-family:var(--ui);font-size:1rem;padding:10px 14px;margin-top:6px;border-radius:2px}
.editing .ci-edit{display:block}
.editing .ci-static{opacity:.4}
.form-card{background:linear-gradient(160deg,rgba(26,39,86,.4),rgba(11,20,48,.25));border:1px solid var(--indigo-line);padding:clamp(28px,4vw,48px);border-radius:2px;position:relative}
.form-card::before{content:"";position:absolute;top:-1px;left:30px;width:50px;height:1px;background:var(--gold)}
.form-card h3{font-family:var(--display);font-size:2rem;font-weight:300;margin-bottom:6px;color:var(--cream)}
.form-card .fc-sub{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:34px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{margin-bottom:22px}
.field label{display:block;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--cream-faint);margin-bottom:9px}
.field input,.field select,.field textarea{width:100%;background:rgba(8,13,30,.55);border:1px solid var(--indigo-line);color:var(--cream);font-family:var(--ui);font-weight:300;font-size:1rem;padding:13px 16px;border-radius:2px;transition:border-color .3s,background .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(8,13,30,.8)}
.field textarea{min-height:130px;resize:vertical}
.field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8'><path d='M1 1l5 5 5-5' stroke='%23d6a455' fill='none' stroke-width='1.4'/></svg>");background-repeat:no-repeat;background-position:right 16px center}
.field select option{background:var(--indigo-deep)}
#f-subject:has(option[value=""]:checked){color:var(--cream-faint)}
.submit-btn{width:100%;margin-top:8px;background:var(--gold);color:var(--indigo-abyss);border:none;cursor:pointer;font-family:var(--ui);font-weight:500;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;padding:17px;border-radius:2px;transition:background .3s,transform .2s,box-shadow .3s}
.submit-btn:hover{background:var(--gold-bright);box-shadow:0 16px 40px -14px rgba(240,200,120,.5);transform:translateY(-2px)}
.submit-btn:disabled{opacity:.6;cursor:wait;transform:none}
.form-msg{margin-top:18px;font-size:.85rem;letter-spacing:.04em;color:var(--teal);display:none}
.form-msg.show{display:block}
.form-msg.err{color:#e7886f}
.formspree-cfg{display:none;margin-bottom:26px;padding:16px;border:1px dashed var(--indigo-line);border-radius:2px;background:rgba(8,13,30,.4)}
.editing .formspree-cfg{display:block}
.formspree-cfg label{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.formspree-cfg input{width:100%;background:rgba(8,13,30,.6);border:1px solid var(--indigo-line);color:var(--cream);font-family:var(--ui);font-size:.92rem;padding:10px 14px;border-radius:2px}
.formspree-cfg .hint{font-size:.74rem;color:var(--cream-faint);margin-top:10px;line-height:1.6;letter-spacing:0;text-transform:none}
.formspree-cfg .hint a{color:var(--gold)}

/* FOOTER */
footer{border-top:1px solid var(--indigo-line);margin-top:30px;padding:54px 0 60px}
.foot-wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.foot-brand{font-family:var(--display);font-size:1.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--cream)}
.foot-locs{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:8px}
.foot-copy{font-size:.74rem;letter-spacing:.08em;color:var(--cream-faint);text-align:right;max-width:30em;line-height:1.7}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:500;background:
  radial-gradient(120% 90% at 80% -10%, rgba(76,157,162,.16), transparent 55%),
  radial-gradient(90% 80% at 10% 0%, rgba(214,164,85,.10), transparent 50%),
  radial-gradient(140% 120% at 50% 110%, rgba(26,39,86,.6), transparent 60%),
  linear-gradient(180deg, var(--indigo-deep) 0%, var(--indigo-abyss) 100%);
  display:none;align-items:center;justify-content:center;padding:clamp(20px,5vw,70px);opacity:0;transition:opacity .4s}
.lightbox.open{display:flex;opacity:1}
.lb-inner{display:grid;grid-template-columns:1.4fr .8fr;gap:clamp(30px,5vw,70px);max-width:1400px;width:100%;max-height:90vh;align-items:center}
.lb-img-wrap{position:relative;height:100%;display:flex;align-items:center;justify-content:center;min-height:0}
.lb-img-wrap::before{content:"";position:absolute;inset:-14px;border:1px solid var(--gold-dim);opacity:.4;pointer-events:none}
.lb-img-wrap img{max-width:100%;max-height:84vh;display:block;box-shadow:0 50px 100px -30px rgba(0,0,0,.9)}
.lb-meta{align-self:center}
.lb-meta .lb-kicker{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:12px}
.lb-meta .lb-kicker::before{content:"";width:30px;height:1px;background:var(--gold)}
.lb-meta h3{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,4vw,3.4rem);line-height:1.04;color:var(--cream);margin-bottom:22px}
.lb-spec{display:flex;gap:34px;margin-bottom:28px;flex-wrap:wrap}
.lb-spec .sp .sp-l{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--cream-faint);margin-bottom:5px}
.lb-spec .sp .sp-v{font-size:.92rem;letter-spacing:.1em;color:var(--gold-bright)}
.lb-meta .lb-desc{font-family:var(--display);font-size:1.22rem;line-height:1.7;color:var(--cream-dim);font-weight:300;white-space:pre-wrap}
.lb-meta .lb-desc.empty{font-style:italic;color:var(--cream-faint)}
.lb-close{position:fixed;top:30px;right:34px;width:48px;height:48px;border-radius:50%;border:1px solid var(--indigo-line);background:rgba(11,20,48,.6);color:var(--cream);cursor:pointer;font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:all .3s}
.lb-close:hover{color:var(--gold-bright);border-color:var(--gold);transform:rotate(90deg)}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:1px solid var(--indigo-line);background:rgba(11,20,48,.5);color:var(--cream-dim);cursor:pointer;font-size:1.4rem;display:flex;align-items:center;justify-content:center;transition:all .3s;z-index:2}
.lb-nav:hover{color:var(--gold-bright);border-color:var(--gold)}
.lb-prev{left:24px}.lb-next{right:24px}

/* EDIT UI */
.edit-fab{position:fixed;bottom:30px;right:30px;z-index:300;display:none;align-items:center;gap:12px;background:rgba(11,20,48,.9);border:1px solid var(--indigo-line);backdrop-filter:blur(12px);padding:13px 22px;border-radius:40px;cursor:pointer;color:var(--cream-dim);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;transition:all .3s;box-shadow:0 20px 50px -16px rgba(0,0,0,.7)}
.admin .edit-fab{display:flex}
.edit-fab:hover{color:var(--gold-bright);border-color:var(--gold)}
.edit-fab .dot{width:8px;height:8px;border-radius:50%;background:var(--cream-faint);transition:all .3s}
.editing .edit-fab{border-color:var(--gold);color:var(--gold-bright);background:rgba(214,164,85,.12)}
.editing .edit-fab .dot{background:var(--gold);box-shadow:0 0 12px var(--gold)}
.edit-tools{position:fixed;bottom:30px;left:30px;z-index:300;display:none;gap:10px;flex-wrap:wrap;max-width:62vw}
.admin .edit-tools{display:flex}
.tool-btn{background:rgba(11,20,48,.9);border:1px solid var(--indigo-line);backdrop-filter:blur(12px);color:var(--cream-dim);padding:11px 18px;border-radius:30px;cursor:pointer;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;transition:all .3s}
.tool-btn:hover{color:var(--gold-bright);border-color:var(--gold)}
.tool-btn.primary{background:var(--gold);color:var(--indigo-abyss);border-color:var(--gold);font-weight:500}
.tool-btn.primary:hover{background:var(--gold-bright);color:var(--indigo-abyss)}
.edit-banner{position:fixed;top:0;left:0;right:0;z-index:190;text-align:center;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--indigo-abyss);background:linear-gradient(90deg,var(--gold-dim),var(--gold),var(--gold-dim));padding:5px;display:none}
.editing .edit-banner{display:block}
.editing header.nav{top:24px}

/* MODAL */
.modal{position:fixed;inset:0;z-index:600;background:rgba(5,8,20,.9);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:30px}
.modal.open{display:flex}
.modal-card{background:var(--indigo-deep);border:1px solid var(--indigo-line);border-radius:3px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;padding:38px}
.modal-card h3{font-family:var(--display);font-weight:300;font-size:2rem;margin-bottom:6px;color:var(--cream)}
.modal-card .m-sub{font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:28px}
.m-thumb{width:100%;max-height:240px;object-fit:cover;border:1px solid var(--indigo-line);margin-bottom:18px;display:block}
.modal-actions{display:flex;gap:14px;margin-top:10px}
.btn-ghost{flex:1;background:none;border:1px solid var(--indigo-line);color:var(--cream-dim);padding:13px;border-radius:2px;cursor:pointer;font-family:var(--ui);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;transition:all .3s}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-bright)}
.btn-solid{flex:1;background:var(--gold);border:none;color:var(--indigo-abyss);padding:13px;border-radius:2px;cursor:pointer;font-family:var(--ui);font-weight:500;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;transition:all .3s}
.btn-solid:hover{background:var(--gold-bright)}
.hidden-file{display:none}

@media(max-width:900px){
  .about,.contact{grid-template-columns:1fr}
  .about-photo{max-width:420px}
  .lb-inner{grid-template-columns:1fr;overflow-y:auto;max-height:86vh}
  .lb-img-wrap img{max-height:60vh}
  .frow{grid-template-columns:1fr}
  nav.menu{gap:18px}
  .brand .b-name{font-size:1.2rem;letter-spacing:.3em}
  .nav-link{font-size:.66rem;letter-spacing:.18em}
  .foot-copy{text-align:left}
  #hero .hero-veil{background:linear-gradient(180deg,rgba(7,12,29,.7) 0%,rgba(7,12,29,.55) 40%,rgba(7,12,29,.88) 100%)}
  #hero{align-items:flex-end}
  #hero .hero-inner{padding:0 clamp(20px,7vw,40px) 92px}
}
/* --- justified prose --- */
.about-bio p,.lb-desc{text-align:justify;text-justify:inter-word;hyphens:auto}
.foot-copy{white-space:pre-line}
/* --- inline text editing --- */
[data-edit].inline-editing{outline:1px dashed var(--gold-dim);outline-offset:5px;border-radius:2px;cursor:text;transition:background .2s}
[data-edit].inline-editing:hover{background:rgba(214,164,85,.05)}
[data-edit].inline-editing:focus{outline-color:var(--gold-bright);background:rgba(214,164,85,.08)}
.hero-titles .etext{display:inline-block}
/* --- 18+ age gate --- */
.age-gate{border:1px solid var(--indigo-line);background:linear-gradient(160deg,rgba(26,39,86,.4),rgba(11,20,48,.25));border-radius:2px;
  padding:clamp(40px,6vw,72px);text-align:center;max-width:680px;margin:6px auto 60px;position:relative}
.age-gate::before{content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:60px;height:1px;background:var(--gold)}
.age-gate .ag-icon{font-family:var(--display);font-size:2.1rem;letter-spacing:.04em;color:var(--gold-bright);border:1px solid var(--gold-dim);
  border-radius:50%;width:96px;height:96px;display:flex;align-items:center;justify-content:center;margin:0 auto 26px}
.age-gate .ag-title{font-family:var(--display);font-size:1.9rem;color:var(--cream);margin-bottom:14px}
.age-gate .ag-text{color:var(--cream-dim);max-width:46ch;margin:0 auto 32px;font-size:1.02rem;line-height:1.75}
.age-gate .ag-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.age-gate .ag-actions button{min-width:200px}
/* --- appearance panel --- */
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 22px;margin-bottom:22px}
.tfield label{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-faint);margin-bottom:9px}
.tfield .color-row{display:flex;align-items:center;gap:12px}
.tfield input[type=color]{width:48px;height:40px;border:1px solid var(--indigo-line);background:none;border-radius:4px;cursor:pointer;padding:2px}
.tfield .hexval{font-family:var(--ui);font-size:.82rem;color:var(--cream-dim);letter-spacing:.08em}
.tfield select{width:100%;background:rgba(8,13,30,.55);border:1px solid var(--indigo-line);color:var(--cream);font-family:var(--ui);font-size:.95rem;padding:11px 14px;border-radius:2px;cursor:pointer}
.tfield select option{background:var(--indigo-deep)}

/* admin chrome additions */
.edit-tools a.tool-btn{text-decoration:none;display:inline-flex;align-items:center}
.save-status{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-faint);align-self:center;padding:0 6px}
.save-status.err{color:#e7886f}
