/* ===== BENJELLOUN & PARTNERS — dark / enterprise / dramatic =====
   Section-per-block: every <section class="ep-section"> = one Elementor section.
   Tone grounded in the brochure: near-black ink, signature gold, bone text. */
@font-face{
  font-family:"BastligaOne";
  src:url("fonts/BastligaOne.woff2") format("woff2");
  font-weight:normal;font-style:normal;font-display:swap;
}
:root{
  --ink:#0E0D0B; --ink2:#000000; --panel:#15120D; --panel2:#1B1813;
  --gold:#B8924A; --gold-lt:#D4AF6A; --bone:#F4F0E7; --bone-dim:#CFC8B8;
  --muted:#8A8174; --line:#2A261D; --line-lt:#3A352B;
  --maxw:1280px; --pad:clamp(20px,5vw,80px);
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--bone);background:var(--ink);line-height:1.6;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* ---------- typography ---------- */
h1,h2,h3{font-weight:300;line-height:1.06;letter-spacing:-.015em}
.eyebrow{font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:400}
.script{font-family:"BastligaOne",cursive;color:var(--gold);font-weight:400;letter-spacing:0}
.the-script{display:inline-flex;align-items:baseline;gap:.32em}
.the-script .the{font-size:.42em;text-transform:uppercase;letter-spacing:.3em;color:var(--bone-dim);transform:translateY(-.15em)}
.gold{color:var(--gold)}
.lead{font-size:clamp(16px,1.55vw,20px);color:var(--bone-dim);font-weight:300;max-width:62ch}
.display{font-size:clamp(40px,7vw,104px);letter-spacing:-.025em;line-height:.98}

/* ---------- header ---------- */
.site-head{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s,border-color .4s,padding .4s;border-bottom:1px solid transparent;padding:6px 0}
.site-head.scrolled{background:rgba(14,13,11,.86);backdrop-filter:blur(14px) saturate(1.3);border-bottom-color:var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand-logo{height:30px;width:auto;display:block}
.nav{display:flex;gap:30px;align-items:center}
.nav a{font-size:13px;letter-spacing:.05em;color:var(--bone-dim);transition:color .25s;position:relative}
.nav a:hover,.nav a.active{color:var(--bone)}
.nav a:not(.cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav a:not(.cta):hover::after,.nav a.active::after{width:100%}
.nav .cta{border:1px solid var(--gold);color:var(--gold);padding:10px 20px;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;transition:.3s}
.nav .cta:hover{background:var(--gold);color:var(--ink)}
.nav .cta::after{display:none}
.burger{display:none;background:none;border:0;color:var(--bone);font-size:24px;cursor:pointer;z-index:101}

/* ---------- sections ---------- */
.ep-section{padding:clamp(72px,11vw,150px) 0;position:relative}
.ep-section.tight{padding:clamp(44px,6vw,76px) 0}
.ep-section.black{background:var(--ink2)}
.ep-section.panel{background:var(--panel)}
.ep-section.bone{background:var(--bone);color:var(--ink)}
.ep-section.bone .eyebrow{color:#9A7B36}
.ep-section.bone .lead{color:#4A4438}
.ep-section.bone .the-script .the{color:#7A715F}
.section-head{margin-bottom:clamp(34px,5vw,64px)}
.section-title{font-size:clamp(30px,5vw,64px);letter-spacing:-.02em}
.section-title .l2{display:block}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--ink2)}
.hero .media{position:absolute;inset:0;z-index:0}
.hero .media video,.hero .media img{width:100%;height:100%;object-fit:cover;opacity:.82}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(14,13,11,.88) 0%,rgba(14,13,11,.6) 45%,rgba(14,13,11,.32) 75%,rgba(14,13,11,.18) 100%),
  linear-gradient(180deg,rgba(14,13,11,.4) 0%,transparent 30%,transparent 55%,rgba(14,13,11,.72) 100%)}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero h1.display{text-shadow:0 2px 28px rgba(14,13,11,.55),0 1px 4px rgba(14,13,11,.4)}
.hero .eyebrow{margin-bottom:26px;opacity:0;animation:fadeUp 1s .2s forwards}
.hero h1{opacity:0;animation:fadeUp 1.1s .4s forwards}
.hero .sub{margin-top:30px;font-size:clamp(15px,1.7vw,20px);max-width:50ch;color:var(--bone-dim);opacity:0;animation:fadeUp 1.1s .7s forwards}
.hero .actions{margin-top:42px;display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp 1.1s .95s forwards}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;color:var(--bone-dim);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:0;animation:fadeIn 1s 1.4s forwards;display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-cue .bar{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);animation:scrollBar 2s infinite}

