/* Skip-to-main-content link */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  padding: 0.5rem 1rem;
  background: #000;
  color: #fff;
  z-index: 9999;
}
.skip-link:focus { top: 0; }

/* Self-hosted fonts */

/* Rajdhani — 300, 400, 500, 600, 700 */
@font-face {
  font-family: 'Rajdhani';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../assets/fonts/rajdhani-v17-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Rajdhani';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../assets/fonts/rajdhani-v17-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Rajdhani';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../assets/fonts/rajdhani-v17-latin-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Rajdhani';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../assets/fonts/rajdhani-v17-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Rajdhani';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../assets/fonts/rajdhani-v17-latin-700.woff2') format('woff2');
}

/* Orbitron — 700 (display headings, hero name, numbers) */
@font-face {
  font-family: 'Orbitron';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../assets/fonts/orbitron-v35-latin-700.woff2') format('woff2');
}

/* Barlow Condensed — 700, 900 (replaces Google Fonts CDN) */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../assets/fonts/barlow-condensed-v13-latin-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('../assets/fonts/barlow-condensed-v13-latin-900.woff2') format('woff2');
}

/* Bebas Neue — 400 only */
@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../assets/fonts/bebas-neue-v10-latin-regular.woff2') format('woff2');
}

/* DM Mono — 300, 400, 500 (no italic — unused in CSS) */
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../assets/fonts/dm-mono-v14-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../assets/fonts/dm-mono-v14-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../assets/fonts/dm-mono-v14-latin-500.woff2') format('woff2');
}

/* Figtree — 300, 400, 500, 600 (700 declared in old GF URL but unused in CSS) */
@font-face {
  font-family: 'Figtree';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../assets/fonts/figtree-v6-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Figtree';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../assets/fonts/figtree-v6-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Figtree';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../assets/fonts/figtree-v6-latin-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Figtree';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../assets/fonts/figtree-v6-latin-600.woff2') format('woff2');
}

