:root{
  --bg:#0b0710;
  --panel: rgba(255,255,255,0.03);
  --muted:#bfc0c8;
  --text:#eef0f6;
  --accent-1:#2b076e;
  --accent-2:#6441a5;
  --accent-glow: rgba(156, 102, 255, 0.18);
  --glass: rgba(255,255,255,0.03);
  --brand-green: #093f03;
  --brand-green-light: #92d121;
  --radius:14px;
  --gap:20px;
  --transition:300ms cubic-bezier(.2,.9,.3,1);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

/* Make all hyperlinks use the right colors */
a {
  color: var(--brand-green-light);
  text-decoration: none;
}
a:hover,
a:focus {
  color: var(--brand-green-light);
  text-decoration: underline;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:linear-gradient(180deg,#06040a 0%, #2b076e 90%);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  font-size:16px;
}

/* ===== HEADER ===== */
.site-header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  backdrop-filter: blur(6px);
  background: linear-gradient(180deg, rgba(10,6,14,0.6), rgba(10,6,14,0.35));
  border-bottom: 2px solid rgba(255,255,255,0.03);
  min-height: 72px;          
  display: block;
}

.page-container.header-row {
  width: 100%;
  max-width: 100%;
  padding: 12px 56px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
  box-sizing: border-box;
}

/* MOBILE BUTTON */
.mobile-menu-btn {
  display: none; 
  background: none;
  border: 0;
  color: var(--text);
  padding: 6px;
  border-radius: 8px;
  margin-left: 0; 
  flex: 0 0 auto;
  cursor: pointer;
}

/* BRAND */
.brand {
  display: flex;
  gap: 10px;
  align-items: center;
  flex: 0 0 auto;
  min-width: 0;
  max-width: 340px;     
  justify-content: flex-start;
  text-decoration: none;
  color: inherit;
}
.brand:hover,
.brand:focus-visible {
  opacity: 0.9;               
  text-decoration: none;
}
.brand-favicon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  object-fit: cover;
  flex: 0 0 auto;
  display: block;
}
.brand-text { display:flex; flex-direction:column; min-width:0; overflow:hidden; }
.brand-title { font-weight:700; font-size:18px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.brand-tag { font-size:12px; color:var(--muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* NAV */
.top-nav {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex: 1 1 auto;
  justify-content: center;
  gap: 20px;
  align-items: center;
  width: max-content;
  pointer-events: auto;
}
.top-nav .nav-link {
  color: var(--muted);
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 10px;
  font-size: 14px;
  transition: var(--transition);
  white-space: nowrap;
}
.top-nav .nav-link:hover {
  color: var(--text);
  background: linear-gradient(90deg, var(--accent-1), var(--accent-2));
  box-shadow: 0 6px 20px var(--accent-glow);
  transform: translateY(-2px);
}

/* ---------------- Mobile menu (desktop: absolute anchored via JS; mobile: inline block) ---------------- */
#mobile-menu {
  position: absolute;
  width: 220px;
  max-width: calc(100vw - 48px);
  padding: 10px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.03);
  box-shadow: 0 12px 40px rgba(6,6,12,0.6);
  transform-origin: top left;
  opacity: 0;
  transform: translateY(-6px) scale(0.98);
  transition: opacity 200ms ease, transform 200ms cubic-bezier(.2,.9,.3,1);
  z-index: 1200;
  outline: none;
  display: none; 
}

/* visible state */
#mobile-menu.open {
  display: block;
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* when #mobile-menu is hidden via the attribute, keep it truly collapsed for layout/screen-readers */
#mobile-menu[hidden] {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none;
}

/* inside menu link styles - reuse .mobile-link */
#mobile-menu .mobile-link {
  display: block;
  padding: 10px 8px;
  color: var(--muted);
  text-decoration: none;
  border-radius: 8px;
  transition: background 180ms ease, color 180ms ease;
}
#mobile-menu .mobile-link:hover,
#mobile-menu .mobile-link:focus {
  color: var(--text);
  background: linear-gradient(90deg, var(--accent-1), var(--accent-2));
}

/* ========== LAYOUT ========== */
.container{
  max-width:1100px;
  margin:28px auto;
  display:grid;
  grid-template-columns: 220px 1fr 220px;
  gap:var(--gap);
  padding:0 20px 60px;
  align-items:start;
  box-sizing:border-box;
}

/* prevent horizontal overflow */
html, body { overflow-x: hidden; }
.container { max-width: 100vw; width: 100%; overflow-x: hidden; }
.left-col, .center-col, .right-col { max-width: 100%; overflow-x: hidden; }
.project-btn, .card, .carousel { max-width: 100%; box-sizing: border-box; }