/* ---------- buttons ---------- */
.btn{display:inline-block;padding:15px 32px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;transition:.35s;position:relative;overflow:hidden}
.btn-gold{background:var(--gold);color:var(--ink);font-weight:500}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(244,240,231,.35);color:var(--bone)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-ink{background:var(--ink);color:var(--bone)}
.btn-ink:hover{background:var(--panel2);transform:translateY(-2px)}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:14px 26px;border-left:1px solid var(--line)}
.stat:first-child{border-left:0;padding-left:0}
.stat .n{font-size:clamp(40px,6vw,76px);color:var(--gold);font-weight:200;letter-spacing:-.04em;line-height:1}
.stat .l{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:12px}
.bone .stat{border-color:#D9D2C2}
.bone .stat .n{color:var(--gold)}

/* ---------- founder ---------- */
.founder{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.founder .portrait{position:relative;overflow:hidden}
.founder .portrait img{width:100%;height:auto;filter:grayscale(1) contrast(1.04)}
.founder .portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(14,13,11,.5))}
.founder .sig{font-family:"BastligaOne",cursive;font-size:clamp(40px,6vw,72px);color:var(--gold);line-height:1;margin:8px 0 0}
.founder blockquote{font-size:clamp(20px,2.4vw,32px);font-weight:300;line-height:1.3;color:var(--bone);letter-spacing:-.01em;margin:0}
.founder blockquote .gold{font-style:normal}
.pull{font-size:clamp(22px,3vw,40px);font-weight:200;line-height:1.25;letter-spacing:-.015em}

/* ---------- approach pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pillar{background:var(--ink);padding:clamp(28px,3.5vw,48px);transition:background .4s}
.pillar:hover{background:var(--panel)}
.pillar .px{font-size:12px;letter-spacing:.2em;color:var(--gold);font-weight:400}
.pillar h3{font-size:clamp(20px,2.2vw,27px);margin:16px 0 14px;font-weight:300}
.pillar p{font-size:14.5px;color:var(--bone-dim);line-height:1.65}

/* ---------- projects ---------- */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.filters button{background:none;border:1px solid var(--line-lt);padding:10px 20px;font-size:12px;letter-spacing:.08em;cursor:pointer;color:var(--bone-dim);transition:.3s;font-family:inherit;text-transform:uppercase}
.filters button.active,.filters button:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(8px,1vw,14px)}
.card{position:relative;overflow:hidden;background:var(--panel);aspect-ratio:4/5;cursor:pointer}
.card img{width:100%;height:100%;object-fit:cover;opacity:.86;transition:transform .9s cubic-bezier(.16,1,.3,1),opacity .5s}
.card:hover img{transform:scale(1.07);opacity:1}
.card .meta{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:26px 24px;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.85));transition:background .4s}
.card .cat{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:0;transform:translateY(8px);transition:.4s}
.card:hover .cat{opacity:1;transform:none}
.card .nm{font-size:19px;margin-top:6px;font-weight:300}
.card .loc{font-size:12px;color:var(--bone-dim);margin-top:3px}
.card.feat{aspect-ratio:16/10}
.badge{position:absolute;top:16px;left:16px;z-index:3;background:var(--gold);color:var(--ink);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:6px 11px;font-weight:600}
.feat-row{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:1fr;gap:clamp(8px,1vw,14px)}
.feat-row .card:first-child{grid-row:span 2}