:root {
  --bg:#E8E7E5; --bg-card:#FFFFFF; --bg-dark:#0A0A0A;
  --orange:#FF4F1A; --black:#0A0A0A; --gray:#888888;
  --gray-lt:#BBBBBB; --border:#CCCCCC; --border-dk:#2A2A2A;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'Rajdhani',sans-serif;background:var(--black);color:var(--black);font-size:14px;line-height:1.5;}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:0.04;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px;}
.outer-frame{min-height:100vh;margin:0;position:relative;z-index:1;background:var(--bg);}
nav{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1.5px solid var(--border);display:flex;align-items:center;padding:0 32px;height:64px;}
.nav-logo{display:flex;align-items:center;gap:10px;padding-right:32px;border-right:1.5px solid var(--border);height:100%;}
a.nav-logo{text-decoration:none;color:inherit;cursor:pointer;transition:opacity 0.2s;}
a.nav-logo:hover{opacity:0.65;}
a.nav-logo:focus-visible{outline:1.5px solid var(--orange);outline-offset:2px;}
.nav-logo svg{width:22px;height:auto;}
.nav-logo-text{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.15em;text-transform:uppercase;font-weight:500;}
.nav-toggle{display:none;}.mobile-menu{display:none;}.nav-links{display:flex;align-items:center;gap:0;margin-left:auto;height:100%;}
.nav-links a{display:flex;align-items:center;height:100%;padding:0 20px;font-size:14px;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none;color:var(--gray);border-left:1.5px solid var(--border);transition:color 0.2s;position:relative;}
.nav-links a::before{content:'';position:absolute;top:14px;left:12px;width:8px;height:8px;border-top:1.5px solid var(--orange);border-left:1.5px solid var(--orange);opacity:0;transform:translate(-4px,-4px);transition:opacity 0.2s ease,transform 0.2s ease;}
.nav-links a::after{content:'';position:absolute;bottom:14px;right:12px;width:8px;height:8px;border-bottom:1.5px solid var(--orange);border-right:1.5px solid var(--orange);opacity:0;transform:translate(4px,4px);transition:opacity 0.2s ease,transform 0.2s ease;}
.nav-links a:hover{color:var(--black);}
.nav-links a:hover::before,.nav-links a:hover::after{opacity:1;transform:translate(0,0);}
.nav-links a[aria-current="page"]{color:var(--black);}
.nav-links a[aria-current="page"]::before,.nav-links a[aria-current="page"]::after{opacity:1;transform:translate(0,0);}
.nav-cta{background:var(--orange)!important;color:#fff!important;font-weight:500;}
.nav-cta:hover{background:#c94400!important;}
.nav-links .nav-cta::before,.nav-links .nav-cta::after{display:none;}
.nav-status{display:flex;align-items:center;gap:6px;padding:0 20px;border-left:1.5px solid var(--border);font-size:14px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gray);height:100%;}
.status-dot{width:6px;height:6px;border-radius:50%;background:#4CAF50;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
/* ── READING PROGRESS BAR ── */
.cs-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--orange);z-index:9998;pointer-events:none;transition:width 0.1s linear;}

/* ── HERO (dark split: video left 60%, content right 40%) ── */
.hero{background:#000;border-bottom:1.5px solid var(--border-dk);display:grid;grid-template-columns:1fr minmax(280px,45%);min-height:580px;}
/* Content panel — left 40% */
.hero-left{padding:100px 40px 40px;display:flex;flex-direction:column;gap:20px;position:relative;border-right:1.5px solid var(--border-dk);}
/* Video panel — right 60%, video centered with padding */
.hero-video-panel{background:#000;display:flex;align-items:center;justify-content:center;padding:48px 56px;position:relative;}
.hero-video-frame{position:relative;overflow:hidden;width:100%;max-width:456px;aspect-ratio:3/4;}
.hero-video-frame::before,.hero-video-frame::after{content:'';position:absolute;width:20px;height:20px;border-color:var(--orange);border-style:solid;z-index:2;}
.hero-video-frame::before{top:12px;left:12px;border-width:1.5px 0 0 1.5px;}
.hero-video-frame::after{bottom:12px;right:12px;border-width:0 1.5px 1.5px 0;}
.face-video{width:100%;height:100%;object-fit:cover;object-position:60% top;display:block;}
.face-scanlines{position:absolute;inset:0;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 3px,rgba(0,0,0,0.08) 3px,rgba(0,0,0,0.08) 4px);pointer-events:none;z-index:1;}
.hero-left::before,.hero-left::after{content:'';position:absolute;width:16px;height:16px;border-color:rgba(255,79,26,0.25);border-style:solid;pointer-events:none;}
.hero-left::before{top:16px;left:16px;border-width:1.5px 0 0 1.5px;}
.hero-left::after{bottom:16px;right:16px;border-width:0 1.5px 1.5px 0;}
.hero-mark{width:56px;flex-shrink:0;}.hero-mark svg{width:100%;height:auto;}
/* Dark hero overrides for label / coord */
.hero .hero-label{margin-bottom:0;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.45);background:linear-gradient(225deg,transparent 5.66px,rgba(255,79,26,0.45) 5.66px,rgba(255,79,26,0.45) 7.16px,transparent 7.16px) top right/8px 8px no-repeat,rgba(255,79,26,0.1);}
.hero .hero-coord{color:rgba(232,231,229,0.35);opacity:1;}
/* Name */
.hero-name{font-family:'Orbitron',sans-serif;font-weight:700;font-size:clamp(72px,8vw,120px);line-height:0.88;letter-spacing:-0.01em;color:#E8E7E5;margin:0;}
.hero-name .bracket-name{color:rgba(232,231,229,0.18);}
/* Bio */
.hero-bio{font-size:16px;line-height:1.7;color:rgba(232,231,229,0.5);border-top:1.5px solid var(--border-dk);padding-top:20px;margin-top:auto;}
/* Orange CTA variant (for dark hero) */
.cta-btn--orange{background:var(--orange)!important;color:#fff!important;}
.cta-btn--orange:hover{background:#d93e0a!important;}
.cta-btn--orange .cta-btn-arrow{border-color:rgba(255,255,255,0.3);}

.marquee-strip{background:var(--black);border-bottom:1.5px solid var(--border-dk);overflow:hidden;padding:22px 0;display:flex;align-items:center;}
.marquee-track{display:flex;align-items:center;animation:marquee 40s linear infinite;white-space:nowrap;}
.marquee-track:hover{animation-play-state:paused;}
.marquee-item{font-size:15px;letter-spacing:0.15em;text-transform:uppercase;color:#666;padding:0 28px;flex-shrink:0;}
.marquee-sep{font-size:14px;letter-spacing:0.1em;color:rgba(232,64,10,0.55);flex-shrink:0;}
@keyframes marquee{from{transform:translateX(-50%);}to{transform:translateX(0);}}

/* ── LOGO MARQUEE ──────────────────────────────────── */
.logo-strip{background:var(--black);overflow:hidden;padding:0 0 20px;position:relative;}
.logo-strip::before,.logo-strip::after{content:'';position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none;}
.logo-strip::before{left:0;background:linear-gradient(to right,var(--black) 30%,transparent);}
.logo-strip::after{right:0;background:linear-gradient(to left,var(--black) 30%,transparent);}
.logo-strip-label{padding:16px 40px 14px;font-size:14px;letter-spacing:0.18em;text-transform:uppercase;color:#444;position:relative;z-index:3;}
.logo-track{display:flex;flex-wrap:nowrap;width:max-content;animation:logo-scroll 50s linear infinite;will-change:transform;}
.logo-track>[aria-hidden="true"]{display:contents;}
.logo-card{flex-shrink:0;width:200px;height:110px;margin-right:12px;background:#111;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:20px 26px;}
.logo-card img{width:100%;height:100%;object-fit:contain;filter:brightness(0) invert(1);opacity:0.65;}
@keyframes logo-scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.section-header{border-bottom:1.5px solid var(--border);padding:16px 40px;display:flex;align-items:center;justify-content:space-between;}
.section-title{display:flex;align-items:center;gap:10px;font-size:14px;letter-spacing:0.15em;text-transform:uppercase;color:var(--black);font-weight:500;}
.section-title .sq{width:8px;height:8px;background:var(--black);flex-shrink:0;}
.section-index{font-size:14px;letter-spacing:0.1em;color:var(--gray-lt);}
.work-intro{font-size:clamp(1.1rem,2vw,1.4rem);padding:32px 40px 0;color:var(--fg-muted,#888);letter-spacing:0.02em;}
.work-grid{display:grid;grid-template-columns:1fr 1fr 1fr;}
.work-card{border-right:1.5px solid var(--border);border-bottom:1.5px solid var(--border);background:var(--bg-card);overflow:hidden;cursor:pointer;transition:background 0.2s, box-shadow 0.2s;position:relative;text-decoration:none;color:inherit;display:block;}
.work-card:nth-child(3n){border-right:none;}
.work-card:hover{background:#F5F4F2;box-shadow:0 8px 32px rgba(0,0,0,0.08);}
.work-card-top{padding:20px 40px 16px;border-bottom:1.5px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;}
.work-card-number{font-size:14px;letter-spacing:0.1em;color:var(--gray-lt);}
.work-card-tag{font-size:14px;letter-spacing:0.1em;text-transform:uppercase;padding:3px 8px 3px 6px;border:1.5px solid var(--border);color:var(--gray);display:flex;align-items:center;gap:5px;}
.work-card-tag::before{content:'';width:5px;height:5px;background:var(--orange);flex-shrink:0;display:inline-block;}
.work-card-img{height:200px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;}
.work-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.work-card:hover .work-card-img img{transform:scale(1.05);}
.corner-tl,.corner-br{position:absolute;width:16px;height:16px;border-color:var(--orange);border-style:solid;opacity:0.45;transition:opacity 0.2s;}
.corner-tl{top:10px;left:10px;border-width:1.5px 0 0 1.5px;}
.corner-br{bottom:10px;right:10px;border-width:0 1.5px 1.5px 0;}
.work-card:hover .corner-tl,.work-card:hover .corner-br{opacity:1;}
.work-card-body{padding:20px 40px 88px;}/* extra bottom space for absolute arrow (40px pos + 36px height + 12px gap) */
.work-card-company{font-size:14px;letter-spacing:0.18em;text-transform:uppercase;color:var(--orange);margin-bottom:6px;}
.work-card-title{font-size:15px;font-weight:500;letter-spacing:0.02em;color:var(--black);margin-bottom:10px;line-height:1.3;font-family:'Rajdhani',sans-serif;}
.work-card-desc{font-size:16px;color:#555;line-height:1.65;margin-bottom:16px;}
.work-card-stats{display:flex;gap:16px;border-top:1.5px solid var(--border);padding-top:14px;}
.wc-stat-val{font-size:18px;color:var(--black);font-family:'Orbitron',sans-serif;font-weight:700;letter-spacing:0.04em;}
.wc-stat-key{font-size:14px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray);margin-top:1px;}
/* .work-card-arrow styles in button system block */
.about-section{display:grid;grid-template-columns:1fr 1fr;border-bottom:1.5px solid var(--border);}
.about-left{border-right:1.5px solid var(--border);padding:48px 40px;}
.about-left .section-header--inset{margin-right:calc(-40px - 1.5px);}
.about-right{padding:48px 40px;}
/* Pull section-header flush to column edges (negative margin cancels parent 48px/40px padding) */
.section-header--inset{margin:-48px -40px 32px;padding:16px 40px;border-bottom:1.5px solid var(--border);}
.about-heading{font-family:'Orbitron',sans-serif;font-weight:700;font-size:52px;letter-spacing:0.03em;line-height:0.92;color:var(--black);margin-bottom:28px;padding-top:10px;padding-left:14px;}
.about-body{font-family:'Rajdhani',sans-serif;font-size:17px;line-height:1.75;color:#444;}
.about-body p+p{margin-top:16px;}
.about-left>.cta-btn,.about-left>.btn{display:inline-flex;margin-top:48px;}
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1.5px solid var(--border);}
.skill-item{padding:14px 20px;border-bottom:1.5px solid var(--border);border-right:1.5px solid var(--border);display:flex;align-items:center;gap:14px;}
.skill-item:nth-child(2n){border-right:none;}
.skill-item:nth-last-child(-n+2){border-bottom:none;}
.skill-dot{width:5px;height:5px;background:var(--orange);flex-shrink:0;}
.skill-name{font-size:14px;letter-spacing:0.08em;text-transform:uppercase;color:var(--black);}
.impact-section{background:var(--bg-dark);border-bottom:1.5px solid var(--border-dk);}
.impact-section .section-header{border-color:var(--border-dk);}
.impact-section .section-title{color:#fff;}
.impact-section .section-title .sq{background:var(--orange);}
.impact-section .section-index{color:var(--orange);}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.impact-cell{border-right:1.5px solid var(--border-dk);border-bottom:1.5px solid var(--border-dk);padding:36px 32px;}
.impact-cell:nth-child(4n){border-right:none;}
.impact-num{font-family:'Orbitron',sans-serif;font-weight:700;font-size:56px;letter-spacing:0.03em;color:var(--orange);line-height:1;margin-bottom:6px;}
.impact-label{font-size:14px;letter-spacing:0.15em;text-transform:uppercase;color:#666;}
.impact-label-main{color:#ccc;margin-bottom:4px;}
/* ── TESTIMONIAL CAROUSEL ── */
.ts-section{border-bottom:1.5px solid var(--border);}
.ts-inner{display:grid;grid-template-columns:320px 1fr;position:relative;cursor:none;}
.ts-left{border-right:1.5px solid var(--border);padding:48px 40px;display:flex;flex-direction:column;gap:28px;}
.ts-right{padding:48px 56px;display:flex;flex-direction:column;justify-content:center;}
/* Mini avatar strip */
.ts-mini-avatars{display:flex;align-items:center;}
.ts-mini-avatar{width:28px;height:28px;border:1.5px solid var(--border);background:var(--bg);font-family:'Orbitron',sans-serif;font-weight:700;font-size:10px;color:var(--gray);display:flex;align-items:center;justify-content:center;overflow:hidden;transition:opacity 0.25s,border-color 0.25s;opacity:0.35;margin-right:4px;flex-shrink:0;cursor:pointer;position:relative;}
.ts-mini-avatar:last-child{margin-right:0;}
.ts-mini-avatar--active{opacity:1;border-color:var(--orange);}
.ts-mini-avatar img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.6);}
.ts-mini-avatar--active img{filter:none;}
/* Author */
.ts-author-block{display:flex;align-items:flex-start;gap:16px;}
.ts-avatar{width:64px;height:64px;flex-shrink:0;border:1.5px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;}
.ts-avatar::before,.ts-avatar::after{content:'';position:absolute;width:10px;height:10px;border-color:var(--orange);border-style:solid;z-index:2;}
.ts-avatar::before{top:4px;left:4px;border-width:1.5px 0 0 1.5px;}
.ts-avatar::after{bottom:4px;right:4px;border-width:0 1.5px 1.5px 0;}
.ts-avatar-initials{font-family:'Orbitron',sans-serif;font-weight:700;font-size:22px;color:var(--gray);}
.ts-avatar-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.ts-author-detail{display:flex;flex-direction:column;gap:5px;padding-left:14px;position:relative;}
.ts-author-bar{position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--orange);transform-origin:top;animation:tsBarGrow 0.4s ease forwards;}
@keyframes tsBarGrow{from{transform:scaleY(0);}to{transform:scaleY(1);}}
.ts-author-name{font-size:14px;color:var(--black);font-family:'Rajdhani',sans-serif;line-height:1.3;}
.ts-author-role{font-size:14px;letter-spacing:0.14em;text-transform:uppercase;color:var(--gray);}
/* Progress */
.ts-progress-wrap{height:1px;background:var(--border);position:relative;overflow:hidden;margin-top:auto;}
.ts-progress-fill{position:absolute;left:0;top:0;bottom:0;background:var(--orange);transition:width 0.5s cubic-bezier(0.22,1,0.36,1);}
/* Counter + hint */
.ts-footer-row{display:flex;align-items:center;justify-content:space-between;}
.ts-counter{font-family:'Orbitron',sans-serif;font-weight:700;font-size:14px;color:var(--gray);display:flex;align-items:baseline;gap:3px;}
.ts-counter-cur{font-size:28px;color:var(--black);line-height:1;}
.ts-counter-sep{color:var(--border);}
.ts-hint{font-size:14px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray);opacity:0.5;}
/* Quote */
.ts-quote-mark{display:none;}
.ts-quote{font-size:16px;line-height:1.75;color:#2a2a2a;font-weight:300;font-family:'Rajdhani',sans-serif;font-style:italic;}
.ts-quote::before{content:'\201C';margin-right:2px;}
.ts-quote::after{content:'\201D';margin-left:2px;}
/* Word animation */
@keyframes tsWordReveal{from{opacity:0;transform:translateY(10px);filter:blur(5px);}to{opacity:1;transform:translateY(0);filter:blur(0);}}
.ts-word{display:inline-block;margin-right:0.22em;opacity:0;transform:translateY(10px);filter:blur(5px);animation:tsWordReveal 0.38s ease forwards;}
/* Author fade */
@keyframes tsFadeSlide{from{opacity:0;transform:translateX(-6px);}to{opacity:1;transform:translateX(0);}}
.ts-author-anim{animation:tsFadeSlide 0.3s ease forwards;}
/* Custom cursor */
/* ── TESTIMONIAL CARD (single, inline variant) ── */
.ts-section--card{border-top:1.5px solid var(--border);border-bottom:1.5px solid var(--border);margin-top:-1.5px;}
.ts-section--card .ts-inner{display:flex;flex-direction:column;cursor:default;padding:0;}
/* Header: photo + name/role */
.ts-section--card .ts-left{border-right:none;border-bottom:1.5px solid var(--border);padding:28px 32px;flex-direction:row;align-items:flex-start;gap:20px;}
.ts-section--card .ts-avatar{width:88px;height:110px;flex-shrink:0;clip-path:polygon(16px 0%,100% 0%,100% 100%,0% 100%,0% 16px);}
.ts-section--card .ts-avatar img,.ts-section--card .ts-avatar-img{filter:grayscale(1);}
.ts-section--card .ts-avatar::before,.ts-section--card .ts-avatar::after{display:none;}
.ts-section--card .ts-avatar-initials{font-size:30px;}
.ts-section--card .ts-author-block{gap:20px;align-items:flex-start;}
.ts-section--card .ts-author-detail{padding-left:0;}
.ts-section--card .ts-author-bar{display:none;}
.ts-section--card .ts-author-name{font-size:22px;line-height:1.1;}
.ts-section--card .ts-author-role{font-size:14px;letter-spacing:0.1em;margin-top:8px;}
.ts-section--card .ts-progress-wrap,.ts-section--card .ts-footer-row,.ts-section--card .ts-mini-avatars,.ts-section--card .section-header{display:none!important;}
/* Body: quote left + narrow right column */
.ts-section--card .ts-right{padding:0;display:grid;grid-template-columns:1fr 80px;}
.ts-section--card .ts-quote-mark{display:none;}
.ts-section--card .ts-quote{padding:32px;font-family:'Rajdhani',sans-serif;font-size:16px;line-height:1.95;min-height:0;font-weight:400;color:var(--black);font-style:italic;}
.ts-section--card .ts-right::after{content:'';display:block;border-left:1.5px solid var(--border);}
@media(max-width:640px){
  .ts-section--card .ts-left{padding:20px 24px;}
  .ts-section--card .ts-avatar{width:68px;height:84px;}
  .ts-section--card .ts-author-name{font-size:18px;}
  .ts-section--card .ts-quote{padding:24px;font-size:16px;}
  .ts-section--card .ts-right{grid-template-columns:1fr 48px;}
}
/* ── CTA LABEL SECTION ── */
.cta-section{background:var(--orange);position:relative;overflow:hidden;padding-bottom:24px;}
.cta-section::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(to bottom,transparent 0,transparent 3px,rgba(0,0,0,0.04) 3px,rgba(0,0,0,0.04) 4px);pointer-events:none;z-index:0;}
.cta-section>*{position:relative;z-index:1;}
/* Header strip */
.cta-strip{display:flex;align-items:center;border-bottom:1.5px solid rgba(255,255,255,0.15);font-size:14px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.5);font-family:'Rajdhani',sans-serif;}
.cta-strip-item{padding:10px 24px;border-right:1.5px solid rgba(255,255,255,0.15);display:flex;align-items:center;gap:8px;}
.cta-strip-item--right{border-right:none;margin-left:auto;}
.cta-strip-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.7);flex-shrink:0;animation:pulse 2s ease infinite;}
/* Columns */
.cta-cols{display:grid;grid-template-columns:1.4fr 1fr 1.4fr 220px;}
.cta-col{padding:40px 32px;border-right:1.5px solid rgba(255,255,255,0.15);display:flex;flex-direction:column;gap:20px;align-items:flex-start;}
.cta-col:last-child{border-right:none;align-items:center;gap:16px;}
/* Meta labels */
.cta-meta-lbl{font-size:14px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.45);font-family:'Rajdhani',sans-serif;display:block;}
.cta-meta-lbl::before{content:'> ';opacity:0.5;}
/* Data fields */
.cta-field{display:flex;flex-direction:column;gap:6px;}
.cta-field-val{font-size:14px;color:#fff;line-height:1.5;font-family:'Rajdhani',sans-serif;}
/* Heading */
.cta-heading{font-family:'Orbitron',sans-serif;font-weight:700;font-size:clamp(48px,5.5vw,80px);letter-spacing:0.03em;line-height:0.9;color:#fff;margin-top:4px;}
/* Body */
.cta-body{font-size:16px;line-height:1.75;color:rgba(255,255,255,0.65);font-family:'Rajdhani',sans-serif;}
/* Buttons */
.cta-btn-group{display:flex;flex-direction:column;gap:10px;margin-top:auto;}
.cta-btn{background:var(--black);color:#fff;font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.18em;text-transform:uppercase;padding:14px 28px;border:none;cursor:pointer;display:flex;align-items:center;gap:12px;transition:background 0.15s;text-decoration:none;}
.cta-btn:hover{background:#222;}
.cta-btn-arrow{width:28px;height:28px;border:1.5px solid #555;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.cta-btn--ghost{background:transparent;color:rgba(255,255,255,0.75);border:1.5px solid rgba(255,255,255,0.35);}
.cta-btn--ghost::after{content:'';position:absolute;top:18px;right:0;width:26px;height:1.5px;background:rgba(255,255,255,0.35);transform-origin:right top;transform:rotate(-45deg);pointer-events:none;}
.cta-btn--ghost:hover{background:rgba(255,255,255,0.08);}
.cta-btn--ghost .cta-btn-arrow{border-color:rgba(255,255,255,0.3);}
/* ── TESTIMONIAL (shared clean style) ── */
.cs-testimonial{padding:48px 40px;border-top:1.5px solid var(--border);}
.cs-testimonial blockquote{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:300;line-height:1.75;letter-spacing:-0.01em;color:var(--black);margin:0 0 28px;font-style:italic;}
.cs-testimonial blockquote::before{content:'\201C';margin-right:2px;}
.cs-testimonial blockquote::after{content:'\201D';margin-left:2px;}
.cs-testimonial-author{display:flex;align-items:center;gap:14px;}
.cs-testimonial-avatar{width:56px;height:56px;background:var(--bg);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--gray);font-family:'Rajdhani',sans-serif;flex-shrink:0;overflow:hidden;position:relative;}
.cs-testimonial-avatar::before,.cs-testimonial-avatar::after{content:'';position:absolute;width:10px;height:10px;border-color:var(--orange);border-style:solid;z-index:2;}
.cs-testimonial-avatar::before{top:4px;left:4px;border-width:1.5px 0 0 1.5px;}
.cs-testimonial-avatar::after{bottom:4px;right:4px;border-width:0 1.5px 1.5px 0;}
.cs-testimonial-avatar img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;display:block;filter:grayscale(0.6);}
.cs-testimonial-info{border-left:1.5px solid var(--orange);padding-left:14px;}
.cs-testimonial-name{font-size:14px;font-weight:500;color:var(--black);display:block;margin-bottom:2px;}
.cs-testimonial-role{font-size:14px;color:var(--gray);font-family:'Rajdhani',sans-serif;letter-spacing:0.08em;text-transform:uppercase;}
.cs-testimonial-bar{margin-top:32px;height:1px;background:var(--border);}

/* ── TESTIMONIALS BLOCK (index / about grid) ── */
.testimonials-block{border-bottom:1.5px solid var(--border);}
.testimonials-grid{display:grid;grid-template-columns:1fr 1fr;}
.testimonials-grid .cs-testimonial{border-top:none;border-right:1.5px solid var(--border);padding:48px 40px;}
.testimonials-grid .cs-testimonial:last-child{border-right:none;}

footer{background:var(--black);border-top:1.5px solid rgba(255,79,26,0.35);position:relative;}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr;padding:48px 40px;gap:40px;border-bottom:1.5px solid var(--border-dk);}
.footer-brand-col{display:flex;flex-direction:column;gap:16px;}
.footer-logo{display:flex;align-items:center;gap:10px;}
a.footer-logo{text-decoration:none;color:inherit;transition:opacity 0.2s;cursor:pointer;}
a.footer-logo:hover{opacity:0.65;}
.footer-wordmark{font-family:'Orbitron',sans-serif;font-weight:700;font-size:clamp(52px,12vw,160px);letter-spacing:0.06em;color:transparent;-webkit-text-stroke:1.5px #1c1c1c;line-height:1;text-align:center;padding:4px 40px 0;user-select:none;pointer-events:none;border-top:1.5px solid var(--border-dk);position:relative;}
.footer-logo svg{width:20px;height:auto;}
.footer-brand{font-size:14px;letter-spacing:0.2em;text-transform:uppercase;color:#888;}
.footer-tagline{font-size:16px;line-height:1.7;color:#444;letter-spacing:0.04em;}
.footer-status-badge{display:flex;align-items:center;gap:6px;font-size:14px;letter-spacing:0.1em;text-transform:uppercase;color:#444;}
.footer-nav-col,.footer-connect-col{display:flex;flex-direction:column;gap:14px;}
.footer-nav-col a,.footer-connect-col a{font-size:14px;letter-spacing:0.1em;text-transform:uppercase;color:#555;text-decoration:none;transition:color 0.15s;}
.footer-connect-col a{text-transform:none;letter-spacing:0.02em;font-size:14px;}
.footer-nav-col a:hover,.footer-connect-col a:hover{color:var(--orange);}
.footer-bottom{padding:20px 40px;display:flex;align-items:center;justify-content:space-between;}
.footer-copy{font-size:14px;letter-spacing:0.1em;color:#333;}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
.hero-video-panel{animation:fadeUp 0.6s ease both;}
.hero-left{animation:fadeUp 0.6s ease 0.08s both;}

/* ════════════════════════════════════════════════════
   CYBER LABEL SYSTEM
   ════════════════════════════════════════════════════ */
.hero-label{display:inline-flex;align-items:center;gap:6px;font-size:14px;letter-spacing:0.2em;text-transform:uppercase;color:var(--orange);margin-bottom:24px;padding:5px 12px 5px 8px;border:none;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.35);background:linear-gradient(225deg,transparent 5.66px,rgba(255,79,26,0.35) 5.66px,rgba(255,79,26,0.35) 7.16px,transparent 7.16px) top right/8px 8px no-repeat,rgba(255,79,26,0.05);clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);}
.hero-label-dot{display:none;}
.hero-label::before{content:'//';letter-spacing:0.05em;opacity:0.5;}
.work-card-tag{border:none;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.4);filter:drop-shadow(0 0 0.5px rgba(255,79,26,0.55));color:var(--orange);background:linear-gradient(225deg,transparent 4.24px,rgba(255,79,26,0.45) 4.24px,rgba(255,79,26,0.45) 5.74px,transparent 5.74px) top right/6px 6px no-repeat,rgba(255,79,26,0.04);clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,0 100%);}
.work-card-tag::before{background:var(--orange);}
.section-index{color:var(--orange);border:none;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.5);filter:drop-shadow(0 0 0.5px rgba(255,79,26,0.55));padding:0 8px;margin:0;background:linear-gradient(225deg,transparent 2.83px,rgba(255,79,26,0.45) 2.83px,rgba(255,79,26,0.45) 4.33px,transparent 4.33px) top right/4px 4px no-repeat,rgba(255,79,26,0.04);clip-path:polygon(0 0,calc(100% - 4px) 0,100% 4px,100% 100%,0 100%);}
.footer-col-label{font-size:14px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,79,26,0.7);padding:4px 10px 4px 8px;border:1.5px solid rgba(255,79,26,0.22);background:linear-gradient(225deg,transparent 3.54px,rgba(255,79,26,0.22) 3.54px,rgba(255,79,26,0.22) 5.04px,transparent 5.04px) top right/5px 5px no-repeat border-box,rgba(255,79,26,0.04);clip-path:polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,0 100%);display:inline-block;margin-bottom:6px;align-self:flex-start;}
.footer-col-label::before{content:'> ';opacity:0.5;}

/* ════════════════════════════════════════════════════
   SCROLL REVEAL
   ════════════════════════════════════════════════════ */
[data-reveal]{opacity:0;transform:translateY(14px);filter:blur(1px);transition:opacity 0.6s ease,transform 0.6s ease,filter 0.55s ease;}
[data-reveal].is-revealed{opacity:1;transform:translateY(0);filter:blur(0);}
[data-reveal="from-left"]{opacity:0;transform:translateX(-28px);filter:blur(1px);transition:opacity 0.55s ease,transform 0.55s ease,filter 0.5s ease;}
[data-reveal="from-left"].is-revealed{opacity:1;transform:translateX(0);filter:blur(0);}
[data-reveal-img]{opacity:0;transform:scale(0.97);transition:opacity 0.7s ease,transform 0.7s ease;}
[data-reveal-img].is-revealed{opacity:1;transform:scale(1);}

/* ════════════════════════════════════════════════════
   QR CODE CHIPS
   ════════════════════════════════════════════════════ */
.qr-link-wrap{display:flex;align-items:center;gap:10px;}
.qr-chip{display:flex;align-items:center;justify-content:center;width:64px;height:64px;flex-shrink:0;border:none;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.4);background:linear-gradient(225deg,transparent 4.24px,rgba(255,79,26,0.4) 4.24px,rgba(255,79,26,0.4) 5.74px,transparent 5.74px) top right/6px 6px no-repeat,linear-gradient(225deg,transparent 4.24px,rgba(255,79,26,0.4) 4.24px,rgba(255,79,26,0.4) 5.74px,transparent 5.74px) bottom left/6px 6px no-repeat,rgba(10,10,10,0.85);clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px));cursor:default;}
.qr-chip .qr-canvas{line-height:0;}.qr-chip .qr-canvas canvas,.qr-chip .qr-canvas img{display:block;image-rendering:pixelated;width:54px;height:54px;}
.qr-label{display:none;}
.qr-chip--lg{width:140px;height:140px;}.qr-chip--lg .qr-canvas canvas,.qr-chip--lg .qr-canvas img{width:120px;height:120px;}
.qr-chip--light{border-color:rgba(10,10,10,0.18);background:rgba(255,79,26,0.04);}
.qr-chip--light .qr-label{color:var(--black);opacity:0.4;}
.qr-chip--on-orange{border-color:rgba(0,0,0,0.25);background:rgba(0,0,0,0.18);}
.qr-chip--on-orange .qr-label{color:rgba(0,0,0,0.45);}

/* ════════════════════════════════════════════════════
   SKILL ICONS (Lucide SVGs)
   ════════════════════════════════════════════════════ */
.skill-icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:none;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.4);filter:drop-shadow(0 0 0.5px rgba(255,79,26,0.55));background:linear-gradient(225deg,transparent 3.54px,rgba(255,79,26,0.45) 3.54px,rgba(255,79,26,0.45) 5.04px,transparent 5.04px) top right/5px 5px no-repeat,rgba(255,79,26,0.04);clip-path:polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,0 100%);}
.skill-item svg{width:17px;height:17px;stroke:var(--orange);stroke-width:2;fill:none;flex-shrink:0;}

