/* =========================================================================
   beaulien.fr — thème partagé galeries + pages d'oeuvres
   Aquarelle marine, côte du Léon. Motion via site.js.
   ========================================================================= */
@import url('fonts/fonts.css');

:root{
  --ink:#15303b; --body:#2f3e45; --muted:#6d6557;
  --paper:#f3ece0; --paper2:#ece2d2; --sheet:#fffdf8;
  --line:#d7ccb8; --sea:#578fa8; --sea-deep:#2f6b86; --indigo:#2b3f52; --ocre:#b5743f;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--body);font-family:"Spectral",Georgia,serif;font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:var(--sea-deep);text-decoration:none}
h1,h2,h3{font-family:"Cormorant Garamond",serif;color:var(--ink);font-weight:600;line-height:1.1;margin:0}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background:radial-gradient(120% 120% at 50% 0,transparent 60%,rgba(43,63,82,.06)),
  repeating-linear-gradient(0deg,transparent 0 3px,rgba(120,100,70,.012) 3px 4px)}

/* ---- transition de page (lavis) injectée par site.js ---- */
#fx{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0;
  background:radial-gradient(130% 100% at 50% 0,#3a6b81,#15303b 70%);}
#fx.in{opacity:1;transition:opacity .5s ease}
#fx.out{opacity:0;transition:opacity .7s ease}
.boot{opacity:0}

/* ---- NAV ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s,box-shadow .4s,padding .4s;padding:20px 0}
.nav.solid{background:rgba(243,236,224,.92);backdrop-filter:blur(8px);box-shadow:0 1px 0 var(--line);padding:11px 0}
.nav .wrap{display:flex;align-items:baseline;justify-content:space-between;gap:18px}
.nav .mark{font-family:"Cormorant Garamond",serif;font-size:24px;font-weight:600;letter-spacing:.04em;color:var(--ink)}
.nav .mark span{color:var(--sea);font-style:italic}
.nav .links a{color:var(--ink);margin-left:24px;font-size:15.5px;letter-spacing:.04em;opacity:.85;position:relative}
.nav .links a:hover{opacity:1}
.nav .links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--sea);transition:width .3s}
.nav .links a:hover::after{width:100%}
@media(max-width:680px){.nav .links a{margin-left:13px;font-size:13px}}

.breadcrumb{max-width:1200px;margin:0 auto;padding:104px 28px 0;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);position:relative;z-index:1}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--ink)}

/* ---- reveal ---- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].seen{opacity:1;transform:none}

/* ========== GALERIE (index d'une galerie) ========== */
.g-head{position:relative;z-index:1;padding:130px 0 10px;text-align:center}
.g-head .eyebrow{font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--ocre);font-weight:500;margin:0 0 14px}
.g-head h1{font-size:clamp(40px,6vw,68px)}
.g-head p{max-width:60ch;margin:14px auto 0;font-size:19px;font-weight:300;color:#3c4c54}
.g-grid{position:relative;z-index:1;max-width:1200px;margin:46px auto 30px;padding:0 28px;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:26px}
.g-card{display:block;background:var(--sheet);border:1px solid var(--line);overflow:hidden}
.g-card .ph{overflow:hidden;background:#e9e0cf;line-height:0;aspect-ratio:4/3}
.g-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .6s}
.g-card:hover .ph img{transform:scale(1.06)}
.g-card .t{padding:14px 16px 18px}
.g-card .t .h{font-family:"Cormorant Garamond",serif;font-size:21px;color:var(--ink);line-height:1.15}
.g-card .t .n{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ocre);font-weight:600}

