/* ============================================================================
   Emre Portfolio — standard scrolling pages
   Shares the Explored Parallel design tokens with the immersive deck, but for
   normal vertical-scroll content (project detail, work overview, about,
   contact). Loaded on every non-immersive view.
   ========================================================================== */

:root {
  --ep-canvas:#0F2A26;
  --ep-canvas-deep:#0B211E;
  --ep-panel:#143630;
  --ep-cyan:#4FE3CB;
  --ep-brass:#C9A24A;
  --ep-ink:#E7E7EB;
  --ep-mut-1:#CFE3DD;
  --ep-mut-2:#A9C7BF;
  --ep-mut-3:#8FB3AA;
  --ep-mut-4:#6E938B;
  --ep-border:rgba(79,227,203,0.20);
  --ep-glow:0 0 0 1px rgba(79,227,203,0.35), 0 0 30px -4px rgba(79,227,203,0.6), 0 0 70px -14px rgba(57,163,144,0.5);
  --ep-maxw:1180px;
}

html, body.ep-page {
  margin:0;
  min-height:100%;
  background:radial-gradient(120% 120% at 70% 30%, #103029 0%, #0B211E 60%, #081A17 100%) fixed, #0B211E;
  color:var(--ep-ink);
  font-family:'RNS Sanz', sans-serif;
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
body.ep-page { overflow-x:hidden; }
.ep-page *, .ep-page *::before, .ep-page *::after { box-sizing:border-box; }
.ep-page a { color:inherit; }
.ep-page img { max-width:100%; height:auto; display:block; }
::selection { background:var(--ep-cyan); color:var(--ep-canvas); }
.ep-page a:focus-visible, .ep-page button:focus-visible { outline:2px solid var(--ep-cyan); outline-offset:3px; border-radius:4px; }

/* film-grain overlay to match the deck */
body.ep-page::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:0.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

.ep-wrap { max-width:var(--ep-maxw); margin:0 auto; padding:0 7vw; }
.ep-sc { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; text-transform:uppercase; }
.ep-mono { font-family:'JetBrains Mono', monospace; }
.ep-eyebrow { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:13px; letter-spacing:0.2em; color:var(--ep-brass); text-transform:uppercase; }

/* ---------- Site header (nav) ---------- */
.ep-site-header {
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 7vw;
  background:rgba(11,33,30,0.72); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(79,227,203,0.12);
}
.ep-brand { display:flex; align-items:center; gap:12px; text-decoration:none; }
.ep-brand img { width:18px; height:18px; }
.ep-brand span { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:800; font-size:13px; letter-spacing:0.2em; text-transform:uppercase; color:var(--ep-ink); }
.ep-nav { display:flex; align-items:center; gap:28px; margin:0; padding:0; list-style:none; }
.ep-nav li { list-style:none; }
.ep-nav a { display:inline-block; font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-mut-3); text-decoration:none; transition:color .25s; }
.ep-nav a:hover, .ep-nav a.current, .ep-nav .current-menu-item > a { color:var(--ep-cyan); }

/* hamburger toggle — hidden on desktop, shown on mobile */
.ep-nav-toggle { display:none; align-items:center; justify-content:center; width:44px; height:44px; background:transparent; border:1px solid var(--ep-border); border-radius:10px; cursor:pointer; }
.ep-burger, .ep-burger::before, .ep-burger::after { display:block; width:20px; height:2px; background:var(--ep-ink); transition:transform .25s, opacity .25s, top .25s; }
.ep-burger { position:relative; }
.ep-burger::before, .ep-burger::after { content:''; position:absolute; left:0; }
.ep-burger::before { top:-6px; }
.ep-burger::after { top:6px; }
.ep-nav-toggle[aria-expanded="true"] .ep-burger { background:transparent; }
.ep-nav-toggle[aria-expanded="true"] .ep-burger::before { top:0; transform:rotate(45deg); }
.ep-nav-toggle[aria-expanded="true"] .ep-burger::after { top:0; transform:rotate(-45deg); }

/* ---------- Pills / buttons ---------- */
.ep-pill {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--ep-cyan); color:var(--ep-canvas);
  padding:14px 26px; border:0; border-radius:999px;
  font-family:'RNS Sanz',sans-serif; font-weight:600; font-size:15px;
  text-decoration:none; cursor:pointer; box-shadow:var(--ep-glow);
  transition:transform .3s, box-shadow .3s;
}
.ep-pill:hover { transform:translateY(-2px); }
.ep-pill--ghost { background:rgba(15,42,38,0.5); color:var(--ep-ink); box-shadow:0 0 0 1px rgba(79,227,203,0.4); }
.ep-pill--sc { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:11px; letter-spacing:0.16em; text-transform:uppercase; padding:11px 18px; }

