/* ============================================================
   Triman Kaur — personal site
   Playful · colourful · minimal
   ============================================================ */

:root{
  --cream:#FFF8EF;
  --cream-2:#FFF1E2;
  --ink:#2B2118;
  --ink-soft:#5b4f43;
  --coral:#FF6B6B;
  --sun:#FFC93C;
  --teal:#2EC4B6;
  --grape:#7C5CFF;
  --pink:#FF8FB1;
  --leaf:#7BC950;
  --sky:#4EA8DE;
  --white:#ffffff;
  --shadow: 0 18px 40px -20px rgba(43,33,24,.35);
  --shadow-sm: 0 8px 20px -12px rgba(43,33,24,.4);
  --radius:26px;
  --maxw:1120px;
  --ff-display:"Fredoka", system-ui, sans-serif;
  --ff-body:"Nunito", system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* subtle dotted playful backdrop */
/* decorative tints kept lightweight (no fixed-attachment repaint on scroll) */

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:40px 0;position:relative}
.eyebrow{
  font-family:var(--ff-display);font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;font-size:.78rem;color:var(--coral);
  display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--coral)}
h2.title{
  font-family:var(--ff-display);font-weight:600;line-height:1.08;
  font-size:clamp(1.9rem,4.4vw,3rem);max-width:16ch;margin-bottom:10px;
}
.title .squig{
  background:linear-gradient(transparent 62%, var(--sun) 62% 92%, transparent 92%);
  padding:0 2px;
}
.lede{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(255,248,239,.94);
  border-bottom:1px solid rgba(43,33,24,.06);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{font-family:var(--ff-display);font-weight:600;font-size:1.2rem;display:flex;align-items:center;gap:9px}
.brand .dot{width:14px;height:14px;border-radius:50%;background:var(--coral);box-shadow:6px 0 0 var(--sun),12px 0 0 var(--teal)}
.brand span{margin-left:14px}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{
  font-family:var(--ff-display);font-weight:500;font-size:.95rem;
  padding:8px 14px;border-radius:999px;transition:.2s;color:var(--ink-soft)
}
.nav-links a:hover{background:var(--ink);color:var(--cream)}
.nav-links a.cta{background:var(--coral);color:#fff}
.nav-links a.cta:hover{background:var(--ink)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;font-size:1.6rem;color:var(--ink)}

/* ---------- hero ---------- */
.hero{
  min-height:100svh;display:flex;align-items:center;position:relative;
  padding:120px 0 90px;overflow:hidden;color:#fff;isolation:isolate;
}
.hero-bg,.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-3}
.hero-bg{
  background:linear-gradient(135deg,#7C5CFF,#2EC4B6 55%,#FFC93C);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-2;
  background:linear-gradient(180deg, rgba(20,14,8,.35), rgba(20,14,8,.62));
}
.hero .wrap{position:relative;z-index:2}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:7px 16px;
  font-family:var(--ff-display);font-weight:500;font-size:.86rem;margin-bottom:22px;
}
.hero-badge .pulse{width:9px;height:9px;border-radius:50%;background:var(--leaf);box-shadow:0 0 0 0 rgba(123,201,80,.7);animation:pulse 2.2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 12px rgba(123,201,80,0)}100%{box-shadow:0 0 0 0 rgba(123,201,80,0)}}
.hero h1{
  font-family:var(--ff-display);font-weight:600;line-height:1;
  font-size:clamp(3rem,9vw,6rem);letter-spacing:-.01em;margin-bottom:8px;
}
.hero h1 .hi{display:inline-block;transform-origin:70% 70%;animation:wave 2.6s ease-in-out infinite}
@keyframes wave{0%,60%,100%{transform:rotate(0)}20%{transform:rotate(16deg)}40%{transform:rotate(-8deg)}}
.hero .quote{
  font-family:var(--ff-display);font-weight:400;font-style:italic;
  font-size:clamp(1.15rem,2.5vw,1.7rem);max-width:26ch;margin:6px 0 20px;
  text-wrap:balance;
}
.hero .quote b{font-weight:600;color:var(--sun)}
.hero .teaser{max-width:56ch;font-size:1.08rem;color:rgba(255,255,255,.94)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.btn{
  font-family:var(--ff-display);font-weight:500;font-size:1rem;
  padding:14px 26px;border-radius:999px;cursor:pointer;border:0;
  transition:transform .15s, box-shadow .2s, background .2s;display:inline-flex;align-items:center;gap:9px;
}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--coral);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--sun);color:var(--ink)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.scroll-cue{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  font-family:var(--ff-display);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:6px;opacity:.85;z-index:2;
}
.scroll-cue .m{width:22px;height:34px;border:2px solid #fff;border-radius:12px;position:relative}
.scroll-cue .m::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:4px;height:7px;border-radius:3px;background:#fff;animation:mouse 1.5s infinite}
@keyframes mouse{0%{opacity:0;top:6px}30%{opacity:1}100%{opacity:0;top:18px}}

/* floating doodles */
.doodle{position:absolute;z-index:1;opacity:.9;pointer-events:none;animation:float 7s ease-in-out infinite}
.doodle.d2{animation-duration:9s}
.doodle.d3{animation-duration:6s}
@keyframes float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(8deg)}}

