:root{
    --ink:#15110C;
    --ink-soft:#403a30;
    --paper:#F2E9D6;
    --paper-2:#EFE3CB;
    --cream:#FBF7EE;
    --majorelle:#2533B0;
    --majorelle-deep:#171F7E;
    --saffron:#F2A81C;
    --vermilion:#E03A1E;
    --zellige:#0E6E5A;
    --line:#15110C;

    --display:"Fraunces",Georgia,serif;
    --poster:"Anton",Impact,sans-serif;
    --kufi:"Reem Kufi",sans-serif;
    --body:"Manrope",system-ui,sans-serif;
    --mono:"Space Mono",ui-monospace,monospace;

    --b:3px solid var(--ink);
    --sh:7px 7px 0 var(--ink);
    --sh-sm:4px 4px 0 var(--ink);
    --maxw:1280px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  @media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;animation-iteration-count:1!important}}

  body{
    margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.62;
    -webkit-font-smoothing:antialiased;overflow-x:hidden;
  }
  /* paper grain + halftone dust */
  body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.06;mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

  html[dir="rtl"] body{font-family:var(--kufi)}
  html[dir="rtl"] h1,html[dir="rtl"] h2,html[dir="rtl"] h3,html[dir="rtl"] .poster{font-family:var(--kufi)}

  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}
  .section{padding:104px 0;position:relative;z-index:2}
  @media (max-width:760px){.section{padding:68px 0}}
  :focus-visible{outline:3px solid var(--vermilion);outline-offset:3px}

  h1,h2,h3{margin:0;line-height:1}
  .poster{font-family:var(--poster);text-transform:uppercase;letter-spacing:.01em;line-height:.92;font-weight:400}
  .serif{font-family:var(--display);font-weight:900;letter-spacing:-.02em;line-height:1.02}
  .h-xl{font-size:clamp(2.8rem,8.5vw,7rem)}
  .h-lg{font-size:clamp(2.2rem,5vw,4rem)}
  .h-md{font-size:clamp(1.7rem,3vw,2.6rem)}
  p{margin:0 0 1rem}
  .lead{font-size:1.13rem;color:var(--ink-soft);max-width:60ch}
  .kufi{font-family:var(--kufi)}

  .eyebrow{font-family:var(--mono);font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--vermilion);
    display:inline-flex;align-items:center;gap:.6em;font-weight:700;margin:0 0 18px}
  .eyebrow::before{content:"";width:30px;height:3px;background:var(--vermilion)}
  html[dir="rtl"] .eyebrow{letter-spacing:0;font-family:var(--kufi)}

  /* confetti / pointillist signature band (from banner.jpg) */
  .confetti{height:18px;background:
     radial-gradient(circle at 6px 9px, var(--majorelle) 2.4px, transparent 2.6px) 0 0/22px 18px,
     radial-gradient(circle at 17px 5px, var(--saffron) 2.2px, transparent 2.4px) 0 0/22px 18px,
     radial-gradient(circle at 11px 13px, var(--vermilion) 2px, transparent 2.2px) 0 0/22px 18px;
     background-color:var(--ink)}

  .btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--body);font-weight:800;font-size:.94rem;
    padding:15px 26px;border:var(--b);background:var(--saffron);color:var(--ink);box-shadow:var(--sh-sm);cursor:pointer;
    transition:transform .15s ease,box-shadow .15s ease}
  .btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
  .btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}
  .btn--blue{background:var(--majorelle);color:#fff}
  .btn--ghost{background:transparent}
  .btn--white{background:var(--cream)}
  .btn .arr{transition:transform .2s ease}
  .btn:hover .arr{transform:translateX(4px)}
  html[dir="rtl"] .btn .arr{transform:scaleX(-1)}
  html[dir="rtl"] .btn:hover .arr{transform:translateX(-4px) scaleX(-1)}

  /* ---------- HEADER ---------- */
  header{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:var(--b)}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:74px}
  .brand img{height:46px;width:auto}
  .nav-links{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
  .nav-links a{font-weight:700;font-size:.9rem;padding:9px 13px;position:relative}
  .nav-links a::after{content:"";position:absolute;left:13px;right:13px;bottom:5px;height:2.5px;background:var(--vermilion);transform:scaleX(0);transform-origin:left;transition:transform .2s}
  .nav-links a:hover::after{transform:scaleX(1)}
  .nav-right{display:flex;align-items:center;gap:14px}
  .lang{display:inline-flex;border:var(--b);font-family:var(--mono);font-size:.74rem;font-weight:700;overflow:hidden}
  .lang button{border:0;background:transparent;padding:8px 12px;cursor:pointer;font:inherit;color:var(--ink)}
  .lang button.active{background:var(--ink);color:var(--paper)}
  .burger{display:none;border:var(--b);background:var(--saffron);width:46px;height:42px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
  .burger span{width:22px;height:3px;background:var(--ink)}
  @media (max-width:1040px){
    .nav-links{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);
      border-bottom:var(--b);padding:8px 28px 22px;transform:translateY(-135%);transition:transform .3s ease;z-index:55}
    .nav-links.open{transform:translateY(0)}
    .nav-links a{padding:15px 4px;border-bottom:1px solid rgba(21,17,12,.14);font-size:1.06rem}
    .nav-links a::after{display:none}
    .burger{display:flex}
  }

  /* ---------- HERO (photo slider, screenprint tint) ---------- */
  .hero{position:relative;border-bottom:var(--b);overflow:hidden;background:var(--majorelle-deep)}
  .hero-stage{position:relative;min-height:min(92vh,860px)}
  @media (max-width:760px){.hero-stage{min-height:78vh}}
  .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease}
  .slide.active{opacity:1}
  .slide img{width:100%;height:100%;object-fit:cover}
  /* screenprint tint: keep the real photo, push it Majorelle */
  .hero-tint{position:absolute;inset:0;background:
      linear-gradient(180deg, rgba(23,31,126,.35), rgba(21,17,12,.78)),
      radial-gradient(120% 90% at 75% 10%, rgba(37,51,176,.55), transparent 60%);
      mix-blend-mode:multiply;pointer-events:none}
  .hero-halftone{position:absolute;inset:0;pointer-events:none;opacity:.22;mix-blend-mode:screen;
      background-image:radial-gradient(circle at 2px 2px, #fff 1px, transparent 1.4px);background-size:7px 7px}
  .hero-kufi{position:absolute;inset-inline-end:-.04em;top:-.12em;font-family:var(--kufi);font-weight:700;
      font-size:clamp(8rem,30vw,26rem);line-height:.7;color:transparent;-webkit-text-stroke:2px rgba(242,168,28,.5);
      text-stroke:2px rgba(242,168,28,.5);pointer-events:none;z-index:2;user-select:none}
  .hero-inner{position:absolute;inset:0;z-index:3;display:flex;align-items:flex-end}
  .hero-content{padding:0 28px 64px;max-width:var(--maxw);margin:0 auto;width:100%}
  .hero-eyebrow{font-family:var(--mono);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;font-weight:700;
      color:var(--saffron);display:inline-flex;align-items:center;gap:.7em;margin-bottom:18px}
  .hero-eyebrow::before{content:"";width:34px;height:3px;background:var(--saffron)}
  .hero h1{color:var(--cream);font-size:clamp(2.6rem,6.6vw,6rem);max-width:16ch;text-shadow:3px 3px 0 rgba(21,17,12,.45)}
  .hero h1 em{font-style:normal;color:var(--saffron)}
  .hero .slogan{font-family:var(--kufi);font-weight:700;font-size:clamp(1.8rem,4.5vw,3rem);color:var(--saffron);margin:14px 0 0}
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
  .hero-meta{position:absolute;top:26px;inset-inline-end:28px;z-index:3;font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;
      color:var(--cream);border:2px solid rgba(251,247,238,.6);padding:7px 12px;text-transform:uppercase}
  .festival-stamp{position:absolute;top:96px;inset-inline-start:28px;z-index:3;background:var(--vermilion);color:var(--cream);
      border:var(--b);box-shadow:var(--sh-sm);padding:12px 16px;transform:rotate(-4deg);max-width:230px}
  .festival-stamp .n{font-family:var(--poster);font-size:2.6rem;line-height:.9}
  .festival-stamp .t{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;display:block;margin-top:2px}
  .festival-stamp .ar{font-family:var(--kufi);font-size:1rem;font-weight:700;display:block;margin-top:4px}
  @media (max-width:760px){.festival-stamp{top:auto;bottom:auto;position:static;display:inline-block;transform:rotate(-3deg);margin-bottom:18px}}
  .dots{position:absolute;bottom:24px;inset-inline-end:28px;z-index:4;display:flex;gap:9px}
  .dots button{width:34px;height:7px;border:2px solid var(--cream);background:transparent;cursor:pointer;padding:0}
  .dots button.active{background:var(--saffron);border-color:var(--saffron)}

  /* ---------- MARQUEE ---------- */
  .marquee{background:var(--ink);color:var(--paper);overflow:hidden;border-bottom:var(--b)}
  .marquee-track{display:flex;width:max-content;animation:scroll 34s linear infinite}
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee-track span{font-family:var(--poster);font-size:1.6rem;text-transform:uppercase;padding:15px 26px;display:inline-flex;align-items:center;gap:26px}
  .marquee-track span::after{content:"✦";color:var(--saffron);font-size:.9rem}
  @keyframes scroll{to{transform:translateX(-50%)}}
  html[dir="rtl"] .marquee-track{animation-direction:reverse}

  /* ---------- SPLIT ---------- */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
  @media (max-width:900px){.split{grid-template-columns:1fr;gap:40px}}
  .framed{border:var(--b);box-shadow:var(--sh);background:var(--ink);position:relative}
  .framed img{width:100%;object-fit:cover}
  .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
  .play span{width:80px;height:80px;border-radius:50%;background:var(--vermilion);border:3px solid var(--cream);display:grid;place-items:center;box-shadow:var(--sh-sm);transition:transform .2s}
  .framed:hover .play span{transform:scale(1.09)}
  .play span::after{content:"";border-style:solid;border-width:12px 0 12px 19px;border-color:transparent transparent transparent var(--cream);margin-inline-start:4px}
  .vcap{margin-top:14px;font-family:var(--mono);font-size:.76rem;letter-spacing:.05em;color:var(--ink-soft)}
  .callbar{margin-top:28px;display:inline-flex;align-items:center;gap:16px;border:var(--b);background:var(--saffron);padding:14px 22px;box-shadow:var(--sh-sm)}
  .callbar small{display:block;font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase}
  .callbar b{font-family:var(--poster);font-size:1.5rem;letter-spacing:.02em}

  /* ---------- PILLARS ---------- */
  .pillars{display:grid;grid-template-columns:repeat(4,1fr);border:var(--b);background:var(--ink);box-shadow:var(--sh)}
  @media (max-width:980px){.pillars{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:560px){.pillars{grid-template-columns:1fr}}
  .pillar{background:var(--cream);padding:32px 26px;border-inline-end:var(--b);border-bottom:var(--b);position:relative;transition:background .2s}
  .pillars .pillar:nth-child(4n){border-inline-end:0}
  .pillar:hover{background:var(--paper-2)}
  .pillar .idx{font-family:var(--mono);font-weight:700;font-size:.78rem;color:var(--vermilion);letter-spacing:.1em}
  .pillar h3{font-family:var(--serif);font-family:var(--display);font-weight:900;font-size:1.4rem;margin:8px 0 12px;color:var(--majorelle)}
  .pillar p{font-size:.92rem;color:var(--ink-soft);margin:0}
  .pillar .glyph{position:absolute;top:20px;inset-inline-end:22px;font-family:var(--kufi);font-size:1.8rem;color:var(--saffron)}
  @media (max-width:980px){.pillars .pillar:nth-child(2n){border-inline-end:0}.pillars .pillar:nth-child(4n){border-inline-end:var(--b)}}
  @media (max-width:560px){.pillar{border-inline-end:0!important}}

  /* ---------- IDENTITY CARD ---------- */
  .idcard{border:var(--b);background:var(--majorelle);color:var(--cream);box-shadow:var(--sh);overflow:hidden}
  .idcard .head{background:var(--majorelle-deep);padding:18px 24px;border-bottom:2px solid rgba(251,247,238,.25);font-family:var(--mono);letter-spacing:.18em;font-size:.74rem;text-transform:uppercase;font-weight:700}
  .idcard dl{margin:0;padding:8px 24px 22px}
  .idcard .row{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px dashed rgba(251,247,238,.32)}
  .idcard .row:last-child{border-bottom:0}
  .idcard dt{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin:0}
  .idcard dd{margin:0;font-weight:700;text-align:end}
  .idcard a{color:var(--saffron)}

  /* ---------- STATS ---------- */
  .stats-band{background:var(--vermilion);border-block:var(--b);color:var(--cream)}
  .stats{display:grid;grid-template-columns:repeat(3,1fr)}
  @media (max-width:760px){.stats{grid-template-columns:1fr}}
  .stat{padding:54px 24px;text-align:center;border-inline-end:2px dashed rgba(251,247,238,.45)}
  .stat:last-child{border-inline-end:0}
  @media (max-width:760px){.stat{border-inline-end:0;border-bottom:2px dashed rgba(251,247,238,.45)}.stat:last-child{border-bottom:0}}
  .stat .n{font-family:var(--poster);font-size:clamp(3rem,6.5vw,5rem);line-height:1}
  .stat .l{font-family:var(--mono);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-top:8px}

  /* ---------- TARGETS ---------- */
  .targets{list-style:none;margin:24px 0 0;padding:0;border-top:var(--b)}
  .targets li{padding:16px 8px 16px 0;border-bottom:var(--b);display:flex;gap:16px;align-items:baseline;font-weight:600}
  .targets li::before{content:"→";color:var(--vermilion);font-weight:800;font-size:1.1rem}
  html[dir="rtl"] .targets li::before{content:"←"}

  /* ---------- PARTNERS ---------- */
  .partners{display:grid;grid-template-columns:repeat(5,1fr);border:var(--b);background:var(--ink);box-shadow:var(--sh)}
  @media (max-width:880px){.partners{grid-template-columns:repeat(2,1fr)}}
  .partner{background:var(--cream);padding:30px;display:grid;place-items:center;border-inline-end:var(--b);border-bottom:var(--b);min-height:130px}
  .partners .partner:nth-child(5n){border-inline-end:0}
  .partner img{max-height:64px;width:auto;filter:grayscale(1) contrast(.92);opacity:.72;transition:filter .25s,opacity .25s}
  .partner:hover img{filter:none;opacity:1}
  @media (max-width:880px){.partners .partner{border-inline-end:var(--b)}.partners .partner:nth-child(2n){border-inline-end:0}}

  /* ---------- GALLERY ---------- */
  .gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  @media (max-width:980px){.gallery{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:520px){.gallery{grid-template-columns:1fr}}
  .gcard{border:var(--b);box-shadow:var(--sh-sm);overflow:hidden;background:var(--ink);position:relative;transition:transform .2s,box-shadow .2s;display:block}
  .gcard:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
  .gcard img{aspect-ratio:4/5;object-fit:cover;width:100%;transition:transform .4s ease}
  .gcard:hover img{transform:scale(1.05)}
  .gcard .cap{position:absolute;inset-inline:0;bottom:0;background:linear-gradient(transparent,rgba(21,17,12,.9));color:var(--cream);padding:30px 16px 14px;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700}

  /* ---------- FEATURE CARDS ---------- */
  .duo{display:grid;grid-template-columns:1fr 1fr;gap:26px}
  @media (max-width:780px){.duo{grid-template-columns:1fr}}
  .feature{border:var(--b);box-shadow:var(--sh);overflow:hidden;background:var(--cream);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
  .feature:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--ink)}
  .feature img{aspect-ratio:16/9;object-fit:cover;width:100%;border-bottom:var(--b)}
  .feature .body{padding:26px}
  .feature h3{font-family:var(--display);font-weight:900;font-size:1.55rem;margin-bottom:6px}
  .feature .link{margin-top:14px;display:inline-flex;font-weight:800;color:var(--majorelle);gap:.4em;align-items:center}
  .team-cta{border:3px dashed var(--ink);background:var(--cream);padding:52px 32px;text-align:center}

  /* ---------- FOOTER ---------- */
  footer{position:relative;z-index:2;color:var(--paper);background:var(--ink)}
  .foot-textile{height:90px;background-image:url("assets/img/footer.webp");background-size:cover;background-position:center;border-bottom:var(--b);filter:saturate(1.05)}
  .foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:42px;padding:66px 0 46px}
  @media (max-width:860px){.foot-top{grid-template-columns:1fr 1fr}}
  @media (max-width:560px){.foot-top{grid-template-columns:1fr}}
  .foot-brand img{height:60px;width:auto;margin-bottom:16px}
  .foot-brand .ar{font-family:var(--kufi);font-size:1.8rem;color:var(--saffron);margin:4px 0 16px}
  .foot-brand .tel{font-family:var(--poster);font-size:1.7rem;color:var(--saffron)}
  .foot-col h4{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--saffron);margin:0 0 16px}
  .foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
  .foot-col a{opacity:.85;font-weight:600}
  .foot-col a:hover{opacity:1;color:var(--saffron)}
  .socials{display:flex;gap:10px;margin-top:18px}
  .socials a{width:44px;height:44px;border:2px solid var(--paper);display:grid;place-items:center;transition:background .2s,color .2s,border-color .2s}
  .socials a:hover{background:var(--saffron);border-color:var(--saffron);color:var(--ink)}
  .socials svg{width:19px;height:19px;fill:currentColor}
  .foot-bottom{border-top:1px solid rgba(242,233,214,.2);padding:20px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;opacity:.82}

  .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}
  @media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}
  .section-head{max-width:62ch;margin-bottom:46px}
  .anchor{scroll-margin-top:90px}

