/* ===== SKIP LINK ===== */
.skip-link { position: absolute; top: -100%; left: 16px; z-index: 9999; padding: 12px 24px; background: var(--color-text); color: var(--color-bg); font-family: 'Lexend', system-ui, sans-serif; font-size: 14px; font-weight: 400; text-decoration: none; border-radius: 0 0 8px 8px; transition: top 0.2s ease; }
.skip-link:focus { top: 0; }

/* ===== BENTO NAV TRIGGER (4-state: idle, hover, pressed, open) ===== */
.bento-trigger { position: fixed; top: 20px; right: 20px; z-index: 1001; display: flex; flex-direction: column; justify-content: center; align-items: center; width: 48px; height: 48px; background: var(--color-trigger-bg); border: 1px solid var(--color-border); cursor: pointer; padding: 8px; border-radius: 14px; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); outline: none; -webkit-tap-highlight-color: transparent; transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.3s ease, border-radius 0.3s ease, box-shadow 0.3s ease; }
.bento-trigger:hover { transform: scale(1.1); background: var(--color-trigger-bg-hover); box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.bento-trigger:active { transform: scale(0.95); background: var(--color-trigger-bg-active); box-shadow: 0 1px 4px rgba(0,0,0,.08); transition-duration: 0.1s; }
.bento-trigger:focus, .bento-trigger:focus-visible { outline: none; }
.bento-trigger-icon { display: flex; flex-direction: column; gap: 4px; }
.bento-trigger-icon span { display: block; width: 22px; height: 2px; background: var(--color-text); transition: transform 0.3s ease, opacity 0.3s ease; }
.bento-trigger[aria-expanded="true"] .bento-trigger-icon span:nth-child(1) { transform: rotate(-45deg) translate(-4.5px, 4.5px); }
.bento-trigger[aria-expanded="true"] .bento-trigger-icon span:nth-child(2) { opacity: 0; }
.bento-trigger[aria-expanded="true"] .bento-trigger-icon span:nth-child(3) { transform: rotate(45deg) translate(-4.5px, -4.5px); }
.bento-trigger[aria-expanded="true"] { background: var(--color-trigger-bg-open); border-radius: 50%; }
.bento-trigger.is-hidden { pointer-events: none; }

/* ===== BENTO NAV OVERLAY ===== */
.bento-overlay { position: fixed; inset: 0; background: var(--color-overlay-bg); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); z-index: 1000; display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 80px 24px 40px; box-sizing: border-box; opacity: 0; visibility: hidden; transition: opacity 0.35s ease, visibility 0.35s ease; overflow-y: auto; }
.bento-overlay.open { opacity: 1; visibility: visible; }
.bento-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; max-width: 480px; width: 100%; }
.bento-tile { position: relative; display: flex; align-items: center; justify-content: center; padding: 18px 12px; background: var(--color-card-bg); border: 1px solid var(--color-border); text-decoration: none; color: var(--color-text); font-family: 'Special Elite', 'Times New Roman', Times, serif; font-weight: 400; letter-spacing: .02em; font-size: 17px; text-align: center; cursor: pointer; overflow: hidden; opacity: 0; transform: scale(0.85) translateY(8px); transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.35s ease, background 0.3s ease; }
/* Surface shift: inner light layer */
.bento-tile::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 20%, rgba(255,255,255,.35) 0%, transparent 60%); opacity: 0; transition: opacity 0.35s ease; pointer-events: none; }
.bento-tile:hover::before, .bento-tile:focus-visible::before { opacity: 1; }
.bento-overlay.open .bento-tile { opacity: 1; transform: scale(1) translateY(0); }
/* Organiska border-radius */
.bento-tile:nth-child(1)  { border-radius: 24px 20px 16px 16px; }
.bento-tile:nth-child(2)  { border-radius: 20px 24px 18px 14px; }
.bento-tile:nth-child(3)  { border-radius: 16px 20px 24px 18px; }
.bento-tile:nth-child(4)  { border-radius: 18px 14px 20px 24px; }
.bento-tile:nth-child(5)  { border-radius: 22px 18px 14px 20px; }
.bento-tile:nth-child(6)  { border-radius: 14px 22px 20px 16px; }
.bento-tile:nth-child(7)  { border-radius: 20px 16px 22px 14px; }
.bento-tile:nth-child(8)  { border-radius: 16px 24px 14px 22px; }
.bento-tile:nth-child(9)  { border-radius: 22px 14px 24px 18px; }
.bento-tile:nth-child(10) { border-radius: 14px 20px 18px 24px; }
.bento-tile:nth-child(11) { border-radius: 18px 22px 16px 20px; }
/* Depth map: varying tile opacities */
.bento-tile:nth-child(2)  { background: var(--color-card-bg-alt1); }
.bento-tile:nth-child(5)  { background: var(--color-card-bg-alt3); }
.bento-tile:nth-child(8)  { background: var(--color-card-bg-alt2); }
.bento-tile:nth-child(10) { background: var(--color-card-bg-alt2); }
.bento-tile:hover, .bento-tile:focus-visible { transform: scale(1.08); box-shadow: 0 6px 20px var(--color-card-shadow); background: var(--color-card-bg-hover); z-index: 1; }
.bento-tile:focus, .bento-tile:focus-visible { outline: none; }
.bento-tile.active { background: var(--color-card-bg-hover); border-color: var(--color-border-hover); font-weight: 400; }
.bento-tile--brand { grid-column: 1 / -1; padding: 22px 12px; border-radius: 24px 24px 16px 16px !important; }
.bento-tile--primary { min-height: 64px; }
/* Staggered entry */
.bento-overlay.open .bento-tile:nth-child(1)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.04s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.04s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(2)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.08s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.08s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(3)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.12s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.12s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(4)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.16s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.16s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(5)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.20s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.20s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(6)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.24s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.24s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(7)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.28s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.28s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(8)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.32s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.32s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(9)  { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.36s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.36s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(10) { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.40s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.40s, box-shadow 0.35s ease, background 0.3s ease; }
.bento-overlay.open .bento-tile:nth-child(11) { transition: opacity 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.44s, transform 0.4s cubic-bezier(0.34,1.56,0.64,1) 0.44s, box-shadow 0.35s ease, background 0.3s ease; }
body.menu-open { overflow: hidden; }

/* Responsive */
@media (max-width: 700px) {
  .bento-trigger { top: 44px; right: 22px; }
  .bento-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; max-width: 340px; }
  .bento-tile { font-size: 16px; padding: 16px 10px; min-height: 48px; }
  .bento-tile--brand { padding: 18px 10px; }
  .bento-tile--primary { min-height: 56px; }
}

@media (prefers-reduced-motion: reduce) {
  .bento-tile, .bento-trigger, .bento-overlay { transition: none !important; animation: none !important; }
}
