/* ==========================================================================
   RASSEDCO — bespoke institutional design system (layer over Bootstrap 5.3)
   One shared stylesheet. Palette sampled from the RASSEDCO brand.
   ========================================================================== */

:root{
  --brand-navy:#254485;
  --deep-navy:#122A52;
  --ink:#0E2240;
  --brand-gold:#D9BB2C;
  --gold-soft:#E8CF57;
  --deep-gold:#8F7011;
  --warm-paper:#FCFBF8;
  --sand:#F3EEE3;
  --white:#FFFFFF;
  --text-dark:#17243A;
  --text-muted:#647083;
  --border-soft:rgba(18,42,82,.14);
  --line-on-dark:rgba(217,187,44,.22);

  --font-display:"Bricolage Grotesque",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-body:"Newsreader",Georgia,"Times New Roman",serif;
  --font-ar:"Tajawal",system-ui,-apple-system,"Segoe UI",sans-serif;

  --maxw:1200px;
  --radius:14px;
  --shadow-card:0 18px 44px -28px rgba(11,34,57,.42);
  --shadow-soft:0 10px 30px -22px rgba(11,34,57,.40);
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:1.075rem;
  line-height:1.7;
  color:var(--text-dark);
  background:var(--warm-paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,.font-display,.eyebrow,.btn,.navbar-nav,.stat__num,.card__kicker{
  font-family:var(--font-display);
  letter-spacing:-.01em;
}
h1,h2,h3,h4{color:var(--deep-navy);font-weight:700;line-height:1.12}
p{color:var(--text-dark)}
a{color:var(--brand-navy);text-underline-offset:3px}
a:hover{color:var(--deep-navy)}
img{max-width:100%;height:auto}
.lead-muted{color:var(--text-muted)}
strong{color:var(--deep-navy)}

/* Arabic / RTL typography — Tajawal */
html[lang="ar"],html[lang="ar"] body{font-family:var(--font-ar);letter-spacing:0}
html[lang="ar"] body{line-height:1.85}
html[lang="ar"] h1,html[lang="ar"] h2,html[lang="ar"] h3,
html[lang="ar"] h4,html[lang="ar"] h5,html[lang="ar"] h6{
  font-family:var(--font-ar);line-height:1.35;letter-spacing:0;font-weight:700
}
html[lang="ar"] .hero h1{font-weight:800}
html[lang="ar"] .navbar,html[lang="ar"] .btn,html[lang="ar"] .eyebrow,
html[lang="ar"] .breadcrumb,html[lang="ar"] .navbar-nav,html[lang="ar"] .card__kicker{
  font-family:var(--font-ar);letter-spacing:0
}
html[lang="ar"] .btn{font-weight:500;--bs-btn-font-weight:500}
html[lang="ar"] .navbar-nav .nav-link{font-weight:500}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw)}
.section{padding-block:clamp(64px,8vw,116px)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.section--sand{background:var(--sand)}
.section--paper{background:var(--warm-paper)}
.section--navy{background:var(--deep-navy);color:rgba(255,255,255,.84);position:relative;overflow:hidden}
.section--navy h1,.section--navy h2,.section--navy h3,.section--navy h4{color:#fff}
.section--navy p{color:rgba(255,255,255,.78)}

/* Eyebrow label */
.eyebrow{
  display:inline-flex;align-items:center;gap:.65rem;
  font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--deep-gold);margin-bottom:1rem;
}
.eyebrow::before{content:"";inline-size:26px;block-size:1.5px;background:currentColor}
.section--navy .eyebrow,.hero .eyebrow{color:var(--gold-soft)}
[dir="rtl"] .eyebrow{letter-spacing:.04em}

.section-head{max-width:46rem;margin-bottom:clamp(2rem,4vw,3.25rem)}
.section-head.center{margin-inline:auto;text-align:center}
h2.section-title{font-size:clamp(1.75rem,3.4vw,2.6rem)}
.section-head p{font-size:1.12rem;color:var(--text-muted);margin-bottom:0}
.section--navy .section-head p{color:rgba(255,255,255,.74)}

/* ---------- Buttons ---------- */
.btn{--bs-btn-font-weight:600;border-radius:10px;padding:.78rem 1.5rem;font-size:.98rem;
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),color .2s,border-color .2s}
.btn:focus-visible{outline:3px solid var(--brand-gold);outline-offset:3px}
.btn-gold{background:var(--brand-gold);color:var(--deep-navy);border:1px solid var(--brand-gold)}
.btn-gold:hover{background:var(--gold-soft);color:var(--deep-navy);transform:translateY(-2px);box-shadow:0 14px 26px -14px rgba(217,187,44,.75)}
.btn-navy{background:var(--deep-navy);color:#fff;border:1px solid var(--deep-navy)}
.btn-navy:hover{background:var(--brand-navy);color:#fff;transform:translateY(-2px)}
.btn-outline-navy{background:transparent;color:var(--deep-navy);border:1.5px solid var(--border-soft)}
.btn-outline-navy:hover{border-color:var(--deep-navy);background:var(--deep-navy);color:#fff;transform:translateY(-2px)}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.34)}
.btn-outline-light:hover{border-color:var(--gold-soft);color:var(--gold-soft);transform:translateY(-2px)}
.btn-lg{padding:.95rem 1.8rem;font-size:1.05rem}

/* text link with arrow */
.link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);
  font-weight:600;font-size:.96rem;color:var(--deep-navy);text-decoration:none}
.link-arrow .bi{transition:transform .25s var(--ease)}
.link-arrow:hover{color:var(--deep-gold)}
.link-arrow:hover .bi{transform:translateX(4px)}
[dir="rtl"] .link-arrow .bi{transform:scaleX(-1)}
[dir="rtl"] .link-arrow:hover .bi{transform:scaleX(-1) translateX(4px)}

/* ---------- Header / Navbar ---------- */
.site-header{position:fixed;inset-block-start:0;inset-inline:0;z-index:1030;
  transition:background .3s var(--ease),box-shadow .3s var(--ease),padding .3s var(--ease);
  padding-block:.85rem;background:transparent}
.site-header.is-solid{background:rgba(14,26,46,.95);backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--line-on-dark);padding-block:.55rem}
.site-header .navbar{padding:0}
.brand-logo{display:flex;align-items:center}
.brand-logo img{height:46px;width:auto;transition:height .3s var(--ease)}
.site-header.is-solid .brand-logo img{height:40px}
.navbar-nav .nav-link{color:rgba(255,255,255,.84);font-weight:500;font-size:.98rem;
  padding-inline:.85rem;position:relative}