/* ---------- Page hero ---------- */
.ep-page-hero { padding:84px 0 40px; }
.ep-page-hero h1 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(40px,7vw,92px); line-height:0.92; letter-spacing:-0.035em; margin:14px 0 0; color:var(--ep-ink); }
.ep-page-hero p.lead { font-size:clamp(17px,2vw,21px); line-height:1.55; color:var(--ep-mut-2); margin:20px 0 0; max-width:60ch; }

/* ---------- Footer ---------- */
.ep-site-footer { position:relative; z-index:2; margin-top:80px; padding:48px 7vw; border-top:1px solid rgba(79,227,203,0.14); display:flex; flex-wrap:wrap; gap:24px; align-items:center; justify-content:space-between; }
.ep-site-footer .ep-mono { font-size:12px; color:#5B7873; }
.ep-foot-links { display:flex; gap:22px; }
.ep-foot-links a { font-family:'RNS Sanz',sans-serif; font-size:14px; color:var(--ep-ink); text-decoration:none; border-bottom:1px solid rgba(79,227,203,0.4); padding-bottom:2px; }

/* ---------- Work overview grid ---------- */
.ep-grid { position:relative; z-index:2; display:grid; grid-template-columns:repeat(auto-fill, minmax(320px,1fr)); gap:28px; padding-bottom:40px; }
.ep-card { display:block; text-decoration:none; color:inherit; }
.ep-card-media { aspect-ratio:4/3; border:1px solid rgba(79,227,203,0.18); border-radius:18px; display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; transition:box-shadow .4s, transform .4s; box-shadow:inset 0 1px 0 rgba(182,242,201,0.14); }
.ep-card:hover .ep-card-media { transform:translateY(-4px); box-shadow:0 0 0 1px rgba(79,227,203,0.5), 0 0 40px -6px rgba(79,227,203,0.5); }
.ep-card-media img.cover { width:100%; height:100%; object-fit:cover; }
.ep-card-media img.logo { max-width:74%; max-height:74%; object-fit:contain; }
.ep-card-media .wordmark { font-family:'RNS Sanz',sans-serif; font-weight:900; font-size:clamp(34px,4vw,52px); letter-spacing:-0.03em; line-height:0.9; }
.ep-card-head { display:flex; align-items:baseline; justify-content:space-between; margin-top:16px; }
.ep-card-head h3 { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:800; font-size:19px; letter-spacing:0.04em; text-transform:uppercase; margin:0; color:var(--ep-ink); }
.ep-card-head .yr { font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--ep-mut-4); }
.ep-card p { font-size:14px; line-height:1.5; color:var(--ep-mut-3); margin:8px 0 0; }
.ep-card .cat { display:block; margin-top:6px; font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-cyan); }

