/* ============================================================
   André Engel — Shared Stylesheet
   Eingebunden in: index.html, impressum.html, datenschutz.html
   Eingebunden in: page/projekt-*.html  →  href="../style.css"
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;700;800&family=Montserrat:wght@300;400;500;600&display=swap');

/* ── Reset & Variablen ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#00E5FF;
  --tr:0,229,255;
  --bg:#05050a;
  --text:#efefef;
  --muted:rgba(200,200,200,0.5);
  --fd:'Syne',sans-serif;
  --fb:'Montserrat',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--fb);overflow-x:hidden;line-height:1.7;font-size:15px;}

/* ── Noise-Overlay ── */
.noise{
  position:fixed;inset:0;z-index:999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:0.022;
}

/* ── Aurora-Hintergrund ── */
.aurora{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;}
.blob{position:absolute;border-radius:50%;filter:blur(90px);}
.b1{width:65vw;height:65vw;background:radial-gradient(circle,rgba(0,229,255,0.11) 0%,transparent 70%);top:-15vw;right:-15vw;animation:f1 28s ease-in-out infinite;}
.b2{width:45vw;height:45vw;background:radial-gradient(circle,rgba(0,60,180,0.08) 0%,transparent 70%);bottom:-8vw;left:-12vw;animation:f2 35s ease-in-out infinite;}
.b3{width:35vw;height:35vw;background:radial-gradient(circle,rgba(0,229,255,0.06) 0%,transparent 70%);top:45%;left:38%;animation:f3 22s ease-in-out infinite;}
@keyframes f1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-2vw,3vw) scale(1.06)}66%{transform:translate(2vw,-2vw) scale(0.94)}}
@keyframes f2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(3vw,-2vw) scale(1.08)}66%{transform:translate(-2vw,3vw) scale(0.92)}}
@keyframes f3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-3vw,-3vw) scale(1.12)}}

/* ── Page-Glow (Cursor-Tracking) ── */
#pglow{position:fixed;top:0;left:0;width:0;height:0;pointer-events:none;z-index:1;will-change:transform;}
#pglow::after{
  content:'';position:absolute;width:1000px;height:1000px;
  border-radius:50%;transform:translate(-50%,-50%);
  background:radial-gradient(500px circle at 50% 50%,rgba(0,229,255,0.048) 0%,rgba(0,229,255,0.015) 45%,transparent 100%);
  pointer-events:none;
}

/* ── App-Wrapper ── */
#app{position:relative;z-index:2;}

/* ── Glass-Cards ── */
.glass{
  background:rgba(255,255,255,0.028);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-radius:20px;position:relative;
}
.glass::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(500px circle at var(--mx,-9999px) var(--my,-9999px),
    rgba(0,229,255,0.048) 0%,rgba(0,229,255,0.015) 45%,transparent 100%);
  pointer-events:none;z-index:0;
}
.glass::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  border:1px solid transparent;
  background:linear-gradient(135deg,rgba(var(--tr),0.35),rgba(255,255,255,0.05) 45%,rgba(255,255,255,0.02)) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:destination-out;mask-composite:exclude;
  pointer-events:none;
}

/* ── Navigation ── */
nav{
  position:sticky;top:0;z-index:50;
  padding:1.1rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(5,5,10,0.75);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.nav-logo{font-family:var(--fd);font-weight:800;font-size:1rem;letter-spacing:0.08em;color:var(--text);text-decoration:none;}
.nav-logo .dot{color:var(--teal);}
.nav-logo img{height:32px;width:auto;display:block;}
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{font-size:0.7rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.2s;}
.nav-links a:hover{color:var(--text);}
.nav-burger{display:none;}
.nav-mobile{display:none;}

/* ── Pills & Section-Tags ── */
.pill{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.38rem 1rem;
  background:rgba(var(--tr),0.08);border:1px solid rgba(var(--tr),0.2);
  border-radius:100px;font-size:0.68rem;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--teal);margin-bottom:2rem;
}
.pill-dot{width:5px;height:5px;border-radius:50%;background:var(--teal);box-shadow:0 0 6px rgba(var(--tr),0.9);animation:blink 2s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.s-tag{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.32rem 0.85rem;
  background:rgba(var(--tr),0.07);border:1px solid rgba(var(--tr),0.16);
  border-radius:100px;font-size:0.62rem;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--teal);margin-bottom:1.1rem;
}
.s-title{font-family:var(--fd);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700;line-height:1.05;letter-spacing:-0.02em;margin-bottom:0.5rem;}

