/* Tarin Filipec — shared styles */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{
  --surface:#fff8f1;
  --surface-container:#f6ede2;
  --surface-container-high:#efe4d4;
  --surface-container-highest:#e8dcc8;
  --surface-container-low:#fbf3e8;
  --on-surface:#1d1b16;
  --on-surface-variant:#4f4639;
  --primary:#911207;
  --primary-container:#b8281b;
  --on-primary:#fff8f1;
  --on-primary-container:#ffdcd6;
  --secondary:#6e5c3f;
}
body{
  font-family:'Noto Serif',Georgia,serif;
  background:var(--surface);
  color:var(--on-surface);
  overflow-x:hidden;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.font-display{font-family:'Gaegu',cursive}
.font-serif-body{font-family:'Noto Serif',Georgia,serif}
.font-label{font-family:'Plus Jakarta Sans',system-ui,sans-serif;letter-spacing:.05em}
.font-numeric{font-family:'Bricolage Grotesque',sans-serif;font-weight:300}

/* Layout helpers */
.container{max-width:1280px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 32px}}

/* Nav */
.nav{position:fixed;top:0;left:0;width:100%;z-index:50;background:rgba(255,248,241,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.nav-inner{display:flex;justify-content:space-between;align-items:center;padding:16px 20px}
@media(min-width:768px){.nav-inner{padding:16px 32px}}
.brand{font-family:'Noto Serif',serif;font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--on-surface)}
.nav-links{display:none;gap:32px;align-items:center}
@media(min-width:768px){.nav-links{display:flex}}
.nav-link{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;text-transform:uppercase;color:var(--on-surface-variant);transition:color .2s}
.nav-link:hover{color:var(--primary)}
.nav-link.active{color:var(--primary);font-weight:700;border-bottom:2px solid var(--primary);padding-bottom:2px}
.btn-pill{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;text-transform:uppercase;background:var(--primary);color:var(--on-primary);padding:8px 24px;border-radius:9999px;transition:all .2s;border:0;cursor:pointer}
.btn-pill:hover{background:var(--primary-container)}
.btn-pill:active{transform:scale(.95)}

/* Footer */
.footer{background:var(--surface-container-highest);width:100%;padding:48px 20px;display:flex;flex-direction:column;justify-content:space-between;align-items:center;gap:16px}
@media(min-width:768px){.footer{flex-direction:row;padding:48px 32px}}
.footer-brand{font-family:'Noto Serif',serif;font-size:24px;font-weight:700}
.footer-links{display:flex;gap:32px;align-items:center}
.footer-link{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--on-surface-variant);text-decoration:underline}
.footer-link:hover{color:var(--primary)}

/* Hero */
main{padding-top:0}
.hero{position:relative;min-height:100vh;padding:128px 0 80px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
@media(min-width:768px){.hero{justify-content:center}}
.bg-numeral{position:absolute;top:-40px;left:-40px;font-family:'Bricolage Grotesque',sans-serif;font-size:240px;line-height:200px;color:var(--on-surface);opacity:.08;user-select:none;pointer-events:none}
.asterisk-float{position:absolute;top:20%;right:10%;animation:float 6s ease-in-out infinite;color:var(--primary);font-size:64px;font-family:'Material Symbols Outlined'}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes spin-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.spin-slow{animation:spin-slow 12s linear infinite;display:inline-block}
.title-xl{font-family:'Gaegu',cursive;font-size:96px;line-height:84px;color:var(--primary);letter-spacing:-.02em;margin:0}
@media(min-width:768px){.title-xl{font-size:192px;line-height:160px;margin-left:-8px}}
.hero-grid{margin-top:48px;display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
@media(min-width:768px){.hero-grid{grid-template-columns:repeat(12,1fr);margin-top:64px}}
.hero-text{display:flex;flex-direction:column;gap:24px}
@media(min-width:768px){.hero-text{grid-column:span 5}}
.lead{font-family:'Noto Serif',serif;font-size:24px;line-height:32px;color:var(--on-surface-variant);max-width:28rem;margin:0}
.btn-cta{align-self:flex-start;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;text-transform:uppercase;background:var(--on-surface);color:var(--surface);padding:20px 40px;border-radius:9999px;transition:background .3s}
.btn-cta:hover{background:var(--primary)}
.hero-img-wrap{position:relative;overflow:hidden;border-radius:12px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);transition:transform .5s;aspect-ratio:3/4}
.hero-img-wrap:hover{transform:scale(1.02)}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover}
@media(min-width:768px){.hero-text{grid-column:span 8}.hero-img-col{grid-column:span 4}}
.hero-img-wrap{width:215px;max-width:60vw;margin-left:auto;margin-top:-16px}
@media(min-width:768px){.hero-img-wrap{width:245px;margin-top:0}.hero-img-col{margin-top:-32px}}

