/* Page-specific extracted styles */
/* embed studio body font */
  @font-face{
    font-family: 'Blacker Sans Text';
    font-weight: 300;
    font-style: normal;
    src: url(../../../media/extracted/686a3bf5deb0.ttf) format('truetype');
    font-display: swap;
  }

  /* ============================================================
     1. design tokens
     ============================================================ */
  :root{
    --parchment:#F2EDE4;
    --ivory:#EDE6D8;
    --studio-blue:#374E72;
    --ghost-blue:#5A6E8A;
    --ink:#1A1A1A;
    --grey:#4D4D4D;
    --rule:#CCCCCC;
    --umber:#8B4A2E;
    --frame: rgba(26,26,26,0.85);
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{cursor:none}
  body{
    background:var(--parchment);
    color:var(--ink);
    font-family:'Blacker Sans Text','Inter',Helvetica,Arial,sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:1.75;
    letter-spacing:0.005em;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  ::selection{ background:var(--umber); color:var(--parchment); }
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}

  /* ============================================================
     2. typographic primitives
     ============================================================ */
  .serif{ font-family:'Cormorant Garamond', Georgia, serif; font-weight:300; letter-spacing:-0.005em; }
  .serif-i{ font-family:'Cormorant Garamond', Georgia, serif; font-style:italic; font-weight:400; }
  .caps{
    font-family:'Inter',sans-serif; font-weight:300;
    font-size:13px; letter-spacing:0.28em; text-transform:uppercase;
    color:var(--grey);
  }
  .caps.tight{ font-size:12px; letter-spacing:0.22em; }
  .body{ font-weight:300; font-size:17px; line-height:1.75; color:var(--ink); max-width:44ch; }
  .lede{ font-family:'Cormorant Garamond',Georgia,serif; font-weight:300; font-size:20px; line-height:1.55; max-width:48ch; }
  .caption{ font-family:'Inter',sans-serif; font-weight:300; font-size:14px; letter-spacing:0.02em; color:var(--grey); line-height:1.6; }
  .pill{
    display:inline-block;
    padding:6px 14px 5px;
    border:1px solid rgba(26,26,26,0.55);
    border-radius:999px;
    font-family:'Inter',sans-serif; font-weight:300;
    font-size:12px; letter-spacing:0.22em; text-transform:uppercase;
    color:var(--ink); white-space:nowrap;
  }
  .pill.soft{ border-color:rgba(26,26,26,0.3); color:var(--grey); }
  .rule-thin{ height:1px; background:rgba(26,26,26,0.4); }

  /* ============================================================
     3. frame chrome
     ============================================================ */
  main{ position:relative; }

  section.sheet{
    position:relative;
    padding: 42px 48px;
    min-height:100vh;
  }
  @media (max-width: 900px){
    section.sheet{ padding: 20px 16px; }
  }

  .frame{
    position:relative;
    border:1px solid var(--frame);
    padding: 54px 64px 92px;
    min-height: calc(100vh - 84px);
    background: transparent;
  }
  .frame.tall{ min-height: 118vh; }
  .frame.short{ min-height: 82vh; }
  @media (max-width: 900px){
    .frame{ padding: 28px 22px 80px; min-height: calc(100vh - 40px); }
  }

  .frame-corner{
    position:absolute; width:10px; height:10px;
    border:1px solid var(--frame);
    background:var(--parchment);
  }
  .frame-corner.tl{ top:-5px; left:-5px; }
  .frame-corner.tr{ top:-5px; right:-5px; }
  .frame-corner.bl{ bottom:-5px; left:-5px; }
  .frame-corner.br{ bottom:-5px; right:-5px; }

  .rail-v{
    position:absolute;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    font-family:'Inter',sans-serif; font-weight:300;
    font-size:12px; letter-spacing:0.26em; text-transform:uppercase;
    color:var(--grey);
    white-space:nowrap;
  }
  .rail-v.left{ left: 18px; top: 80px; }
  .rail-v.right{ right: 18px; bottom: 80px; }
  @media (max-width: 900px){ .rail-v{ display:none; } }

  .frame-head{
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom: 42px; gap:20px;
  }
  .frame-head .left, .frame-head .right{ display:flex; gap:14px; align-items:center; }
  .frame-head .bar{ width:32px; height:1px; background:var(--frame); opacity:0.5; }

  .frame-foot{
    position:absolute; left:64px; right:64px; bottom:28px;
    display:flex; justify-content:space-between; align-items:center;
    font-family:'Inter',sans-serif; font-weight:300;
    font-size:12px; letter-spacing:0.24em; text-transform:uppercase;
    color:var(--grey);
  }
  .frame-foot .sig{
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    font-size:16px; text-transform:none; letter-spacing:0.02em; color:var(--ink);
  }
  .frame-foot .sig::after{ content:'\2009.'; color:var(--umber); }
  @media (max-width: 900px){ .frame-foot{ left:22px; right:22px; bottom:14px; font-size:11px; } }

  /* ============================================================
     4. image system (.arc)
     ============================================================ */
  .arc{
    position:relative;
    overflow:hidden;
    color:var(--parchment);
  }
  .arc.has-img{ background: var(--ink); }
  .arc.has-img > img.src{
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; display:block;
    z-index:0;
    filter: saturate(0.78) contrast(0.96) sepia(0.08) brightness(0.98);
  }
  .arc.has-img::before{
    content:''; position:absolute; inset:0; z-index:1;
    background:
      radial-gradient(ellipse at 50% 52%, transparent 40%, rgba(26,26,26,0.28) 100%),
      linear-gradient(180deg, rgba(242,237,228,0.10) 0%, transparent 25%, transparent 75%, rgba(139,74,46,0.14) 100%);
  }
  .arc.has-img::after{
    content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
    background-image:
      repeating-linear-gradient(90deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 3px),
      repeating-linear-gradient(0deg, rgba(26,26,26,0.03) 0 1px, transparent 1px 3px);
    opacity:0.7;
  }
  .arc .lab{
    position:absolute; top:12px; left:12px; z-index:2;
    font-family:'Inter',sans-serif;
    font-size:12px; letter-spacing:0.22em; text-transform:uppercase;
    color:rgba(242,237,228,0.88);
    text-shadow: 0 1px 14px rgba(0,0,0,0.5);
  }
  .arc .tag{
    position:absolute; bottom:12px; left:12px; right:12px; z-index:2;
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    font-size:17px; color:rgba(242,237,228,0.92);
    text-shadow: 0 1px 14px rgba(0,0,0,0.5);
  }
  .arc .hair{
    position:absolute; top:12px; right:12px; z-index:2;
    width:34px; height:1px; background:rgba(242,237,228,0.6);
  }

  /* technical drawing variant, preserve line work, parchment letterbox */
  .arc.has-img.diagram-plate{ background: var(--parchment); }
  .arc.has-img.diagram-plate > img.src{
    object-fit: contain;
    filter: saturate(0.88) contrast(0.97) sepia(0.04) brightness(1.0);
  }
  .arc.has-img.diagram-plate::before{ background: none; }
  .arc.has-img.diagram-plate::after{ opacity: 0.30; }

  /* ============================================================
     5. reveals
     ============================================================ */
  .rv{
    opacity:0; transform:translateY(12px);
    transition: opacity 1300ms cubic-bezier(.22,.61,.36,1),
                transform 1300ms cubic-bezier(.22,.61,.36,1);
  }
  .rv.in{ opacity:1; transform:none; }
  .rv.d1{ transition-delay:180ms; }
  .rv.d2{ transition-delay:460ms; }
  .rv.d3{ transition-delay:820ms; }
  .rv.d4{ transition-delay:1240ms; }
  .rv.d5{ transition-delay:1700ms; }

  /* ============================================================
     6. progress rail
     ============================================================ */
  .prog{
    position:fixed; top:0; right:16px; height:100vh; width:1px;
    background:rgba(26,26,26,0.12); z-index:40; pointer-events:none;
  }
  .prog .fill{
    position:absolute; top:0; left:-0.5px; width:2px; height:0;
    background:var(--umber);
    transition: height 60ms linear;
  }

  /* ============================================================
     7. custom cursor
     ============================================================ */
  .cur-dot, .cur-ring{
    position:fixed; top:0; left:0; z-index:100;
    pointer-events:none; transform:translate(-50%,-50%);
  }
  .cur-dot{
    width:7px; height:7px; border-radius:50%; background:var(--studio-blue);
    transition: transform 220ms, opacity 300ms;
  }
  .cur-ring{
    width:22px; height:22px; border:1px solid rgba(55,78,114,0.35); border-radius:50%;
    transition: transform 420ms cubic-bezier(.22,.61,.36,1), opacity 400ms;
  }
  body.cur-link .cur-dot{
    background:transparent; width:auto; height:auto;
    color:var(--studio-blue);
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    font-size:22px; line-height:1;
  }
  body.cur-link .cur-dot::before{ content:'&'; }
  body.cur-cross .cur-dot{ background:transparent; width:16px; height:16px; }
  body.cur-cross .cur-dot::before{
    content:''; position:absolute; left:50%; top:0; bottom:0;
    width:1px; background:var(--umber);
  }
  body.cur-cross .cur-dot::after{
    content:''; position:absolute; top:50%; left:0; right:0;
    height:1px; background:var(--umber);
  }
  body.cur-cross .cur-ring{ opacity:0; }
  @media (max-width: 900px){ html{cursor:auto;} .cur-dot,.cur-ring{display:none;} }

  /* ============================================================
     8. opening (s01)
     ============================================================ */
  .s01 .stage{
    display:grid;
    grid-template-columns: 1fr 1.15fr;
    gap: 70px;
    margin-top: 30px;
    align-items:end;
    min-height: 64vh;
  }
  .s01 .title-block{ padding-bottom: 14px; }
  .s01 .title{
    font-family:'Cormorant Garamond',Georgia,serif; font-weight:300;
    font-size: clamp(56px, 8.4vw, 132px); line-height:0.96;
    letter-spacing:-0.018em; margin: 18px 0 0;
  }
  .s01 .title .it{ font-style:italic; color:var(--umber); }
  .s01 .eyebrow{ display:block; }
  .s01 .hero-plate{
    width:100%; padding:6px;
    background:var(--parchment);
    box-shadow:0 0 0 1px rgba(26,26,26,0.3);
  }
  .s01 .hero-plate .arc{
    width:100%; aspect-ratio: 4 / 3;
  }
  .s01 .opening-foot{
    display:flex; justify-content:space-between; align-items:end;
    margin-top: 50px; padding-top: 30px;
    border-top: 1px solid rgba(26,26,26,0.18);
  }
  @media (max-width: 900px){
    .s01 .stage{ grid-template-columns: 1fr; gap: 30px; }
    .s01 .hero-plate .arc{ height: 50vh; min-height: 320px; }
    .s01 .opening-foot{ flex-direction:column; gap:16px; align-items:flex-start; }
  }

  /* ============================================================
     9. lede (s02)
     ============================================================ */
  .composition{
    display:grid; grid-template-columns: 1fr 0.92fr; gap: 70px;
    min-height: 78vh; align-items:end;
  }
  .lede-line{
    font-family:'Cormorant Garamond',Georgia,serif; font-weight:300;
    font-size: clamp(36px, 4.4vw, 64px); line-height:1.12;
    max-width: 18ch;
  }
  .lede-line .it{ font-style:italic; color:var(--umber); }
  @media (max-width: 900px){
    .composition{ grid-template-columns: 1fr; gap: 30px; }
  }

  /* ============================================================
     10. moment (s03)
     ============================================================ */
  .moment-grid{
    display:grid;
    grid-template-columns: 0.85fr 1.4fr 0.55fr;
    gap: 64px;
    min-height: 70vh;
    align-items: start;
    padding-top: 4vh;
  }
  .moment-prose{
    max-width: 56ch;
  }
  .moment-prose .body{
    max-width: none;
  }
  .stack-num{
    font-family:'Cormorant Garamond',Georgia,serif; font-weight:300;
    font-size: clamp(110px, 13vw, 200px);
    line-height:0.85;
    letter-spacing:-0.03em;
    color:var(--ink);
  }
  .stack-num .yr{
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    color:var(--umber);
    font-size:0.18em; line-height:1;
    display:block; margin-top:18px;
    letter-spacing:0;
  }
  .moment-side{
    position: sticky;
    top: 100px;
  }
  .moment-side .programme-list{
    list-style:none; padding:0; margin:0;
    border-top:1px solid rgba(26,26,26,0.4);
  }
  .moment-side .programme-list li{
    display:grid; grid-template-columns: 50px 1fr;
    gap: 12px;
    padding: 9px 0;
    border-bottom: 1px solid rgba(26,26,26,0.18);
    font-family:'Inter',sans-serif; font-weight:300;
    font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--ink);
  }
  .moment-side .programme-list .yr{
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    color:var(--umber);
    font-size: 13px; letter-spacing: 0;
  }
  @media (max-width: 1100px){
    .moment-grid{ grid-template-columns: 1fr 1fr; }
    .moment-side{ grid-column: 1 / -1; position: static; }
  }
  @media (max-width: 900px){
    .moment-grid{ grid-template-columns: 1fr; gap: 36px; padding-top: 2vh; }
    .stack-num{ font-size: clamp(90px, 22vw, 140px); }
  }

  /* ============================================================
     11. diagnosis (s05)
     ============================================================ */
  .s05 .duet{
    text-align:center; padding: 6vh 0;
  }
  .s05 .duet .line{
    font-family:'Cormorant Garamond',Georgia,serif;
    font-size: clamp(48px, 6.4vw, 110px);
    line-height:1.03; letter-spacing:-0.005em;
  }
  .s05 .duet .line .it{ font-style:italic; font-weight:400; color:var(--umber); }
  .s05 .duet .line.upper{ font-weight:400; text-transform:uppercase; }
  .s05 .duet .amp{
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    font-size: clamp(60px, 8vw, 140px); color: var(--umber); line-height:1;
    display:block; margin: 14px 0;
  }
  .s05 .below{
    max-width: 62ch; margin: 40px auto 0;
  }

  /* ============================================================
     12. strategic role
     ============================================================ */
  .role-grid{
    display:grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px;
    min-height: 60vh; align-items: start;
    padding-top: 4vh;
  }
  @media (max-width: 900px){
    .role-grid{ grid-template-columns: 1fr; gap: 30px; }
  }

  /* ============================================================
     13. proposition
     ============================================================ */
  .proposition-grid{
    display:grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px;
    min-height: 80vh; align-items:start;
  }
  @media (max-width: 900px){
    .proposition-grid{ grid-template-columns: 1fr; gap: 30px; }
  }

  /* ============================================================
     14. numbers (s04 inherited)
     ============================================================ */
  .num-row{
    display:grid; grid-template-columns: 1fr; gap: 0;
    padding-top: 16px;
  }
  .num-row .item{
    display:grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px;
    align-items:center;
    padding: 34px 0; border-top:1px solid rgba(26,26,26,0.4);
  }
  .num-row .item:last-child{ border-bottom:1px solid rgba(26,26,26,0.4); }
  .num-huge{
    font-family:'Cormorant Garamond',Georgia,serif; font-weight:300;
    font-size: clamp(84px, 11vw, 160px); line-height:0.9; letter-spacing:-0.02em;
    color:var(--ink);
  }
  .num-huge .suf{ font-size:0.48em; letter-spacing:0; font-style:italic; color:var(--umber); }
  .num-body{ max-width:44ch; }
  .num-idx{
    font-family:'Cormorant Garamond',Georgia,serif; font-style:italic;
    font-size: 20px; color:var(--umber);
  }
  @media (max-width: 900px){
    .num-row .item{ grid-template-columns:1fr; gap:16px; }
  }

  /* ============================================================
     15. palace, ritual centre
     ============================================================ */
  .palace-head{
    display:grid; grid-template-columns: 1.1fr 0.9fr; gap: 56px;
    align-items:end; margin-bottom: 60px;
  }
  .palace-stack{
    display: grid;
    grid-template-columns: 1fr;
    gap: 80px;
    max-width: 1100px;
    margin: 0 auto;
  }
  .palace-stack .piece{
    position: relative;
  }
  /* offset alternate plates left/right to prevent monotony */
  .palace-stack .piece:nth-child(1){ margin-right: 8%; }
  .palace-stack .piece:nth-child(2){ margin-left:  8%; max-width: 92%; }
  .palace-stack .piece:nth-child(3){ margin-right: 4%; max-width: 96%; }
  @media (max-width: 1000px){
    .palace-head{ grid-template-columns: 1fr; gap: 24px; }
    .palace-stack{ gap: 50px; }
    .palace-stack .piece:nth-child(1),
    .palace-stack .piece:nth-child(2),
    .palace-stack .piece:nth-child(3){ margin-left: 0; margin-right: 0; max-width: 100%; }
  }

  /* ============================================================
     16. the villa
     ============================================================ */
  .villa-grid{
    display:grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px;
    min-height: 78vh; align-items: start;
  }
  @media (max-width: 900px){
    .villa-grid{ grid-template-columns: 1fr; gap: 30px; }
  }

  /* ============================================================
     17. sequence
     ============================================================ */
  .seq-head{
    display:grid; grid-template-columns: 1.1fr 0.9fr; gap: 56px;
    align-items:end; margin-bottom: 36px;
  }
  .seq-grid{
    display:grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  }
  @media (max-width: 1000px){
    .seq-head{ grid-template-columns: 1fr; gap: 24px; }
    .seq-grid{ grid-template-columns: 1fr; gap: 30px; }
  }

  /* ============================================================
     18. map
     ============================================================ */
  .map-grid{
    display:grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px;
    align-items: start; min-height: 70vh;
  }
  .map-frame{
    background: rgba(139,74,46,0.04);
    padding: 24px;
    border: 1px solid rgba(26,26,26,0.18);
    position: relative;
  }
  .map-frame::before{
    /* fine grain on the map plate */
    content:''; position:absolute; inset:0; pointer-events:none;
    background-image:
      repeating-linear-gradient(90deg, rgba(26,26,26,0.04) 0 1px, transparent 1px 3px),
      repeating-linear-gradient(0deg,  rgba(26,26,26,0.03) 0 1px, transparent 1px 3px);
    opacity:0.55;
  }
  .malta-map{ width:100%; height:auto; display:block; position:relative; z-index:1; }
  .malta-map #malta-outline{
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset 3200ms cubic-bezier(.22,.61,.36,1);
  }
  .map-plate.in .malta-map #malta-outline{ stroke-dashoffset: 0; }
  @media (max-width: 900px){
    .map-grid{ grid-template-columns: 1fr; gap: 30px; }
  }

  /* ============================================================
     19. closing (s-final / black ground, pure typography)
     ============================================================ */
  .s-final{
    background: #0E0E0E; color: var(--parchment);
    min-height: 100vh; position:relative; overflow:hidden;
    padding: 42px 48px;
  }
  .s-final .frame{ border-color: rgba(242,237,228,0.22); }
  .s-final .frame-corner{
    border-color: rgba(242,237,228,0.22);
    background: #0E0E0E;
  }
  .s-final .rail-v{ color: rgba(242,237,228,0.55); }
  .s-final .frame-head .left .caps,
  .s-final .frame-head .right .caps{ color: rgba(242,237,228,0.78); }
  .s-final .frame-head .bar{ background: rgba(242,237,228,0.4); }
  .s-final .pill.soft{
    border-color: rgba(242,237,228,0.32);
    color: rgba(242,237,228,0.72);
  }

  .s-final .body-wrap{
    position:relative; z-index:1;
    display:flex; flex-direction:column; justify-content:flex-end;
    min-height: calc(100vh - 200px);
    padding-bottom: clamp(132px, 15vh, 180px);
  }
  .s-final .closing-line{
    font-family:'Cormorant Garamond',Georgia,serif; font-weight:300;
    font-size: clamp(48px, 6.4vw, 108px); line-height:1.04;
    letter-spacing: -0.012em;
    color: var(--parchment); max-width: 22ch;
    margin-bottom: 44px;
  }
  .s-final .closing-line .it{
    font-style:italic; font-weight:400;
    color: #C9A878;
  }
  .s-final .closing-rule{
    width: 56px; height: 1px;
    background: var(--umber);
    margin: 0 0 22px;
  }
  .s-final .closing-label{
    color: rgba(242,237,228,0.62);
    font-family:'Inter',sans-serif; font-weight:300;
    font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase;
    line-height: 1.7;
    max-width: 60ch;
  }
  .s-final .back-link{
    margin-top: 28px; display:inline-block;
    font-family:'Inter',sans-serif; font-weight:300;
    font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase;
    color: rgba(242,237,228,0.85);
    transition: color 240ms, letter-spacing 240ms;
  }
  .s-final .back-link:hover{
    color: var(--parchment);
    letter-spacing: 0.30em;
  }

  .s-final .frame-foot{
    left:64px;
    right:64px;
    bottom:42px;
    display:grid;
    grid-template-columns:minmax(0, 1fr) auto;
    gap:clamp(28px, 4vw, 72px);
    align-items:end;
    padding-top:18px;
    border-top:1px solid rgba(242,237,228,0.22);
    color: rgba(242,237,228,0.55);
    font-size: 11px;
  }
  .s-final .frame-foot > span{
    min-width:0;
    line-height:1.55;
    overflow-wrap:anywhere;
  }
  .s-final .frame-foot .footer-logo-link{
    justify-self:end;
    align-self:end;
  }
  .s-final .frame-foot .footer-logo-img{
    width:clamp(250px, 22vw, 340px);
    max-height:105px;
    filter:invert(1);
    opacity:1;
  }
  .s-final .frame-foot .sig{ color: var(--parchment); }
  .s-final .frame-foot .sig::after{ color: var(--umber); }

  @media (max-width: 900px){
    .s-final .frame-foot{
      left:22px;
      right:22px;
      bottom:14px;
      grid-template-columns:1fr;
      gap:14px;
      align-items:start;
    }
    .s-final .frame-foot .footer-logo-link{ justify-self:start; }
    .s-final .frame-foot .footer-logo-img{
      width:min(260px, 78vw);
      max-height:82px;
    }
  }

  /* ============================================================
     19b. lightbox (zoomable image overlay)
     ============================================================ */
  .zoomable{ cursor: none; }
  .zoomable .src{
    transition: transform 1800ms cubic-bezier(.22,.61,.36,1),
                filter   600ms ease;
  }
  .zoomable:hover .src{
    transform: scale(1.025);
  }

  .lightbox{
    position: fixed; inset: 0;
    background: rgba(14,14,14,0.96);
    z-index: 200;
    display: none;
    align-items: center; justify-content: center;
    opacity: 0;
    transition: opacity 360ms cubic-bezier(.22,.61,.36,1);
    cursor: none;
    padding: 4vh 4vw;
  }
  .lightbox.is-open{ display: flex; opacity: 1; }

  .lightbox::before{
    /* fine grain texture, consistent with .arc */
    content:''; position:absolute; inset:0; pointer-events:none;
    background-image:
      repeating-linear-gradient(90deg, rgba(242,237,228,0.025) 0 1px, transparent 1px 3px),
      repeating-linear-gradient(0deg,  rgba(242,237,228,0.020) 0 1px, transparent 1px 3px);
    opacity: 0.5;
    z-index: 1;
  }

  .lightbox__inner{
    position: relative; z-index: 2;
    max-width: 92vw; max-height: 88vh;
    display: flex; flex-direction: column;
    align-items: center;
    transform: scale(0.985);
    transition: transform 580ms cubic-bezier(.22,.61,.36,1);
  }
  .lightbox.is-open .lightbox__inner{ transform: scale(1); }

  .lightbox__plate{
    position: relative;
    max-width: 92vw; max-height: 76vh;
    padding: 8px;
    background: #0E0E0E;
    box-shadow: 0 0 0 1px rgba(242,237,228,0.18);
  }
  .lightbox__img{
    display: block;
    max-width: calc(92vw - 16px);
    max-height: calc(76vh - 16px);
    width: auto; height: auto;
    object-fit: contain;
    filter: saturate(0.78) contrast(0.96) sepia(0.04) brightness(0.99);
  }
  .lightbox__cap{
    margin-top: 18px;
    max-width: 60ch;
    color: rgba(242,237,228,0.72);
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic; font-weight: 300;
    font-size: clamp(14px, 1.05vw, 17px);
    line-height: 1.5;
    text-align: center;
  }
  .lightbox__head{
    position: absolute; top: 28px; right: 32px;
    z-index: 3;
    display: flex; align-items: center; gap: 14px;
    color: rgba(242,237,228,0.72);
    font-family: 'Inter', sans-serif; font-weight: 300;
    font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase;
  }
  .lightbox__close{
    background: none; border: none; padding: 0;
    cursor: none;
    color: inherit; font: inherit; letter-spacing: inherit;
    transition: color 200ms;
  }
  .lightbox__close:hover{ color: var(--parchment); }
  .lightbox__close::before{ content: '\2013\00a0'; color: var(--umber); }

  body.is-locked{ overflow: hidden; }

  @media (max-width: 700px){
    .lightbox{ padding: 2vh 3vw; }
    .lightbox__head{ top: 16px; right: 18px; font-size: 10px; }
  }

  /* ============================================================
     20. accessibility / reduced motion
     ============================================================ */
  @media (prefers-reduced-motion: reduce){
    .rv{ opacity:1; transform:none; transition:none; }
    .malta-map #malta-outline{ stroke-dashoffset: 0; transition:none; }
    .zoomable .src{ transition: none; }
    .zoomable:hover .src{ transform: none; }
    .lightbox, .lightbox__inner{ transition: none; }
  }