/* columns */
.col{min-height: 120px}
.left-col, .right-col{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius: var(--radius);
  padding:16px;
  border:1px solid rgba(255,255,255,0.02);
  box-shadow: 0 6px 18px rgba(8,6,12,0.6);
}

/* center column */
.center-col{padding:0 10px}

/* project buttons */
.project-buttons{display:flex;flex-direction:column;gap:12px}
.project-btn{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;text-decoration:none;color:var(--text);transition:var(--transition);background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.005))}
.project-btn .project-icon{width:36px;height:36px;border-radius:8px;object-fit:cover;filter:drop-shadow(0 6px 18px rgba(86,56,160,0.16))}
.project-btn.primary{background:linear-gradient(90deg,var(--accent-1),var(--accent-2));box-shadow:0 8px 30px var(--accent-glow);color:white}
.project-btn.primary:hover{transform:translateY(-4px)}
.project-btn.secondary{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));}
.project-btn.ghost{background:transparent;border:1px dashed rgba(255,255,255,0.04);color:var(--muted)}

/* about */
.about{background:var(--panel);padding:18px;border-radius:12px;margin-bottom:18px;border:1px solid rgba(255,255,255,0.02)}
.headline{font-size:28px;margin:0 0 6px}
.headline .highlight{background:linear-gradient(90deg,var(--accent-2),#d7b7ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{color:var(--text);margin:0 0 8px;font-weight:500}
.muted{color:var(--muted);font-size:14px}

/* showcase / carousel */
.showcase{margin-top:8px}
.carousel{position:relative;overflow:visible;padding:22px 12px;border-radius:14px;background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.01));border:1px solid rgba(255,255,255,0.02)}
.carousel-track{display:flex;gap:18px;align-items:stretch;transition:transform 380ms cubic-bezier(.2,.9,.3,1)}
.card{display:flex;gap:16px;min-width:420px;max-width:1500px;background:rgba(255,255,255,0.02);border-radius:12px;padding:18px;border:1px solid rgba(255,255,255,0.02);box-shadow:0 8px 30px rgba(6,6,10,0.6);align-items:center}
.card[aria-hidden="true"]{opacity:0;transform:scale(0.99);pointer-events:none}
.card-left{flex:0 0 120px;display:flex;align-items:center;justify-content:center}
.card-thumb{width:96px;height:96px;border-radius:12px;object-fit:cover}
.card-thumb.placeholder{width:96px;height:96px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:34px;background:linear-gradient(180deg,var(--accent-1),var(--accent-2))}
.card-body{flex:1}
.card h3{margin:0 0 6px}
.card-desc{color:var(--muted);margin:0 0 12px}
.card-meta{display:flex;gap:8px;margin-bottom:12px}
.tag{background:rgba(255,255,255,0.03);padding:6px 8px;border-radius:999px;font-size:13px;color:var(--muted)}
.card-actions .btn{margin-right:8px}

/* Make carousel slides fill the visible carousel area */
.carousel { position: relative; overflow: hidden; } 
.carousel-track {
  display: flex;
  gap: 18px;
  align-items: stretch;
  transition: transform 380ms cubic-bezier(.2,.9,.3,1);
  flex-wrap: nowrap;
}

/* each card becomes a full-width slide */
.carousel .card {
  flex: 0 0 100%;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  box-sizing: border-box;

  /* keep the card visual styling you already had */
  gap: 16px;
  background: rgba(255,255,255,0.02);
  border-radius: 12px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,0.02);
  box-shadow: 0 8px 30px rgba(6,6,10,0.6);
  display: flex;
  align-items: center;
}

/* keep hidden-slide behavior */
.card[aria-hidden="true"]{ opacity:0; transform:scale(0.99); pointer-events:none }

/* If you want the image column to shrink on very small screens, allow it */
.card-left { flex: 0 0 120px; display:flex; align-items:center; justify-content:center; }
.card-body { flex: 1 1 auto; min-width: 0; }

/* Optional: if you want small gutters between slide and carousel edges */
.carousel { padding-left: 12px; padding-right: 12px; }
.carousel-track { padding-bottom: 2px; } 

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;text-decoration:none;border:1px solid rgba(255,255,255,0.06);background:transparent;color:var(--text);transition:var(--transition)}
.btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(11,7,20,0.6)}
.btn-primary{background:linear-gradient(90deg,var(--accent-1),var(--accent-2));color:white;border:0}
.btn-outline{border:1px solid rgba(255,255,255,0.06);background:transparent}