/* Philosophy */
.philosophy{background:var(--primary);padding:120px 0;color:var(--surface);text-align:center;position:relative;overflow:hidden}
.philosophy-tag{display:inline-flex;align-items:center;gap:16px;margin-bottom:16px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;letter-spacing:.2em}
.philosophy h2{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;color:var(--surface);margin:8px auto}
@media(min-width:768px){.philosophy h2{font-size:112px;line-height:100px}}
.philosophy p{font-family:'Noto Serif',serif;font-size:18px;line-height:28px;color:var(--on-primary-container);max-width:32rem;margin:16px auto 0}
.btn-outline{margin-top:24px;display:inline-block;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;text-transform:uppercase;border:1px solid var(--surface);color:var(--surface);padding:16px 32px;border-radius:9999px;background:transparent;cursor:pointer;transition:all .2s}
.btn-outline:hover{background:var(--surface);color:var(--primary)}

/* Process */
.process{padding:120px 0;background:var(--surface)}
.process-head{display:flex;flex-direction:column;justify-content:space-between;align-items:baseline;margin-bottom:80px}
@media(min-width:768px){.process-head{flex-direction:row}}
.section-num{font-family:'Bricolage Grotesque',sans-serif;font-size:120px;line-height:1;color:var(--primary);opacity:.2;margin-bottom:16px}
.section-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;color:var(--on-surface);margin:0}
@media(min-width:768px){.section-title{font-size:112px;line-height:100px}}
.cards{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:768px){.cards{grid-template-columns:repeat(3,1fr)}}
.card{padding:40px;display:flex;flex-direction:column;gap:32px;transition:background .5s,color .5s;background:var(--surface-container)}
.card.alt{background:var(--surface-container-high)}
.card:hover{background:var(--primary);color:var(--surface)}
.card .icon{font-family:'Material Symbols Outlined';font-size:48px;color:var(--primary);transition:color .5s}
.card:hover .icon{color:var(--surface)}
.card h3{font-family:'Noto Serif',serif;font-size:24px;font-weight:600;margin:0 0 16px}
.card p{font-family:'Noto Serif',serif;font-size:18px;line-height:28px;color:var(--on-surface-variant);margin:0;transition:color .5s}
.card:hover p,.card:hover h3{color:var(--on-primary-container)}
.card:hover h3{color:var(--surface)}

/* Contact */
.contact-section{position:relative;padding:80px 20px;max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px;align-items:start}
@media(min-width:1024px){.contact-section{grid-template-columns:repeat(12,1fr);padding:80px 32px}}
.contact-left{display:flex;flex-direction:column;gap:48px;position:relative;z-index:10}
@media(min-width:1024px){.contact-left{grid-column:span 5}}
.contact-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;color:var(--primary);margin:0}
@media(min-width:768px){.contact-title{font-size:112px;line-height:100px}}
.contact-info{display:flex;flex-direction:column;gap:32px;margin-top:16px}
.info-label{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--secondary);text-transform:uppercase}
.info-val{font-family:'Noto Serif',serif;font-size:24px;color:var(--on-surface)}
.info-val.link{color:var(--primary)}
.info-val.link:hover{text-decoration:underline}
.contact-right{background:var(--surface-container-low);padding:48px;border-radius:8px;position:relative}
@media(min-width:1024px){.contact-right{grid-column:span 7;padding:64px}}
.form{display:flex;flex-direction:column;gap:48px;position:relative;z-index:10}
.field{display:flex;flex-direction:column;gap:12px}
.field label{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--on-surface-variant);text-transform:uppercase;transition:color .2s}
.field:focus-within label{color:var(--primary)}
.field input,.field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--on-surface-variant);padding:12px 0;font-family:'Noto Serif',serif;font-size:24px;color:var(--on-surface);outline:none;resize:none}
.field input:focus,.field textarea:focus{border-color:var(--primary)}
.btn-submit{position:relative;background:var(--primary);color:var(--on-primary);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;letter-spacing:.2em;padding:24px 48px;border:0;cursor:pointer;transition:all .2s;width:100%;text-align:left}
@media(min-width:768px){.btn-submit{width:auto}}
.btn-submit:active{transform:scale(.95)}