.navbar-nav .nav-link:hover{color:var(--gold-soft)}
.navbar-nav .nav-link.active{color:#fff}
.navbar-nav .nav-link.active::after{content:"";position:absolute;inset-block-end:-4px;inset-inline:.85rem;
  height:2px;background:var(--brand-gold);border-radius:2px}
.nav-lang{color:rgba(255,255,255,.66);font-family:var(--font-display);font-weight:600;font-size:.85rem;
  border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:.4rem .7rem;text-decoration:none;
  transition:.2s;white-space:nowrap}
.nav-lang:hover{color:var(--gold-soft);border-color:var(--gold-soft)}
.navbar-toggler{border:1px solid rgba(255,255,255,.3);padding:.35rem .55rem}
.navbar-toggler:focus{box-shadow:0 0 0 3px rgba(217,187,44,.5)}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.9)' stroke-width='2.2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}
@media (max-width:991.98px){
  .site-header{background:rgba(14,26,46,.97)}
  .navbar-collapse{background:rgba(14,26,46,.99);margin-top:.6rem;border-radius:12px;
    padding:1rem 1.1rem;border:1px solid var(--line-on-dark)}
  .navbar-nav .nav-link{padding-block:.55rem}
  .navbar-nav .nav-link.active::after{display:none}
  .nav-lang{display:inline-block;margin-top:.5rem}
  .header-cta{margin-top:.5rem}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--deep-navy);color:#fff;overflow:hidden;
  padding-block:clamp(140px,17vw,196px) clamp(70px,9vw,108px)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;opacity:.30}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,rgba(14,26,46,.96) 38%,rgba(18,42,82,.78) 70%,rgba(18,42,82,.55) 100%)}
