/* ============================================================
   KUNAAL PORTFOLIO — STYLES
   All colors live in the :root variables below. Change a value
   there and it updates everywhere it's used on the site.
   ============================================================ */

:root{
    --forest:#1E3226;
    --forest-deep:#152219;
    --cream:#F4EEDE;
    --cream-2:#EAE1CB;
    --amber:#E7A83F;
    --rust:#D9572B;
    --ink:#14140F;
    --line: rgba(244,238,222,0.16);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--cream);
    color:var(--ink);
    font-family:'Work Sans', sans-serif;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none;}
  ::selection{background:var(--amber);color:var(--ink);}

  .eyebrow{
    font-family:'Space Mono', monospace;
    font-size:0.72rem;
    letter-spacing:0.18em;
    text-transform:uppercase;
    opacity:0.7;
  }

  /* ---------- NAV ---------- */
  nav{
    position:sticky; top:0; z-index:50;
    display:flex; align-items:center; justify-content:space-between;
    padding:22px 6%;
    background:var(--forest);
    border-bottom:1px solid var(--line);
  }
  .logo{
    display:flex; align-items:center; gap:10px;
    color:var(--cream);
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:1.15rem;
  }
  .logo span{
    color:var(--amber);
    font-size:1.4rem;
  }
  .nav-links{
    display:flex; align-items:center; gap:34px;
    font-size:0.92rem;
  }
  .nav-links a{color:var(--cream); opacity:0.85; transition:opacity .2s;}
  .nav-links a:hover{opacity:1; color:var(--amber);}
  .nav-cta{
    background:var(--amber);
    color:var(--ink) !important;
    padding:9px 20px;
    border-radius:999px;
    font-weight:600;
    opacity:1 !important;
  }
  .nav-cta:hover{background:var(--rust); color:var(--cream) !important;}
  .burger{display:none;}

  /* ---------- HERO ---------- */
  .hero{
    position:relative;
    background:var(--forest);
    color:var(--cream);
    padding:90px 6% 70px;
    overflow:hidden;
  }
  .ghost-type{
    position:absolute;
    top:6%;
    left:0; right:0;
    text-align:center;
    font-family:'Fraunces', serif;
    font-weight:900;
    font-size:min(15vw, 165px);
    line-height:0.85;
    color:transparent;
    -webkit-text-stroke:1px rgba(244,238,222,0.14);
    letter-spacing:-2px;
    white-space:nowrap;
    pointer-events:none;
    user-select:none;
  }
  .hero-grid{
    position:relative;
    display:grid;
    grid-template-columns:1.15fr 0.85fr;
    gap:40px;
    align-items:center;
    margin-top:40px;
  }
  .hero-copy .eyebrow{color:var(--amber); opacity:1; margin-bottom:18px; display:block;}
  .hero-copy h1{
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:clamp(2.4rem, 5vw, 3.6rem);
    line-height:1.08;
    margin-bottom:22px;
  }
  .hero-copy h1 em{
    font-style:italic;
    font-weight:500;
    color:var(--amber);
  }
  .hero-copy p{
    max-width:480px;
    font-size:1.03rem;
    line-height:1.65;
    color:rgba(244,238,222,0.82);
    margin-bottom:32px;
  }
  .hero-btns{display:flex; gap:16px; flex-wrap:wrap;}
  .btn{
    display:inline-flex; align-items:center; gap:8px;
    padding:13px 26px;
    border-radius:999px;
    font-weight:600;
    font-size:0.92rem;
    border:1px solid transparent;
    transition:all .2s ease;
  }
  .btn-solid{background:var(--amber); color:var(--ink);}
  .btn-solid:hover{background:var(--rust); color:var(--cream); transform:translateY(-2px);}
  .btn-outline{border-color:rgba(244,238,222,0.4); color:var(--cream);}
  .btn-outline:hover{border-color:var(--amber); color:var(--amber); transform:translateY(-2px);}

  .hero-photo-wrap{
    position:relative;
    justify-self:center;
  }
  .hero-photo-frame{
    position:relative;
    width:300px;
    height:390px;
    border-radius:6px;
    overflow:hidden;
    background:var(--cream-2);
    box-shadow:14px 14px 0 var(--rust);
  }
  .hero-photo-frame img{
    width:100%; height:100%; object-fit:cover; display:block;
    filter:grayscale(15%) contrast(1.05);
  }
  .stamp{
    position:absolute;
    bottom:-22px; left:-26px;
    background:var(--amber);
    color:var(--ink);
    font-family:'Space Mono', monospace;
    font-size:0.68rem;
    letter-spacing:0.08em;
    text-transform:uppercase;
    padding:10px 14px;
    border-radius:4px;
    transform:rotate(-6deg);
    box-shadow:0 6px 14px rgba(0,0,0,0.25);
  }

  .tool-strip{
    position:relative;
    margin-top:64px;
    padding-top:26px;
    border-top:1px solid var(--line);
    display:flex; flex-wrap:wrap; gap:14px 34px;
    justify-content:center;
    opacity:0.75;
    font-family:'Space Mono', monospace;
    font-size:0.78rem;
    letter-spacing:0.05em;
  }

  /* ---------- SECTION SHELL ---------- */
  section{padding:90px 6%;}
  .section-head{
    display:flex; align-items:flex-end; justify-content:space-between;
    flex-wrap:wrap; gap:16px;
    margin-bottom:48px;
  }
  .section-head h2{
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:clamp(1.8rem, 3.4vw, 2.6rem);
  }
  .section-num{
    font-family:'Space Mono', monospace;
    font-size:0.85rem;
    opacity:0.5;
  }

  /* ---------- ABOUT ---------- */
  .about{background:var(--cream);}
  .about-grid{
    display:grid;
    grid-template-columns:0.9fr 1.1fr;
    gap:60px;
  }
  .about-lead{
    font-family:'Fraunces', serif;
    font-size:clamp(1.3rem, 2.4vw, 1.7rem);
    line-height:1.5;
    font-weight:500;
  }
  .about-lead .accent{color:var(--rust); font-style:italic;}
  .about-facts{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px 30px;
  }
  .fact{
    border-top:2px solid var(--ink);
    padding-top:12px;
  }
  .fact h4{
    font-family:'Space Mono', monospace;
    font-size:0.7rem;
    letter-spacing:0.1em;
    text-transform:uppercase;
    opacity:0.55;
    margin-bottom:8px;
  }
  .fact p{font-size:0.98rem; line-height:1.5;}

  /* ---------- SKILLS ---------- */
  .skills{background:var(--forest); color:var(--cream);}
  .skills .section-head h2{color:var(--cream);}
  .skills .section-num{color:var(--cream); opacity:0.5;}
  .skill-cols{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:36px;
  }
  .skill-col h3{
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:1.1rem;
    color:var(--amber);
    margin-bottom:16px;
    padding-bottom:10px;
    border-bottom:1px solid var(--line);
  }
  .tag-row{display:flex; flex-wrap:wrap; gap:9px;}
  .tag{
    font-size:0.82rem;
    padding:7px 13px;
    border:1px solid rgba(244,238,222,0.3);
    border-radius:999px;
    color:rgba(244,238,222,0.9);
  }
  .skill-col.wide{grid-column:span 1;}

  /* ---------- EXPERIENCE ---------- */
  .experience{background:var(--cream-2);}
  .timeline{border-left:2px solid var(--ink); margin-left:6px;}
  .tl-item{
    position:relative;
    padding:0 0 46px 34px;
  }
  .tl-item:last-child{padding-bottom:0;}
  .tl-dot{
    position:absolute; left:-9px; top:2px;
    width:16px; height:16px;
    background:var(--rust);
    transform:rotate(45deg);
    border:2px solid var(--cream-2);
  }
  .tl-date{
    font-family:'Space Mono', monospace;
    font-size:0.78rem;
    color:var(--rust);
    letter-spacing:0.03em;
    display:block;
    margin-bottom:6px;
  }
  .tl-item h3{
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:1.3rem;
    margin-bottom:4px;
  }
  .tl-item .role-meta{
    font-size:0.88rem;
    opacity:0.65;
    margin-bottom:14px;
  }
  .tl-item ul{padding-left:18px; line-height:1.7; font-size:0.96rem;}
  .tl-item ul li{margin-bottom:6px;}

  /* ---------- EDU + CERT ---------- */
  .split{
    background:var(--cream);
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:70px;
  }
  .split h2{
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:1.6rem;
    margin-bottom:26px;
  }
  .edu-block{
    border:1px solid rgba(20,20,15,0.15);
    border-radius:10px;
    padding:24px 26px;
    margin-bottom:18px;
  }
  .edu-block .tl-date{color:var(--rust); margin-bottom:8px;}
  .edu-block h3{font-family:'Fraunces', serif; font-size:1.15rem; margin-bottom:4px;}
  .edu-block p{font-size:0.9rem; opacity:0.7;}
  .cert-list{display:flex; flex-direction:column; gap:14px;}
  .cert-item{
    display:flex; gap:14px; align-items:flex-start;
    padding-bottom:14px;
    border-bottom:1px dashed rgba(20,20,15,0.2);
    font-size:0.95rem;
    line-height:1.5;
  }
  .cert-item .dot{
    min-width:8px; height:8px; border-radius:50%;
    background:var(--amber);
    margin-top:7px;
  }

  /* ---------- CONTACT ---------- */
  .contact{
    background:var(--forest);
    color:var(--cream);
    text-align:center;
    position:relative;
    overflow:hidden;
  }
  .contact .eyebrow{color:var(--amber); display:block; margin-bottom:14px;}
  .contact h2{
    font-family:'Fraunces', serif;
    font-weight:600;
    font-size:clamp(2rem, 5vw, 3.2rem);
    margin-bottom:18px;
  }
  .contact h2 em{color:var(--amber); font-style:italic; font-weight:500;}
  .contact p.sub{
    max-width:460px; margin:0 auto 44px;
    color:rgba(244,238,222,0.75);
    line-height:1.6;
  }
  .icon-row{
    display:flex; justify-content:center; gap:16px; flex-wrap:wrap;
  }
  .icon-pill{
    display:flex; align-items:center; gap:10px;
    background:rgba(244,238,222,0.06);
    border:1px solid rgba(244,238,222,0.22);
    padding:13px 22px;
    border-radius:999px;
    font-size:0.9rem;
    font-weight:500;
    transition:all .2s ease;
  }
  .icon-pill:hover{
    background:var(--amber);
    color:var(--ink);
    border-color:var(--amber);
    transform:translateY(-3px);
  }
  .icon-pill svg{width:18px; height:18px; flex-shrink:0;}

  footer{
    background:var(--forest-deep);
    color:rgba(244,238,222,0.5);
    text-align:center;
    padding:26px 6%;
    font-family:'Space Mono', monospace;
    font-size:0.75rem;
    letter-spacing:0.04em;
    border-top:1px solid var(--line);
  }

  /* ---------- STATEMENT STRIP (black & white marquee) ---------- */
  .statement-strip{
    background:#0b0b0a;
    color:#fff;
    overflow:hidden;
    padding:20px 0;
    border-top:1px solid rgba(255,255,255,0.12);
    border-bottom:1px solid rgba(255,255,255,0.12);
  }
  .statement-track{
    display:flex;
    width:max-content;
    animation:strip-scroll 34s linear infinite;
    will-change:transform;
  }
  .statement-track span{
    font-family:'Space Mono', monospace;
    font-weight:700;
    font-size:0.95rem;
    letter-spacing:0.14em;
    text-transform:uppercase;
    white-space:nowrap;
    padding:0 30px;
  }
  @keyframes strip-scroll{
    from{transform:translateX(-50%);}
    to{transform:translateX(0%);}
  }

  /* ---------- PROJECTS MARQUEE ---------- */
  .projects{background:var(--cream-2); padding:90px 0;}
  .projects .section-head{padding:0 6%;}
  .marquee-viewport{width:100%; overflow:hidden; padding:12px 0 8px;}
  .marquee-track{
    display:flex;
    gap:26px;
    width:max-content;
    padding:0 6%;
    animation:proj-scroll 48s linear infinite;
  }
  .marquee-viewport:hover .marquee-track,
  .marquee-viewport:focus-within .marquee-track{
    animation-play-state:paused;
  }
  @keyframes proj-scroll{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
  }
  .proj-card{
    position:relative;
    flex:0 0 auto;
    width:min(300px, 68vw);
    aspect-ratio:1/1;
    border-radius:8px;
    overflow:hidden;
    display:block;
    box-shadow:8px 8px 0 rgba(20,20,15,0.12);
    transition:transform .15s ease, box-shadow .15s ease;
  }
  .proj-card:hover, .proj-card:focus-visible{
    box-shadow:14px 14px 0 rgba(20,20,15,0.18);
    outline:none;
  }
  .proj-media{
    position:absolute; inset:0;
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:10px; text-align:center; padding:20px;
    color:rgba(244,238,222,0.85);
  }
  .proj-media img, .proj-media video{
    position:absolute; inset:0;
    width:100%; height:100%; object-fit:cover; display:block;
  }
  .proj-media .placeholder-icon{width:32px; height:32px; opacity:0.85;}
  .proj-media .placeholder-txt{
    font-family:'Space Mono', monospace;
    font-size:0.7rem; letter-spacing:0.06em; text-transform:uppercase;
    opacity:0.85; max-width:180px;
  }
  .proj-card:nth-child(6n+1) .proj-media{background:linear-gradient(150deg, var(--forest), var(--forest-deep));}
  .proj-card:nth-child(6n+2) .proj-media{background:linear-gradient(150deg, var(--rust), #a83f1f);}
  .proj-card:nth-child(6n+3) .proj-media{background:linear-gradient(150deg, var(--amber), #b97e26);}
  .proj-card:nth-child(6n+4) .proj-media{background:linear-gradient(150deg, var(--forest-deep), var(--ink));}
  .proj-card:nth-child(6n+5) .proj-media{background:linear-gradient(150deg, #8a4a30, var(--rust));}
  .proj-card:nth-child(6n+0) .proj-media{background:linear-gradient(150deg, #7c6a2e, var(--amber));}
  .proj-overlay{
    position:absolute; left:0; right:0; bottom:0;
    padding:16px 18px;
    background:linear-gradient(to top, rgba(20,20,15,0.85), transparent);
    color:var(--cream);
  }
  .proj-overlay .proj-tag{
    font-family:'Space Mono', monospace;
    font-size:0.66rem; letter-spacing:0.1em; text-transform:uppercase;
    opacity:0.8; display:block; margin-bottom:4px;
  }
  .proj-overlay h3{font-family:'Fraunces', serif; font-weight:600; font-size:1.02rem;}

  /* ---------- REVIEWS ---------- */
  .reviews{background:var(--cream);}
  .review-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:26px;}
  .review-card{
    background:var(--cream-2);
    border:1px solid rgba(20,20,15,0.1);
    border-radius:10px;
    padding:26px 26px 22px;
    transition:transform .15s ease, box-shadow .15s ease;
  }
  .review-card:hover{box-shadow:0 10px 24px rgba(20,20,15,0.12);}
  .review-stars{color:var(--amber); font-size:0.9rem; letter-spacing:2px; margin-bottom:12px;}
  .review-quote{
    font-family:'Fraunces', serif;
    font-size:1.02rem; line-height:1.55; font-style:italic;
    margin-bottom:20px;
  }
  .review-person{display:flex; align-items:center; gap:12px;}
  .review-avatar{
    width:42px; height:42px; border-radius:50%; flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    font-family:'Space Mono', monospace; font-weight:700; font-size:0.85rem;
    color:var(--cream);
  }
  .review-card:nth-child(4n+1) .review-avatar{background:var(--forest);}
  .review-card:nth-child(4n+2) .review-avatar{background:var(--rust);}
  .review-card:nth-child(4n+3) .review-avatar{background:var(--amber); color:var(--ink);}
  .review-card:nth-child(4n+0) .review-avatar{background:var(--forest-deep);}
  .review-name{font-weight:600; font-size:0.92rem;}
  .review-role{font-size:0.8rem; opacity:0.6;}

  @media (max-width:860px){
    .nav-links{display:none;}
    .hero-grid{grid-template-columns:1fr;}
    .hero-photo-wrap{order:-1; margin-bottom:20px;}
    .about-grid{grid-template-columns:1fr;}
    .skill-cols{grid-template-columns:1fr;}
    .split{grid-template-columns:1fr;}
    .ghost-type{font-size:22vw;}
    .review-grid{grid-template-columns:1fr;}
  }