/* ---------- Single project ---------- */
.ep-project-hero { position:relative; z-index:2; padding:60px 0 0; }
.ep-project-cover { border-radius:22px; overflow:hidden; border:1px solid rgba(79,227,203,0.18); aspect-ratio:16/8; display:flex; align-items:center; justify-content:center; margin-top:28px; box-shadow:inset 0 1px 0 rgba(182,242,201,0.14); }
.ep-project-cover img.cover { width:100%; height:100%; object-fit:cover; }
.ep-project-cover img.logo { max-width:42%; max-height:60%; object-fit:contain; }
.ep-project-meta { display:flex; flex-wrap:wrap; gap:32px; margin-top:32px; padding:24px 0; border-top:1px solid rgba(79,227,203,0.16); border-bottom:1px solid rgba(79,227,203,0.16); }
.ep-project-meta .item .k { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-mut-4); }
.ep-project-meta .item .v { font-size:15px; color:var(--ep-ink); margin-top:4px; }
.ep-project-body { position:relative; z-index:2; max-width:760px; margin:40px 0 0; font-size:18px; line-height:1.7; color:var(--ep-mut-2); }
.ep-project-body h2 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(26px,3vw,38px); letter-spacing:-0.02em; color:var(--ep-ink); margin:36px 0 14px; }
.ep-project-body h3 { font-family:'RNS Sanz',sans-serif; font-weight:700; font-size:22px; color:var(--ep-ink); margin:28px 0 10px; }
.ep-project-body a { color:var(--ep-cyan); }
.ep-project-intro { font-size:clamp(20px,2.4vw,26px); line-height:1.5; color:var(--ep-mut-1); max-width:46ch; margin:28px 0 0; letter-spacing:-0.01em; }
.ep-gallery { position:relative; z-index:2; display:grid; grid-template-columns:repeat(auto-fit, minmax(280px,1fr)); gap:18px; margin:44px 0 0; }
.ep-gallery img { width:100%; border-radius:16px; border:1px solid rgba(79,227,203,0.14); }
.ep-project-nav { position:relative; z-index:2; display:flex; justify-content:space-between; gap:18px; margin-top:56px; }

/* ---------- About ---------- */
.ep-about { position:relative; z-index:2; }
.ep-about-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:56px; align-items:start; }
@media (max-width:860px){ .ep-about-grid { grid-template-columns:1fr; gap:32px; } }
.ep-about p { font-size:18px; line-height:1.7; color:var(--ep-mut-2); }
.ep-about .signature { font-family:'Scripter',cursive; font-size:34px; line-height:1; color:var(--ep-cyan); margin:24px 0 0; }
.ep-stats { display:flex; gap:48px; flex-wrap:wrap; margin-top:36px; }
.ep-stats .num { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:42px; letter-spacing:-0.02em; color:var(--ep-cyan); }
.ep-stats .lbl { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-mut-3); margin-top:6px; }
.ep-panel { background:rgba(20,54,48,0.55); border:1px solid var(--ep-border); border-radius:20px; padding:28px 30px; box-shadow:inset 0 1px 0 rgba(182,242,201,0.16); }

/* ---------- Journey list (About default + [ep_journey]) ---------- */
.ep-journey-list { margin-top:18px; display:flex; flex-direction:column; gap:18px; }
.ep-journey-row { border-left:2px solid rgba(79,227,203,0.3); padding-left:14px; }
.ep-journey-row .yr { font-size:11px; color:var(--ep-cyan); }
.ep-journey-row .role { font-weight:600; font-size:15px; color:var(--ep-ink); margin-top:3px; }
.ep-journey-row .org { font-size:13px; color:var(--ep-mut-3); margin-top:2px; }
.ep-journey-row .story { font-size:14px; line-height:1.55; color:var(--ep-mut-2); margin:8px 0 0; }
.ep-jr-chip { display:inline-block; margin-top:8px; font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ep-mut-1); border:1px solid rgba(79,227,203,0.28); border-radius:999px; padding:5px 11px; }