[dir="rtl"] .hero::after{background:linear-gradient(255deg,rgba(14,26,46,.96) 38%,rgba(18,42,82,.78) 70%,rgba(18,42,82,.55) 100%)}
.hero__inner{position:relative;z-index:2}
.hero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.9rem);line-height:1.04;margin-bottom:1.1rem;max-width:15ch}
.hero__lede{font-size:1.2rem;color:rgba(255,255,255,.82);max-width:40rem;line-height:1.65}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.hero--inner{padding-block:clamp(132px,15vw,168px) clamp(48px,6vw,72px)}
.hero--inner h1{font-size:clamp(2rem,4.2vw,3.1rem)}

/* arch motif */
.arch-motif{position:absolute;z-index:1;pointer-events:none;opacity:.5}
.arch-motif--hero{inset-inline-end:-40px;inset-block-start:64px;width:min(46%,520px)}
[dir="rtl"] .arch-motif--hero{transform:scaleX(-1)}
.section--navy .arch-motif{inset-inline-start:-60px;inset-block-end:-40px;width:min(40%,440px);opacity:.3}

/* ---------- Cards: services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem}
.svc-card{background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);
  padding:2rem 1.7rem;display:flex;flex-direction:column;height:100%;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card);border-color:transparent}
.svc-card__icon{inline-size:54px;block-size:54px;border-radius:12px;background:var(--sand);
  color:var(--deep-navy);display:grid;place-items:center;margin-bottom:1.25rem;font-size:1.5rem;transition:.3s}
.svc-card:hover .svc-card__icon{background:var(--deep-navy);color:var(--gold-soft)}
.card__kicker{font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--deep-gold)}
.svc-card h3{font-size:1.28rem;margin:.4rem 0 .55rem}
.svc-card p{color:var(--text-muted);font-size:1rem;margin-bottom:1rem;flex-grow:1}
.svc-card .link-arrow{margin-top:auto}
[dir="rtl"] .card__kicker{letter-spacing:.02em}

/* feature list with gold ticks */
.tick-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.7rem}
.tick-list li{position:relative;padding-inline-start:1.7rem;color:var(--text-dark);font-size:1.02rem}
.tick-list li::before{content:"\F26E";font-family:"bootstrap-icons";position:absolute;
  inset-inline-start:0;inset-block-start:.05em;color:var(--brand-gold);font-size:1.05rem}
/* fix: tick-list on dark (navy) backgrounds — explicit override for the dark-section variant */
.section--navy .tick-list li{color:rgba(255,255,255,.82)}

/* ---------- Project cards ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.proj-card{position:relative;display:block;border-radius:var(--radius);overflow:hidden;
  background:var(--deep-navy);text-decoration:none;box-shadow:var(--shadow-soft);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.proj-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card)}
.proj-card__img{aspect-ratio:4/3;width:100%}
.proj-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.proj-card:hover .proj-card__img img{transform:scale(1.05)}
.proj-card__panel{aspect-ratio:4/3;width:100%;display:grid;place-items:center;
  background:linear-gradient(140deg,var(--deep-navy),var(--brand-navy));color:var(--gold-soft);font-size:2.4rem}
.proj-card__body{position:absolute;inset-block-end:0;inset-inline:0;padding:1.5rem 1.3rem 1.2rem;
  background:linear-gradient(to top,rgba(8,18,34,.92),rgba(8,18,34,.35) 65%,transparent);
  color:#fff}
.proj-card__cat{font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.13em;
  text-transform:uppercase;color:var(--gold-soft)}
.proj-card__name{font-family:var(--font-display);font-weight:700;font-size:1.22rem;color:#fff;margin:.25rem 0 0;line-height:1.2}
.proj-card__loc{font-size:.9rem;color:rgba(255,255,255,.72);margin-top:.2rem}
[dir="rtl"] .proj-card__cat{letter-spacing:.03em}

/* ---------- Approach / steps ---------- */
.steps{display:grid;gap:0}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;padding-block:1.5rem;
  border-top:1px solid var(--line-on-dark)}