/* ---------- services ---------- */
.svc-list{border-top:1px solid var(--line)}
.svc-row{display:grid;grid-template-columns:80px 1fr 1.4fr;gap:30px;padding:clamp(26px,3vw,42px) 0;border-bottom:1px solid var(--line);align-items:baseline;transition:padding-left .4s}
.svc-row:hover{padding-left:14px}
.svc-row .no{font-size:13px;color:var(--gold);letter-spacing:.1em}
.svc-row h3{font-size:clamp(21px,2.4vw,30px);font-weight:300}
.svc-row p{font-size:14.5px;color:var(--bone-dim)}

/* ---------- team ---------- */
.team-group{margin-bottom:60px}
.team-group .gh{display:flex;align-items:baseline;gap:16px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:34px}
.team-group .gn{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500}
.team-group .gc{font-size:12.5px;color:var(--muted)}
.tgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(10px,1.4vw,20px)}
.person .ph{aspect-ratio:1/1;background:var(--panel2);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:30px;font-weight:200;overflow:hidden;position:relative}
.person.lead-card .ph{aspect-ratio:3/4}
.person .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(1)}
.person .nm{font-size:14px;margin-top:12px;font-weight:400}
.person .rl{font-size:11px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-top:4px}

/* ---------- recognition ---------- */
.awards{border-top:1px solid var(--line)}
.award-row{display:grid;grid-template-columns:1fr auto;gap:24px;padding:24px 0;border-bottom:1px solid var(--line);align-items:center}
.award-row h3{font-size:clamp(17px,1.9vw,23px);font-weight:300}
.award-row .for{font-size:13px;color:var(--muted);margin-top:3px}
.award-row .res{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding:6px 14px;white-space:nowrap}
.award-row .res.won{background:var(--gold);color:var(--ink);font-weight:600}
.award-row .res.nom{border:1px solid var(--line-lt);color:var(--bone-dim)}
.press-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.press-strip .p{background:var(--ink);padding:26px 12px;text-align:center;font-size:12.5px;letter-spacing:.04em;color:var(--bone-dim);display:flex;align-items:center;justify-content:center;min-height:78px;transition:.3s}
.press-strip .p:hover{background:var(--panel);color:var(--gold)}
.bone .press-strip{background:#D9D2C2;border-color:#D9D2C2}
.bone .press-strip .p{background:var(--bone);color:#4A4438}

/* ---------- feature rows ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,80px);align-items:center}
.feature.rev .ftxt{order:2}
.feature .fimg{overflow:hidden;aspect-ratio:5/4;background:var(--panel)}
.feature .fimg img{width:100%;height:100%;object-fit:cover}

/* ---------- logos wall ---------- */
.logos{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.logos .lg{background:var(--ink);min-height:132px;display:flex;align-items:center;justify-content:center;padding:26px 24px;transition:background .3s}
.logos .lg img{max-width:100%;max-height:58px;width:auto;height:auto;object-fit:contain;opacity:.55;transition:opacity .3s}
.logos .lg:hover{background:var(--panel)}
.logos .lg:hover img{opacity:1}

/* ---------- CTA ---------- */
.cta-band{text-align:center}
.cta-band h2{font-size:clamp(28px,4.5vw,58px);max-width:20ch;margin:0 auto .5em;font-weight:300}

/* ---------- forms ---------- */
.form{display:grid;gap:14px;max-width:520px}
.form input,.form textarea,.form select{font-family:inherit;font-size:15px;padding:15px 18px;border:1px solid var(--line-lt);background:var(--panel);color:var(--bone)}
.form input::placeholder,.form textarea::placeholder{color:var(--muted)}
.form textarea{min-height:130px;resize:vertical}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px)}
.cinfo .row{padding:20px 0;border-bottom:1px solid var(--line)}
.cinfo .row .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.cinfo .row .v{font-size:16px;margin-top:6px;color:var(--bone)}

/* ---------- footer ---------- */
.site-foot{background:var(--ink2);padding:clamp(56px,8vw,100px) 0 40px;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:46px;padding-bottom:46px;border-bottom:1px solid var(--line)}
.foot-logo{height:185px;width:auto;margin-bottom:18px}
.foot-tag{font-size:12px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.award-badge{display:inline-block;border:1px solid var(--gold);color:var(--gold);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;margin-top:20px}
.fcol h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;font-weight:500}
.fcol a{display:block;font-size:14px;padding:6px 0;color:var(--bone-dim);transition:color .25s}
.fcol a:hover{color:var(--gold)}
.fcol.explore{display:flex;flex-direction:column}
.fcol.explore a{display:inline-block}
.fcol.explore .explore-links{display:grid;grid-template-columns:1fr 1fr;gap:0 28px}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:30px;font-size:12.5px;color:var(--muted);flex-wrap:wrap;gap:12px}