/* carousel controls */
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:0;background:rgba(255,255,255,0.02);display:flex;align-items:center;justify-content:center;color:var(--text);cursor:pointer;transition:var(--transition)}
.carousel-btn.prev{left:-18px}
.carousel-btn.next{right:-18px}
.carousel-btn:hover{transform:translateY(-50%) scale(1.06);box-shadow:0 10px 30px rgba(6,6,10,0.6)}

.carousel-dots{display:flex;gap:8px;justify-content:center;margin-top:14px}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.04);border:0;cursor:pointer}
.dot.active{background:linear-gradient(90deg,var(--accent-1),var(--accent-2));box-shadow:0 6px 20px var(--accent-glow)}

/* socials */
.socials{display:flex;flex-direction:column;gap:10px}
.social-btn{display:flex;gap:10px;align-items:center;padding:10px;border-radius:10px;color:var(--text);text-decoration:none;background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.005));border:1px solid rgba(255,255,255,0.02);transition:var(--transition)}
.social-btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(6,6,10,0.6)}

/* ---------- Footer ---------- */
.site-footer {
  width: 100%;
  border-top: 2px solid rgba(255, 255, 255, 0.08);
  margin-top: 40px;
  padding: 20px 0;
  color: var(--muted);
  background: linear-gradient(180deg, rgba(10, 6, 14, 0.7), rgba(10, 6, 14, 0.95));
  position: fixed;
  bottom: 0;
  flex-shrink: 0;
}
.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column; 
  align-items: center;
  justify-content: center;
  gap: 14px;
  text-align: center;
}
.footer-left {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}
.footer-icon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  object-fit: contain;
}
.footer-right {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}
.footer-right a {
  color: var(--muted);
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  transition: color 180ms ease, transform 180ms ease;
}
.footer-right a:hover {
  color: var(--text);
  transform: translateY(-2px);
}
html, body { height: 100%; margin: 0; } 
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.site-main {
  flex: 1 1 auto;
  display: block;
}

/* Safety: override any accidental :target overlay rules */
#contact:target, .right-col:target {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  transform: none !important;
  margin: 0 !important;
  width: auto !important;
  box-shadow: none !important;
}

/* ========== Hide Scrollbars ========== */
html::-webkit-scrollbar, body::-webkit-scrollbar { display: none; width: 0; height: 0; }
html, body { -ms-overflow-style: none; scrollbar-width: none; }

/* ========== 404 Page ========== */
.page-404 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 20px;
  min-height: 60vh;
}
.notfound-wrap {
  position: relative;
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
}
/* card */
.nf-card {
  display: flex;
  gap: 26px;
  align-items: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.03);
  padding: 28px;
  border-radius: 14px;
  box-shadow: 0 18px 60px rgba(6,6,12,0.5);
  overflow: hidden;
}
/* large gradient “404” */
.nf-code {
  font-weight: 900;
  font-size: 88px;
  line-height: 1;
  background: linear-gradient(180deg, var(--accent-1), var(--accent-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--accent-2);
  min-width: 142px;
  text-align: center;
  filter: drop-shadow(0 10px 30px rgba(100,64,165,0.12));
}
/* text content */
.nf-content { flex: 1; min-width: 0; }
.nf-content h1 { margin: 0 0 8px; font-size: 22px; }
.nf-lead { margin: 0 0 14px; color: var(--muted); }
.nf-muted { color: var(--muted); font-size: 13px; margin: 8px 0 0; }
/* actions */
.nf-actions {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.nf-actions .btn {
  min-width: 140px;
  text-align: center;
}

/* ========== Contact Page ========== */
#contact-page.contact-page { 
  background: transparent; 
  color: var(--text);
  flex: 1 1 auto;
  display: block;
}

/* hero */
#contact-page .contact-hero {
  background: linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius: 12px;
  padding: 22px 18px;
  margin: 18px 0;
  border: 1px solid rgba(255,255,255,0.02);
  box-shadow: 0 8px 30px rgba(6,6,10,0.4);
}
#contact-page .contact-hero-inner { max-width: 1100px; margin: 0 auto; }
#contact-page .contact-title { margin: 0 0 6px; font-size: 28px; font-weight:700; }
#contact-page .contact-sub { margin: 0; color: var(--muted); }

/* grid */
#contact-page .contact-grid {
  max-width: 1100px;
  margin: 18px auto 60px;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 20px;
  align-items: start;
  box-sizing: border-box;
  padding: 0 20px;
}