/* ════════════════════════════════════════════════════
   FOOTER ENHANCEMENTS
   ════════════════════════════════════════════════════ */
footer::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(to bottom,transparent 0,transparent 3px,rgba(255,255,255,0.012) 3px,rgba(255,255,255,0.012) 4px);pointer-events:none;z-index:0;}
.footer-inner,.footer-wordmark,.footer-bottom{position:relative;z-index:1;}
.footer-wordmark::before{content:'';position:absolute;top:0;left:40px;right:40px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,79,26,0.35),transparent);}
.footer-connect-col .qr-chip{margin-top:4px;}

/* ════════════════════════════════════════════════════
   BUTTON SYSTEM
   Top-right chamfer only. TL / BL / BR = 90°.
   Hover = colour change. No animations.
   ════════════════════════════════════════════════════ */

/* ── Base ── */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:13px 22px;
  font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;text-decoration:none;
  cursor:pointer;border:none;outline:none;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);
  transition:background 0.18s ease,color 0.18s ease,filter 0.18s ease,transform 0.12s ease;
  will-change:transform;user-select:none;-webkit-user-select:none;
}
.btn:active{transform:scale(0.96);}

/* ── Icon box ── */
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;font-size:0;line-height:1;}
.btn-icon::before{content:'';display:block;width:14px;height:14px;background:currentColor;-webkit-mask-image:url('../img/arrow-icon.svg');mask-image:url('../img/arrow-icon.svg');-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;}
/* Download — rotate arrow to point southeast */
.btn--primary .btn-icon::before{transform:rotate(90deg);}