/* ---------- animations ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollBar{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.js-anim .reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.js-anim .reveal.in{opacity:1;transform:none}
/* project grid cards: gentle reveal, but failsafe so a filtered/All view is never stuck invisible */
.js-anim .pgrid .card{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.js-anim .pgrid .card.in{opacity:1;transform:none}
.js-anim .reveal-stagger>*{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.js-anim .reveal-stagger.in>*{opacity:1;transform:none}
.js-anim .reveal-stagger.in>*:nth-child(2){transition-delay:.08s}
.js-anim .reveal-stagger.in>*:nth-child(3){transition-delay:.16s}
.js-anim .reveal-stagger.in>*:nth-child(4){transition-delay:.24s}
.js-anim .reveal-stagger.in>*:nth-child(5){transition-delay:.32s}
.js-anim .reveal-stagger.in>*:nth-child(6){transition-delay:.4s}
@media (prefers-reduced-motion:reduce){
  .js-anim .reveal,.js-anim .reveal-stagger>*{opacity:1!important;transform:none!important;transition:none}
  .hero .eyebrow,.hero h1,.hero .sub,.hero .actions,.scroll-cue{animation:none;opacity:1}
  .card img,.scroll-cue .bar{transition:none;animation:none}
}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .founder,.feature,.contact-grid{grid-template-columns:1fr;gap:36px}
  .feature.rev .ftxt{order:0}
  .pillars{grid-template-columns:1fr}
  .pgrid,.tgrid{grid-template-columns:repeat(2,1fr)}
  .logos,.press-strip{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:20px 0}
  .stat{padding:14px 20px}
  .feat-row{grid-template-columns:1fr 1fr}
  .feat-row .card:first-child{grid-row:auto;grid-column:1/3}
  .svc-row{grid-template-columns:50px 1fr;gap:8px 20px}
  .svc-row p{grid-column:2}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
}
/* ---------- Mobile menu (burger) ---------- */
@media(max-width:1000px){
  .burger{display:block}
  .nav{
    position:fixed;
    inset:0;
    width:100%;
    height:100%;
    height:100dvh;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    gap:6px;
    padding:84px 24px 40px;
    background:#0E0D0B;            /* solid opaque, no bleed-through */
    overflow-y:auto;               /* scroll if items exceed screen */
    -webkit-overflow-scrolling:touch;
    transform:translateX(100%);
    transition:transform .4s ease;
    z-index:100;                   /* above page content, below burger(101) */
    display:flex;
  }
  .nav.open{transform:none}
  .nav a{font-size:18px;padding:13px 12px;width:100%;text-align:center;max-width:340px}
  .nav .cta{margin-top:10px}
}
@media(max-width:600px){
  .pgrid,.tgrid,.logos,.press-strip{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .feat-row{grid-template-columns:1fr}
  .feat-row .card:first-child{grid-column:auto}
  .foot-top{grid-template-columns:1fr}
}

/* script-over-image band (brochure signature device) */
.script-band{position:relative;min-height:clamp(380px,55vh,620px);display:flex;align-items:center;justify-content:center;overflow:hidden}
.script-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;filter:grayscale(1)}
.script-band::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(14,13,11,.4),rgba(14,13,11,.85))}
.script-band-text{position:relative;z-index:2;text-align:center;padding:0 24px}
.aspire-band{position:relative;width:100%;line-height:0}
.aspire-band img{width:100%;height:auto;display:block;object-fit:cover}