.step:last-child{border-bottom:1px solid var(--line-on-dark)}
.step__no{font-family:var(--font-display);font-weight:700;color:var(--brand-gold);font-size:1rem;padding-top:.15rem}
.step h4{color:#fff;font-size:1.18rem;margin-bottom:.3rem}
.step p{color:rgba(255,255,255,.7);margin:0;font-size:1rem}

/* ---------- Stat / value tiles (no numbers — qualitative) ---------- */
.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.3rem}
.value-tile{background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);padding:1.7rem}
.value-tile .bi{font-size:1.7rem;color:var(--brand-navy);margin-bottom:.7rem}
.value-tile h3{font-size:1.12rem;margin-bottom:.4rem}
.value-tile p{color:var(--text-muted);font-size:.98rem;margin:0}

/* ---------- Media + text split ---------- */
.media-frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);
  border:1px solid var(--border-soft)}
.media-frame img{display:block;width:100%}

/* ---------- Detail hero (service/project) ---------- */
.detail-hero{background:var(--deep-navy);color:#fff;position:relative;overflow:hidden}
.detail-hero__media{position:absolute;inset:0}
.detail-hero__media img{width:100%;height:100%;object-fit:cover;opacity:.34}
.detail-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(14,26,46,.95),rgba(18,42,82,.62))}
.detail-hero .container{position:relative;z-index:2}
.detail-hero,.detail-hero h1,.detail-hero h2,.detail-hero h3,.detail-hero p{color:#fff}
.detail-hero .hero__lede{color:rgba(255,255,255,.86)}
[dir="rtl"] .detail-hero::after{background:linear-gradient(260deg,rgba(14,26,46,.95),rgba(18,42,82,.62))}

/* ---------- Breadcrumb ---------- */
.crumb{--bs-breadcrumb-divider:none;font-family:var(--font-display);font-size:.86rem;margin:0}
.crumb .breadcrumb-item{display:flex;align-items:center}
.crumb .breadcrumb-item+.breadcrumb-item::before{content:"\F285";font-family:"bootstrap-icons";
  color:rgba(255,255,255,.45);padding-inline:.55rem;font-size:.7rem}
[dir="rtl"] .crumb .breadcrumb-item+.breadcrumb-item::before{content:"\F284"}
.crumb a{color:rgba(255,255,255,.7);text-decoration:none}
.crumb a:hover{color:var(--gold-soft)}
.crumb .active{color:#fff}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.gallery button{padding:0;border:0;background:none;border-radius:12px;overflow:hidden;cursor:pointer;
  box-shadow:var(--shadow-soft);transition:transform .3s var(--ease)}
.gallery button:hover{transform:translateY(-3px)}
.gallery button:focus-visible{outline:3px solid var(--brand-gold);outline-offset:3px}
.gallery img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:1080;background:rgba(8,16,30,.92);display:none;
  align-items:center;justify-content:center;padding:5vw}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:90vh;border-radius:8px;box-shadow:0 30px 80px -20px #000}
.lightbox__close{position:absolute;inset-block-start:1.2rem;inset-inline-end:1.4rem;background:none;border:0;
  color:#fff;font-size:2rem;cursor:pointer;line-height:1}
.lightbox__close:focus-visible{outline:3px solid var(--brand-gold);outline-offset:3px}

/* prev/next nav */
.pn-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.pn-nav a{display:flex;flex-direction:column;gap:.2rem;padding:1.2rem 1.4rem;border:1px solid var(--border-soft);
  border-radius:var(--radius);text-decoration:none;background:#fff;transition:.25s}
.pn-nav a:hover{border-color:var(--deep-navy);transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.pn-nav .pn-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--deep-gold);font-family:var(--font-display);font-weight:600}
.pn-nav .pn-name{font-family:var(--font-display);font-weight:700;color:var(--deep-navy)}
.pn-nav .next{text-align:end}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(140deg,var(--deep-navy),var(--brand-navy));border-radius:22px;
  padding:clamp(2.5rem,5vw,3.8rem);text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff;margin-bottom:.8rem}
.cta-band p{color:rgba(255,255,255,.78);max-width:36rem;margin:0 auto 1.6rem}