/* ---------- Contact ---------- */
.ep-contact-grid { position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
@media (max-width:860px){ .ep-contact-grid { grid-template-columns:1fr; gap:32px; } }
.ep-form .row { margin-bottom:18px; }
.ep-form label { display:block; font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ep-mut-3); margin-bottom:7px; }
.ep-form input, .ep-form textarea {
  width:100%; background:rgba(20,54,48,0.5); border:1px solid var(--ep-border); border-radius:12px;
  padding:13px 15px; color:var(--ep-ink); font-family:'RNS Sanz',sans-serif; font-size:15px; transition:border-color .25s, box-shadow .25s;
}
.ep-form input:focus, .ep-form textarea:focus { outline:none; border-color:var(--ep-cyan); box-shadow:0 0 0 3px rgba(79,227,203,0.15); }
.ep-form textarea { min-height:140px; resize:vertical; }
.ep-form .notice { padding:13px 16px; border-radius:12px; margin-bottom:18px; font-size:14px; }
.ep-form .notice.ok { background:rgba(79,227,203,0.12); border:1px solid rgba(79,227,203,0.4); color:var(--ep-mut-1); }
.ep-form .notice.err { background:rgba(255,90,54,0.12); border:1px solid rgba(255,90,54,0.45); color:#FFD9CF; }
.ep-contact-aside .line { display:flex; flex-direction:column; gap:4px; margin-bottom:22px; }
.ep-contact-aside .line .k { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-mut-4); }
.ep-contact-aside .line a, .ep-contact-aside .line span.v { font-size:17px; color:var(--ep-ink); text-decoration:none; }
.ep-contact-aside .line a:hover { color:var(--ep-cyan); }

/* ---------- 404 / generic ---------- */
.ep-center { position:relative; z-index:2; min-height:60vh; display:flex; flex-direction:column; align-items:flex-start; justify-content:center; }

/* ---- Scroll reveal (JS adds .ep-reveal then .ep-in) ---- */
.ep-reveal { opacity:0; transform:translateY(24px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); will-change:opacity, transform; }
.ep-reveal.ep-in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) { .ep-reveal { opacity:1 !important; transform:none !important; transition:none !important; } }

/* ---- Skip link (a11y) ---- */
.ep-skip { position:absolute; left:-9999px; top:0; z-index:100; background:var(--ep-cyan); color:var(--ep-canvas); padding:10px 16px; border-radius:0 0 8px 0; font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:12px; letter-spacing:0.12em; text-transform:uppercase; text-decoration:none; }
.ep-skip:focus { left:0; }

/* ---- Elementor full-width canvas template ---- */
.ep-canvas { width:100%; max-width:none; margin:0; padding:0; position:relative; z-index:2; }

/* Seeded/classic content inside the canvas (headings, paragraphs) */
.ep-content { padding-top:clamp(72px,9vw,104px); padding-bottom:56px; }
.ep-content > h1 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(40px,7vw,84px); line-height:0.95; letter-spacing:-0.035em; margin:0 0 16px; color:var(--ep-ink); }
.ep-content > h2 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(26px,3.4vw,40px); line-height:1.05; letter-spacing:-0.02em; margin:44px 0 16px; color:var(--ep-ink); }
.ep-content > p { font-size:clamp(16px,1.9vw,19px); line-height:1.7; color:var(--ep-mut-2); max-width:62ch; margin:0 0 20px; }

/* ============================================================================
   Designed pages: Portfolio / About (CV) / Contact — Explored Parallel style
   ========================================================================== */

.ep-section { margin-top:clamp(48px,7vw,88px); }
.ep-section > .ep-eyebrow { display:block; margin-bottom:22px; }