/* Extracted inline styles */
.selmun-palace-estate-i001 {
  max-width: 42ch !important;
}

.selmun-palace-estate-i002 {
  font-size: 30px !important;
  margin-top: 10px !important;
}

.selmun-palace-estate-i003 {
  margin-bottom: 22px !important;
}

.selmun-palace-estate-i004 {
  margin-top: 40px !important;
  max-width: 38ch !important;
}

.selmun-palace-estate-i005 {
  width: 40px !important;
  margin-bottom: 14px !important;
}

.selmun-palace-estate-i006 {
  width: 100% !important;
  aspect-ratio: 4 / 5 !important;
  padding: 6px !important;
  background: var(--parchment) !important;
  box-shadow: 0 0 0 1px rgba(26,26,26,0.3) !important;
}

.selmun-palace-estate-i007 {
  display: flex !important;
  justify-content: space-between !important;
  margin-top: 14px !important;
}

.selmun-palace-estate-i008 {
  font-size: 14px !important;
}

.selmun-palace-estate-i009 {
  margin-bottom: 18px !important;
}

.selmun-palace-estate-i010 {
  color: var(--umber) !important;
}

.selmun-palace-estate-i011 {
  margin-top: 16px !important;
}

.selmun-palace-estate-i012 {
  margin-bottom: 14px !important;
}