/* ── Label ── */
.btn-label{flex:1;}

/* ── Primary — orange fill, black text ── */
.btn--primary{background:var(--orange);color:var(--black);}
.btn--primary:hover{background:#FF6633;color:var(--black);filter:drop-shadow(0 0 12px rgba(255,79,26,0.4));}
.btn--primary .btn-icon{background:rgba(0,0,0,0.18);}
.btn--primary:hover .btn-icon{background:rgba(0,0,0,0.25);}

/* ── Secondary — dark fill, orange text + border incl. cut edge ── */
.btn--secondary{background:var(--black);color:var(--orange);box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.35);filter:drop-shadow(0 0 0.5px rgba(255,79,26,0.55));}
.btn--secondary:hover{background:#111;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.85);filter:drop-shadow(0 0 12px rgba(255,79,26,0.4));}
.btn--secondary .btn-icon{background:rgba(255,79,26,0.08);}

/* ── Secondary on light backgrounds ── */
.btn--secondary-light{background:transparent;color:var(--black);box-shadow:inset 0 0 0 1.5px rgba(10,10,10,0.25);}
.btn--secondary-light:hover{background:rgba(10,10,10,0.05);box-shadow:inset 0 0 0 1.5px rgba(10,10,10,0.6);filter:drop-shadow(0 0 12px rgba(255,79,26,0.25));}
.btn--secondary-light .btn-icon{background:rgba(10,10,10,0.06);}

/* ── Icon-only — square ── */
.btn--icon-only{padding:13px;gap:0;}
.btn--icon-only .btn-label{display:none;}
.btn--icon-only .btn-icon{width:20px;height:20px;}

/* ── Small ── */
.btn--sm{padding:9px 16px;font-size:12px;letter-spacing:0.16em;gap:9px;}
.btn--sm .btn-icon{width:20px;height:20px;font-size:12px;}

/* ── Legacy .cta-btn — same system ── */
.cta-btn{position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:13px 22px;font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;text-decoration:none;
  cursor:pointer;border:none;background:var(--black);color:var(--orange);
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);
  box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.35);
  transition:background 0.18s ease,color 0.18s ease,transform 0.12s ease;}