/* ---------- Portfolio ---------- */
.ep-portfolio-hero { padding-bottom:28px; }
.ep-filter { position:relative; z-index:2; display:flex; flex-wrap:wrap; gap:10px; margin:0 0 30px; }
.ep-filter-btn { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ep-mut-3); background:rgba(20,54,48,0.5); border:1px solid var(--ep-border); border-radius:999px; padding:9px 16px; cursor:pointer; transition:color .25s, border-color .25s, background .25s; }
.ep-filter-btn:hover { color:var(--ep-ink); }
.ep-filter-btn.is-active { color:var(--ep-canvas); background:var(--ep-cyan); border-color:var(--ep-cyan); }
.ep-grid--portfolio .ep-card.is-hidden { display:none; }
.ep-card-media { position:relative; }
.ep-card-overlay { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; gap:4px; padding:18px; text-align:left; background:linear-gradient(to top, rgba(8,26,23,0.92) 0%, rgba(8,26,23,0.45) 45%, transparent 80%); opacity:0; transition:opacity .35s; }
.ep-card:hover .ep-card-overlay { opacity:1; }
.ep-card-overlay .cat { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-cyan); }
.ep-card-overlay .t { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:24px; letter-spacing:-0.02em; color:#fff; line-height:1.05; }
.ep-card-overlay .v { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ep-mut-1); margin-top:4px; }

/* ---------- About / CV ---------- */
.ep-cv-hero { display:grid; grid-template-columns:1.3fr 0.9fr; gap:56px; align-items:center; padding-top:clamp(56px,8vw,96px); }
.ep-cv-hero__text h1 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(40px,6.5vw,80px); line-height:0.95; letter-spacing:-0.035em; margin:14px 0 0; color:var(--ep-ink); }
.ep-cv-hero__text .lead { font-size:clamp(17px,1.9vw,20px); line-height:1.7; color:var(--ep-mut-2); margin:22px 0 0; max-width:56ch; }
.ep-cv-sign { font-family:'Scripter',cursive; font-size:30px; line-height:1; color:var(--ep-cyan); margin:22px 0 0; }
.ep-cv-actions { display:flex; flex-wrap:wrap; align-items:center; gap:24px; margin-top:30px; }
.ep-cv-social { display:flex; flex-wrap:wrap; align-items:center; gap:20px; }
.ep-cv-social a { font-size:15px; color:var(--ep-ink); text-decoration:none; border-bottom:1px solid rgba(79,227,203,0.4); padding-bottom:2px; }
.ep-cv-social a:hover { color:var(--ep-cyan); }
.ep-cv-loc { font-size:12px; color:var(--ep-mut-4); }
.ep-portrait-frame { position:relative; border:1px solid var(--ep-border); border-radius:22px; background:rgba(20,54,48,0.45); box-shadow:inset 0 1px 0 rgba(182,242,201,0.16), 0 0 60px -20px rgba(79,227,203,0.5); padding:18px; overflow:hidden; }
.ep-portrait-frame::after { content:''; position:absolute; right:-60px; top:-60px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle, rgba(79,227,203,0.22), transparent 70%); filter:blur(30px); pointer-events:none; }
.ep-portrait-frame img { width:100%; height:auto; display:block; border-radius:14px; }

.ep-stats--bar { display:flex; flex-wrap:wrap; gap:0; margin-top:40px; border:1px solid var(--ep-border); border-radius:18px; overflow:hidden; }
.ep-stats--bar > div { flex:1; min-width:140px; padding:24px 26px; border-right:1px solid var(--ep-border); }
.ep-stats--bar > div:last-child { border-right:0; }

.ep-disciplines { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:18px; margin-top:6px; }
.ep-discipline { background:rgba(20,54,48,0.5); border:1px solid var(--ep-border); border-radius:16px; padding:24px; box-shadow:inset 0 1px 0 rgba(182,242,201,0.14); }
.ep-discipline .num { font-size:12px; color:var(--ep-cyan); }
.ep-discipline h3 { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:800; font-size:15px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ep-mut-1); margin:10px 0 8px; }
.ep-discipline p { font-size:14px; line-height:1.55; color:var(--ep-mut-3); margin:0; }

.ep-edu-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:6px; }
.ep-edu-item { background:rgba(20,54,48,0.4); border:1px solid var(--ep-border); border-radius:14px; padding:20px 22px; }
.ep-edu-item h4 { font-family:'RNS Sanz',sans-serif; font-weight:600; font-size:16px; margin:0 0 4px; color:var(--ep-ink); }
.ep-edu-item .ep-sc { font-weight:700; font-size:10px; letter-spacing:0.12em; color:var(--ep-mut-3); margin:0; }