/* ============ SUB-PAGE COMPONENTS ============ */
.page-hero{position:relative;background:var(--majorelle-deep);color:var(--cream);border-bottom:var(--b);overflow:hidden}
.page-hero .ph-bg{position:absolute;inset:0;opacity:.32;object-fit:cover;width:100%;height:100%}
.page-hero .ph-tint{position:absolute;inset:0;background:linear-gradient(180deg,rgba(23,31,126,.5),rgba(21,17,12,.7));mix-blend-mode:multiply}
.page-hero .ph-halftone{position:absolute;inset:0;opacity:.18;mix-blend-mode:screen;background-image:radial-gradient(circle at 2px 2px,#fff 1px,transparent 1.4px);background-size:7px 7px}
.page-hero .ph-kufi{position:absolute;inset-inline-end:-.04em;top:-.18em;font-family:var(--kufi);font-weight:700;font-size:clamp(7rem,24vw,20rem);line-height:.7;color:transparent;-webkit-text-stroke:2px rgba(242,168,28,.4);pointer-events:none;user-select:none}
.page-hero .inner{position:relative;z-index:2;padding:84px 0 72px}
.page-hero h1{font-family:var(--poster);text-transform:uppercase;font-size:clamp(2.8rem,8vw,6rem);line-height:.92}
.crumb{font-family:var(--mono);font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--saffron);margin-bottom:16px;display:flex;gap:.6em;align-items:center}
.crumb a{opacity:.85}.crumb a:hover{opacity:1}
.crumb span{opacity:.6}

/* prose */
.prose{max-width:70ch}
.prose p{font-size:1.08rem;color:var(--ink-soft);margin-bottom:1.2rem}
.prose strong{color:var(--ink)}

/* about gallery */
.about-gal{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:760px){.about-gal{grid-template-columns:1fr}}
.about-gal .framed img{aspect-ratio:4/3;width:100%}
.band-img{border:var(--b);box-shadow:var(--sh);overflow:hidden;background:var(--ink)}
.band-img img{width:100%;object-fit:cover;max-height:460px}

/* feature list (about core features) */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:var(--b);background:var(--ink);box-shadow:var(--sh)}
@media (max-width:680px){.features{grid-template-columns:1fr}}
.feat{background:var(--cream);padding:30px;border-inline-end:var(--b);border-bottom:var(--b)}
.features .feat:nth-child(2n){border-inline-end:0}
.feat h3{font-family:var(--display);font-weight:900;font-size:1.4rem;color:var(--majorelle);margin-bottom:10px;display:flex;align-items:center;gap:.5em}
.feat h3 .k{font-family:var(--kufi);color:var(--saffron);font-size:1.5rem}
.feat p{font-size:.94rem;color:var(--ink-soft);margin:0}
@media (max-width:680px){.feat{border-inline-end:0}}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:34px}}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:7px}
.field input,.field textarea{width:100%;border:var(--b);background:var(--cream);padding:13px 15px;font:inherit;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;box-shadow:var(--sh-sm);transform:translate(-1px,-1px)}
.field textarea{min-height:140px;resize:vertical}
.contact-info{border:var(--b);background:var(--majorelle);color:var(--cream);box-shadow:var(--sh);padding:30px}
.contact-info h3{font-family:var(--display);font-weight:900;font-size:1.5rem;margin-bottom:18px}
.contact-info .ci-row{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-bottom:1px dashed rgba(251,247,238,.3)}
.contact-info .ci-row:last-child{border-bottom:0}
.contact-info .ci-row a{color:var(--saffron);font-weight:700}
.contact-info .ic{width:24px;flex:none;color:var(--saffron)}
.map-frame{border:var(--b);box-shadow:var(--sh);overflow:hidden;line-height:0;margin-top:46px}
.map-frame iframe{width:100%;height:420px;border:0;display:block;filter:grayscale(.2) contrast(1.05)}
.form-note{font-family:var(--mono);font-size:.74rem;color:var(--ink-soft);margin-top:10px}