.cta-btn:hover{background:#111;box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.85);filter:drop-shadow(0 0 12px rgba(255,79,26,0.4));}
.cta-btn:active{transform:scale(0.96);}
.cta-btn--orange{background:var(--orange)!important;color:var(--black)!important;box-shadow:none!important;}
.cta-btn--orange:hover{background:#FF6633!important;filter:drop-shadow(0 0 12px rgba(255,79,26,0.4));}
.cta-btn--orange .cta-btn-arrow{background:rgba(0,0,0,0.18);}
.cta-btn-arrow{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;font-size:0;}
.cta-btn-arrow::before{content:'';display:block;width:13px;height:13px;background:currentColor;-webkit-mask-image:url('../img/arrow-icon.svg');mask-image:url('../img/arrow-icon.svg');-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;}
.cta-btn--ghost{background:transparent;color:rgba(255,255,255,0.75);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,0.35);}
.cta-btn--ghost:hover{background:rgba(255,255,255,0.08);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,0.7);filter:drop-shadow(0 0 12px rgba(255,255,255,0.2));}

/* ── Nav CTA — primary button style, auto height (does not stretch to nav edges) ── */
.nav-cta{background:var(--orange)!important;color:var(--black)!important;
  height:auto!important;align-self:center!important;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%)!important;
  font-size:13px!important;font-weight:700;letter-spacing:0.18em;
  padding:13px 22px!important;gap:12px!important;
  display:inline-flex!important;align-items:center!important;
  transition:background 0.18s ease,filter 0.18s ease!important;}
