:root{--bg:#f5f5f7;--bg-alt:#ffffff;--text:#111827;--text-soft:#4b5563;--accent:#2563eb;--accent-soft:rgba(37,99,235,.08);--border-subtle:#e5e7eb;--border-strong:#d1d5db;--radius-pill:999px}
body.dark-theme{--bg:#020617;--bg-alt:#020617;--text:#e5e7eb;--text-soft:#9ca3af;--accent:#3b82f6;--accent-soft:rgba(59,130,246,.22);--accent-strong:#60a5fa;--pill-bg:#020617;--pill-border:#3b82f6;--border-subtle:#1f2937;--border-strong:#4b5563;}
body.high-contrast{--bg:#000000;--bg-alt:#000000;--text:#ffffff;--text-soft:#e5e7eb;--accent:#38bdf8;--accent-soft:rgba(56,189,248,.35);--accent-strong:#eab308;--pill-bg:#000000;--pill-border:#eab308;--border-subtle:#ffffff;--border-strong:#ffffff;}
body.text-large{font-size:18.5px}
body.text-xlarge{font-size:21px}
*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at top,#e5edff 0,var(--bg) 34%,var(--bg) 100%);color:var(--text);line-height:1.6;font-size:16px}
a{color:var(--accent);text-decoration:none}
body.links-underlined a{text-decoration:underline}
a:hover{text-decoration:underline}
.skip-link{position:absolute;left:-999px;top:.5rem;padding:.4rem .7rem;background:#111827;color:#f9fafb;z-index:100;border-radius:4px;font-size:.85rem}
.skip-link:focus{left:.5rem}
body.reduce-motion *{animation:none!important;transition:none!important}
.page-wrapper{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
.site-header{position:sticky;top:0;z-index:40;border-bottom:1px solid rgba(148,163,184,.28);backdrop-filter:blur(16px);background:rgba(248,250,252,.95)}
body.dark-theme .site-header{background:rgba(15,23,42,.96)}
.inner-header{max-width:980px;margin:0 auto;padding:.55rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:inline-flex;align-items:center;gap:.65rem;text-decoration:none}
.brand-mark{width:32px;height:32px;border-radius:50%;background:radial-gradient(circle at 30% 15%,#60a5fa,#2563eb);color:#f9fafb;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.85rem}
.brand-text{display:flex;flex-direction:column}
.brand-name{font-weight:600;font-size:.98rem;letter-spacing:.02em}
.brand-subtle{font-size:.78rem;color:var(--text-soft)}
.nav{display:flex;align-items:center;gap:.55rem;font-size:.86rem}
.nav-link{padding:.3rem .8rem;border-radius:var(--radius-pill);color:var(--text-soft);transition:background .16s,color .16s,transform .12s}
.nav-link:hover,.nav-link:focus-visible{background:rgba(148,163,184,.18);color:var(--text);transform:translateY(-1px)}
.header-actions{position:relative;margin-left:1.5rem}
.a11y-button{border-radius:var(--radius-pill);border:1px solid var(--border-subtle);padding:.3rem .8rem;font-size:.78rem;background:transparent;color:var(--text-soft);cursor:pointer;transition:background .16s,border-color .16s}
.a11y-button:hover{background:rgba(148,163,184,.16);border-color:var(--border-strong)}
.a11y-panel{position:absolute;right:0;margin-top:.4rem;padding:.75rem .9rem;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg-alt);box-shadow:0 16px 40px rgba(15,23,42,.12);min-width:260px;font-size:.82rem;display:none}
.a11y-panel.open{display:block}
.a11y-group{margin-bottom:.6rem;display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}
.a11y-label{font-weight:500;margin-right:.3rem;white-space:nowrap}
.a11y-group-display{flex-wrap:nowrap}
.a11y-chip{border-radius:var(--radius-pill);border:1px solid var(--border-subtle);padding:.2rem .55rem;background:transparent;cursor:pointer;font-size:.78rem;color:var(--text-soft);transition:background .16s,border-color .16s,color .16s,transform .12s}
.a11y-chip.active{background:var(--accent);border-color:var(--accent);color:#f9fafb}
.a11y-chip:hover{background:rgba(148,163,184,.16);transform:translateY(-1px)}
.a11y-toggle{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;color:var(--text-soft)}
.hero{border-bottom:1px solid rgba(148,163,184,.24)}
.hero-inner{max-width:980px;margin:0 auto;padding:2.6rem 1.5rem 3rem;display:grid;grid-template-columns:auto minmax(0,1fr);gap:1.8rem;align-items:center}
.hero-avatar-wrap{display:flex;justify-content:flex-start}
.hero-avatar-frame{width:160px;height:160px;border-radius:32px;background:radial-gradient(circle at 0 0,rgba(37,99,235,.25),transparent 60%);padding:6px;box-shadow:0 22px 40px rgba(15,23,42,.25);display:flex;align-items:center;justify-content:center}
.hero-avatar-img{width:100%;height:100%;border-radius:26px;object-fit:cover;background:#111827}
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;color:var(--text-soft);margin-bottom:.4rem}
.hero-title{font-size:clamp(2.1rem,3vw,2.6rem);line-height:1.15;margin:0 0 .8rem}
.highlight{background:linear-gradient(120deg,#2563eb,#22c1c3);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-subtitle{font-size:.96rem;color:var(--text-soft);margin-bottom:1.3rem;max-width:32rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.7rem}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.3rem;border-radius:999px;border:1px solid transparent;font-size:.86rem;font-weight:500;cursor:pointer;text-decoration:none;transition:background .16s,color .16s,border-color .16s,transform .14s}
.primary-btn{background:var(--accent);color:#f9fafb;box-shadow:none}
.primary-btn:hover{transform:translateY(-1px);background:#1d4ed8}
.ghost-btn{background:transparent;color:var(--text);border-color:rgba(148,163,184,.8);box-shadow:none}
.ghost-btn:hover{background:rgba(148,163,184,.15)}
.animate-hero{animation:heroIntro .9s ease-out forwards;transform-origin:top center;opacity:0}
.bounce-on-load{animation:bounceIn 900ms ease-out 500ms both}
@keyframes heroIntro{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes bounceIn{0%{transform:translateY(10px);opacity:0}60%{transform:translateY(-4px);opacity:1}100%{transform:translateY(0)}}
.section{max-width:980px;margin:0 auto;padding:2.2rem 1.5rem 2.4rem}
.section-header{margin-bottom:1.5rem}
.section-header h1,.section-header h2{margin:0 0 .3rem;font-size:1.4rem}
.section-header p{margin:0;font-size:.95rem;color:var(--text-soft)}
.home-quick-links{margin:1.3rem 0 0;display:flex;flex-wrap:wrap;gap:.6rem}
.chip-link{display:inline-flex;align-items:center;justify-content:center;padding:.4rem .9rem;border-radius:999px;border:1px solid rgba(148,163,184,.7);font-size:.82rem;color:var(--text-soft);background:rgba(255,255,255,.7);backdrop-filter:blur(6px);transition:background .16s,border-color .16s,transform .12s,box-shadow .12s}
.chip-link:hover{background:var(--accent);border-color:var(--accent);color:#f9fafb;text-decoration:none;transform:translateY(-1px);box-shadow:0 12px 30px rgba(37,99,235,.35)}
.chip-animated{animation:chipPulse 8s ease-in-out infinite alternate}
@keyframes chipPulse{0%{box-shadow:0 0 0 rgba(37,99,235,0)}100%{box-shadow:0 0 28px rgba(37,99,235,.2)}}
.business-card{background:var(--bg-alt);border-radius:18px;padding:1.8rem 1.8rem 1.4rem;border:1px solid rgba(148,163,184,.32);box-shadow:0 18px 45px rgba(15,23,42,.12);position:relative;overflow:hidden}
.business-card:before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at 0 0,rgba(37,99,235,.25),transparent 55%),radial-gradient(circle at 100% 100%,rgba(56,189,248,.22),transparent 60%);opacity:.7;pointer-events:none}
.business-card h2{margin-top:.4rem;margin-bottom:.4rem;position:relative}
.business-card p,.business-card ul{position:relative}
.business-card-centered{text-align:center}
.business-logo{width:96px;height:auto;object-fit:contain;position:relative;margin:0 auto .3rem}
.business-points{margin:.4rem 0 0;padding-left:1.1rem;font-size:.9rem;color:var(--text-soft);text-align:left;display:inline-block}
.business-actions{margin-top:1rem;position:relative}
.business-actions-centered{display:flex;justify-content:center}
.timeline{position:relative;padding-left:1.25rem}
.timeline:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,rgba(148,163,184,.9),transparent 80%)}
.timeline-item{position:relative;margin-bottom:1.35rem;padding-left:2.25rem}
.timeline-dot{position:absolute;left:0;top:.7rem;width:10px;height:10px;border-radius:50%;border:2px solid var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.timeline-content{font-size:.9rem;padding-bottom:.8rem;border-bottom:1px dashed rgba(148,163,184,.5);transition:transform .18s,box-shadow .18s;background:transparent;border-radius:8px}

.timeline-role{font-weight:600;margin-bottom:.1rem}
.timeline-meta{font-size:.78rem;color:var(--text-soft);margin-bottom:.35rem}
.timeline-description{font-size:.88rem;color:var(--text-soft)}
.timeline-tags{margin-top:.35rem;display:flex;flex-wrap:wrap;gap:.3rem}
.tag{font-size:.74rem;padding:.12rem .55rem;border-radius:999px;border:1px solid rgba(148,163,184,.7)}
.cv-cta-wrapper{margin-top:1.4rem;display:flex;justify-content:flex-start}
.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem}
.project-card{background:var(--bg-alt);border-radius:16px;border:1px solid rgba(148,163,184,.3);padding:1rem 1rem 0.9rem;cursor:pointer;transition:transform .16s,box-shadow .16s,border-color .16s}
.project-card:hover{transform:translateY(-4px);box-shadow:0 18px 45px rgba(15,23,42,.18);border-color:var(--accent-soft)}
.project-header{display:flex;flex-direction:column;gap:.15rem}
.project-title{font-weight:600}
.project-meta{font-size:.8rem;color:var(--text-soft)}
.project-summary{font-size:.88rem;color:var(--text-soft);margin-top:.35rem}
.project-extra{margin-top:.7rem;border-top:1px solid rgba(148,163,184,.25);padding-top:.7rem;max-height:0;opacity:0;transform:translateY(4px);transition:max-height .3s ease,opacity .3s ease,transform .3s ease;overflow:hidden}
.project-card.expanded .project-extra{max-height:520px;opacity:1;transform:translateY(0)}
.project-gallery{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.6rem}
.project-frame{border-radius:12px;border:1px solid rgba(148,163,184,.3);background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(56,189,248,.05));height:180px;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--text-soft);overflow:hidden}
.project-frame img{max-width:100%;max-height:100%;display:block}
.project-gallery-controls{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--text-soft)}
.gallery-buttons{display:flex;gap:.4rem}
.gallery-btn{border-radius:999px;border:1px solid var(--border-subtle);background:rgba(255,255,255,.9);padding:.2rem .6rem;font-size:.76rem;cursor:pointer;transition:background .14s,border-color .14s,transform .12s}
.gallery-btn:hover{background:var(--accent);border-color:var(--accent);color:#f9fafb;transform:translateY(-1px)}
.project-links{font-size:.8rem}
.article-section{margin-top:2rem}
.subsection-header h2{margin:0 0 .25rem;font-size:1.2rem}
.subsection-header p{margin:0;font-size:.9rem;color:var(--text-soft)}
.article-card-grid{--cards-per-view:3;--card-gap:1rem;margin-top:.9rem;display:flex;flex-wrap:nowrap;gap:var(--card-gap);overflow:hidden;scroll-behavior:smooth;scroll-snap-type:x mandatory;}
.article-card{background:var(--bg-alt);border-radius:14px;border:1px solid var(--border-subtle);padding:1.1rem 1.1rem 1.05rem;cursor:pointer;display:flex;flex-direction:column;gap:.4rem;flex:0 0 calc((100% - (var(--cards-per-view) - 1)*var(--card-gap))/var(--cards-per-view));max-width:calc((100% - (var(--cards-per-view) - 1)*var(--card-gap))/var(--cards-per-view));box-shadow:0 10px 30px rgba(15,23,42,.06);transition:transform .16s,box-shadow .16s,border-color .16s;scroll-snap-align:start;}
.article-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(15,23,42,.15);border-color:var(--accent-soft)}
.article-card-header{display:flex;flex-direction:column;gap:.1rem}
.article-title{margin:0;font-size:.96rem}
.article-meta{font-size:.8rem;color:var(--text-soft)}
.article-teaser{font-size:.86rem;color:var(--text-soft);margin-top:.25rem}
.overlay-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;z-index:60;opacity:0;pointer-events:none;transition:opacity .2s ease-out}
.overlay-backdrop.open{opacity:1;pointer-events:auto}
.overlay-panel{background:var(--bg-alt);max-width:960px;width:92%;max-height:86vh;border-radius:22px;border:1px solid rgba(148,163,184,.5);box-shadow:0 28px 80px rgba(0,0,0,.35);padding:1.4rem 1.6rem 1.2rem;position:relative;overflow:hidden;display:flex;flex-direction:column}
.overlay-body{overflow:auto;padding-right:.2rem;margin-top:.4rem}
.overlay-header h2{margin:.1rem 0 .1rem;font-size:1.3rem}
.overlay-header p{margin:0;font-size:.86rem;color:var(--text-soft)}
.overlay-close{position:absolute;top:.6rem;right:.7rem;border-radius:999px;border:1px solid var(--border-subtle);background:rgba(0,0,0,0.02);width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer}
.overlay-close:hover{background:rgba(148,163,184,.18)}
.overlay-article-text{font-size:.9rem;color:var(--text-soft);margin-top:.7rem}
.cv-form-grid{display:flex;flex-direction:column;gap:.8rem;font-size:.88rem;color:var(--text-soft)}
.cv-form-row{display:flex;gap:.8rem;flex-wrap:wrap}
.cv-form-field{flex:1;display:flex;flex-direction:column;gap:.25rem}
.cv-form-field label{font-weight:500;font-size:.84rem}
.cv-form-field input,.cv-form-field textarea{border-radius:10px;border:1px solid var(--border-subtle);padding:.5rem .65rem;font-family:inherit;font-size:.86rem;background:rgba(255,255,255,.95);color:var(--text);outline:none;transition:border-color .14s,box-shadow .14s,background .14s}
.cv-form-field input:focus,.cv-form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);background:#fff}
.cv-form-field textarea{resize:vertical;min-height:90px}
.cv-form-footer{margin-top:.6rem;display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}
.cv-form-footer small{font-size:.76rem;color:var(--text-soft)}
.contact-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:1.6rem}
.contact-column h2{margin-top:0;margin-bottom:.4rem;font-size:1rem}
.contact-column p{font-size:.9rem;color:var(--text-soft)}
.contact-layout-form{align-items:flex-start}
.contact-form-card{background:var(--bg-alt);border-radius:18px;padding:1.5rem 1.6rem 1.4rem;border:1px solid rgba(148,163,184,.3);box-shadow:0 18px 45px rgba(15,23,42,.12);display:flex;flex-direction:column;gap:1rem;position:relative;overflow:hidden}
.contact-form-card:before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at 0 0,rgba(37,99,235,.18),transparent 55%),radial-gradient(circle at 100% 100%,rgba(56,189,248,.16),transparent 60%);opacity:.6;pointer-events:none}
.contact-form-card>*{position:relative}
.contact-form-header h2{margin:0 0 .25rem;font-size:1.1rem}
.contact-form-header p{margin:0;font-size:.88rem;color:var(--text-soft)}
.form-row{display:flex;gap:.85rem;flex-wrap:wrap}
.form-field{flex:1;display:flex;flex-direction:column;gap:.25rem;font-size:.86rem}
.form-field label{font-weight:500}
.form-field input,.form-field select,.form-field textarea{border-radius:10px;border:1px solid var(--border-subtle);padding:.55rem .7rem;font-family:inherit;font-size:.86rem;background:rgba(255,255,255,.9);color:var(--text);outline:none;transition:border-color .14s,box-shadow .14s,background .14s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);background:#fff}
.form-field textarea{resize:vertical;min-height:140px}
.form-footer{margin-top:.3rem;display:flex;align-items:center;justify-content:space-between;gap:.9rem;flex-wrap:wrap}
.form-hint{font-size:.78rem;color:var(--text-soft)}
.form-submit-btn{padding-inline:1.4rem}
.site-footer{padding:1.6rem 1.5rem 1.8rem;font-size:.85rem;color:var(--text-soft);border-top:1px solid rgba(148,163,184,.3);}
.footer-links{display:flex;align-items:center;gap:.45rem;font-size:.82rem}
.footer-links a{color:var(--text-soft)}
.footer-links a:hover{color:var(--accent)}
.fade-in-on-scroll{opacity:0;transform:translateY(24px);transition:opacity .6s ease-out,transform .6s ease-out;transition-delay:var(--stagger-delay,0s)}
.fade-in-on-scroll.visible{opacity:1;transform:translateY(0)}
@media (max-width:920px){.hero-inner{grid-template-columns:minmax(0,1fr);gap:1.8rem}.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.article-card-grid{--cards-per-view:3;--card-gap:1rem;margin-top:.9rem;display:flex;flex-wrap:nowrap;gap:var(--card-gap);overflow:hidden;scroll-behavior:smooth;scroll-snap-type:x mandatory;}}
@media (max-width:760px){.inner-header{flex-wrap:wrap;justify-content:space-between;row-gap:.4rem}.nav{order:3;width:100%;justify-content:center;flex-wrap:wrap}.header-actions{order:2}.brand-subtle{display:none}.projects-grid{grid-template-columns:minmax(0,1fr)}.form-footer,.cv-form-footer{flex-direction:column;align-items:flex-start}}
@media (max-width:480px){.inner-header{padding-inline:1rem}.section,.hero-inner{padding-inline:1rem}.contact-form-card{padding:1.3rem 1.2rem}.overlay-panel{padding:1.1rem 1.1rem}}

/* Custom additions for centred home summary and project cards */

.home-summary {
    text-align: center;
}
.home-summary-inner {
    max-width: 640px;
    margin: 0 auto;
}
.home-summary-inner > p {
    font-size: 0.95rem;
    color: var(--text-soft);
}
.home-summary .home-quick-links {
    justify-content: center;
    flex-wrap: nowrap;
    overflow-x: auto;
}

.projects-feature-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
}