/* ---------- Contact ---------- */
.contact-card{background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);padding:1.6rem}
.contact-line{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:1.1rem}
.contact-line .bi{color:var(--brand-navy);font-size:1.25rem;margin-top:.15rem}
.contact-line .label{font-family:var(--font-display);font-weight:600;color:var(--deep-navy);font-size:.95rem}
.contact-line .val{color:var(--text-muted);font-size:1rem}
.form-label{font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--deep-navy)}
.form-control,.form-select{border:1px solid var(--border-soft);border-radius:10px;padding:.7rem .9rem;background:var(--warm-paper)}
.form-control:focus,.form-select:focus{border-color:var(--brand-navy);box-shadow:0 0 0 3px rgba(37,68,133,.16)}
.req{color:var(--deep-gold)}
.map-placeholder{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border-soft);
  background:repeating-linear-gradient(45deg,var(--sand),var(--sand) 14px,#efe8d8 14px,#efe8d8 28px);
  min-height:240px;display:grid;place-items:center;text-align:center;color:var(--text-muted);padding:1.5rem}
.form-note{font-size:.95rem;border-radius:10px;padding:.9rem 1.1rem;display:none}
.form-note.show{display:block}
.form-note--info{background:#eef3fb;border:1px solid #cbd9f0;color:#1f3a6b}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.66);padding-block:clamp(3rem,5vw,4rem) 1.6rem}
.site-footer h5{font-family:var(--font-display);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand-gold);margin-bottom:1.1rem}
[dir="rtl"] .site-footer h5{letter-spacing:.03em}
.site-footer a{color:rgba(255,255,255,.66);text-decoration:none;display:inline-block;margin-bottom:.55rem;transition:.2s}
.site-footer a:hover{color:var(--gold-soft)}
.footer-logo{height:50px;width:auto;margin-bottom:1rem}
.footer-blurb{font-size:.98rem;color:rgba(255,255,255,.55);max-width:24rem;line-height:1.7}
.footer-contact .bi{color:var(--brand-gold);margin-inline-end:.5rem}
.footer-bottom{border-top:1px solid var(--line-on-dark);margin-top:2.4rem;padding-top:1.4rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.86rem;color:rgba(255,255,255,.45);
  font-family:var(--font-display)}
.footer-bottom a{margin:0}
/* Fix: p{color:var(--text-dark)} overrides inherited footer color — make footer paragraphs explicitly light */
.site-footer p{color:rgba(255,255,255,.72)}
.footer-blurb{color:rgba(255,255,255,.62)!important}

/* ---------- Skip link & focus ---------- */
.skip-link{position:absolute;inset-inline-start:-999px;inset-block-start:0;z-index:2000;background:var(--brand-gold);
  color:var(--deep-navy);padding:.7rem 1.1rem;border-radius:0 0 8px 0;font-family:var(--font-display);font-weight:600}
.skip-link:focus{inset-inline-start:0}
:focus-visible{outline:3px solid var(--brand-gold);outline-offset:2px;border-radius:3px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Utilities ---------- */
.text-gold{color:var(--brand-gold)!important}
.bg-sand{background:var(--sand)!important}
.fact-pills{display:flex;gap:.6rem;flex-wrap:wrap;margin:.1rem 0 1.2rem}
.fact-pill{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-display);font-weight:600;
  font-size:.86rem;color:var(--deep-navy);background:var(--sand);border:1px solid var(--border-soft);
  border-radius:999px;padding:.4rem .85rem}
.fact-pill .bi{color:var(--deep-gold)}
.fact-pills--dark{margin-top:1.4rem}
.fact-pills--dark .fact-pill{color:#fff;background:rgba(255,255,255,.08);border-color:var(--line-on-dark)}
.fact-pills--dark .fact-pill .bi{color:var(--gold-soft)}
.rule-gold{width:54px;height:3px;background:var(--brand-gold);border-radius:3px;border:0;opacity:1;margin:0 0 1.3rem}
.section-head.center .rule-gold{margin-inline:auto}
.lead{font-family:var(--font-body);font-size:1.2rem;color:var(--text-muted)}
[dir="rtl"] .lead{font-family:var(--font-ar)}

/* ---------- Project card gallery cue ---------- */
.proj-card__gallery{display:inline-flex;align-items:center;gap:.4rem;margin-top:.55rem;
  font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--gold-soft);
  background:rgba(8,18,34,.55);border:1px solid rgba(217,187,44,.4);border-radius:999px;
  padding:.25rem .7rem;backdrop-filter:blur(2px)}
.proj-card__gallery .bi{font-size:.9rem}

