/* ============================================================
   Cosmic Sea Tattoo — Portland, ME
   Art direction: deep cosmic-ocean. Abyss base, sea-teal accent,
   warm coral (from the studio goldfish mural). B&W work photos.
   ============================================================ */

:root{
  --abyss:#060a12;
  --abyss-2:#0a1018;
  --deep:#0c1726;
  --surf:#101d30;
  --surf-2:#16263c;
  --line:#1f3147;
  --line-2:#2c425e;

  --ink:#eef3f8;
  --ink-2:#c4d2e0;
  --muted:#8295ac;

  --teal:#4fd6c9;
  --teal-2:#6fe6da;
  --teal-deep:#1f6e6b;
  --coral:#f0875a;
  --coral-2:#ff9d6e;

  --disp:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, sans-serif;

  --maxw:1200px;
  --r:18px;
  --r-sm:12px;
  --r-lg:26px;

  --h1:clamp(40px, 6.4vw, 78px);
  --h2:clamp(30px, 4vw, 50px);
  --h3:clamp(21px, 2.3vw, 26px);

  --shadow:0 32px 70px -38px rgba(2,8,20,.9);
  --shadow-soft:0 18px 44px -28px rgba(2,8,20,.8);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

body{
  margin:0;
  background:var(--abyss);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- cosmic-sea atmosphere ---------- */
.cosmos{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(115% 80% at 50% -8%, rgba(31,110,107,.32), transparent 55%),
    radial-gradient(80% 60% at 84% 8%, rgba(240,135,90,.10), transparent 60%),
    radial-gradient(120% 100% at 50% 120%, rgba(79,214,201,.10), transparent 60%),
    linear-gradient(180deg, var(--abyss) 0%, var(--abyss-2) 40%, var(--abyss) 100%);
}
.stars{
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.55;
  background-image:
    radial-gradient(1.4px 1.4px at 12% 18%, rgba(255,255,255,.8), transparent),
    radial-gradient(1.2px 1.2px at 28% 62%, rgba(255,255,255,.55), transparent),
    radial-gradient(1.6px 1.6px at 47% 30%, rgba(180,235,230,.7), transparent),
    radial-gradient(1.1px 1.1px at 67% 75%, rgba(255,255,255,.5), transparent),
    radial-gradient(1.5px 1.5px at 82% 22%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.2px 1.2px at 91% 58%, rgba(180,235,230,.55), transparent),
    radial-gradient(1.1px 1.1px at 6% 84%, rgba(255,255,255,.5), transparent);
  animation:drift 60s linear infinite;
}
@keyframes drift{ from{transform:translateY(0)} to{transform:translateY(-40px)} }
@media (prefers-reduced-motion: reduce){ .stars{animation:none} }

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px)}