.projects-card {
    text-align: center;
}

.projects-card-title {
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

.projects-card-logo {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 1.1rem;
    margin-bottom: 0.3rem;
    color: #f9fafb;
}

.projects-card-logo-riyst {
    background: linear-gradient(135deg, #22c55e, #16a34a);
}

.projects-card-logo-churchfinder {
    background: linear-gradient(135deg, #eab308, #f97316);
}

body.reduce-motion .animate-hero{opacity:1;}

/* Dark theme background tweak to remove bright glare */

body.dark-theme{--bg:#020617;--bg-alt:#020617;--text:#e5e7eb;--text-soft:#9ca3af;--accent:#3b82f6;--accent-soft:rgba(59,130,246,.22);--accent-strong:#60a5fa;--pill-bg:#020617;--pill-border:#3b82f6;--border-subtle:#1f2937;--border-strong:#4b5563;}

/* Ensure colourblind mode in dark theme keeps the same dark background */
body.dark-theme.cb-mode{
    background:radial-gradient(circle at top,#020b3b 0,#020617 45%,#020617 100%);
}

/* Additional accessibility modes */

body.cb-mode{
    --accent:#0ea5e9;
    --accent-soft:rgba(14,165,233,.25);
}
body.strong-focus *:focus-visible{
    outline:3px solid var(--accent);
    outline-offset:3px;
}


.a11y-group-color {
    flex-wrap: nowrap;
}
.a11y-group-color .a11y-chip {
    flex-shrink: 0;
}


/* Home hero: remove divider line under hero */
.hero{
    border-bottom:none;
}

/* Timeline spacing: make entries larger so they reveal as you scroll */
.timeline{
    margin-top:1.6rem;
    padding-left:1.6rem;
}
.timeline-item{position:relative;margin-bottom:1.35rem;padding-left:2.25rem}
.timeline-content{
    font-size:0.95rem;
    padding:1.05rem 1.05rem 1.1rem;
}
.timeline-item:hover .timeline-content{
    transform:none;
    box-shadow:none;
}


/* Layout tweak: keep brand + nav on the left, accessibility on far right */
.inner-header{
    justify-content:flex-start;
}
.header-actions{
    margin-left:auto;
}

.footer-inner{max-width:980px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.site-footer .footer-main{margin:0;}
.footer-social{display:flex;align-items:center;gap:.5rem;}
.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;border:1.5px solid var(--accent);color:var(--accent);text-decoration:none;font-size:.9rem;font-weight:600;line-height:1;background:transparent;}
.footer-social-link span{display:inline-block;line-height:1;}
.footer-social-link:hover{background:rgba(37,99,235,.03);}
@media (max-width:640px){
  .footer-inner{flex-direction:column;align-items:flex-start;}
}

.nav-link.is-current{background:rgba(37,99,235,.1);color:var(--accent);font-weight:600;}

.article-card-grid::-webkit-scrollbar{display:none;}
.article-card-grid{--cards-per-view:3;--card-gap:1rem;margin-top:.9rem;display:flex;flex-wrap:nowrap;gap:var(--card-gap);overflow:hidden;scroll-behavior:smooth;scroll-snap-type:x mandatory;}

.article-carousel{margin-top:.9rem;position:relative;}
.article-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);border-radius:999px;border:1px solid var(--border-subtle);background:var(--bg-alt);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-soft);cursor:pointer;transition:background .16s,border-color .16s,color .16s;}
.article-scroll-prev{left:-2.4rem;}
.article-scroll-next{right:-2.4rem;}
.article-scroll-btn:hover{background:rgba(148,163,184,.16);border-color:var(--accent);color:var(--accent);}
.article-scroll-btn:disabled{opacity:.4;cursor:default;}
@media (max-width:640px){
  .article-scroll-prev{left:-2.4rem;}
  .article-scroll-next{right:-2.4rem;}
}

.footer-social-link svg{width:20px;height:20px;}

body.dark-theme .footer-social-link,body.high-contrast .footer-social-link{border-color:var(--accent-strong);}

.footer-social-link:hover{background:var(--accent-soft);border-color:var(--accent-strong);}

.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;border:1.5px solid var(--accent);background:transparent;}
.footer-social-link svg{width:22px;height:22px;display:block;}

.a11y-group{flex-wrap:wrap;}
.a11y-group-color{flex-wrap:wrap;}
.a11y-group-color .a11y-chip{max-width:100%;white-space:nowrap;}
.a11y-panel{max-width:320px;}

.chip-animated{animation:none;}

.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;border:1.5px solid var(--accent);background:transparent;}
.footer-social-link img{width:22px;height:22px;display:block;object-fit:contain;}