/* card base */
#contact-page .contact-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.005));
  border-radius: 12px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,0.02);
  box-shadow: 0 8px 24px rgba(6,6,10,0.35);
}

/* info card */
#contact-page .contact-info .contact-card-title { margin: 0 0 8px; font-size: 18px; }
#contact-page .contact-info .contact-card-desc { color: var(--muted); margin-bottom: 12px; }
#contact-page .contact-meta { margin: 10px 0 12px; }
#contact-page .contact-meta .meta-row { display:flex; gap:8px; align-items:center; margin:8px 0; }
#contact-page .contact-meta dt { font-weight:700; color:var(--muted); min-width:70px; }
#contact-page .contact-meta dd { margin:0; color:var(--text); }

/* socials (simple pill links) */
#contact-page .contact-socials { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }
#contact-page .social-link {
  padding:8px 10px; border-radius:10px; text-decoration:none; color:var(--text);
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.005));
  border:1px solid rgba(255,255,255,0.02);
  font-weight:600; font-size:13px;
}
#contact-page .social-link:hover { 
  transform: translateY(-3px); 
  box-shadow:0 8px 24px rgba(6,6,10,0.2); 
  background: var(--accent-2)
}

/* form card */
#contact-page .contact-form-wrap { display:block; }
#contact-page .contact-form .form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
#contact-page .contact-form .form-field { display:block; }
#contact-page .contact-form .form-field.full { grid-column: 1 / -1; }

/* label text */
#contact-page .label-text { display:block; font-size:13px; color:var(--muted); margin-bottom:6px; }

/* ---------- Contact form: inputs, focus, spinner, actions (scoped) ---------- */
#contact-page .contact-form input[type="text"],
#contact-page .contact-form input[type="email"],
#contact-page .contact-form textarea {
  background: rgba(255,255,255,0.01);             
  border: 1px solid rgba(255,255,255,0.04);       
  padding: 0.5rem 0.6rem;
  border-radius: 8px;
  color: var(--text);
  font-size: 0.95rem;
  outline: none;
  transition: box-shadow 150ms ease, border-color 150ms ease;
  width: 100%;
  box-sizing: border-box;
}
#contact-page .contact-form input:focus,
#contact-page .contact-form textarea:focus {
  border-color: rgba(156,102,255,0.26);           
  box-shadow: 0 0 0 6px rgba(156,102,255,0.08);   
}
/* textarea sizing */
#contact-page .contact-form textarea {
  min-height: 140px;
  resize: vertical;
}
/* form actions row */
#contact-page .form-actions {
  display: flex;
  gap: 1rem;
  align-items: center;
  margin-top: 1rem;
  flex-wrap: wrap;
}
#contact-page .form-status {
  color: var(--muted);
  font-size: 0.95rem;
}
/* Load button spinner */
#contact-page .btn-spinner {
  width: 20px;
  height: 20px;
  margin-left: 0.6rem;
  display: none;
  vertical-align: middle;
}
/* When the submit button is in loading state, dim text slightly and show spinner. */
#contact-page button.btn.loading .btn-text {
  opacity: 0.85;
}
#contact-page button.btn.loading .btn-spinner {
  display: inline-block;
  animation: sh-spinner 1s linear infinite;
  transform-origin: center;
}
/* spinner rotate animation */
@keyframes sh-spinner {
  to { transform: rotate(360deg); }
}
/* disabled state for clarity */
#contact-page button.btn[disabled] {
  opacity: 0.8;
  cursor: not-allowed;
}

/* ========== Mobile Rules - Responsive ========== */
/* Small screens adjustments */
@media (max-width: 520px) {
  .brand-title { font-size: 16px; }
  .brand-favicon { width: 40px; height: 40px; }
  .headline { font-size: 22px; }
  #about-page .about-hero__title { font-size:22px; }
  #about-page .card { padding:14px; }
}