/* ── Buttons ── */
.btn-glow{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.82rem 1.85rem;background:var(--teal);color:#000;
  border-radius:100px;border:none;cursor:pointer;text-decoration:none;
  font-family:var(--fb);font-size:0.74rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;
  box-shadow:0 0 22px rgba(var(--tr),0.4),0 0 60px rgba(var(--tr),0.12);
  transition:box-shadow 0.3s,transform 0.2s;
}
.btn-glow:hover{box-shadow:0 0 35px rgba(var(--tr),0.6),0 0 90px rgba(var(--tr),0.22);transform:translateY(-2px);}
.btn-ghost{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.82rem 1.85rem;background:rgba(255,255,255,0.04);color:var(--text);
  border-radius:100px;border:1px solid rgba(255,255,255,0.1);
  cursor:pointer;text-decoration:none;
  font-family:var(--fb);font-size:0.74rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;
  transition:border-color 0.2s,background 0.2s;
}
.btn-ghost:hover{border-color:rgba(var(--tr),0.35);background:rgba(var(--tr),0.05);}

/* ── Footer ── */
footer{
  padding:1.5rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid rgba(255,255,255,0.05);
  flex-wrap:wrap;gap:0.75rem;
}
.f-logo{font-family:var(--fd);font-size:0.85rem;font-weight:800;letter-spacing:0.06em;}
.f-logo .dot{color:var(--teal);}
.f-copy{font-size:0.68rem;color:var(--muted);}
.f-links{display:flex;gap:1.5rem;}
.f-links a{font-size:0.68rem;color:var(--muted);text-decoration:none;letter-spacing:0.06em;transition:color 0.2s;}
.f-links a:hover{color:var(--text);}

/* ── Animationen ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease;}
.anim.in{opacity:1;transform:none;}
.d1{transition-delay:.12s}.d2{transition-delay:.22s}.d3{transition-delay:.32s}

/* ── Scroll Indicator ── */
.scroll-indicator{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;cursor:pointer;opacity:0;animation:fadeUp 0.8s 1s forwards;z-index:10;}
.scroll-indicator:hover .scroll-dot{box-shadow:0 0 12px rgba(var(--tr),1);}
.scroll-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 6px rgba(var(--tr),0.9);}
.scroll-arrow{display:flex;flex-direction:column;gap:3px;}
.scroll-arrow span{display:block;width:10px;height:10px;border-right:1.5px solid rgba(var(--tr),0.7);border-bottom:1.5px solid rgba(var(--tr),0.7);transform:rotate(45deg);animation:arrowPulse 1.8s ease-in-out infinite;}
.scroll-arrow span:nth-child(2){animation-delay:0.2s;opacity:0.5;}
@keyframes arrowPulse{0%,100%{opacity:0.3;transform:rotate(45deg) translateY(-2px)}50%{opacity:1;transform:rotate(45deg) translateY(2px)}}