.nav-links .nav-cta::before,.nav-links .nav-cta::after{display:none;}
.nav-cta:hover{background:#FF6633!important;filter:drop-shadow(0 0 10px rgba(255,79,26,0.45));color:var(--black)!important;}
.nav-cta-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;font-size:0;line-height:1;background:rgba(0,0,0,0.18);}
.nav-cta-icon::before{content:'';display:block;width:13px;height:13px;background:currentColor;-webkit-mask-image:url('../img/arrow-icon.svg');mask-image:url('../img/arrow-icon.svg');-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;}
.nav-cta:hover .nav-cta-icon{background:rgba(0,0,0,0.25);}

/* ── Card icon buttons (work cards + overview cells) ── */
/* Same icon-only style — top-right chamfer, orange accent, no background */
.work-card-arrow,.home-nav-arrow{
  display:flex;align-items:center;justify-content:center;
  font-size:0;color:rgba(255,79,26,0.7);
  box-shadow:inset 0 0 0 1.5px rgba(255,79,26,0.4);
  filter:drop-shadow(0 0 0.5px rgba(255,79,26,0.6));
  background:linear-gradient(225deg,transparent 4.24px,rgba(255,79,26,0.45) 4.24px,rgba(255,79,26,0.45) 5.74px,transparent 5.74px) top right/6px 6px no-repeat,transparent;
  clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,0 100%);
  transition:background 0.18s ease,color 0.18s ease,filter 0.18s ease,box-shadow 0.18s ease;
  flex-shrink:0;
  width:36px;height:36px;
}
.work-card-arrow::before,.home-nav-arrow::before{content:'';display:block;width:18px;height:18px;background:currentColor;-webkit-mask-image:url('../img/arrow-icon.svg');mask-image:url('../img/arrow-icon.svg');-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;}
.work-card-arrow{
  /* Positioned within card body padding area */
  position:absolute;bottom:40px;right:40px;
}
.home-nav-arrow{
  /* In-flow at bottom of flex column, right-aligned */
  align-self:flex-end;
}
.work-card:hover .work-card-arrow,.home-nav-cell:hover .home-nav-arrow{
  background:var(--orange);
  box-shadow:inset 0 0 0 1.5px var(--orange);
  filter:drop-shadow(0 0 12px rgba(255,79,26,0.4));
  color:#fff;
}

/* ════════════════════════════════════════════════════
   HUD CORNER BRACKETS
   ════════════════════════════════════════════════════ */

/* Impact cells — static orange corner brackets (decorative) */
.impact-cell{position:relative;}
.impact-cell::before,.impact-cell::after{content:'';position:absolute;width:10px;height:10px;border-color:rgba(255,79,26,0.22);border-style:solid;pointer-events:none;}
.impact-cell::before{top:12px;left:12px;border-width:1.5px 0 0 1.5px;}
.impact-cell::after{bottom:12px;right:12px;border-width:0 1.5px 1.5px 0;}

/* Hero name wrap — subtle corner brackets */
.hero-name-wrap{position:relative;}

/* ════════════════════════════════════════════════════
   ANIMATED ACCENT LINES
   ════════════════════════════════════════════════════ */

/* Orange underline removed — clean number display */
.impact-num{display:inline-block;position:relative;}

/* ════════════════════════════════════════════════════
   ORANGE ACCENT DETAILS — data panel micro-signals
   ════════════════════════════════════════════════════ */


/* Work card company — + prefix (Image 3: "+ CONTROLER" pattern) */
.work-card-company{display:flex;align-items:center;gap:5px;}
.work-card-company::before{content:'+';font-family:'Rajdhani',sans-serif;font-size:7px;color:var(--orange);opacity:0.65;line-height:1;flex-shrink:0;}

/* Work card arrow — base state handled in main .work-card-arrow rule above */

/* Section index — > indicator prefix */
.section-index::before{content:'> ';opacity:0.45;}

/* ════════════════════════════════════════════════════
   HUD INSTRUMENT PANEL DETAILS
   ════════════════════════════════════════════════════ */

/* Section indicator: solid black square → hollow orange diamond reticle */
.section-title .sq{background:transparent;border:1.5px solid var(--orange);transform:rotate(45deg);}
/* Dark section (impact): filled orange diamond */
.impact-section .section-title .sq{background:var(--orange);border-color:var(--orange);}


/* About heading: corner bracket framing */
.about-heading{position:relative;}
.about-heading::before,.about-heading::after{content:'';position:absolute;width:16px;height:16px;border-color:rgba(255,79,26,0.28);border-style:solid;pointer-events:none;}
.about-heading::before{top:0;left:0;border-width:1.5px 0 0 1.5px;}
.about-heading::after{bottom:0;right:0;border-width:0 1.5px 1.5px 0;}

/* Skill icons: orange glow — reinforces the HUD instrumentation read */
.skill-item svg{filter:drop-shadow(0 0 4px rgba(255,79,26,0.45));}

/* ════════════════════════════════════════════════════
   COORDINATE ANNOTATION — hero HUD data layer
   ════════════════════════════════════════════════════ */
.hero-coord{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gray);opacity:0.55;margin-top:6px;margin-bottom:20px;}

/* ════════════════════════════════════════════════════
   WORK CARD NUMBER — bracket notation [01]
   ════════════════════════════════════════════════════ */
.work-card-number{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.08em;color:var(--gray-lt);}



/* ════════════════════════════════════════════════════
   HOME ROUTING BLOCK — three-panel nav signal
   ════════════════════════════════════════════════════ */