.selmun-palace-estate-i013 {
  margin-bottom: 16px !important;
}

.selmun-palace-estate-i014 {
  text-align: center !important;
  margin: 0 auto !important;
  max-width: 62ch !important;
}

.selmun-palace-estate-i015 {
  font-size: clamp(36px, 4.4vw, 60px) !important;
  line-height: 1.12 !important;
  font-weight: 300 !important;
  max-width: 17ch !important;
}

.selmun-palace-estate-i016 {
  max-width: 44ch !important;
}

.selmun-palace-estate-i017 {
  max-width: 44ch !important;
  margin-top: 16px !important;
}

.selmun-palace-estate-i018 {
  margin-top: 36px !important;
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.selmun-palace-estate-i019 {
  max-width: 44ch !important;
  margin-top: 30px !important;
}

.selmun-palace-estate-i020 {
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  padding: 6px !important;
  background: var(--parchment) !important;
  box-shadow: 0 0 0 1px rgba(26,26,26,0.3) !important;
}

.selmun-palace-estate-i021 {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 56px !important;
  align-items: end !important;
  margin-bottom: 40px !important;
}

.selmun-palace-estate-i022 {
  font-size: clamp(36px,4.2vw,60px) !important;
  line-height: 1.04 !important;
  margin: 0 !important;
  font-weight: 300 !important;
  max-width: 18ch !important;
}

.selmun-palace-estate-i023 {
  margin-top: 10px !important;
}

.selmun-palace-estate-i024 {
  font-size: clamp(34px, 4.2vw, 56px) !important;
  line-height: 1.12 !important;
  font-weight: 300 !important;
  max-width: 19ch !important;
}

.selmun-palace-estate-i025 {
  width: 100% !important;
  aspect-ratio: 3 / 2 !important;
  padding: 6px !important;
  background: var(--parchment) !important;
  box-shadow: 0 0 0 1px rgba(26,26,26,0.3) !important;
}

.selmun-palace-estate-i026 {
  width: 100% !important;
  aspect-ratio: 6 / 5 !important;
  padding: 6px !important;
  background: var(--parchment) !important;
  box-shadow: 0 0 0 1px rgba(26,26,26,0.3) !important;
}

.selmun-palace-estate-i027 {
  font-size: clamp(34px, 4.2vw, 56px) !important;
  line-height: 1.12 !important;
  font-weight: 300 !important;
  max-width: 17ch !important;
}

.selmun-palace-estate-i028 {
  max-width: 44ch !important;
  margin-top: 28px !important;
}

.selmun-palace-estate-i029 {
  margin-top: 32px !important;
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.selmun-palace-estate-i030 {
  width: 100% !important;
  aspect-ratio: 5 / 4 !important;
  padding: 6px !important;
  background: var(--parchment) !important;
  box-shadow: 0 0 0 1px rgba(26,26,26,0.3) !important;
}

.selmun-palace-estate-i031 {
  margin-top: 36px !important;
}

.selmun-palace-estate-i032 {
  font-size: clamp(34px, 4.2vw, 56px) !important;
  line-height: 1.12 !important;
  font-weight: 300 !important;
  max-width: 18ch !important;
}