/* ---------- typography helpers ---------- */
.kicker{
  font-family:var(--sans);
  font-size:13px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--teal); margin:0 0 14px;
}
h1,h2,h3{font-family:var(--disp);font-weight:500;line-height:1.04;letter-spacing:-.01em;margin:0}
h2{font-size:var(--h2);letter-spacing:-.015em}
h3{font-size:var(--h3)}
.section-lead{color:var(--ink-2);max-width:56ch;font-size:clamp(16px,1.6vw,18px);margin:16px 0 0}
.muted{color:var(--muted)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:13px 22px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  will-change:transform;
}
.btn-lg{padding:16px 30px;font-size:16px}
.btn-primary{background:var(--coral);color:#1a0d06;box-shadow:0 14px 30px -14px rgba(240,135,90,.7)}
.btn-primary:hover{background:var(--coral-2);transform:translateY(-2px);box-shadow:0 20px 38px -14px rgba(240,135,90,.8)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-2);transform:translateY(-2px)}
.text-link{color:var(--teal-2);font-weight:600;display:inline-block;margin-top:10px;transition:color .2s var(--ease), transform .2s var(--ease)}
.text-link:hover{color:var(--ink);transform:translateX(3px)}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(12px);
  background:linear-gradient(180deg, rgba(6,10,18,.86), rgba(6,10,18,.5));
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.site-header.scrolled{border-bottom-color:var(--line);background:rgba(6,10,18,.92)}
.header-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand-mark{width:30px;height:30px;color:var(--teal);display:inline-flex}
.brand-mark svg{width:100%;height:100%}
.brand-text{font-family:var(--disp);font-size:20px;font-weight:600;line-height:1;display:flex;flex-direction:column;gap:3px}
.brand-sub{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.nav{display:flex;gap:30px}
.nav a{font-size:14.5px;font-weight:500;color:var(--ink-2);position:relative;transition:color .2s var(--ease)}
.nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--teal);transition:width .25s var(--ease)}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:18px}
.phone{font-weight:600;font-size:14.5px;color:var(--ink-2);transition:color .2s}
.phone:hover{color:var(--teal-2)}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:14px clamp(20px,4vw,40px) 22px;border-top:1px solid var(--line);background:rgba(6,10,18,.97)}
@media (max-width:980px){ .mobile-menu:not([hidden]){display:flex} }
.mobile-menu a{padding:12px 4px;font-size:17px;font-weight:500;color:var(--ink-2);border-bottom:1px solid rgba(255,255,255,.05)}
.mobile-menu a.btn{margin-top:12px;border-bottom:0;color:#1a0d06}

/* ---------- hero ---------- */
.hero{position:relative;min-height:clamp(620px,92vh,900px);display:flex;align-items:center;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-img{width:100%;height:120%;object-fit:cover;object-position:50% 40%;filter:saturate(1.08) contrast(1.04) brightness(.92);position:absolute;inset:0;top:-10%;will-change:transform}
.hero-scrim{
  position:absolute;inset:0;
  background:
    radial-gradient(78% 72% at 50% 50%, rgba(6,10,18,.5), transparent 72%),
    linear-gradient(180deg, rgba(6,10,18,.58) 0%, rgba(6,10,18,.32) 28%, rgba(6,10,18,.42) 64%, var(--abyss) 99%);
}
.hero-content{position:relative;z-index:2;padding-top:54px;padding-bottom:74px;max-width:1180px;margin-inline:auto;display:flex;flex-direction:row;align-items:center;gap:clamp(34px,5vw,76px);text-align:left}
.hero-logo{height:clamp(230px,30vw,420px);width:auto;flex-shrink:0;filter:drop-shadow(0 12px 40px rgba(0,0,0,.6))}
.hero-text{min-width:0}
.hero-title{font-size:clamp(34px,4.4vw,58px);margin:0;font-weight:500}
.hero-title em{font-style:italic;color:var(--teal-2);font-weight:400}
.hero-lead{color:var(--ink-2);font-size:clamp(17px,1.9vw,20px);max-width:52ch;margin:22px 0 0}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;justify-content:flex-start}
.hero-proof{display:flex;align-items:center;justify-content:flex-start;gap:12px;margin-top:28px;font-size:15px;color:var(--ink-2)}
.hero-proof strong{font-size:18px;color:var(--ink)}
.stars-row{color:var(--coral-2);letter-spacing:3px;font-size:16px}
.stars-row.big{font-size:22px}

/* ---------- trust strip ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--abyss-2),var(--deep))}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:26px 0}
.trust-item{display:flex;flex-direction:column;gap:3px;text-align:center;padding:6px 8px}
.trust-item+.trust-item{border-left:1px solid var(--line)}
.trust-item strong{font-family:var(--disp);font-size:clamp(19px,2.2vw,24px);font-weight:600;color:var(--ink)}
.trust-item span{font-size:13px;color:var(--muted);letter-spacing:.02em}

/* ---------- section rhythm ---------- */
section{position:relative}
.about,.work,.artists,.reviews,.visit{padding:clamp(70px,9vw,118px) 0}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,6vw,72px);align-items:center}
.about-copy h2{margin-bottom:18px}
.about-copy p{color:var(--ink-2);margin:0 0 16px;max-width:50ch}
.about-media{position:relative}
.about-media img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow);border:1px solid var(--line)}
.about-badge{
  position:absolute;right:-14px;bottom:-22px;
  background:var(--coral);color:#1a0d06;border-radius:var(--r);
  padding:18px 22px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-soft);
}
.about-badge .badge-num{font-family:var(--disp);font-size:34px;font-weight:600;line-height:1}
.about-badge .badge-label{font-size:12px;font-weight:700;line-height:1.2;text-transform:uppercase;letter-spacing:.04em}