/* ── Link-Farben (nur Fließtext, nicht Buttons/Nav) ── */
a{text-decoration:none;}
.btn-glow{color:#000;}
.btn-glow:hover{color:#000;}
.btn-ghost{color:var(--text);}
.nav-links a{color:var(--muted);}
.nav-links a:hover{color:var(--teal);opacity:1;}
.nav-mobile a{color:var(--text);}
.f-links a{color:var(--muted);}
.f-links a:hover{color:var(--text);opacity:1;}
.bcard{color:inherit;}
.cb-p{color:#000;}
.cb-p:hover{color:#000;}
.motiv {text-align: center;}

/* ── Dot-Grid (Hero) ── */
.dot-grid{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,0.07) 1px,transparent 1px);background-size:32px 32px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);}

/* ── Hero ── */
#hero{height:calc(100vh - 60px);display:grid;grid-template-columns:1fr 0.8fr;align-items:center;gap:4rem;padding:0 3rem;position:relative;overflow:hidden;}
.hero-name{font-family:var(--fd);font-size:clamp(3.5rem,7vw,7rem);font-weight:800;line-height:0.92;letter-spacing:-0.03em;margin-bottom:1.75rem;}
.hero-name .ln1{display:block;color:var(--text);}
.hero-name .ln2{display:block;color:transparent;background:linear-gradient(100deg,var(--teal) 0%,rgba(var(--tr),0.45) 100%);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 28px rgba(var(--tr),0.35));}
.hero-sub{font-size:0.92rem;font-weight:300;color:var(--muted);max-width:380px;line-height:1.85;margin-bottom:2.5rem;}
.hero-btns{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;}
.hero-card-stack{display:flex;flex-direction:column;gap:0.85rem;}
.hcard{padding:1.5rem;position:relative;z-index:1;}
.hcard-label{font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(var(--tr),0.7);margin-bottom:1rem;}
.hcard-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
.stat-n{font-family:var(--fd);font-size:2.2rem;font-weight:800;color:var(--teal);line-height:1;margin-bottom:0.15rem;}
.stat-l{font-size:0.68rem;color:var(--muted);letter-spacing:0.06em;}
.loc-row{display:flex;align-items:center;gap:0.5rem;font-size:0.78rem;color:var(--muted);margin-top:0.4rem;}
.loc-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px rgba(var(--tr),0.7);flex-shrink:0;}
.chips{display:flex;flex-wrap:wrap;gap:0.4rem;}
.chip{padding:0.28rem 0.72rem;background:rgba(var(--tr),0.07);border:1px solid rgba(var(--tr),0.15);border-radius:100px;font-size:0.63rem;font-weight:500;color:rgba(var(--tr),0.9);letter-spacing:0.06em;}
.statement-card{padding:1.25rem 1.5rem;position:relative;z-index:1;}
.statement-top{display:flex;align-items:center;gap:0.85rem;margin-bottom:1rem;}
.icon-ring{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:rgba(var(--tr),0.12);border:1px solid rgba(var(--tr),0.25);display:flex;align-items:center;justify-content:center;box-shadow:0 0 16px rgba(var(--tr),0.15);}
.icon-ring svg{width:18px;height:18px;fill:var(--teal);}
.statement-title{font-family:var(--fd);font-size:0.92rem;font-weight:700;letter-spacing:0.04em;color:var(--text);}
.statement-line{height:1px;background:linear-gradient(90deg,rgba(var(--tr),0.5),transparent);margin-bottom:1rem;}
.statement-attrs{display:flex;flex-direction:column;gap:0.45rem;}
.s-attr{display:flex;align-items:center;gap:0.6rem;font-size:0.73rem;color:var(--muted);}
.s-attr::before{content:'';width:3px;height:3px;border-radius:50%;background:rgba(var(--tr),0.7);box-shadow:0 0 5px rgba(var(--tr),0.5);flex-shrink:0;}

/* Hero-Animationen */
.he1{opacity:0;animation:fadeUp 0.8s 0.1s forwards;}
.he2{opacity:0;animation:fadeUp 0.8s 0.25s forwards;}
.he3{opacity:0;animation:fadeUp 0.8s 0.4s forwards;}
.he4{opacity:0;animation:fadeUp 0.8s 0.55s forwards;}
.he5{opacity:0;animation:fadeUp 0.9s 0.65s forwards;}

/* ── Showreel ── */
.reel-wrap{padding:0 3rem 4rem;}
.reel-box{aspect-ratio:21/5;border-radius:24px;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative;background:rgba(0,0,0,0.5);}
.reel-glow{position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(var(--tr),0.07) 0%,transparent 70%);}
.reel-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.25rem;}
.play-btn{width:76px;height:76px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(var(--tr),0.1);border:1px solid rgba(var(--tr),0.3);box-shadow:0 0 30px rgba(var(--tr),0.15);cursor:pointer;transition:all 0.3s;}
.play-btn:hover{background:rgba(var(--tr),0.2);box-shadow:0 0 50px rgba(var(--tr),0.3);transform:scale(1.06);}
.play-btn svg{width:26px;height:26px;fill:var(--teal);margin-left:4px;}
.reel-txt{font-family:var(--fd);font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);}