/* Experience */
.exp-section{padding:128px 20px 80px;max-width:1280px;margin:0 auto}
@media(min-width:768px){.exp-section{padding:128px 32px 80px}}
.exp-grid{display:grid;grid-template-columns:1fr;gap:48px;margin-top:64px}
@media(min-width:768px){.exp-grid{grid-template-columns:repeat(12,1fr)}}
.exp-item{padding:32px;background:var(--surface-container);border-left:4px solid var(--primary)}
@media(min-width:768px){.exp-item{grid-column:span 6}}
.exp-role{font-family:'Noto Serif',serif;font-size:22px;font-weight:700;margin:0 0 4px}
.exp-org{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--secondary);text-transform:uppercase;margin-bottom:12px}
.exp-desc{font-family:'Noto Serif',serif;color:var(--on-surface-variant);margin:0}

/* Portfolio */
.work-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-top:64px}
@media(min-width:768px){.work-grid{grid-template-columns:repeat(2,1fr)}}
.work-card{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:8px}
.work-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.work-card:hover img{transform:scale(1.05)}
.work-meta{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff}
.work-meta h3{font-family:'Noto Serif',serif;font-size:24px;margin:0 0 4px}
.work-meta span{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;opacity:.85}

.material-symbols-outlined{font-family:'Material Symbols Outlined';font-weight:normal;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:'liga';-webkit-font-smoothing:antialiased}


/* Portfolio page */
.portfolio-header{position:relative;min-height:520px;display:flex;flex-direction:column;justify-content:flex-end;padding:128px 0 64px;border-bottom:1px solid var(--surface-container-high)}
.portfolio-bgnum{position:absolute;top:80px;right:-20px;font-family:'Bricolage Grotesque',sans-serif;font-size:240px;line-height:200px;opacity:.05;pointer-events:none;user-select:none}
@media(min-width:768px){.portfolio-bgnum{right:40px}}
.portfolio-tag{display:inline-flex;align-items:center;gap:16px;margin-bottom:16px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--secondary);text-transform:uppercase;letter-spacing:.2em}
.portfolio-tag .material-symbols-outlined{color:var(--primary);font-size:36px}
.portfolio-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;color:var(--primary);margin:0;max-width:56rem}
@media(min-width:768px){.portfolio-title{font-size:110px;line-height:100px}}
.portfolio-filters{display:flex;flex-wrap:wrap;gap:12px;margin-top:48px}
.filter{padding:12px 32px;border-radius:9999px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;text-transform:uppercase;border:1px solid var(--surface-container-highest);background:transparent;color:var(--on-surface);cursor:pointer;transition:all .2s}
.filter:hover{background:var(--surface-container)}
.filter.active{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}
.project-hero{position:relative;width:100%;height:720px;overflow:hidden;background:var(--on-surface)}
@media(min-width:768px){.project-hero{height:921px}}
.project-hero-img{width:100%;height:100%;object-fit:cover;opacity:.8}
.project-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--on-surface),transparent 60%);opacity:.6}
.project-hero-content{position:absolute;bottom:0;left:0;width:100%;padding:48px 20px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;z-index:10;gap:24px}
@media(min-width:768px){.project-hero-content{padding:48px 32px;flex-direction:row}}
.project-hero-text{max-width:42rem;color:var(--surface)}
.project-hero-tag{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;opacity:.8;text-transform:uppercase;letter-spacing:.2em;margin-bottom:16px;display:block}
.project-hero-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;margin:0 0 24px}
@media(min-width:768px){.project-hero-title{font-size:110px;line-height:100px}}
.project-hero-body{font-family:'Noto Serif',serif;font-size:18px;line-height:28px;opacity:.9;max-width:32rem;margin-bottom:32px}
.project-hero-link{display:inline-flex;align-items:center;gap:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;text-transform:uppercase;border-bottom:1px solid var(--surface);padding-bottom:4px;color:var(--surface)}
.project-hero-aster{display:none;color:var(--surface);font-size:128px;opacity:.2}
@media(min-width:768px){.project-hero-aster{display:inline-block}}
.project-split{display:flex;flex-direction:column;background:var(--surface)}
@media(min-width:768px){.project-split{flex-direction:row}}
.project-col{width:100%;padding:20px;transition:background .5s}
@media(min-width:768px){.project-col{width:50%;padding:32px}}
.project-col:hover{background:var(--surface-container)}
.project-col.bordered{border-right:1px solid var(--surface-container-high)}
.project-col-img{position:relative;margin-bottom:32px;overflow:hidden;aspect-ratio:4/5}
.project-col-img img{width:100%;height:100%;object-fit:cover}
.project-col-tag{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--primary);text-transform:uppercase;letter-spacing:.2em;margin-bottom:8px}
.project-col-body{font-family:'Noto Serif',serif;font-size:18px;line-height:28px;color:var(--secondary);margin:0 0 24px}
.portfolio-cta{padding:120px 20px;background:var(--surface-container-low);display:flex;flex-direction:column;align-items:center;text-align:center}
.portfolio-cta-tag{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--primary);text-transform:uppercase;letter-spacing:.2em;margin-bottom:24px}
.portfolio-cta-title{font-family:'Gaegu',cursive;font-size:96px;line-height:84px;color:var(--on-surface);margin:0 0 48px}
@media(min-width:768px){.portfolio-cta-title{font-size:192px;line-height:160px}}
.portfolio-cta-email{font-family:'Gaegu',cursive;font-size:32px;color:var(--on-surface);border-bottom:4px solid var(--primary);padding-bottom:8px;transition:color .2s}
@media(min-width:768px){.portfolio-cta-email{font-size:64px}}
.portfolio-cta-email:hover{color:var(--primary)}