/* ---------- work / gallery ---------- */
.work-head{max-width:680px;margin-bottom:clamp(30px,4vw,48px)}
.gallery{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px clamp(20px,4vw,40px) 8px}
.gallery::-webkit-scrollbar{display:none}
.gallery-track{display:flex;gap:18px;width:max-content}
.g-item{margin:0;flex:0 0 auto;width:min(78vw,440px);scroll-snap-align:center;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-soft);background:var(--surf)}
.g-item img{width:100%;height:330px;object-fit:cover;transition:transform .7s var(--ease), filter .4s var(--ease)}
.g-item:hover img{transform:scale(1.05)}
.gallery-dots{display:flex;gap:8px;justify-content:center;margin-top:24px}
.gallery-dots button{width:8px;height:8px;border-radius:50%;border:0;background:var(--line-2);cursor:pointer;padding:0;transition:.25s var(--ease)}
.gallery-dots button.active{background:var(--teal);width:24px;border-radius:5px}

/* ---------- artists ---------- */
.artists{background:linear-gradient(180deg,transparent,rgba(12,23,38,.55),transparent)}
.artists-head{max-width:680px;margin-bottom:clamp(34px,4vw,52px)}
.artist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px)}
.artist-card{
  background:var(--surf);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.artist-card:hover{transform:translateY(-6px);border-color:var(--teal-deep);box-shadow:var(--shadow)}
.artist-photo{aspect-ratio:4/5;overflow:hidden;background:var(--deep)}
.artist-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 28%;filter:grayscale(100%) contrast(1.03);transition:transform .6s var(--ease), filter .5s var(--ease)}
.artist-card:hover .artist-photo img{transform:scale(1.05);filter:grayscale(60%) contrast(1.05)}
.artist-body{padding:22px 24px 26px}
.artist-body h3{margin-bottom:4px}
.artist-role{color:var(--teal-2);font-size:13.5px;font-weight:600;letter-spacing:.02em;margin:0 0 12px}
.artist-note{color:var(--ink-2);font-size:15px;margin:0 0 18px}
.artist-links{display:flex;flex-wrap:wrap;gap:10px}
.artist-links a{
  font-size:13.5px;font-weight:600;padding:8px 15px;border-radius:999px;
  border:1px solid var(--line-2);color:var(--ink-2);transition:.25s var(--ease);
}
.artist-links a:hover{border-color:var(--teal);color:var(--teal-2);transform:translateY(-2px)}

/* ---------- reviews ---------- */
.reviews-head{max-width:680px;margin-bottom:clamp(30px,4vw,44px)}
.reviews-rating{display:flex;align-items:center;gap:12px;margin-top:18px;font-size:16px;color:var(--ink-2)}
.reviews-rating strong{color:var(--ink)}
.review-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,22px)}
.review-card{
  margin:0;background:linear-gradient(180deg,var(--surf),var(--deep));
  border:1px solid var(--line);border-radius:var(--r);padding:28px 30px;position:relative;
  transition:transform .3s var(--ease), border-color .3s var(--ease)
}
.review-card::before{content:"\201C";position:absolute;top:6px;left:20px;font-family:var(--disp);font-size:80px;line-height:1;color:var(--teal);opacity:.16}
.review-card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.review-card p{margin:0 0 16px;color:var(--ink);font-size:16.5px;line-height:1.62;position:relative}
.review-card cite{font-style:normal;font-weight:600;font-size:14px;color:var(--teal-2);letter-spacing:.02em}