/* resources */
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media (max-width:860px){.res-grid{grid-template-columns:1fr}}
.res-card{border:var(--b);box-shadow:var(--sh);overflow:hidden;background:var(--cream);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.res-card:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--ink)}
.res-card .cover{aspect-ratio:4/3;background:var(--ink);overflow:hidden;border-bottom:var(--b)}
.res-card .cover img{width:100%;height:100%;object-fit:cover}
.res-card .rb{padding:24px;display:flex;flex-direction:column;gap:14px;flex:1}
.res-card .tag{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--vermilion);font-weight:700}
.res-card h3{font-family:var(--kufi);font-weight:700;font-size:1.35rem;line-height:1.4}
.res-card .dl{margin-top:auto}

/* empty / coming soon state */
.empty{border:3px dashed var(--ink);background:var(--cream);padding:60px 32px;text-align:center}
.empty .big{font-family:var(--poster);text-transform:uppercase;font-size:clamp(2rem,5vw,3.4rem);color:var(--majorelle);line-height:.95;margin-bottom:14px}

/* blog grid */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media (max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.blog-grid{grid-template-columns:1fr}}
.post{border:var(--b);box-shadow:var(--sh-sm);overflow:hidden;background:var(--cream);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.post:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.post .pimg{aspect-ratio:16/10;overflow:hidden;border-bottom:var(--b);background:var(--ink)}
.post .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post:hover .pimg img{transform:scale(1.05)}
.post .pb{padding:22px}
.post .meta{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--vermilion);font-weight:700;margin-bottom:10px}
.post h3{font-family:var(--display);font-weight:900;font-size:1.3rem;line-height:1.1;margin-bottom:8px}
.post p{font-size:.92rem;color:var(--ink-soft);margin:0}

.nav-links a[aria-current="page"]{color:var(--vermilion)}
.nav-links a[aria-current="page"]::after{transform:scaleX(1)}