/* sélecteur de galeries */
.g-switch{position:relative;z-index:1;max-width:1200px;margin:0 auto 80px;padding:24px 28px 0;border-top:1px solid var(--line);text-align:center}
.g-switch a{display:inline-block;margin:6px;padding:8px 16px;border:1px solid var(--line);color:var(--ink);font-size:14px;letter-spacing:.05em;background:var(--sheet);transition:.25s}
.g-switch a:hover,.g-switch a.cur{background:var(--sea-deep);border-color:var(--sea-deep);color:#fff}

/* ========== PAGE OEUVRE (notice de musée) ========== */
.art-wrap{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:18px 28px 0}
.art-stage{display:grid;grid-template-columns:1.25fr .75fr;gap:46px;align-items:center;padding:18px 0 10px}
.art-frame{justify-self:center;width:100%}
.art-frame .mat{background:var(--sheet);padding:24px;border:1px solid var(--line);
  box-shadow:0 2px 0 #fff inset,0 44px 80px -46px rgba(21,48,59,.6),0 10px 26px -18px rgba(21,48,59,.4)}
.art-frame .stage{position:relative;line-height:0;background:#e9e0cf}
.art-frame .stage img{width:100%;height:auto}
.art-frame .stage canvas{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.art-meta .eyebrow{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--ocre);font-weight:500;margin:0 0 16px}
.art-meta h1{font-size:clamp(32px,4.4vw,50px);line-height:1.04;font-style:italic;font-weight:500}
.art-meta .info{margin:22px 0 0;border-top:1px solid var(--line);padding-top:16px;font-size:15px;color:var(--muted);letter-spacing:.02em}
.art-meta .info div{margin:6px 0}
.art-meta .info b{color:var(--ink);font-weight:600;font-style:normal}
@media(max-width:820px){.art-stage{grid-template-columns:1fr;gap:24px}.art-frame{max-width:460px}}

/* prev / next */
.art-nav{position:relative;z-index:1;max-width:1080px;margin:40px auto 0;padding:22px 28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;font-family:"Cormorant Garamond",serif}
.art-nav a{flex:1;color:var(--ink)}
.art-nav a.nx{text-align:right}
.art-nav .lbl{font-family:"Spectral",serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ocre);display:block;margin-bottom:4px}
.art-nav .ti{font-size:22px;font-style:italic;color:var(--ink);transition:color .25s}
.art-nav a:hover .ti{color:var(--sea-deep)}
.art-back{text-align:center;margin:26px 0 0}
.art-back a{font-size:14px;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--sea);padding-bottom:3px;color:var(--ink)}

/* autres oeuvres */
.more-w{position:relative;z-index:1;background:var(--paper2);margin-top:70px;padding:54px 0}
.more-w h2{text-align:center;font-size:30px;margin:0 0 28px}
.more-grid{max-width:1100px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px}
.more-grid a{display:block;background:var(--sheet);border:1px solid var(--line);overflow:hidden}
.more-grid img{width:100%;height:140px;object-fit:cover;transition:transform 1s}
.more-grid a:hover img{transform:scale(1.07)}
.more-grid .c{padding:9px 11px;font-family:"Cormorant Garamond",serif;font-size:16px;color:var(--ink);line-height:1.12}

/* ---- footer ---- */
.foot{background:var(--ink);color:#bcd0d6;position:relative;z-index:1;padding:54px 0 40px;text-align:center;margin-top:0}
.foot .m{font-family:"Cormorant Garamond",serif;font-size:28px;color:#fff;letter-spacing:.03em}
.foot .m span{color:var(--sea);font-style:italic}
.foot .ln{margin:16px 0 8px}
.foot .ln a{color:#dbe8eb;margin:0 11px;font-size:14.5px}
.foot .fine{font-size:12.5px;color:#7f99a1;margin-top:12px}

/* ---- accessibilite + perf ---- */
.skip{position:absolute;left:-9999px;top:0;z-index:10000;background:var(--ink);color:#fff;padding:11px 18px;font-family:"Spectral",serif;font-size:15px;letter-spacing:.04em}
.skip:focus{left:0}
a:focus-visible,button:focus-visible,.marker:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--sea-deep);outline-offset:3px}
:focus:not(:focus-visible){outline:none}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}