/* ---------- visit / book ---------- */
.visit{background:linear-gradient(180deg,transparent,rgba(12,23,38,.6))}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:stretch}
.visit-info h2{margin:0 0 14px}
.visit-lead{color:var(--ink-2);max-width:48ch;margin:0 0 26px}
.visit-facts{list-style:none;padding:0;margin:0 0 26px;display:grid;gap:18px}
.visit-facts li{display:grid;grid-template-columns:84px 1fr;gap:14px;align-items:start;padding-bottom:18px;border-bottom:1px solid var(--line)}
.vf-label{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);padding-top:3px}
.vf-value{font-size:15.5px;color:var(--ink)}
.vf-value a{color:var(--ink);border-bottom:1px solid var(--teal-deep);transition:color .2s}
.vf-value a:hover{color:var(--teal-2)}
.book-steps{background:rgba(79,214,201,.05);border:1px solid var(--line);border-radius:var(--r);padding:20px 24px;margin-bottom:26px}
.book-steps-title{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin:0 0 10px}
.book-steps ol{margin:0;padding-left:20px;color:var(--ink-2)}
.book-steps li{margin:0 0 6px;font-size:15.5px}
.visit-actions{display:flex;flex-wrap:wrap;gap:14px}
.visit-map{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);min-height:420px}
.visit-map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.3) contrast(1.05) brightness(.92)}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);background:var(--abyss-2);padding:clamp(46px,6vw,68px) 0 28px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px}
.footer-brand{display:flex;gap:18px;align-items:center}
.footer-logo{height:84px;width:auto;flex-shrink:0}
.footer-tag{color:var(--ink-2);font-size:14.5px;margin:0;max-width:32ch}
.footer-col .footer-h{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin:0 0 12px}
.footer-col p{margin:0 0 8px;font-size:14.5px;color:var(--ink-2)}
.footer-col a:hover{color:var(--teal-2)}
.socials{display:flex;flex-wrap:wrap;gap:9px}
.socials a{font-size:13px;font-weight:600;padding:7px 14px;border:1px solid var(--line-2);border-radius:999px;color:var(--ink-2);transition:.25s var(--ease)}
.socials a:hover{border-color:var(--teal);color:var(--teal-2);transform:translateY(-2px)}
.footer-base{display:flex;justify-content:space-between;gap:16px;margin-top:34px;padding-top:22px;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-img{top:0;height:100%}
}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .hero-content{flex-direction:column;text-align:center;gap:18px}
  .hero-logo{height:clamp(160px,42vw,260px)}
  .hero-lead{margin-inline:auto}
  .hero-actions,.hero-proof{justify-content:center}
}
@media (max-width:980px){
  .nav,.header-cta .phone{display:none}
  .menu-toggle{display:flex}
  .header-cta .btn{display:none}
  .about-grid,.visit-grid{grid-template-columns:1fr}
  .about-media{order:-1}
  .about-badge{right:14px;bottom:-18px}
  .artist-grid{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:680px){
  body{font-size:16px}
  .trust-inner{grid-template-columns:1fr 1fr;gap:0}
  .trust-item{padding:14px 8px}
  .trust-item:nth-child(2n){border-left:1px solid var(--line)}
  .trust-item:nth-child(1),.trust-item:nth-child(2){border-bottom:1px solid var(--line)}
  .review-grid{grid-template-columns:1fr}
  .artist-grid{grid-template-columns:1fr;max-width:380px}
  .footer-inner{grid-template-columns:1fr}
  .footer-base{flex-direction:column;gap:6px}
  .hero-content{padding-bottom:54px}
  .g-item{width:82vw}
  .g-item img{height:280px}
}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