.home-nav-block{display:grid;grid-template-columns:1fr 1fr 1fr;border-bottom:1.5px solid var(--border);}
.home-nav-cell{padding:40px;border-right:1.5px solid var(--border);display:flex;flex-direction:column;gap:12px;text-decoration:none;color:inherit;transition:background 0.2s;position:relative;min-height:200px;}
.home-nav-cell:last-child{border-right:none;}
.home-nav-cell:hover{background:#F5F4F2;}
.home-nav-num{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.12em;color:var(--gray-lt);}
.home-nav-title{font-family:'Orbitron',sans-serif;font-weight:700;font-size:40px;letter-spacing:0.03em;color:var(--black);line-height:0.95;margin-top:4px;}
.home-nav-desc{font-size:16px;color:#555;line-height:1.65;padding-top:16px;border-top:1.5px solid var(--border);margin-top:auto;}
/* .home-nav-arrow and its hover state are now in the button system block */

/* ════════════════════════════════════════════════════
   PAGE TRANSITIONS — orange bar wipe
   ════════════════════════════════════════════════════ */
.page-transition-bar{position:fixed;inset:0;background:var(--orange);transform:scaleY(0);transform-origin:top center;z-index:9999;pointer-events:none;will-change:transform;}
@keyframes pt-cover{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes pt-reveal{from{transform:scaleY(1)}to{transform:scaleY(0)}}
.page-transition-bar.pt-cover{transform-origin:top center;animation:pt-cover 0.38s cubic-bezier(0.76,0,0.24,1) both;}
[data-pt="in"] .page-transition-bar{transform-origin:bottom center;animation:pt-reveal 0.42s cubic-bezier(0.76,0,0.24,1) 0.05s both;}
@media(prefers-reduced-motion:reduce){.page-transition-bar,.page-transition-bar.pt-cover,[data-pt="in"] .page-transition-bar{animation:none;transform:scaleY(0);}}

/* ════════════════════════════════════════════════════
   HERO ENTRANCE ANIMATION
   ════════════════════════════════════════════════════ */
@keyframes hero-word-up{from{clip-path:inset(0 0 105% 0);opacity:0;}to{clip-path:inset(0 0 0% 0);opacity:1;}}
@keyframes hero-fade-up{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
.hero-word{display:inline-block;clip-path:inset(0 0 105% 0);opacity:0;animation:hero-word-up 0.6s cubic-bezier(0.16,1,0.3,1) both;}
.hero-subline{display:inline-block;opacity:0;animation:hero-fade-up 0.4s ease both;}
.hero-mark{opacity:0;animation:hero-fade-up 0.5s ease 0.05s both;}
.hero-name{opacity:0;animation:hero-fade-up 0.7s cubic-bezier(0.16,1,0.3,1) 0.2s both;}
.hero-coord{opacity:0;animation:hero-fade-up 0.5s ease 0.35s both;}
.hero-bio{opacity:0;animation:hero-fade-up 0.5s ease 0.5s both;}
.qr-link-wrap{opacity:0;animation:hero-fade-up 0.5s ease 0.65s both;}
@media(prefers-reduced-motion:reduce){.hero-word,.hero-subline,.hero-mark,.hero-name,.hero-coord,.hero-bio,.qr-link-wrap{animation:none;opacity:1;clip-path:none;transform:none;}}

/* ════════════════════════════════════════════════════
   CAREER TIMELINE — about page
   ════════════════════════════════════════════════════ */
.timeline{display:flex;flex-direction:column;}
.timeline-item{display:grid;grid-template-columns:28px 1fr;gap:0 20px;}
.timeline-rail{display:flex;flex-direction:column;align-items:center;}
.timeline-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1.5px solid var(--border);background:var(--bg);transform:scale(0.4);transition:transform 0.5s cubic-bezier(0.34,1.56,0.64,1),background 0.25s,border-color 0.25s;margin-top:5px;}
.timeline-item.is-active .timeline-dot{transform:scale(1);background:var(--orange);border-color:var(--orange);}
.timeline-seg{width:1.5px;flex:1;min-height:40px;background:var(--border);transform:scaleY(0);transform-origin:top;transition:transform 0.55s cubic-bezier(0.16,1,0.3,1) 0.28s;}
.timeline-item.is-active .timeline-seg{transform:scaleY(1);}
.timeline-item:last-child .timeline-seg{display:none;}
.timeline-content{padding-bottom:36px;}
.timeline-item:last-child .timeline-content{padding-bottom:0;}
.timeline-head{display:flex;align-items:baseline;gap:10px;margin-bottom:4px;}
.timeline-year{font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.16em;color:var(--orange);text-transform:uppercase;}
.timeline-co{font-family:'Orbitron',sans-serif;font-weight:700;font-size:22px;letter-spacing:0.05em;color:var(--black);line-height:1;}
.timeline-role{font-size:14px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gray-lt);margin-bottom:6px;}
.timeline-desc{font-size:16px;line-height:1.7;color:#555;}
.timeline-now{display:inline-flex;align-items:center;gap:5px;font-family:'Rajdhani',sans-serif;font-size:14px;letter-spacing:0.16em;text-transform:uppercase;color:var(--orange);margin-left:8px;}
.timeline-now::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--orange);animation:pulse 1.8s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.4;transform:scale(0.7);}}

/* ════════════════════════════════════════════════════
   CUSTOM CURSOR (P8)
   ════════════════════════════════════════════════════ */
html.has-custom-cursor,html.has-custom-cursor *{cursor:none!important;}
.cursor{position:fixed;top:0;left:0;width:16px;height:16px;border-radius:50%;border:1px solid var(--orange);pointer-events:none;z-index:99999;opacity:0;will-change:transform;transition:width 0.25s cubic-bezier(0.23,1,0.32,1),height 0.25s cubic-bezier(0.23,1,0.32,1),background 0.25s,border-color 0.25s,opacity 0.3s;display:flex;align-items:center;justify-content:center;}
.cursor.is-visible{opacity:1;}
.cursor.cursor--hover{width:48px;height:48px;background:rgba(255,79,26,0.12);border-color:rgba(255,79,26,0.55);}
.cursor.cursor--click{width:36px;height:36px;background:rgba(255,79,26,0.25);}
.cursor.cursor--on-orange{border-color:rgba(255,255,255,0.8);background:rgba(255,255,255,0.08);}
.cursor.cursor--testimonial{width:80px;height:80px;background:var(--black);border-color:transparent;}
.cursor-label{display:none;font-family:'Rajdhani',sans-serif;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:#fff;pointer-events:none;user-select:none;}
.cursor--testimonial .cursor-label{display:block;}


/* ════════════════════════════════════════════════════
   VERSIONS OF ME — about page interactive tabs
   ════════════════════════════════════════════════════ */
.versions-inner{display:grid;grid-template-columns:260px 1fr;border:1.5px solid var(--border);overflow:hidden;height:760px;}
.versions-left{display:flex;flex-direction:column;border-right:1.5px solid var(--border);}
.versions-tabs{display:flex;flex-direction:column;flex:1;}
.versions-tab{font-family:'Orbitron',sans-serif;font-weight:700;font-size:28px;letter-spacing:0.06em;color:var(--black);background:none;border:none;border-top:1px solid var(--border);padding:16px 24px;text-align:left;cursor:pointer;transition:color 0.15s,background 0.15s;line-height:1;position:relative;flex:1;display:flex;align-items:center;}
.versions-tab:first-child{border-top:none;}
.versions-tab:last-child{border-bottom:1.5px solid var(--border);}
.versions-tab:hover{color:var(--orange);background:#F5F4F2;}
.versions-tab.is-active{color:var(--orange);}
.versions-tab.is-active::after{content:'→';position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:14px;font-family:'Rajdhani',sans-serif;color:var(--orange);}
.versions-blurb{padding:24px;font-size:16px;line-height:1.75;color:#555;transition:opacity 0.2s ease;height:310px;overflow:hidden;}
.versions-right{position:relative;overflow:hidden;background:#111;}
.versions-portrait{position:absolute;inset:0;clip-path:inset(0 100% 0 0);}
.versions-portrait.is-active{clip-path:inset(0 0% 0 0);transition:clip-path 0.55s cubic-bezier(0.16,1,0.3,1);}
.versions-portrait img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;filter:grayscale(100%);}
@media(max-width:767px){
  .versions-inner{grid-template-columns:1fr 42%;height:auto;}
  .versions-right{order:0;}
  .versions-tabs{display:grid;grid-template-columns:1fr 1fr;flex:none;}
  .versions-tab{font-size:20px;padding:10px 12px;flex:none;border-top:1px solid var(--border);}
  .versions-tab:nth-child(1),.versions-tab:nth-child(2){border-top:none;}
  .versions-tab:nth-child(odd){border-right:1px solid var(--border);}
  .versions-tab:last-child{border-bottom:none;}
  .versions-tab.is-active::after{display:none;}
  .versions-blurb{padding:10px 12px;border-top:1.5px solid var(--border);overflow:hidden;}
}

/* ══════════════════════════════════════════════════
   MOBILE RESPONSIVE — MAIN SITE
   ══════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── Navigation ── */
  nav {
    padding: 0 16px;
    height: 56px;
    flex-wrap: nowrap;
  }
  .nav-logo {
    padding-right: 16px;
  }
  .nav-links {
    display: none;
  }
  .nav-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    padding: 8px;
    margin-left: auto;
    background: none;
    border: none;
    cursor: pointer;
    flex-shrink: 0;
  }
  .nav-toggle-bar {
    display: block;
    width: 100%;
    height: 1.5px;
    background: var(--black);
    transform-origin: center;
    transition: transform 0.25s ease, opacity 0.2s ease, width 0.25s ease;
  }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
  }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) {
    opacity: 0;
    width: 0;
  }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
  }

  /* Mobile menu overlay */
  .mobile-menu {
    display: none;
    position: fixed;
    top: 56px;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 99;
    background: var(--bg);
    border-top: 1.5px solid var(--border);
    flex-direction: column;
    overflow-y: auto;
  }
  .mobile-menu.is-open {
    display: flex;
  }
  .mobile-menu a,
  .mobile-menu .mobile-menu-status {
    display: flex;
    align-items: center;
    padding: 0 20px;
    height: 56px;
    border-bottom: 1.5px solid var(--border);
    font-family: 'DM Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--gray);
    transition: color 0.15s, background 0.15s;
    flex-shrink: 0;
  }
  .mobile-menu a:hover,
  .mobile-menu a:focus-visible {
    color: var(--black);
    background: #F5F4F2;
    outline: none;
  }
  .mobile-menu a[aria-current] {
    color: var(--black);
  }
  .mobile-menu .mobile-menu-cta {
    background: var(--orange);
    color: #fff !important;
    font-weight: 500;
  }
  .mobile-menu .mobile-menu-cta:hover {
    background: #c94400 !important;
  }
  .mobile-menu .mobile-menu-status {
    gap: 6px;
    font-size: 10px;
    cursor: default;
  }

  /* ── Hero label: don't stretch full-width on mobile ── */
  .hero-label {
    align-self: flex-start;
  }

  /* ── Hero: stack vertically ── */
  .hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .hero-left {
    padding: 28px 20px;
    border-right: none;
    border-bottom: 1.5px solid var(--border-dk);
    order: 1;
  }
  .hero-video-panel {
    order: 2;
    padding: 28px 20px;
    min-height: 280px;
  }
  .hero-video-frame {
    max-width: 220px;
    aspect-ratio: 3/4;
  }
  .hero-name {
    font-size: clamp(56px, 14vw, 96px);
  }

  /* ── Home nav tiles: single column ── */
  .home-nav-block {
    grid-template-columns: 1fr;
  }
  .home-nav-cell {
    border-right: none;
    border-bottom: 1.5px solid var(--border);
    min-height: auto;
    padding: 28px 20px;
  }
  .home-nav-cell:last-child {
    border-bottom: none;
  }

  /* ── Work grid: 1 column ── */
  .work-grid {
    grid-template-columns: 1fr;
  }
  .work-card {
    border-right: none;
  }
  .work-card:nth-child(3n) {
    border-right: none;
  }
  .work-card-top {
    padding: 16px 20px 14px;
  }
  .work-card-body {
    padding: 16px 20px 72px;
  }
  .work-card-arrow {
    right: 20px;
    bottom: 20px;
  }

  /* ── Section headers ── */
  .section-header {
    padding: 14px 20px;
  }

  /* ── About section: single column ── */
  .about-section {
    grid-template-columns: 1fr;
  }
  .about-left {
    border-right: none;
    border-bottom: 1.5px solid var(--border);
    padding: 32px 20px;
  }
  .about-left .section-header--inset {
    margin-right: calc(-20px - 1.5px);
  }
  .about-right {
    padding: 32px 20px;
  }
  .section-header--inset {
    margin: -32px -20px 24px;
    padding: 14px 20px 20px;
  }

  /* ── Skills grid: keep 2 cols, reduce padding ── */
  .skills-grid {
    grid-template-columns: 1fr 1fr;
  }
  .skill-item {
    padding: 12px 14px;
  }

  /* ── Impact grid: 2 columns ── */
  .impact-grid {
    grid-template-columns: 1fr 1fr;
  }
  .impact-cell {
    border-right: none;
    padding: 24px 20px;
  }
  .impact-cell:nth-child(odd) {
    border-right: 1.5px solid var(--border-dk);
  }
  .impact-cell:nth-child(4n) {
    border-right: none;
  }
  .impact-num {
    font-size: 44px;
  }

  /* ── Testimonial carousel ── */
  .ts-inner {
    grid-template-columns: 1fr;
    cursor: default;
  }
  .ts-left {
    border-right: none;
    border-bottom: 1.5px solid var(--border);
    padding: 32px 20px;
  }
  .ts-right {
    padding: 32px 20px;
  }
  .ts-quote {
    font-size: 16px;
    min-height: auto;
  }

  /* ── CTA section ── */
  .cta-cols {
    grid-template-columns: 1fr;
  }
  .cta-col {
    border-right: none;
    border-bottom: 1.5px solid rgba(255,255,255,0.15);
    padding: 24px 20px;
  }
  .cta-col:last-child {
    display: none; /* hide QR chip col on mobile */
  }

  /* ── Hide all QR codes on mobile ── */
  .qr-chip {
    display: none;
  }
  .qr-link-wrap {
    gap: 0;
  }

  /* ── Footer ── */
  .footer-inner {
    grid-template-columns: 1fr;
    padding: 32px 20px;
    gap: 28px;
  }
  .footer-bottom {
    padding: 16px 20px;
    flex-direction: column;
    gap: 4px;
    align-items: flex-start;
  }

  /* ── Work intro ── */
  .work-intro {
    padding: 24px 20px 0;
  }

}

