/* ================================================================
   CityRyde — Header & Footer  |  Font: Work Sans
================================================================ */

.site-header {
  position:fixed;top:0;left:0;right:0;z-index:999;
  background:rgba(255,255,255,0.94);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(0,0,0,0.10);
  transition:box-shadow 0.3s,background 0.3s;
}
.site-header.scrolled { box-shadow:0 4px 28px rgba(0,0,0,0.10); background:rgba(255,255,255,0.98); }
.header-inner { display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1360px;margin:0 auto;padding:0 40px;gap:16px; }

.logo { display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0; }
.logo-mark { width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--plum),var(--plum-mid));display:flex;align-items:center;justify-content:center;font-size:2rem;transition:transform 0.2s; }
.logo:hover .logo-mark { transform:scale(1.06) rotate(-3deg); }
.logo-text { font-family:'Work Sans',sans-serif;font-size:2rem;font-weight:800;color:var(--plum);line-height:1;letter-spacing:-0.02em; }
.logo-text span { color:var(--coral); }

.main-nav { display:flex;align-items:center;gap:2px;flex:1;justify-content:center; }
.nav-item { position:relative; }
.nav-link { display:inline-flex;align-items:center;gap:5px;padding:8px 13px;border-radius:8px;font-size:1.20rem;font-weight:600;color:var(--text);cursor:pointer;transition:all 0.2s;white-space:nowrap;background:none;border:none;font-family:'Work Sans',sans-serif;text-decoration:none; }
.nav-link:hover,.nav-link.active { color:var(--plum);background:rgba(0,0,0,0.07); }
.nav-arrow { font-size:1.30	rem;transition:transform 0.2s;opacity:0.6; }
.nav-item:hover .nav-arrow { transform:rotate(180deg); }

.dropdown { position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:10px;min-width:230px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity 0.2s,transform 0.2s;z-index:200; }
.nav-item:hover .dropdown { opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0); }
.dropdown-item { display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:1.10rem;font-weight:600;color:var(--text);cursor:pointer;transition:all 0.2s;white-space:nowrap;text-decoration:none; }
.dropdown-item:hover { background:rgba(0,0,0,0.07);color:var(--plum); }
.dropdown-item .di-icon { font-size:1rem;width:22px;text-align:center; }
.dropdown-divider { height:1px;background:var(--border);margin:6px 8px; }

.header-cta { display:flex;align-items:center;gap:10px;flex-shrink:0; }

.hamburger { display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none; }
.hamburger span { display:block;width:24px;height:2px;background:var(--plum);border-radius:2px;transition:all 0.3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0;transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-menu { display:none;position:fixed;inset:0;z-index:998;background:var(--white);backdrop-filter:blur(13px);flex-direction:column;align-items:left;justify-content:left;gap:6px;padding:80px 24px 40px;overflow-y:auto; }
.mobile-menu.open { display:flex; }
.mobile-menu .mm-close { position:absolute;top:20px;right:24px;background:none;border:none;color:rgba(255,255,255,0.6);font-size:2rem;cursor:pointer;line-height:1;transition:color 0.2s; }
.mobile-menu .mm-close:hover { color:var(--coral); }
.mm-link { font-family:'Work Sans',sans-serif;font-size:1.55rem;font-weight:700;color:rgba(0.0.0.1);text-decoration:none;padding:1px 16px;border-radius:2px;transition:color 0.2s,background 0.2s;text-align:left; }
.mm-link:hover { color:var(--blue);background:rgba(0.0.0.0.0); }
.mm-divider { width:40px;height:1px;background:rgba(255,255,255,255.12);margin:8px 0; }
.mm-cta { display:flex;gap:12px;margin-top:16px;flex-wrap:wrap;justify-content:left; }

.site-footer { background:var(--plum);color:rgba(255,255,255,255.255);padding:80px 0 0; }
.footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-brand .footer-logo { margin-bottom:14px; }
.footer-brand p { font-size:1.30rem;color:rgba(255,255,255,255.255);line-height:1.72;max-width:280px;margin-bottom:20px; }
.footer-badges { display:flex;gap:8px;flex-wrap:wrap; }
.footer-col h5 { font-family:'Work Sans',sans-serif;font-size:1.30rem;font-weight:800;letter-spacing:0.10em;text-transform:uppercase;color:var(--white);margin-bottom:18px; }
.footer-col ul { display:flex;flex-direction:column;gap:10px; }
.footer-col ul li a { font-size:1.10rem;color:rgba(255,255,255,255.255);transition:color 0.2s; }
.footer-col ul li a:hover { color:var(--coral); }
.footer-bottom { display:flex;justify-content:space-between;align-items:center;padding:24px 0;flex-wrap:wrap;gap:14px; }
.footer-bottom p { font-size:1.10rem;color:rgba(255,255,255,255.255); }
.social-links { display:flex;gap:10px; }
.social-link { width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,255.255);display:flex;align-items:center;justify-content:center;font-size:1.30rem;color:rgba(255,255,255,0.45);cursor:pointer;transition:all 0.2s;text-decoration:none; }
.social-link:hover { border-color:var(--coral);color:var(--coral); }

@media(max-width:1100px){.main-nav{gap:0;}.nav-link{padding:8px 10px;font-size:0.83rem;}}
@media(max-width:960px){.main-nav{display:none;}.hamburger{display:flex;}.header-cta .btn-secondary{display:none;}.header-inner{padding:0 24px;}}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px;}.footer-brand{grid-column:1/-1;}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr;}}