/* ── Works / Bento ── */
.works-section{padding:5rem 3rem;}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem;flex-wrap:wrap;gap:1rem;}
.section-head p{font-size:0.87rem;color:var(--muted);max-width:300px;line-height:1.7;}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;}
.bcard{border-radius:20px;overflow:hidden;cursor:pointer;transition:transform 0.3s;text-decoration:none;color:inherit;display:block;}
.bcard:hover{transform:translateY(-4px);}
.bcard:nth-child(1){grid-column:span 7;}.bcard:nth-child(2){grid-column:span 5;}.bcard:nth-child(3){grid-column:span 5;}.bcard:nth-child(4){grid-column:span 7;}
.bcard-thumb{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.bcard-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,0.55) 100%);}
.bt1{background:linear-gradient(145deg,#04141c,#003d52);}.bt2{background:linear-gradient(145deg,#040e18,#001a3d);}
.bt3{background:linear-gradient(145deg,#0e0e04,#2a2900);}.bt4{background:linear-gradient(145deg,#0c0418,#1e0040);}
.bcard-thumb .ph{font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.1);font-family:var(--fd);position:relative;z-index:1;}
.bcard-body{padding:1.1rem 1.35rem 1.35rem;}
.btag{font-size:0.62rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);margin-bottom:0.35rem;display:block;}
.btitle{font-family:var(--fd);font-size:1rem;font-weight:700;margin-bottom:0.3rem;}
.bdesc{font-size:0.8rem;color:var(--muted);line-height:1.6;}

/* ── About ── */
.about-section{padding:5rem 3rem;}
.about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:4.5rem;align-items:center;margin-top:3rem;}
.about-img{aspect-ratio:3/4;max-height:480px;width:100%;border-radius:24px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.about-text p{font-size:0.9rem;color:var(--muted);line-height:1.9;margin-bottom:1rem;}
.about-text p strong{color:var(--text);font-weight:500;}
.career{display:flex;flex-direction:column;gap:0.6rem;margin-top:2rem;}
.c-item{display:flex;align-items:center;gap:1rem;padding:0.85rem 1.1rem;}
.c-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.c-role{font-size:0.82rem;font-weight:500;}
.c-co{font-size:0.74rem;color:var(--muted);margin-left:auto;}

/* ── Skills ── */
.skills-section{padding:5rem 3rem;}
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem;}
.scard{padding:2rem;position:relative;transition:transform 0.3s;}
.scard:hover{transform:translateY(-3px);}
.scard-line{position:absolute;top:0;left:1.5rem;right:1.5rem;height:1px;background:linear-gradient(90deg,rgba(var(--tr),0.6),transparent);}
.scard-title{font-family:var(--fd);font-size:0.78rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--teal);margin-bottom:1.25rem;position:relative;z-index:1;}
.scard-list{list-style:none;display:flex;flex-direction:column;gap:0.6rem;position:relative;z-index:1;}
.scard-list li{font-size:0.87rem;color:rgba(200,200,200,0.68);font-weight:300;display:flex;align-items:center;gap:0.7rem;}
.scard-list li::before{content:'';width:3px;height:3px;border-radius:50%;background:rgba(var(--tr),0.6);box-shadow:0 0 5px rgba(var(--tr),0.4);flex-shrink:0;}