/* ---------- marquee ---------- */
.marquee{padding:26px 0;overflow:hidden;background:var(--ink);position:relative}
.marquee-row{display:flex;gap:16px;width:max-content;animation:scrollx 60s linear infinite}
.marquee-row.rev{animation-direction:reverse;animation-duration:70s;margin-top:16px}
.marquee:hover .marquee-row{animation-play-state:paused}
.marquee-row img{
  height:170px;width:250px;object-fit:cover;border-radius:16px;flex:0 0 auto;
  image-orientation:from-image;filter:saturate(1.05);
}
@keyframes scrollx{to{transform:translateX(-50%)}}
.marquee-tag{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;
  font-family:var(--ff-display);font-weight:600;color:#fff;background:var(--coral);
  padding:10px 22px;border-radius:999px;box-shadow:var(--shadow);white-space:nowrap;
  font-size:1.05rem;border:3px solid var(--cream);
}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.about-copy p{margin-bottom:16px;font-size:1.06rem}
.about-copy .kicker{font-family:var(--ff-display);font-size:1.2rem;color:var(--grape);font-weight:600}
.about-invite{
  margin-top:8px;background:var(--cream-2);border:2px dashed var(--pink);
  border-radius:18px;padding:16px 20px;font-family:var(--ff-display);font-weight:500;
}
.about-visual{position:relative}
.caricature{
  width:100%;border-radius:var(--radius);box-shadow:var(--shadow);
  border:6px solid #fff;transform:rotate(-2deg);
}
.about-portrait{
  position:absolute;bottom:-26px;left:-26px;width:38%;border-radius:20px;border:5px solid #fff;
  box-shadow:var(--shadow-sm);transform:rotate(4deg);object-fit:cover;aspect-ratio:1/1;
  image-orientation:from-image;
}
.sticker{
  position:absolute;font-family:var(--ff-display);font-weight:600;font-size:.85rem;
  background:var(--sun);color:var(--ink);padding:7px 13px;border-radius:999px;
  box-shadow:var(--shadow-sm);transform:rotate(7deg);
}