/* ---------- Contact (designed) ---------- */
.ep-contact-page .ep-contact-grid { grid-template-columns:0.8fr 1.2fr; }
.ep-contact-formwrap { background:rgba(20,54,48,0.4); border:1px solid var(--ep-border); border-radius:20px; padding:30px 32px; box-shadow:inset 0 1px 0 rgba(182,242,201,0.14); }

/* ============================================================================
   Single project — case study
   ========================================================================== */
.ep-cs { position:relative; z-index:2; width:100%; }

.ep-cs-hero { position:relative; }
.ep-cs-hero__media { position:relative; width:100%; height:clamp(360px,58vh,640px); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ep-cs-hero__media > img { width:100%; height:100%; object-fit:cover; display:block; }
.ep-cs-hero__media > img.logo { width:auto; height:auto; max-width:42%; max-height:56%; object-fit:contain; }
.ep-cs-hero__media .wordmark { font-family:'RNS Sanz',sans-serif; font-weight:900; font-size:clamp(48px,9vw,120px); letter-spacing:-0.03em; line-height:0.9; }
/* gradient + overlaid caption when there is a cover image */
.ep-cs-hero.has-cover .ep-cs-hero__media::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,26,23,0.92) 0%, rgba(8,26,23,0.35) 45%, rgba(8,26,23,0.15) 100%); pointer-events:none; }
.ep-cs-hero.has-cover .ep-cs-hero__caption { position:absolute; left:0; right:0; bottom:0; padding-bottom:clamp(28px,4vw,52px); z-index:2; }
.ep-cs-hero:not(.has-cover) .ep-cs-hero__caption { padding-top:30px; }
.ep-cs-back { display:inline-block; text-decoration:none; margin-bottom:14px; }
.ep-cs-hero__caption h1 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(44px,8vw,104px); line-height:0.9; letter-spacing:-0.035em; margin:0; color:#fff; }
.ep-cs-tags { display:flex; flex-wrap:wrap; align-items:center; gap:16px; margin-top:16px; }
.ep-cs-tags .cat { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-cyan); }
.ep-cs-tags .yr { font-size:13px; color:var(--ep-mut-2); }

.ep-cs-meta { display:flex; flex-wrap:wrap; gap:0; margin:36px 0 0; border-top:1px solid var(--ep-border); border-bottom:1px solid var(--ep-border); }
.ep-cs-meta .item { flex:1; min-width:150px; padding:20px 24px 20px 0; }
.ep-cs-meta .item .k { font-family:'RNS Sanz SC','RNS Sanz',sans-serif; font-weight:700; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ep-mut-4); }
.ep-cs-meta .item .v { font-size:15px; color:var(--ep-ink); margin-top:5px; }

.ep-cs-body { max-width:780px; margin-top:clamp(40px,6vw,72px); }
.ep-cs-lead { font-family:'RNS Sanz',sans-serif; font-weight:500; font-size:clamp(20px,2.6vw,30px); line-height:1.45; letter-spacing:-0.01em; color:var(--ep-mut-1); margin:0 0 28px; }
.ep-cs-rich { font-size:18px; line-height:1.75; color:var(--ep-mut-2); }
.ep-cs-rich > * { margin:0 0 20px; }
.ep-cs-rich h2 { font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(24px,3vw,36px); letter-spacing:-0.02em; color:var(--ep-ink); margin:38px 0 14px; }
.ep-cs-rich h3 { font-family:'RNS Sanz',sans-serif; font-weight:700; font-size:22px; color:var(--ep-ink); margin:30px 0 10px; }
.ep-cs-rich img { border-radius:14px; }
.ep-cs-rich a { color:var(--ep-cyan); }
.ep-cs-rich blockquote { border-left:2px solid var(--ep-cyan); margin:28px 0; padding:4px 0 4px 22px; font-family:'RNS Sanz',sans-serif; font-style:italic; font-size:22px; color:var(--ep-mut-1); }