.brand-mark-image img{
  width:100%;
  height:100%;
  border-radius:50%;
  display:block;
}

.overlay-panel{max-height:90vh;}
.overlay-body{overflow-y:auto;max-height:72vh;}

/* Article card width override to keep cards compact */
.article-card{
  flex:0 0 320px;
  max-width:320px;
}
@media (max-width: 768px){
  .article-card{
    flex:0 0 85%;
    max-width:85%;
  }
}


@media (min-width: 768px) {
    .projects-feature-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}


.projects-card-logo-roc {
    background: linear-gradient(135deg, #6366f1, #4f46e5);
}


@media (max-width: 640px){
  .home-quick-links{
    justify-content: center;
  }
  .chip-link{
    flex: 0 1 calc(50% - 0.6rem);
    justify-content: center;
    text-align: center;
    padding-inline: 0.6rem;
  }
}


/* ================== Final overlay centering fix ================== */
.overlay-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,0.62);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 60;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease-out;
}

.overlay-backdrop.open{
  opacity: 1;
  pointer-events: auto;
}

.overlay-panel{
  background: var(--bg-alt);
  box-shadow: 0 24px 60px rgba(15,23,42,0.45);
  border-radius: 22px;
  width: calc(100% - 2rem);
  max-width: 640px;
  max-height: calc(100vh - 3rem);
  margin: 0;
  padding: 1.4rem 1.4rem 1.1rem;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.overlay-body{
  overflow-y: auto;
  margin-top: 0.8rem;
}

@media (max-width: 640px){
  .overlay-backdrop{
    align-items: center;
  }
  .overlay-panel{
    max-height: calc(100vh - 2rem);
    width: calc(100% - 2.5rem);
  }
}

@media (max-width: 640px){
  .home-quick-links{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
    justify-items: center;
  }
  .chip-link{
    width: 100%;
    justify-content: center;
    text-align: center;
    white-space: normal;
  }
}

/* === Simplified overlay centering override === */
.overlay-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,0.62);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 60;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease-out;
}
.overlay-backdrop.open{
  opacity: 1;
  pointer-events: auto;
}
.overlay-panel{
  background: var(--bg-alt);
  box-shadow: 0 24px 60px rgba(15,23,42,0.45);
  border-radius: 22px;
  width: min(640px, 100% - 2rem);
  max-height: calc(100vh - 3rem);
  margin: 0;
  padding: 1.4rem 1.4rem 1.1rem;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.overlay-body{
  overflow-y: auto;
  margin-top: 0.8rem;
}