/* Experience page (rewrite) */
.exp-hero{position:relative;padding:48px 0;overflow:hidden}
.exp-bgnum{position:absolute;top:40px;right:0;font-family:'Bricolage Grotesque',sans-serif;font-size:240px;line-height:200px;opacity:.1;pointer-events:none;user-select:none}
@media(min-width:768px){.exp-bgnum{right:32px}}
.exp-tag{display:inline-flex;align-items:center;gap:16px;margin-bottom:16px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--primary);text-transform:uppercase;letter-spacing:.2em}
.exp-tag .material-symbols-outlined{color:var(--primary);font-size:36px}
.exp-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;color:var(--primary);margin:0;max-width:56rem}
@media(min-width:768px){.exp-title{font-size:112px;line-height:100px}}
.jobs{padding:48px 0;background:var(--surface)}
.jobs-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:768px){.jobs-grid{grid-template-columns:repeat(3,1fr)}}
.job{border-top:1px solid var(--surface-container-highest);padding-top:16px}
.job-period{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--primary);text-transform:uppercase;display:block;margin-bottom:4px}
.job-role{font-family:'Noto Serif',serif;font-size:24px;font-weight:600;color:var(--on-surface);margin:0 0 4px}
.job-company{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--on-surface-variant);margin:0 0 16px;text-transform:uppercase;letter-spacing:.05em}
.job-body{font-family:'Noto Serif',serif;font-size:18px;line-height:28px;color:var(--on-surface-variant);margin:0}
.education{background:var(--primary);color:var(--on-primary);padding:120px 0;position:relative;overflow:hidden}
.edu-aster-1{position:absolute;top:80px;right:80px;color:var(--on-primary-container);opacity:.2;font-size:128px;user-select:none}
.edu-aster-2{position:absolute;bottom:-40px;left:-40px;color:var(--on-primary-container);opacity:.2;font-size:200px;user-select:none}
.edu-section-tag{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--on-primary-container);text-transform:uppercase;letter-spacing:.2em;display:block;margin-bottom:16px}
.edu-section-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;margin:0;color:var(--on-primary)}
@media(min-width:768px){.edu-section-title{font-size:112px;line-height:100px}}
.edu-grid{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:768px){.edu-grid{grid-template-columns:repeat(2,1fr)}}
.edu-item{border-top:1px solid rgba(255,220,214,.3);padding-top:32px}
.edu-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}
.edu-title{font-family:'Noto Serif',serif;font-size:24px;font-weight:600;margin:0 0 8px;color:var(--on-primary)}
.edu-school{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:rgba(255,220,214,.8);text-transform:uppercase;margin:0}
.edu-year{font-family:'Bricolage Grotesque',sans-serif;font-size:36px;opacity:.5;color:var(--on-primary)}
.edu-body{font-family:'Noto Serif',serif;font-size:18px;line-height:28px;color:rgba(255,220,214,.9);max-width:32rem;margin:0}
.exp-cta{padding:80px 20px;background:var(--surface);text-align:center}
.exp-cta-title{font-family:'Gaegu',cursive;font-size:56px;line-height:52px;color:var(--on-surface);margin:32px 0 48px}
@media(min-width:768px){.exp-cta-title{font-size:112px;line-height:100px}}
