/* Matt Wilson / bunnylever — atmospheric art site
   Design tokens carried from the approved "Hub" direction. */
:root{
  --bg:#0a0b0e;
  --bg-2:#0d0f13;
  --teal:#94c2c8;
  --text:#e9e7e1;
  --muted:#aeaba3;
  --dim:#76736b;
  --cream:#ece8e0;
  --hair:rgba(255,255,255,.08);
  --wrap:1320px;
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter','Segoe UI',Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html{overflow-x:hidden}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--sans);font-weight:300;line-height:1.5;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,4vw,54px)}
.kicker{font-size:12px;letter-spacing:.44em;text-transform:uppercase;color:var(--teal)}
.skip{position:absolute;left:-9999px;top:0;background:var(--cream);color:#0b0b0b;padding:10px 16px;z-index:200}
.skip:focus{left:12px;top:12px}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(10,11,14,.72);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--hair)}
.header-inner{height:74px;display:flex;align-items:center;justify-content:space-between}
.brand{font-size:15px;letter-spacing:.4em;font-weight:500;color:#f3f1ea}
.nav{display:flex;gap:clamp(20px,2.4vw,38px)}
.nav a{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#b7b4ac;padding:6px 0;transition:color .2s}
.nav a:hover{color:#fff}
.navtoggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.navtoggle span{width:24px;height:1.5px;background:#e9e7e1;transition:transform .3s,opacity .2s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:68vh;display:flex;align-items:center;overflow:hidden;border-bottom:1px solid var(--hair)}
.hero-bg{position:absolute;inset:0;background:url('../img/hero.jpg') center 46%/cover no-repeat;opacity:.52}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,11,14,.55),rgba(10,11,14,.3) 38%,rgba(10,11,14,.94))}
.hero-inner{position:relative;z-index:2;width:100%;padding-top:8vh;padding-bottom:8vh}
.hero-name{font-family:var(--serif);font-weight:300;font-size:clamp(58px,11vw,128px);line-height:.95;letter-spacing:.01em;color:#f7f5ef;margin-top:18px}
.hero-tag{font-size:clamp(16px,2vw,22px);font-weight:300;color:#d7d4cc;margin-top:20px;max-width:640px;overflow-wrap:break-word}
.scrollcue{display:inline-block;margin-top:40px;font-size:11px;letter-spacing:.38em;text-transform:uppercase;color:#9b988f;transition:color .2s}
.scrollcue:hover{color:var(--text)}

/* ---------- tiles ---------- */
/* same mechanism as the Somnium banner: a row with a clamped (telescoping)
   height, each tile flexing to an equal share of the width and cropping via
   object-fit:cover, so the row fills edge-to-edge with no gaps at any width. */
.tiles{display:flex;height:clamp(420px,40vw,600px)}
.tile{position:relative;flex:1 1 0;min-width:0;overflow:hidden;border-right:1px solid var(--hair);display:block}
.tile:last-child{border-right:0}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.82;transition:transform .9s cubic-bezier(.2,.7,.2,1),opacity .4s}
.tile-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,12,.12),rgba(8,9,12,.08) 45%,rgba(8,9,12,.86))}
.tile-label{position:absolute;left:clamp(22px,2.4vw,34px);right:clamp(22px,2.4vw,34px);bottom:clamp(26px,3vw,36px);display:block}
.tile-no{display:block;font-size:11px;letter-spacing:.34em;color:var(--teal)}
.tile-title{display:block;font-family:var(--serif);font-size:clamp(30px,3.2vw,40px);font-weight:500;color:#f6f4ee;margin-top:6px}
.tile-sub{display:block;font-size:13px;color:#c6c3bb;margin-top:7px}
.tile-arrow{position:absolute;right:clamp(22px,2.4vw,30px);bottom:clamp(28px,3vw,38px);font-family:var(--serif);font-size:22px;color:#eceae4;transform:translateX(0);transition:transform .4s}
.tile:hover img{transform:scale(1.05);opacity:.95}
.tile:hover .tile-arrow{transform:translateX(8px)}

/* ---------- somnium banner ---------- */
.somnium{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.somnium-link{position:relative;display:block;overflow:hidden}
/* flex windows: each image fills an equal share and crops (object-fit:cover),
   so the row always fills the width edge-to-edge with no gaps, and every window
   telescopes as the viewport widens (height scales with vw, bounded by clamp). */
.somnium-strip{display:flex;height:clamp(300px,34vw,520px)}
.somnium-strip img{flex:1 1 0;min-width:0;width:100%;height:100%;object-fit:cover;display:block;
  opacity:.9;transition:transform 1s cubic-bezier(.2,.7,.2,1),opacity .4s}
.somnium-scrim{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,9,12,.5),rgba(8,9,12,.16) 46%,rgba(8,9,12,.82))}
.somnium-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 24px;pointer-events:none}
.somnium-title{font-family:var(--serif);font-weight:300;font-size:clamp(50px,8vw,104px);line-height:1;
  color:#f7f5ef;margin-top:10px;letter-spacing:.02em;text-shadow:0 2px 36px rgba(0,0,0,.45)}
.somnium-sub{font-size:clamp(11px,1.4vw,14px);letter-spacing:.2em;text-transform:uppercase;color:#dcd9d1;margin-top:18px}
.somnium-link:hover .somnium-strip img{transform:scale(1.05);opacity:1}
.somnium-link:hover .somnium-sub{color:#fff}

/* ---------- social ---------- */
.social{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:var(--bg-2)}
.social-inner{display:grid;grid-template-columns:380px 1fr;gap:clamp(36px,5vw,64px);align-items:center;padding-top:clamp(56px,7vw,88px);padding-bottom:clamp(56px,7vw,88px)}
.social-h{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5vw,58px);line-height:1;margin-top:14px;color:#f5f3ed}
.social-copy{font-size:16px;color:#cbc8c0;margin-top:18px;max-width:340px}
.btn{display:inline-block;margin-top:24px;background:var(--cream);color:#0b0b0b;padding:14px 30px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;font-weight:500;transition:background .2s,transform .2s}
.btn:hover{background:#fff;transform:translateY(-1px)}
.feed{list-style:none;display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(8px,1vw,14px)}
.feed img{aspect-ratio:1;object-fit:cover;width:100%;border:1px solid var(--hair);transition:opacity .3s,transform .4s}
.feed a:hover img{opacity:1;transform:scale(1.03)}
.feed img{opacity:.88}

/* ---------- footer ---------- */
.site-footer{padding-top:clamp(44px,5vw,60px)}
.footer-inner{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;padding-bottom:36px}
.foot-name{font-family:var(--serif);font-size:30px;color:#f2efe9}
.foot-tag{font-size:13px;color:var(--dim);margin-top:8px}
.foot-col h3{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--dim);margin-bottom:14px}
.foot-col a{display:block;font-size:13.5px;color:#cbc8c0;line-height:2;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-base{display:flex;justify-content:space-between;padding-top:22px;padding-bottom:30px;border-top:1px solid var(--hair);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim)}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .navtoggle{display:flex}
  .nav{position:fixed;inset:74px 0 auto 0;flex-direction:column;gap:0;background:rgba(10,11,14,.97);
    backdrop-filter:blur(12px);border-bottom:1px solid var(--hair);
    max-height:0;overflow:hidden;transition:max-height .35s ease}
  .nav.open{max-height:60vh}
  .nav a{padding:18px clamp(20px,4vw,54px);border-bottom:1px solid var(--hair);font-size:13px}
  .tiles{flex-direction:column;height:auto}
  .tile{flex:0 0 auto;border-right:0;border-bottom:1px solid var(--hair);height:clamp(280px,56vw,420px)}
  .social-inner{grid-template-columns:1fr;gap:34px}
  .somnium-strip img:nth-child(n+5){display:none}        /* show 4 across */
}
@media (max-width:600px){
  .feed{grid-template-columns:repeat(3,1fr)}
  .hero{min-height:84vh}
  .footer-inner{gap:28px}
  .kicker{letter-spacing:.26em;font-size:11px}
  .hero-name{font-size:clamp(46px,14vw,72px)}
  .hero-tag{font-size:15px}
  .somnium-strip{height:clamp(320px,64vw,440px)}
  .somnium-strip img:nth-child(n+3){display:none}        /* show 2 across */
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none!important}
}

/* ---------- reel modal (Vimeo) ---------- */
.reel-modal{position:fixed;inset:0;z-index:400;background:rgba(6,7,9,.93);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.reel-modal.open{opacity:1;visibility:visible}
.reel-dialog{position:relative;width:min(1100px,92vw)}
.reel-frame{position:relative;width:100%;padding-top:56.25%;background:#000;
  box-shadow:0 30px 90px rgba(0,0,0,.6);border:1px solid var(--hair)}
.reel-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.reel-close{position:absolute;top:-44px;right:-2px;background:none;border:0;color:#cfccc4;
  font-size:30px;line-height:1;cursor:pointer;padding:6px;transition:color .2s,transform .2s}
.reel-close:hover{color:#fff;transform:scale(1.08)}
@media (max-width:600px){.reel-close{top:-40px}}