/* ---------- Foundation: Record (big figures) ---------- */
.record-list{border-top:1px solid var(--line)}
.record-row{display:grid;grid-template-columns:minmax(180px,260px) 1fr;gap:8px 36px;align-items:baseline;padding:clamp(24px,3vw,40px) 0;border-bottom:1px solid var(--line)}
.record-row .fig{font-size:clamp(40px,6vw,72px);font-weight:200;line-height:1;color:var(--bone);letter-spacing:-.02em}
.record-row .rmeta h3{font-size:clamp(16px,1.7vw,20px);font-weight:400;color:var(--gold);margin-bottom:6px}
.record-row .rmeta p{font-size:14px;color:var(--bone-dim);line-height:1.5}
@media(max-width:720px){
  .record-row{grid-template-columns:1fr;gap:6px}
  .record-row .fig{font-size:clamp(38px,12vw,56px)}
}

/* ---------- News: text cards (no image) ---------- */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.news-card{display:block;background:var(--panel);padding:30px 28px 34px;transition:background .4s}
.news-card:hover{background:#1b1813}
.news-card .ncat{display:inline-block;background:var(--gold);color:var(--ink);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:5px 10px;font-weight:600}
.news-card .nkick{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:18px}
.news-card h3{font-size:clamp(18px,1.7vw,21px);font-weight:300;margin-top:8px;line-height:1.3;color:var(--bone)}
.news-card p{font-size:14px;color:var(--bone-dim);margin-top:12px;line-height:1.55}
.news-card .nmore{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:18px;display:inline-block}

/* ---------- CTA band: center the lead paragraph + button stack ---------- */
.cta-band .lead{max-width:54ch;margin-left:auto;margin-right:auto}
.cta-band > div{display:flex;justify-content:center}

/* ---------- Careers: CV attach field ---------- */
.filefield{display:flex;flex-direction:column;gap:8px}
.filefield .flabel{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.filefield input[type=file]{font-family:inherit;font-size:14px;color:var(--bone-dim);padding:12px 14px;border:1px dashed var(--line-lt);background:var(--panel);cursor:pointer}
.filefield input[type=file]::file-selector-button{font-family:inherit;background:var(--gold);color:var(--ink);border:0;padding:9px 16px;margin-right:14px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:.3s}
.filefield input[type=file]::file-selector-button:hover{background:var(--gold-lt)}
.filefield .fhint{font-size:12px;color:var(--muted)}

/* ---------- Project galleries ---------- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.gallery .gitem{position:relative;overflow:hidden;background:var(--panel);aspect-ratio:4/3}
.gallery .gitem:first-child:nth-last-child(odd){grid-column:1/-1;aspect-ratio:16/9}
.gallery .gitem img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.16,1,.3,1)}
.gallery .gitem:hover img{transform:scale(1.04)}
@media(max-width:700px){.gallery{grid-template-columns:1fr}.gallery .gitem:first-child:nth-last-child(odd){aspect-ratio:4/3}}

.form-status{font-size:14px;line-height:1.5;margin-top:4px;min-height:1.2em}
.form-status.ok{color:var(--gold)}
.form-status.err{color:#d98a6a}