/* ---------- Project gallery carousel ---------- */
.gallery-wrap{max-width:980px}
.gallery-carousel{position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);background:var(--deep-navy)}
.gallery-carousel:focus-visible{outline:3px solid var(--brand-gold);outline-offset:3px}
.gallery-carousel .carousel-item img{display:block;width:100%;aspect-ratio:3/2;object-fit:cover;cursor:zoom-in}
@media (max-width:575.98px){.gallery-carousel .carousel-item img{aspect-ratio:4/3}}
/* custom control circles, visible on light or dark images */
.gal-ctrl{width:auto;opacity:1}
.gal-ctrl .gal-ctrl__circle{display:grid;place-items:center;width:50px;height:50px;border-radius:50%;
  background:rgba(14,26,46,.62);border:1.5px solid rgba(255,255,255,.5);color:#fff;font-size:1.3rem;
  transition:background .2s,transform .2s,border-color .2s;backdrop-filter:blur(3px)}
.gal-ctrl:hover .gal-ctrl__circle{background:var(--deep-navy);border-color:var(--brand-gold);color:var(--gold-soft);transform:scale(1.06)}
.gal-ctrl:focus-visible .gal-ctrl__circle{outline:3px solid var(--brand-gold);outline-offset:2px}
[dir="rtl"] .gal-ctrl .bi{transform:scaleX(-1)}
/* slide counter */
.gal-counter{position:absolute;inset-block-end:.8rem;inset-inline-end:.9rem;z-index:5;
  font-family:var(--font-display);font-weight:600;font-size:.82rem;color:#fff;
  background:rgba(14,26,46,.7);border:1px solid var(--line-on-dark);border-radius:999px;
  padding:.25rem .75rem;backdrop-filter:blur(3px)}
/* thumbnail strip */
.gal-thumbs{display:flex;gap:.6rem;margin-top:.9rem;overflow-x:auto;padding-bottom:.4rem;scrollbar-width:thin}
.gal-thumb{flex:0 0 auto;width:104px;height:70px;padding:0;border:2px solid transparent;border-radius:10px;
  overflow:hidden;background:none;cursor:pointer;opacity:.62;transition:opacity .2s,border-color .2s,transform .2s}
.gal-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.gal-thumb:hover{opacity:1;transform:translateY(-2px)}
.gal-thumb.active{opacity:1;border-color:var(--brand-gold)}
.gal-thumb:focus-visible{outline:3px solid var(--brand-gold);outline-offset:2px}
/* single-image presentation (no carousel) */
.gallery-single{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);background:var(--deep-navy);max-width:980px}
.gallery-single img{display:block;width:100%;aspect-ratio:3/2;object-fit:cover;cursor:zoom-in}
/* branded panel (no public-safe photos) */
.gallery-panel{max-width:980px;border-radius:var(--radius);background:linear-gradient(140deg,var(--deep-navy),var(--brand-navy));
  color:rgba(255,255,255,.8);padding:clamp(2.2rem,5vw,3.4rem);text-align:center}
.gallery-panel .bi{font-size:2.4rem;color:var(--gold-soft)}
.gallery-panel p{color:rgba(255,255,255,.78);max-width:34rem;margin:.8rem auto 0}

/* ---------- Lightbox prev/next ---------- */
.lightbox__nav{position:absolute;inset-block-start:50%;transform:translateY(-50%);z-index:1090;
  display:grid;place-items:center;width:54px;height:54px;border-radius:50%;border:1.5px solid rgba(255,255,255,.45);
  background:rgba(14,26,46,.55);color:#fff;font-size:1.5rem;cursor:pointer;transition:.2s}
.lightbox__nav:hover{background:var(--deep-navy);border-color:var(--brand-gold);color:var(--gold-soft)}
.lightbox__nav:focus-visible{outline:3px solid var(--brand-gold);outline-offset:2px}
.lightbox__prev{inset-inline-start:3vw}
.lightbox__next{inset-inline-end:3vw}
[dir="rtl"] .lightbox__nav .bi{transform:scaleX(-1)}
.lightbox__counter{position:absolute;inset-block-end:3vh;inset-inline:0;text-align:center;z-index:1090;
  font-family:var(--font-display);font-weight:600;color:rgba(255,255,255,.9);font-size:.95rem}
.lightbox figure{margin:0;display:grid;place-items:center}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .carousel-item{transition:none!important}
}