/* Mobile rules consolidated */
@media (max-width: 800px) {
  .container { grid-template-columns: 1fr; background: transparent !important; background-color: transparent !important; }
  .left-col,
  .right-col { order: 2; }
  .center-col { order: 1; }
  .top-nav { display: none; }
  .mobile-menu-btn { display: inline-flex; }
  .page-container.header-row { padding-left: 12px; padding-right: 16px; overflow: visible !important; }

  /* #mobile-menu (existing element) */
  #mobile-menu {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin: 8px 0 0 0 !important;
    padding: 8px 12px !important;
    border-radius: 12px !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)) !important;
    border-top: 1px solid rgba(255,255,255,0.02) !important;
    box-shadow: none !important;
    transform: none !important;
    opacity: 1 !important;
    transition: none !important;
    display: none !important;
  }
  #mobile-menu.open { display: block !important; }
  nav#mobile-menu-top {
    display: block;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    overflow: hidden;
    max-height: 0;
    transition: max-height 260ms ease, padding 180ms ease, background 180ms ease;
    background: transparent;
    border-bottom: none;
    z-index: 999; 
  }
  /* when open: panel look and comfortable padding */
  nav#mobile-menu-top.open {
    padding: 0 14px;
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
    border-bottom: 1px solid rgba(255,255,255,0.02);
    max-height: 300px;
    padding-bottom: 165px;
    pointer-events: auto;
  }
  /* stacked list — give breathing room above first link too */
  nav#mobile-menu-top .mobile-top-list {
    list-style: none;
    margin: 0;
    padding: 14px 0;
    display: block;
    flex-direction: column;
    gap: 6px;
  }
  nav#mobile-menu-top .mobile-top-list li { margin: 0; }
  /* links: default (transparent), strong weight, comfortable tappable padding */
  .mobile-top-link {
    display: block;
    padding: 12px 10px;
    border-radius: 10px;
    text-decoration: none;
    color: var(--text) !important;
    font-weight: 700;
    background: transparent !important; 
  }
  /* hover/focus highlight (higher specificity + !important to override earlier transparency) */
  nav#mobile-menu-top.open .mobile-top-link:hover,
  nav#mobile-menu-top.open .mobile-top-link:focus,
  nav#mobile-menu-top .mobile-top-link:hover,
  nav#mobile-menu-top .mobile-top-link:focus {
    background: linear-gradient(90deg, var(--accent-1, #2b076e) 0%, var(--accent-2, #6441a5) 100%) !important;
    color: #ffffff !important;
    text-decoration: none; 
  }
  /* Defensive: ensure header doesn't clip expanded menu */
  .site-header,
  .page-container.header-row { overflow: visible !important; }
  nav#mobile-menu-top[style*="max-height: 0"] { pointer-events: none; }

  /* Footer / background defensive rules */
  /* ensure main content and footer don't show white artifacts on mobile */
  main,
  .page-container,
  .site-footer,
  .footer-inner {
    background: transparent !important;
    background-color: transparent !important;
  }
  .site-footer {
    color: var(--muted);
    background: linear-gradient(180deg, rgba(255,255,255,0.00), rgba(255,255,255,0.00)) !important;
    box-sizing: border-box;
    padding-bottom: calc(var(--safe-bottom) + 12px);
  }
  body, #about-page, .page-container {
    padding-bottom: calc(80px + var(--safe-bottom));
  }
  /* Some mobile browsers show an overscroll "rubberband" background — make sure it's dark */
  ::-webkit-scrollbar { background: transparent; }
  body, html { overscroll-behavior-y: contain; -webkit-overflow-scrolling: touch; }
  /* ensure any white "page-bottom" artifacts from children are hidden */
  .site-footer * { background: transparent !important; }
  /* make each card vertical, with image centered at top */
  .carousel .card {
    flex-direction: column;
    align-items: stretch;
    text-align: center;     
    padding: 14px;
  }
  /* card-left becomes full width and centers the thumbnail */
  .carousel .card-left {
    flex: 0 0 auto;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 12px 0;
  }
  /* slightly larger thumbnail on mobile for better visibility */
  .carousel .card-thumb {
    width: 120px;
    height: 120px;
    border-radius: 12px;
  }
  /* card body occupies full width under the image */
  .carousel .card-body {
    width: 100%;
    text-align: center;
  }
  /* ensure meta/tags stack and are centered */
  .carousel .card-meta {
    display: flex;
    gap: 8px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 12px;
  }
  /* actions centered */
  .carousel .card-actions {
    display: flex;
    justify-content: center;
    gap: 8px;
  }

  /* ========== Mobile 404 Page ========== */
  .nf-card {
    flex-direction: column;
    gap: 18px;
    padding: 20px;
    text-align: center;
  }
  .nf-code {
    font-size: 56px;
    min-width: auto;
  }
  .nf-deco { display: none; }
  .nf-actions {
    justify-content: center;
  }

  /* ========== Mobile Contact Page ========== */
  #contact-page .contact-grid { grid-template-columns: 1fr; }
  #contact-page .contact-form .form-grid { grid-template-columns: 1fr; }
  #contact-page .contact-card { padding: 14px; }
  #contact-page .contact-hero { padding: 18px; }

}