/* ── Contact ── */
.contact-section{padding:5rem 3rem;text-align:center;}
.contact-inner{max-width:520px;margin:3rem auto 0;padding:3rem 2.5rem;}
.contact-inner p{font-size:0.9rem;color:var(--muted);line-height:1.75;margin-bottom:2rem;position:relative;z-index:1;}
.contact-btns{display:flex;flex-direction:column;gap:0.75rem;position:relative;z-index:1;}
.cb{display:flex;align-items:center;justify-content:center;gap:0.65rem;padding:0.9rem;border-radius:12px;font-size:0.74rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;text-decoration:none;transition:all 0.2s;}
.cb svg{width:15px;height:15px;fill:currentColor;flex-shrink:0;}
.cb-p{background:var(--teal);color:#000;box-shadow:0 0 18px rgba(var(--tr),0.28);}
.cb-p:hover{opacity:0.9;box-shadow:0 0 32px rgba(var(--tr),0.48);}
.cb-g{background:rgba(255,255,255,0.025);color:var(--text);border:1px solid rgba(255,255,255,0.09);}
.cb-g:hover{border-color:rgba(var(--tr),0.3);color:var(--teal);}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* ── TABLET (≤ 768px) ── */
@media (max-width: 768px) {

  nav { padding: 1rem 1.5rem; }
  .nav-links { display: none; }

  .nav-burger {
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 4px;
    background: none;
    border: none;
  }
  .nav-burger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text);
    border-radius: 2px;
    transition: all 0.3s;
  }

  .nav-mobile {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 49;
    background: rgba(5,5,10,0.97);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2.5rem;
  }
  .nav-mobile.open { display: flex; }
  .nav-mobile a {
    font-family: var(--fd);
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text);
    text-decoration: none;
    transition: color 0.2s;
  }
  .nav-mobile a:hover { color: var(--teal); }
  .nav-mobile-close {
    position: absolute;
    top: 1.2rem;
    right: 1.5rem;
    background: none;
    border: none;
    color: var(--muted);
    font-size: 1.8rem;
    cursor: pointer;
    line-height: 1;
  }

  #hero {
    grid-template-columns: 1fr;
    height: auto;
    padding: 4rem 1.5rem 3rem;
    gap: 2.5rem;
  }
  .hero-name { font-size: clamp(3rem, 11vw, 5rem); }
  .he5 { width: 100%; }
  .hcard-row { grid-template-columns: 1fr 1fr; }

  .reel-wrap { padding: 0 1.5rem 3rem; }

  .works-section { padding: 4rem 1.5rem; }
  .bento { grid-template-columns: 1fr 1fr; gap: 0.85rem; }
  .bcard:nth-child(1),
  .bcard:nth-child(2),
  .bcard:nth-child(3),
  .bcard:nth-child(4) { grid-column: span 1; }

  .about-section { padding: 4rem 1.5rem; }
  .about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .about-img { max-height: 340px; aspect-ratio: 4/3; }

  .skills-section { padding: 4rem 1.5rem; }
  .skills-grid { grid-template-columns: 1fr 1fr; }

  .contact-section { padding: 4rem 1.5rem; }
  .contact-inner { padding: 2rem 1.5rem; }

  footer {
    padding: 1.25rem 1.5rem;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }

  .scroll-indicator { bottom: 3rem; }
}

/* ── MOBILE (≤ 480px) ── */
@media (max-width: 480px) {

.c-item { 
  display: grid;
  grid-template-columns: 16px 1fr;
  grid-template-rows: auto auto;
  align-items: center;
  gap: 0 0.6rem;
}
.c-dot {
  grid-row: 1;
  grid-column: 1;
  align-self: center;
}
.c-role {
  grid-row: 1;
  grid-column: 2;
}
.c-co {
  grid-row: 2;
  grid-column: 2;
  margin-left: 0;
  width: auto;
}
  nav { padding: 0.9rem 1.25rem; }

  #hero { padding: 3rem 1.25rem 2.5rem; gap: 2rem; }
  .hero-name { font-size: clamp(2.6rem, 13vw, 4rem); margin-bottom: 1.25rem; }
  .hero-sub { font-size: 0.85rem; max-width: 100%; }
  .hero-btns { flex-direction: column; align-items: stretch; }
  .hero-btns .btn-glow,
  .hero-btns .btn-ghost { justify-content: center; }
  .pill { font-size: 0.6rem; }

  .hero-card-stack { gap: 0.65rem; }
  .hcard { padding: 1.1rem; }
  .hcard-row { grid-template-columns: 1fr 1fr; gap: 0.75rem; }
  .stat-n { font-size: 1.7rem; }
  .chips { gap: 0.3rem; }
  .chip { font-size: 0.58rem; padding: 0.22rem 0.6rem; }

  .bento { grid-template-columns: 1fr; }
  .bcard:nth-child(n) { grid-column: span 1; }

  .about-img { max-height: 280px; aspect-ratio: 1/1; }

  .skills-grid { grid-template-columns: 1fr; }

  .works-section,
  .about-section,
  .skills-section { padding: 3rem 1.25rem; }
  .contact-section { padding: 3rem 1.25rem; }
  .contact-inner { padding: 1.5rem 1.1rem; }
  .reel-wrap { padding: 0 1.25rem 2.5rem; }

  .s-title { font-size: clamp(1.5rem, 7vw, 2.2rem); }

  footer { padding: 1rem 1.25rem; }
  .f-links { gap: 1rem; }

  .scroll-indicator { display: none; }
}

.scard-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}
.skill-dots {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.skill-dots .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.skill-dots .dot.filled {
  background: var(--teal);
  box-shadow: 0 0 5px rgba(var(--tr), 0.7);
}
.skill-dots .dot.empty {
  background: rgba(var(--tr), 0.12);
  border: 1px solid rgba(var(--tr), 0.25);
}

.scard-list li::before {
  display: none;
}