@media (max-width: 480px) {

  nav {
    padding: 0 12px;
  }
  .hero-left {
    padding: 20px 16px;
  }
  .hero-video-panel {
    padding: 20px 16px;
  }
  .hero-name {
    font-size: clamp(48px, 16vw, 72px);
  }
  .home-nav-cell {
    padding: 24px 16px;
  }
  .about-left,
  .about-right {
    padding: 24px 16px;
  }
  .section-header--inset {
    margin: -24px -16px 20px;
    padding: 12px 16px 16px;
  }
  .impact-grid {
    grid-template-columns: 1fr 1fr;
  }
  .impact-cell {
    border-right: none;
  }
  .impact-cell:nth-child(odd) {
    border-right: 1.5px solid var(--border-dk);
  }
  .ts-left,
  .ts-right {
    padding: 24px 16px;
  }
  .footer-inner {
    padding: 24px 16px;
  }
  .footer-bottom {
    padding: 14px 16px;
  }

}

/* ══════════════════════════════════════════════════
   TABLET RESPONSIVE — 769px to 1024px
   Desktop layout applies but grids need adjustment
   ══════════════════════════════════════════════════ */

@media (min-width: 769px) and (max-width: 1024px) {

  /* ── Work grid: 2 columns ── */
  .work-grid {
    grid-template-columns: 1fr 1fr;
  }
  .work-card:nth-child(3n) {
    border-right: 1.5px solid var(--border);
  }
  .work-card:nth-child(2n) {
    border-right: none;
  }
  .work-card-top {
    padding: 16px 24px 14px;
  }
  .work-card-body {
    padding: 16px 24px 80px;
  }
  .work-card-arrow {
    right: 24px;
    bottom: 32px;
  }

  /* ── Hero: reduce padding ── */
  .hero-left {
    padding: 48px 24px 32px;
  }
  .hero-video-panel {
    padding: 32px 24px;
  }

  /* ── Section headers ── */
  .section-header {
    padding: 14px 24px;
  }

  /* ── Home nav: reduce padding ── */
  .home-nav-cell {
    padding: 28px 24px;
  }

  /* ── About section ── */
  .about-left,
  .about-right {
    padding: 32px 24px;
  }
  .section-header--inset {
    margin: -32px -24px 24px;
    padding: 14px 24px;
  }
  .about-left .section-header--inset {
    margin-right: calc(-24px - 1.5px);
  }

  /* ── Impact grid: 2 columns ── */
  .impact-grid {
    grid-template-columns: 1fr 1fr;
  }
  .impact-cell:nth-child(4n) {
    border-right: 1.5px solid var(--border-dk);
  }
  .impact-cell:nth-child(2n) {
    border-right: none;
  }
  .impact-num {
    font-size: 44px;
  }

  /* ── Testimonials ── */
  .ts-inner {
    grid-template-columns: 240px 1fr;
  }
  .ts-left {
    padding: 32px 24px;
  }
  .ts-right {
    padding: 32px 24px;
  }

  /* ── CTA section ── */
  .cta-cols {
    grid-template-columns: 1fr 1fr;
  }
  .cta-col {
    padding: 28px 24px;
  }
  .cta-col:last-child {
    display: none;
  }

  /* ── Footer ── */
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    padding: 40px 24px;
    gap: 32px;
  }

  /* ── Work intro ── */
  .work-intro {
    padding: 24px 24px 0;
  }

}