.ep-cs-gallery { display:grid; grid-template-columns:repeat(2, 1fr); gap:18px; margin-top:clamp(40px,6vw,64px); }
.ep-cs-gallery figure { margin:0; }
.ep-cs-gallery img { width:100%; border-radius:16px; border:1px solid rgba(79,227,203,0.14); display:block; }
.ep-cs-gallery figure:nth-child(3n+1) { grid-column:span 2; } /* occasional full-width image for rhythm */

.ep-cs-next { display:block; text-decoration:none; margin-top:clamp(56px,8vw,96px); position:relative; overflow:hidden; }
.ep-cs-next::before { content:''; position:absolute; inset:0; background:rgba(8,26,23,0.55); transition:background .35s; }
.ep-cs-next:hover::before { background:rgba(8,26,23,0.4); }
.ep-cs-next__inner { position:relative; z-index:2; padding:clamp(40px,6vw,72px) 7vw; text-align:center; }
.ep-cs-next__inner .ep-eyebrow { color:#fff; opacity:0.7; }
.ep-cs-next__title { display:block; font-family:'RNS Sanz',sans-serif; font-weight:800; font-size:clamp(32px,5vw,68px); letter-spacing:-0.03em; line-height:1; color:#fff; margin-top:10px; transition:transform .35s; }
.ep-cs-next:hover .ep-cs-next__title { transform:translateX(8px); }

/* ---- Responsive ---- */
/* allow the nav to wrap rather than overflow on narrow screens */
.ep-nav { flex-wrap:wrap; row-gap:8px; }

/* Designed pages — tablet/mobile */
@media (max-width:860px) {
  .ep-cv-hero { grid-template-columns:1fr; gap:32px; }
  .ep-cv-hero__portrait { order:-1; max-width:360px; }
  .ep-contact-page .ep-contact-grid { grid-template-columns:1fr; }
  .ep-edu-grid { grid-template-columns:1fr; }
}

/* Tablet (768–1024) */
@media (min-width:768px) and (max-width:1024px) {
  .ep-wrap { padding:0 5vw; }
  .ep-grid { grid-template-columns:repeat(auto-fill, minmax(260px,1fr)); gap:22px; }
  .ep-project-cover { aspect-ratio:16/9; }
  .ep-gallery { grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); }
}

/* Mobile (≤767) */
@media (max-width:767px) {
  .ep-wrap { padding:0 22px; }
  .ep-site-header { padding:14px 22px; flex-wrap:wrap; gap:10px; }
  .ep-nav-toggle { display:inline-flex; }
  .ep-nav { display:none; width:100%; flex-direction:column; align-items:flex-start; gap:2px; padding-top:6px; }
  .ep-nav.open { display:flex; }
  .ep-nav li { width:100%; }
  .ep-nav a { display:block; width:100%; padding:12px 2px; font-size:13px; letter-spacing:0.14em; } /* ≥44px tap targets */
  .ep-page-hero { padding:48px 0 24px; }
  .ep-grid { grid-template-columns:1fr; gap:20px; }
  .ep-project-meta { gap:18px; }
  .ep-project-cover { aspect-ratio:4/3; }
  .ep-project-cover img.logo { max-width:60%; max-height:60%; }
  .ep-gallery { grid-template-columns:1fr; }
  .ep-project-nav { flex-direction:column; }
  .ep-project-nav .ep-pill { justify-content:center; text-align:center; }
  .ep-stats { gap:28px; }
  .ep-site-footer { flex-direction:column; align-items:flex-start; gap:16px; padding:36px 22px; }
}

/* Small phones (≤420) */
@media (max-width:420px) {
  .ep-page-hero h1 { font-size:clamp(34px,11vw,52px); }
  .ep-stats { gap:20px; }
  .ep-stats .num { font-size:34px; }
}

@media (prefers-reduced-motion: reduce) { .ep-page * { transition:none !important; } }
