:root{
      --bg:#000;
      --txt:#f4f4f5;
      --muted:rgba(244,244,245,.72);
      --muted2:rgba(244,244,245,.52);
      --line:rgba(255,255,255,.12);

      --acc1:#a855f7;
      --acc2:#7c3aed;
      --acc3:#6366f1;
      --accG: linear-gradient(90deg, var(--acc1), var(--acc2), var(--acc3));

      --wrap:1160px;
      --shadow2: 0 1px 0 rgba(255,255,255,.06) inset;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family:"Nunito",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
      font-weight:400;
      background:var(--bg);
      color:var(--txt);
      overflow-x:hidden;
    }

    /* lock scroll when menu open */
    html.navOpen, html.navOpen body { overflow:hidden; }

    body::before{
      content:"";
      position:fixed; inset:0;
      pointer-events:none;
      z-index:0;
      background:
        radial-gradient(1100px 600px at 50% 10%, rgba(255,255,255,.06), transparent 62%),
        radial-gradient(1400px 820px at 50% 92%, rgba(255,255,255,.04), transparent 65%);
      filter: blur(10px);
      opacity:.55;
    }

    .grain{
      pointer-events:none;
      position:fixed; inset:0;
      opacity:.06;
      mix-blend-mode:overlay;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
      z-index:0;
    }

    .wrap{
      max-width:var(--wrap);
      margin:0 auto;
      padding:0 22px;
      position:relative;
      z-index:2;
    }

    .accentText{
      background:var(--accG);
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      filter:
        drop-shadow(0 0 10px rgba(168,85,247,.16))
        drop-shadow(0 0 16px rgba(124,58,237,.10));
    }

    /* ---------- Entry overlay ---------- */
    .entry{
      position:fixed; inset:0;
      z-index:120;
      display:grid;
      place-items:center;
      background: transparent;
    }
    .entryGlass{
      position:absolute; inset:0;
      pointer-events:none;
      background: rgba(0,0,0,.28);
      backdrop-filter: blur(28px);
      -webkit-backdrop-filter: blur(28px);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
      opacity:1;
      will-change: opacity;
    }
    .entryGlass::before{
      content:"";
      position:absolute; inset:-20px;
      background:
        radial-gradient(520px 520px at 50% 45%, rgba(168,85,247,.24), transparent 60%),
        radial-gradient(760px 480px at 58% 55%, rgba(99,102,241,.14), transparent 68%),
        radial-gradient(520px 320px at 42% 60%, rgba(124,58,237,.14), transparent 64%);
      filter: blur(18px);
      opacity:.9;
    }
    .entryGlass::after{
      content:"";
      position:absolute; inset:0;
      background:
        radial-gradient(900px 520px at 50% 42%, rgba(255,255,255,.06), transparent 65%),
        radial-gradient(900px 520px at 50% 66%, rgba(255,255,255,.04), transparent 70%);
      opacity:.65;
    }
    .entryWord{
      position:relative;
      display:inline-flex;
      align-items:baseline;
      gap:0;
      font-weight:600;
      letter-spacing:-.055em;
      line-height:1.02;
      font-size: clamp(46px, 6.2vw, 78px);
      user-select:none;
      pointer-events:none;
      will-change: transform, opacity, filter;
    }
    .entryT, .entryRest{
      display:inline-block;
      line-height:inherit;
      font-size: inherit;
      font-weight: inherit;
    }
    .entryRest{
      color: rgba(244,244,245,.92);
      opacity:0;
      transform: translateX(26px) translateY(6px);
      filter: blur(12px);
      will-change: transform, opacity, filter;
    }

    /* ---------- Scroll reveal (fixed) ---------- */
    .reveal{ opacity:1; transform:none; filter:none; }
    .js .reveal{
      opacity:0;
      transform: translateY(14px);
      filter: blur(10px);
      transition: opacity .85s cubic-bezier(.16,1,.3,1),
                  transform .85s cubic-bezier(.16,1,.3,1),
                  filter .85s cubic-bezier(.16,1,.3,1);
      will-change: opacity, transform, filter;
    }
    .js .reveal.in{ opacity:1; transform:none; filter: blur(0); }
    .js .reveal.slow{ transition-duration: 1.05s; }
    .js .reveal.fast{ transition-duration: .70s; }
    @media (max-width: 860px){
      .js .reveal{ filter: blur(7px); }
    }

    /* ---------- Buttons ---------- */
    .btn{
      position:relative;
      height:40px;
      padding:0 14px;
      border-radius:12px;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      text-decoration:none;
      font-size:12px;
      letter-spacing:.18em;
      text-transform:uppercase;
      border:1px solid rgba(255,255,255,.14);
      background:rgba(255,255,255,.03);
      color:rgba(244,244,245,.92);
      transition: transform .18s cubic-bezier(.16,1,.3,1),
                  background .18s cubic-bezier(.16,1,.3,1),
                  border-color .18s cubic-bezier(.16,1,.3,1);
      user-select:none;
      overflow:hidden;
      cursor:pointer;
    }
    .btn:hover{
      transform:translateY(-1px);
      background:rgba(255,255,255,.05);
      border-color:rgba(255,255,255,.18);
    }
    .btn.primary{
      color:#0a0a0a;
      border-color: rgba(168,85,247,.35);
      background: linear-gradient(90deg, rgba(168,85,247,.92), rgba(124,58,237,.92), rgba(99,102,241,.88));
      font-weight:600;
      box-shadow: 0 18px 55px rgba(124,58,237,.14);
    }
    .btn.primary::before{
      content:"";
      position:absolute; inset:-2px;
      background: var(--accG);
      opacity:0;
      filter: blur(18px);
      transition: opacity .20s cubic-bezier(.16,1,.3,1);
      pointer-events:none;
    }
    .btn.primary:hover::before{ opacity:.22; }

    /* ---------- Navbar ---------- */
    header{
      position:fixed;
      top:14px; left:0; right:0;
      z-index:90;
      transition: opacity .25s cubic-bezier(.16,1,.3,1), transform .25s cubic-bezier(.16,1,.3,1);
      will-change: opacity, transform;
    }
    .topbar{
      border:1px solid rgba(255,255,255,.12);
      background: rgba(0,0,0,.62);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border-radius: 14px;
      padding:10px 12px;
      box-shadow: 0 24px 80px rgba(0,0,0,.45);
      position:relative;
      overflow:hidden;
    }
    .topbar::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: radial-gradient(700px 160px at 50% 0%, rgba(168,85,247,.10), transparent 68%);
      pointer-events:none;
      opacity:.9;
      filter: blur(18px);
    }
    .topbarInner{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      position:relative;
      z-index:1;
    }
    .logo{
      display:flex;
      align-items:center;
      gap:10px;
      text-decoration:none;
      color:rgba(244,244,245,.94);
      user-select:none;
      white-space:nowrap;
      min-width:auto;
    }
    .logo img{
      display:block;
      width:44px;
      height:44px;
      object-fit:contain;
      border-radius:12px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.02);
      padding:6px;
    }

    .nav{ display:flex; align-items:center; gap:10px; }
    .nav a{
      text-decoration:none;
      color: rgba(244,244,245,.72);
      font-size:12px;
      letter-spacing:.18em;
      text-transform:uppercase;
      padding:10px 10px;
      border-radius:10px;
      transition: color .18s cubic-bezier(.16,1,.3,1),
                  background .18s cubic-bezier(.16,1,.3,1),
                  border-color .18s cubic-bezier(.16,1,.3,1);
      border:1px solid transparent;
      outline:none;
      white-space:nowrap;
    }
    .nav a:hover{
      color: rgba(244,244,245,.94);
      background: rgba(255,255,255,.04);
      border-color: rgba(255,255,255,.10);
    }
    .nav a.active{
      color: rgba(244,244,245,.94);
      background: rgba(168,85,247,.10);
      border-color: rgba(168,85,247,.18);
      box-shadow: 0 10px 30px rgba(124,58,237,.10);
    }

    .actions{ display:flex; align-items:center; gap:10px; white-space:nowrap; }

    /* menu button */
    .menuBtn{
      display:none;
      width:44px;height:44px;
      border-radius:16px;
      border:1px solid rgba(168,85,247,.32);
      background: rgba(0,0,0,.22);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      color:rgba(244,244,245,.92);
      cursor:pointer;
      position:relative;
      box-shadow: 0 18px 55px rgba(124,58,237,.10);
    }
    .menuBtn::before{
      content:"";
      position:absolute; inset:-2px;
      background: radial-gradient(240px 160px at 50% 35%, rgba(168,85,247,.22), transparent 70%);
      filter: blur(14px);
      opacity:.85;
      pointer-events:none;
    }
    .burger{
      position:relative;
      width:18px;
      height:12px;
      display:block;
      margin:0 auto;
    }
    .burger::before,
    .burger::after,
    .burger span{
      content:"";
      position:absolute;
      left:0; right:0;
      height:2px;
      border-radius:999px;
      background: rgba(244,244,245,.86);
      box-shadow: 0 0 0 1px rgba(0,0,0,.18);
    }
    .burger::before{ top:0; }
    .burger span{ top:5px; }
    .burger::after{ bottom:0; }

    /* ---------- Mobile drawer (blurred overlay) ---------- */
    .drawerWrap{
      position:fixed;
      inset:0;
      z-index:80;
      display:none;
      align-items:flex-start;
      justify-content:center;
      padding: 84px 16px 16px;
      background: rgba(0,0,0,.58);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
    }
    .drawerWrap::before{
      content:"";
      position:absolute; inset:0;
      background:
        radial-gradient(520px 420px at 50% 20%, rgba(168,85,247,.16), transparent 65%),
        radial-gradient(820px 520px at 70% 40%, rgba(99,102,241,.10), transparent 70%);
      opacity:.95;
      pointer-events:none;
    }
    .drawerPanel{
      position:relative;
      width: min(520px, calc(100vw - 32px));
      border-radius: 20px;
      border: 1px solid rgba(255,255,255,.12);
      background: rgba(0,0,0,.58);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      box-shadow: 0 28px 110px rgba(0,0,0,.70), var(--shadow2);
      padding: 12px;
      overflow:hidden;
      transform: translateY(-8px);
      opacity:0;
      filter: blur(10px);
      transition: transform .28s cubic-bezier(.16,1,.3,1),
                  opacity .28s cubic-bezier(.16,1,.3,1),
                  filter .28s cubic-bezier(.16,1,.3,1);
    }
    .drawerPanel::before{
      content:"";
      position:absolute; inset:-2px;
      background: radial-gradient(640px 160px at 20% 0%, rgba(168,85,247,.14), transparent 70%);
      filter: blur(18px);
      opacity:.95;
      pointer-events:none;
    }
    .drawerPanel > *{ position:relative; z-index:1; }

    .drawerTop{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
      padding: 6px 6px 12px;
    }
    .drawerBrand{
      display:flex;
      align-items:center;
      gap:10px;
      color: rgba(244,244,245,.92);
      font-weight:600;
      letter-spacing:-.02em;
    }
    .drawerBrand .mark{
      width:38px;height:38px;
      border-radius:14px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.03);
      display:grid;
      place-items:center;
      position:relative;
      overflow:hidden;
    }
    .drawerBrand .mark::before{
      content:"";
      position:absolute; inset:-2px;
      background: radial-gradient(220px 120px at 50% 50%, rgba(168,85,247,.20), transparent 70%);
      filter: blur(12px);
      opacity:.9;
      pointer-events:none;
    }
    .drawerBrand .mark span{ position:relative; }
    .drawerClose{
      width:44px;height:44px;
      border-radius:16px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.03);
      color: rgba(244,244,245,.92);
      cursor:pointer;
    }

    .drawerList{
      display:grid;
      gap:10px;
      padding: 2px;
    }
    .drawerItem{
      display:flex;
      align-items:center;
      justify-content:space-between;
      padding: 15px 14px;
      border-radius: 16px;
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.02);
      text-decoration:none;
      color: rgba(244,244,245,.86);
      font-size:12px;
      letter-spacing:.22em;
      text-transform:uppercase;
      transition: transform .16s cubic-bezier(.16,1,.3,1),
                  background .16s cubic-bezier(.16,1,.3,1),
                  border-color .16s cubic-bezier(.16,1,.3,1),
                  color .16s cubic-bezier(.16,1,.3,1);
    }
    .drawerItem:hover{
      transform: translateY(-1px);
      background: rgba(255,255,255,.04);
      border-color: rgba(255,255,255,.14);
      color: rgba(244,244,245,.94);
    }
    .drawerArrow{
      opacity:.65;
      letter-spacing:0;
      font-size:14px;
    }

    .drawerWrap.open{ display:flex; }
    .drawerWrap.open .drawerPanel{
      transform: translateY(0);
      opacity:1;
      filter: blur(0);
    }

    /* ---------- Hero ---------- */
    .hero{
      min-height:100vh;
      position:relative;
      display:flex;
      align-items:flex-start;
      justify-content:center;
      padding-top: 152px;
      z-index:1;
    }
    .heroInner{
      text-align:center;
      display:flex;
      flex-direction:column;
      align-items:center;
      gap:14px;
      padding-top: 18px;
    }
    .badge{
      position:relative;
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:7px 12px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.14);
      background:rgba(255,255,255,.03);
      color:rgba(244,244,245,.82);
      font-size:11px;
      letter-spacing:.18em;
      text-transform:uppercase;
      user-select:none;
      overflow:hidden;
    }
    .badge::before{
      content:"";
      position:absolute; inset:-2px;
      background: radial-gradient(400px 120px at 50% 50%, rgba(168,85,247,.22), transparent 70%);
      opacity:.55;
      filter: blur(18px);
      pointer-events:none;
    }
    .badge > *{ position:relative; z-index:1; }
    .badgeDot{
      width:8px;height:8px;
      border-radius:999px;
      background: var(--accG);
      box-shadow: 0 0 0 4px rgba(255,255,255,.04);
    }
    h1{
      margin:0;
      font-weight:600;
      letter-spacing:-.055em;
      line-height:1.02;
      font-size: clamp(44px, 5.6vw, 86px);
      max-width: 18ch;
    }
    .sub{
      margin:0;
      color:var(--muted);
      font-size:16px;
      line-height:1.65;
      max-width: 78ch;
    }
    .ctaRow{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-top:6px; }

    .terrain{
      position:absolute;
      left:0; right:0;
      bottom:-10px;
      width:100%;
      pointer-events:none;
      z-index:1;
      opacity:.98;
      filter: drop-shadow(0 30px 85px rgba(0,0,0,.70));
    }

    /* ---------- Sections ---------- */
    .section{
      padding:86px 0;
      position:relative;
      z-index:2;
    }
    .sectionHead{
      display:flex;
      justify-content:space-between;
      align-items:flex-end;
      gap:16px;
      flex-wrap:wrap;
    }
    .kicker{
      font-size:11px;
      letter-spacing:.22em;
      text-transform:uppercase;
      color: rgba(244,244,245,.52);
      margin-bottom:10px;
    }
    .h2{
      margin:0;
      font-weight:600;
      letter-spacing:-.03em;
      font-size: 34px;
      line-height:1.10;
      max-width: 28ch;
    }
    .lead{
      margin:12px 0 0;
      color: var(--muted);
      line-height:1.75;
      max-width: 74ch;
    }

    /* ---------- Showcase / cards ---------- */
    .showcaseGrid{
      margin-top:22px;
      display:grid;
      grid-template-columns: 1fr 1.2fr 1fr;
      gap:14px;
      align-items:stretch;
    }
    .panelCard{
      border-radius: 18px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.03);
      box-shadow: var(--shadow2);
      overflow:hidden;
      position:relative;
      transition: transform .18s cubic-bezier(.16,1,.3,1),
                  border-color .18s cubic-bezier(.16,1,.3,1),
                  background .18s cubic-bezier(.16,1,.3,1);
    }
    .panelCard:hover{
      transform: translateY(-2px);
      border-color: rgba(255,255,255,.16);
      background: rgba(255,255,255,.04);
    }
    .shot{
      position:relative;
      height: 220px;
      background:
        radial-gradient(900px 260px at 20% 10%, rgba(168,85,247,.16), transparent 65%),
        radial-gradient(900px 260px at 80% 25%, rgba(99,102,241,.10), transparent 68%),
        linear-gradient(180deg, rgba(255,255,255,.05), transparent);
      border-bottom: 1px solid rgba(255,255,255,.08);
      overflow:hidden;
    }
    .shot::after{
      content:"";
      position:absolute; inset:0;
      background-image: radial-gradient(rgba(255,255,255,.16) 1px, transparent 1px);
      background-size: 14px 14px;
      opacity:.12;
      mask-image: linear-gradient(180deg, rgba(0,0,0,.85), transparent 80%);
      -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,.85), transparent 80%);
      pointer-events:none;
    }
    .panelBody{ padding:16px; }
    .panelTitle{
      margin:0;
      font-weight:600;
      letter-spacing:-.01em;
      font-size:15px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
    }
    .badgeMini{
      font-size:11px;
      letter-spacing:.16em;
      text-transform:uppercase;
      color: rgba(244,244,245,.68);
      padding:7px 10px;
      border-radius: 12px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.14);
    }
    .panelBody p{
      margin:10px 0 0;
      color: rgba(244,244,245,.68);
      line-height:1.7;
      font-size:14px;
    }
    .panelCard.side{ opacity:.70; transform: translateY(6px); }
    .panelCard.side:hover{ opacity:.92; transform: translateY(4px); }
    .panelCard.focus{
      box-shadow: 0 34px 120px rgba(0,0,0,.72), var(--shadow2);
      border-color: rgba(255,255,255,.14);
    }

    /* ---------- Projects: desktop grid / mobile slow carousel ---------- */
    .projectsRail{
      margin-top:18px;
      position:relative;
    }
    .projectsTrack{
      display:grid;
      grid-template-columns: repeat(3, 1fr);
      gap:14px;
      align-items:stretch;
    }

    @keyframes projectsMarquee{
      from{ transform: translateX(0); }
      to{ transform: translateX(-50%); }
    }

    @media (max-width: 860px){
      .projectsRail{
        overflow:hidden;
        padding-bottom: 8px;
      }
      /* edge fade */
      .projectsRail::before,
      .projectsRail::after{
        content:"";
        position:absolute;
        top:0; bottom:0;
        width:36px;
        pointer-events:none;
        z-index:2;
      }
      .projectsRail::before{
        left:0;
      }
      .projectsRail::after{
        right:0;
      }

      .projectsTrack{
        display:flex;
        gap:12px;
        align-items:stretch;
        width:max-content;
        padding: 2px 36px 12px; /* room for fade */
        animation: projectsMarquee 34s linear infinite;
        will-change: transform;
      }
      .projectsTrack:hover{ animation-play-state: paused; }

      .projectsTrack .panelCard{
        min-width: 270px;
        border-radius: 26px;
      }
      .projectsTrack .shot{ height: 210px !important; }

      /* keep cards crisp */
      .projectsTrack .panelCard:hover{ transform:none; }
    }

    @media (prefers-reduced-motion: reduce){
      .projectsRail{ overflow-x:auto; -webkit-overflow-scrolling: touch; }
      .projectsRail::before, .projectsRail::after{ display:none; }
      .projectsTrack{
        animation:none !important;
        display:flex !important;
        gap:12px !important;
        width:max-content !important;
        padding: 2px 2px 12px !important;
      }
      .projectsTrack .panelCard{ min-width: 270px; }
    }

    /* ---------- FAQ (always 1 column) ---------- */
    .faqGrid{
      margin-top:22px;
      display:grid;
      grid-template-columns: 1fr; /* fixed: no 2-column */
      gap:12px;
      align-items:start;
    }
    .faqItem{
      align-self:start;
      border-radius:18px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.03);
      box-shadow: var(--shadow2);
      overflow:hidden;
      position:relative;
    }
    .faqItem::before{
      content:"";
      position:absolute; inset:-2px;
      background: radial-gradient(600px 160px at 20% 0%, rgba(168,85,247,.10), transparent 70%);
      filter: blur(18px);
      opacity:.8;
      pointer-events:none;
    }
    .faqItem > *{ position:relative; z-index:1; }
    .faqBtn{
      width:100%;
      border:0;
      background:transparent;
      color:inherit;
      padding:16px;
      display:flex;
      justify-content:space-between;
      align-items:center;
      gap:12px;
      cursor:pointer;
      text-align:left;
      font-family:inherit;
    }
    .faqBtn .q{ font-weight:600; letter-spacing:-.01em; color: rgba(244,244,245,.92); }
    .faqBtn .meta{
      font-size:11px;
      letter-spacing:.16em;
      text-transform:uppercase;
      color: rgba(244,244,245,.56);
      margin-top:6px;
      display:block;
    }
    .faqIcon{
      width:38px;height:38px;
      border-radius:14px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.18);
      display:grid;
      place-items:center;
      color: rgba(244,244,245,.80);
      flex:0 0 auto;
      transition: transform .28s cubic-bezier(.16,1,.3,1),
                  background .28s cubic-bezier(.16,1,.3,1),
                  border-color .28s cubic-bezier(.16,1,.3,1);
      user-select:none;
    }
    .faqAnswerWrap{ display:grid; grid-template-rows: 0fr; transition: grid-template-rows .34s cubic-bezier(.16,1,.3,1); }
    .faqAnswer{
      overflow:hidden;
      opacity:0;
      transform: translateY(-4px);
      filter: blur(8px);
      transition: opacity .26s cubic-bezier(.16,1,.3,1),
                  transform .26s cubic-bezier(.16,1,.3,1),
                  filter .26s cubic-bezier(.16,1,.3,1);
      padding: 0 16px 0;
    }
    .faqAnswerInner{ padding: 0 0 16px; color: rgba(244,244,245,.70); line-height:1.85; font-size:14px; max-width: 78ch; }
    .faqItem.open .faqAnswerWrap{ grid-template-rows: 1fr; }
    .faqItem.open .faqAnswer{ opacity:1; transform:none; filter: blur(0); }
    .faqItem.open .faqIcon{
      transform: rotate(45deg);
      background: rgba(168,85,247,.10);
      border-color: rgba(168,85,247,.18);
      box-shadow: 0 18px 55px rgba(124,58,237,.12);
    }

    /* ---------- Footer ---------- */
    .footerSimple{
      margin-top:26px;
      padding:18px 0 26px;
      border-top:1px solid rgba(255,255,255,.06);
      display:flex;
      justify-content:space-between;
      align-items:center;
      gap:12px;
      flex-wrap:wrap;
      color: rgba(244,244,245,.52);
      font-size:12px;
    }
    .footerSimple a{ color: rgba(244,244,245,.62); text-decoration:none; }
    .footerSimple a:hover{ color: rgba(244,244,245,.86); }
    .footerLinks{ display:flex; gap:14px; flex-wrap:wrap; }

    a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
      outline:2px solid rgba(168,85,247,.35);
      outline-offset:3px;
      border-radius:12px;
    }

    @media (max-width: 1040px){
      .showcaseGrid{ grid-template-columns: 1fr; }
      .panelCard.side{ opacity:.95; transform:none; }
    }
    @media (max-width: 860px){
      .wrap{ padding:0 16px; } /* better phone padding */
      .nav{ display:none; }
      .menuBtn{ display:inline-flex; align-items:center; justify-content:center; }
      header{ top:10px; }
      .topbar{
        padding:8px 10px;               /* tighter */
        border-radius:16px;
        backdrop-filter: blur(18px);    /* stronger blur on phone */
        -webkit-backdrop-filter: blur(18px);
      }
      .topbarInner{ gap:10px; }
      .logo img{
        width:42px;
        height:42px;
        padding:6px;
        border-radius:14px;
      }
      .actions .btn{ display:none; } /* keep header clean on phones */
    }

    @media (prefers-reduced-motion: reduce){
      html{scroll-behavior:auto}
      *{ transition:none !important; }
      .reveal{ opacity:1 !important; transform:none !important; filter:none !important; }
      .entry{ display:none !important; }
      .drawerPanel{ transition:none !important; }
    }