/* ---------- section tinting ---------- */
.tint-teal{background:linear-gradient(180deg,var(--cream),#EAFBF8 60%,var(--cream))}
.tint-grape{background:linear-gradient(180deg,var(--cream),#F1EEFF 55%,var(--cream))}
.tint-pink{background:linear-gradient(180deg,var(--cream),#FFF0F4 55%,var(--cream))}

/* ---------- cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px;margin-top:34px}
.card{
  background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);
  border:1px solid rgba(43,33,24,.06);transition:transform .2s, box-shadow .2s;position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .tagrow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.chip{
  font-family:var(--ff-display);font-weight:500;font-size:.74rem;padding:5px 11px;border-radius:999px;
  background:var(--cream-2);color:var(--ink-soft);border:1px solid rgba(43,33,24,.08)
}
.chip.adv{background:#fff0d6;color:#8a5a00}
.card h3{font-family:var(--ff-display);font-weight:600;font-size:1.24rem;margin-bottom:8px;line-height:1.2}
.card p{color:var(--ink-soft);font-size:1rem}
.card .next{margin-top:12px;font-size:.96rem;color:var(--ink);background:var(--cream-2);border-radius:14px;padding:10px 14px}
.card .next b{color:var(--grape)}
.card-accent{position:absolute;top:0;left:0;height:6px;width:100%}
.a-coral{background:var(--coral)}.a-teal{background:var(--teal)}.a-grape{background:var(--grape)}.a-sun{background:var(--sun)}.a-pink{background:var(--pink)}.a-leaf{background:var(--leaf)}
.card .link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:var(--ff-display);font-weight:600;color:var(--coral)}
.card .link:hover{gap:10px;color:var(--ink)}

/* feature (building toward) */
.feature{
  background:linear-gradient(120deg,var(--grape),var(--teal));color:#fff;border:0;
  grid-column:1/-1;
}
.feature h3{color:#fff;font-size:1.5rem}
.feature p{color:rgba(255,255,255,.95);font-size:1.08rem;max-width:70ch}
.feature .chip{background:rgba(255,255,255,.2);color:#fff;border-color:rgba(255,255,255,.4)}

/* aside note (golinkoff) */
.aside-note{
  margin-top:26px;background:#fff;border-left:6px solid var(--sun);border-radius:16px;
  padding:20px 24px;box-shadow:var(--shadow-sm);display:flex;gap:16px;align-items:flex-start;
}
.aside-note .emoji{font-size:1.8rem;flex:0 0 auto}
.aside-note p{color:var(--ink-soft)}

/* ---------- projects / story ---------- */
.story{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:38px;margin-top:34px;border:1px solid rgba(43,33,24,.06);position:relative;overflow:hidden
}
.story .badge-home{display:inline-flex;gap:8px;align-items:center;font-family:var(--ff-display);font-weight:600;color:var(--teal);margin-bottom:6px}
.story h3{font-family:var(--ff-display);font-weight:600;font-size:1.7rem;line-height:1.12;margin:6px 0 6px}
.story .who{color:var(--ink-soft);font-family:var(--ff-display);margin-bottom:18px}
.story p{margin-bottom:15px;font-size:1.05rem}
.story p .hl{background:linear-gradient(transparent 60%, #ffe08a 60%);padding:0 2px;font-weight:600}
.pullquote{
  font-family:var(--ff-display);font-weight:500;font-size:1.25rem;line-height:1.35;
  color:var(--grape);border-top:2px dashed var(--pink);border-bottom:2px dashed var(--pink);
  padding:18px 0;margin:20px 0;text-wrap:balance;
}
/* udaan year timeline */
.timeline{display:grid;gap:14px;margin:22px 0}
.tl{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.tl .yr{font-family:var(--ff-display);font-weight:600;color:#fff;background:var(--coral);border-radius:14px;padding:8px 14px;min-width:74px;text-align:center;height:fit-content}
.tl:nth-child(2) .yr{background:var(--teal)}
.tl:nth-child(3) .yr{background:var(--grape)}
.tl .tl-b{background:var(--cream-2);border-radius:14px;padding:14px 18px}
.tl .tl-b b{font-family:var(--ff-display)}

/* video embeds */
.videos{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:22px}
.vid{
  position:relative;aspect-ratio:16/9;border-radius:18px;overflow:hidden;cursor:pointer;
  box-shadow:var(--shadow-sm);background:#000;border:3px solid #fff;
}
.vid img{width:100%;height:100%;object-fit:cover;transition:.3s}
.vid:hover img{transform:scale(1.06)}
.vid .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;
  background:linear-gradient(0deg,rgba(0,0,0,.55),rgba(0,0,0,.05));color:#fff;
}
.vid .play .circle{width:58px;height:58px;border-radius:50%;background:var(--coral);display:grid;place-items:center;box-shadow:0 6px 20px rgba(0,0,0,.4);transition:.2s}
.vid:hover .play .circle{transform:scale(1.1);background:var(--sun)}
.vid .play .lbl{font-family:var(--ff-display);font-weight:600}
.vid iframe{width:100%;height:100%;border:0}

/* moments (autoplay candid videos) */
.moments{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:26px}
.moments video{width:100%;aspect-ratio:9/13;object-fit:cover;border-radius:18px;border:3px solid #fff;box-shadow:var(--shadow-sm)}

/* ---------- carousel (fade) ---------- */
.carousel{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff;aspect-ratio:4/5}
.carousel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s ease;image-orientation:from-image}
.carousel img.active{opacity:1}
.carousel .dots{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:2}
.carousel .dots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.55)}
.carousel .dots i.on{background:#fff;width:20px;border-radius:6px}

/* ---------- recognition ---------- */
.recog-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.honors{display:grid;gap:16px}
.honor{background:#fff;border-radius:20px;padding:20px 22px;box-shadow:var(--shadow-sm);border-left:6px solid var(--sun);display:flex;gap:16px;align-items:flex-start}
.honor:nth-child(2){border-left-color:var(--teal)}
.honor:nth-child(3){border-left-color:var(--pink)}
.honor .medal{font-size:1.8rem}
.honor h4{font-family:var(--ff-display);font-weight:600;font-size:1.1rem;margin-bottom:3px}
.honor p{color:var(--ink-soft);font-size:.98rem}
.bev-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.bev-gallery img,.bev-gallery video{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center;border-radius:16px;box-shadow:var(--shadow-sm);image-orientation:from-image;display:block}
.bev-gallery img:first-child{grid-column:1/-1;aspect-ratio:16/10}

/* ---------- interests ---------- */
.fun-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;margin-top:34px}
.fun{border-radius:var(--radius);padding:24px;color:#fff;position:relative;overflow:hidden;min-height:180px;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:var(--shadow-sm)}
.fun.dogs{background:linear-gradient(140deg,var(--leaf),var(--teal))}
.fun.ball{background:linear-gradient(140deg,var(--coral),var(--sun))}
.fun.wnba{background:linear-gradient(140deg,var(--grape),var(--pink))}
.fun .big{font-size:2.2rem;line-height:1;margin-bottom:10px}
.fun h4{font-family:var(--ff-display);font-weight:600;font-size:1.3rem;margin-bottom:5px}
.fun p{font-size:.98rem;color:rgba(255,255,255,.95)}
.dogs-strip{grid-column:1/-1;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:4px}
.dogs-strip img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:18px;border:4px solid #fff;box-shadow:var(--shadow-sm);image-orientation:from-image}
@media (max-width:700px){ .dogs-strip{grid-template-columns:repeat(2,1fr)} }

/* ---------- extras / uyff ---------- */
.uyff{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:34px;border:1px solid rgba(43,33,24,.06)}
.uyff .lede{margin-bottom:10px}
details.reader{margin-top:14px;border-top:2px dashed var(--pink);padding-top:14px}
details.reader summary{
  font-family:var(--ff-display);font-weight:600;color:var(--coral);cursor:pointer;font-size:1.05rem;
  list-style:none;display:flex;align-items:center;gap:8px
}
details.reader summary::-webkit-details-marker{display:none}
details.reader summary .arw{transition:.2s}
details.reader[open] summary .arw{transform:rotate(90deg)}
.essay{margin-top:18px;max-width:70ch;font-size:1.02rem}
.essay h5{font-family:var(--ff-display);font-weight:600;color:var(--grape);margin:18px 0 4px}
.essay p{margin-bottom:12px;color:var(--ink-soft)}
.essay .sp{font-weight:600;color:var(--ink)}
.essay hr{border:0;border-top:1px dashed rgba(43,33,24,.2);margin:18px 0}
.essay .close{font-family:var(--ff-display);font-weight:600;color:var(--teal);font-size:1.1rem;text-align:center;margin-top:16px}

/* ---------- contact ---------- */
.contact{background:linear-gradient(140deg,var(--ink),#3a2c1e);color:var(--cream);border-radius:0}
.contact .title{color:#fff}
.contact .lede{color:rgba(255,248,239,.85)}
.contact-links{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.clink{
  display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.22);border-radius:16px;padding:14px 20px;
  font-family:var(--ff-display);font-weight:500;transition:.2s
}
.clink:hover{transform:translateY(-4px);background:#fff;color:var(--ink);border-color:#fff}
.clink .ico{font-size:1.2rem}
.contact-note{margin-top:26px;font-family:var(--ff-display);color:rgba(255,248,239,.7)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(255,248,239,.7);text-align:center;padding:30px 0;font-size:.9rem}
footer .heart{color:var(--coral)}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .nav-links{
    position:fixed;inset:66px 0 auto 0;flex-direction:column;background:var(--cream);
    padding:14px 22px 22px;gap:8px;box-shadow:var(--shadow);transform:translateY(-140%);
    transition:transform .3s;align-items:stretch
  }
  .nav-links.open{transform:none}
  .nav-links a{padding:12px 16px}
  .nav-toggle{display:block}
  .about-grid,.recog-grid{grid-template-columns:1fr;gap:34px}
  .about-portrait{width:34%}
  .story{padding:26px}
  section{padding:32px 0}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   Additions — round 2
   ============================================================ */

/* story subheads */
.story .subhead{
  font-family:var(--ff-display);font-weight:600;font-size:1.15rem;color:var(--coral);
  margin:22px 0 6px;display:flex;align-items:center;gap:9px
}
.story .subhead::before{content:"";width:22px;height:3px;border-radius:3px;background:var(--coral)}
.story:nth-of-type(2) .subhead{color:var(--teal)}
.story:nth-of-type(2) .subhead::before{background:var(--teal)}

/* pink theme chips */
.chip.pk{background:#FFE3EC;color:#c23b6b;border-color:#ffc2d6}

/* centered / small pullquote before videos */
.pullquote.center{text-align:center;max-width:60ch;margin-left:auto;margin-right:auto;font-size:1.12rem;color:var(--teal)}
.pullquote.center b{color:var(--grape)}

/* recognition gallery — show heads, not necks */
.bev-gallery img{object-position:center top}

/* AI / vibe-coding interest card */
.fun.ai{background:linear-gradient(140deg,var(--sky),var(--grape))}

/* full-width project card (Sprout) */
.card.wide{grid-column:1/-1}

/* research "reach out" note — full-width horizontal */
.card.reach{grid-column:1/-1}
.card.reach .tagrow .chip{background:#eafaf7;color:#12897c;border-color:#b9ece4}

/* uyff intro fills the box */
.uyff .lede{max-width:none}

/* STEM video under Sprout */
.stem-wrap{margin-top:24px;display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.stem-vid{width:250px;aspect-ratio:9/16;object-fit:cover;border-radius:18px;border:4px solid #fff;box-shadow:var(--shadow-sm);background:#000}
.stem-cap{font-family:var(--ff-display);color:var(--ink-soft);font-size:.9rem;margin:0}

/* contact intro spans wider so it reads in ~3 lines */
.contact .lede{max-width:78ch}

/* long project headline: wider + a touch smaller so it fits ~2 lines */
.title.compact{max-width:52ch;font-size:clamp(1.5rem,3vw,2.05rem);line-height:1.18}

/* technical-skills subheading inside the toolkit card */
.skill-sub{font-family:var(--ff-display);font-weight:600;font-size:1rem;color:var(--ink-soft);margin:18px 0 10px;padding-top:14px;border-top:1px dashed rgba(43,33,24,.14)}

/* research interests pill strip */
.interests-strip{margin-top:26px}
.strip-h{font-family:var(--ff-display);font-weight:600;font-size:1.15rem;color:var(--grape);margin-bottom:12px}

/* ---------- skills ---------- */
.skill-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:34px}
.skill-card{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);border:1px solid rgba(43,33,24,.06);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}
.skill-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.skill-card h3{font-family:var(--ff-display);font-weight:600;font-size:1.25rem;margin-bottom:15px}
.skill-card.wide{grid-column:1/-1}
.skill-card.wide p{color:var(--ink-soft);font-size:1.06rem;max-width:80ch}
.skill-card.qualities{grid-column:1/-1;background:linear-gradient(120deg,var(--grape),var(--coral));color:#fff;border:0}
.skill-card.qualities h3{color:#fff}
.pills{display:flex;flex-wrap:wrap;gap:9px}
.pills span{font-family:var(--ff-display);font-weight:500;font-size:.94rem;padding:9px 15px;border-radius:999px;background:var(--cream-2);color:var(--ink);border:1.5px solid rgba(43,33,24,.08);transition:transform .12s}
.pills span:hover{transform:translateY(-2px) rotate(-1.5deg)}
.pills span:nth-child(6n+1){background:#FFE3EC;border-color:#ffc2d6;color:#c23b6b}
.pills span:nth-child(6n+2){background:#E7F7F4;border-color:#b9ece4;color:#12897c}
.pills span:nth-child(6n+3){background:#FFF0D6;border-color:#ffe0a3;color:#8a5a00}
.pills span:nth-child(6n+4){background:#EEE9FF;border-color:#d8ccff;color:#5b43c9}
.pills span:nth-child(6n+5){background:#E8F5DC;border-color:#cfe9b3;color:#4e7a1e}
.pills span:nth-child(6n+6){background:#E3F1FF;border-color:#c2ddff;color:#2e6bb0}
.skill-card.qualities .pills span{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.42)}
@media (max-width:860px){ .skill-grid{grid-template-columns:1fr} }

/* ============================================================
   Floating assistant + contact widget
   ============================================================ */
.fab{
  position:fixed;right:20px;bottom:20px;z-index:80;display:flex;align-items:center;gap:10px;
  background:var(--coral);color:#fff;border:0;cursor:pointer;border-radius:999px;
  padding:14px 20px;font-family:var(--ff-display);font-weight:600;font-size:1rem;
  box-shadow:0 14px 30px -8px rgba(255,107,107,.6);transition:transform .18s, background .2s;
}
.fab:hover{transform:translateY(-3px) scale(1.02);background:var(--grape)}
.fab .fab-emoji{font-size:1.25rem;animation:wave 2.6s ease-in-out infinite;transform-origin:70% 70%}
.fab.hide{transform:translateY(140%);opacity:0;pointer-events:none}

.fab-nudge{
  position:fixed;right:20px;bottom:78px;z-index:79;max-width:240px;background:#fff;color:var(--ink);
  border-radius:16px 16px 4px 16px;padding:12px 15px;box-shadow:var(--shadow);
  font-size:.92rem;font-family:var(--ff-body);border:2px solid var(--sun);
  opacity:0;transform:translateY(10px) scale(.96);transition:.25s;pointer-events:none
}
.fab-nudge.show{opacity:1;transform:none;pointer-events:auto}
.fab-nudge b{font-family:var(--ff-display)}
.fab-nudge .x{position:absolute;top:6px;right:9px;cursor:pointer;color:var(--ink-soft);font-weight:700}

.asst-overlay{
  position:fixed;inset:0;z-index:90;background:rgba(20,14,8,.45);backdrop-filter:blur(3px);
  display:flex;align-items:flex-end;justify-content:flex-end;padding:18px;
  opacity:0;pointer-events:none;transition:opacity .25s
}
.asst-overlay.open{opacity:1;pointer-events:auto}
.asst{
  width:min(410px,96vw);max-height:min(86vh,760px);background:var(--cream);border-radius:24px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;
  transform:translateY(16px) scale(.98);transition:.25s
}
.asst-overlay.open .asst{transform:none}
.asst-head{
  background:linear-gradient(120deg,var(--grape),var(--teal));color:#fff;padding:16px 18px;
  display:flex;align-items:center;gap:12px
}
.asst-head .av{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid #fff;image-orientation:from-image}
.asst-head h4{font-family:var(--ff-display);font-weight:600;font-size:1.05rem;line-height:1.1}
.asst-head p{font-size:.8rem;opacity:.9}
.asst-head .close{margin-left:auto;background:rgba(255,255,255,.2);border:0;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.1rem}
.asst-body{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:10px}
.msg{max-width:85%;padding:11px 15px;border-radius:16px;font-size:.96rem;line-height:1.5}
.msg.bot{background:#fff;box-shadow:var(--shadow-sm);border-bottom-left-radius:5px;align-self:flex-start}
.msg.me{background:var(--grape);color:#fff;border-bottom-right-radius:5px;align-self:flex-end}
.msg.bot a{color:var(--coral);font-weight:700}
.chips-q{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}
.chips-q button{
  font-family:var(--ff-display);font-weight:500;font-size:.85rem;cursor:pointer;
  background:#fff;border:1.5px solid var(--pink);color:var(--ink);border-radius:999px;padding:8px 13px;transition:.15s
}
.chips-q button:hover{background:var(--pink);color:#fff}
.asst-foot{padding:12px 14px;border-top:1px solid rgba(43,33,24,.08);background:#fff}
.asst-foot .row{display:flex;gap:8px;margin-bottom:8px}
.asst-foot input,.asst-foot textarea{
  width:100%;font-family:var(--ff-body);font-size:.92rem;border:1.5px solid rgba(43,33,24,.15);
  border-radius:12px;padding:10px 12px;resize:none
}
.asst-foot textarea{min-height:56px}
.asst-foot .send{
  width:100%;background:var(--coral);color:#fff;border:0;border-radius:12px;padding:12px;
  font-family:var(--ff-display);font-weight:600;font-size:1rem;cursor:pointer;transition:.2s
}
.asst-foot .send:hover{background:var(--grape)}
.asst-foot .hint{font-size:.78rem;color:var(--ink-soft);text-align:center;margin-top:7px}
.asst-foot .mini{font-size:.82rem;color:var(--coral);font-weight:700;cursor:pointer;background:none;border:0;font-family:var(--ff-display)}
.hidden{display:none !important}

@media (max-width:520px){
  .fab span.lbl{display:none}
  .asst-overlay{padding:0}
  .asst{width:100vw;max-height:88vh;border-radius:24px 24px 0 0}
}
