:root{
  --navy:#050b18;
  --navy-2:#091426;
  --navy-3:#0e1c33;
  --ink:#111827;
  --muted:#647084;
  --paper:#f7f9fc;
  --white:#ffffff;
  --cyan:#00d7ff;
  --teal:#14d5c4;
  --magenta:#f044ff;
  --line:rgba(255,255,255,.14);
  --dark-line:rgba(17,24,39,.12);
  --shadow:0 22px 70px rgba(1,8,25,.35);
  --radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:var(--paper);line-height:1.55}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
.container{width:min(1160px,calc(100% - 40px));margin:0 auto}.section-dark{background:var(--navy);color:var(--white);position:relative;overflow:hidden}.section-dark-soft{background:#090f1d;color:var(--white)}.section-light{background:var(--paper);color:var(--ink);padding:88px 0}.site-header{position:fixed;z-index:1000;top:0;left:0;right:0;height:76px;padding:0 30px;display:flex;align-items:center;justify-content:space-between;background:rgba(5,11,24,.78);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08);color:#fff}.brand{display:flex;align-items:center;gap:12px;text-transform:uppercase;letter-spacing:.18em}.brand img{width:44px;height:36px;object-fit:contain}.brand span{display:block;font-size:.82rem;font-weight:800}.brand small{display:block;font-size:.6rem;font-weight:700;color:#dbe7ff;letter-spacing:.16em}.desktop-nav{display:flex;gap:28px;font-size:.82rem;font-weight:700}.desktop-nav a{opacity:.84;transition:.2s}.desktop-nav a:hover{color:var(--cyan);opacity:1}.header-actions{display:flex;align-items:center;gap:14px}.lang{font-size:.75rem;font-weight:800;opacity:.55}.lang.active{color:var(--cyan);opacity:1;border-bottom:1px solid var(--cyan)}.menu-toggle{display:none;background:transparent;border:0;color:#fff;font-size:1.7rem}.mobile-nav{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:0;padding:14px 22px;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:900;min-height:48px;transition:.2s;border:1px solid transparent}.btn-small{padding:10px 14px;min-height:38px;font-size:.66rem}.btn-primary{color:#fff;background:linear-gradient(90deg,var(--teal),var(--magenta));box-shadow:0 12px 32px rgba(0,215,255,.18)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(240,68,255,.26)}.btn-outline{color:#fff;border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.03)}.btn-outline:hover{border-color:var(--cyan);color:var(--cyan)}.btn-outline-dark{color:var(--ink);border-color:rgba(17,24,39,.22);background:rgba(255,255,255,.55)}.btn-outline-dark:hover{border-color:var(--magenta);color:#8d1697}.hero{padding:142px 0 80px;min-height:760px;display:flex;align-items:center}.hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 76% 42%,rgba(0,215,255,.23),transparent 24%),radial-gradient(circle at 82% 30%,rgba(240,68,255,.24),transparent 20%),linear-gradient(135deg,rgba(255,255,255,.04) 0 1px,transparent 1px);background-size:auto,auto,38px 38px;opacity:.95}.hero:before{content:"";position:absolute;right:-18%;top:10%;width:72%;height:70%;background:linear-gradient(135deg,transparent 15%,rgba(0,215,255,.16),rgba(240,68,255,.14),transparent 70%);clip-path:polygon(20% 8%,100% 0,82% 72%,0 100%);filter:blur(1px)}.hero-grid{position:relative;display:grid;grid-template-columns:1fr .95fr;align-items:center;gap:54px}.eyebrow{margin:0 0 18px;color:var(--teal);text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;font-weight:900}.eyebrow.dark{color:#0aa7bd}.hero h1{font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(3rem,7vw,5.9rem);line-height:.95;margin:0 0 28px;letter-spacing:-.055em;max-width:680px}.hero-lead{font-size:1.08rem;color:#d5deee;max-width:590px;margin:0 0 34px}.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}.hero-visual{position:relative;min-height:560px}.photo-frame{position:absolute;inset:0 70px 0 0;border-radius:34px;overflow:hidden;background:linear-gradient(135deg,rgba(0,215,255,.12),rgba(240,68,255,.12));box-shadow:var(--shadow)}.photo-frame:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,11,24,.35),transparent 40%,rgba(5,11,24,.06))}.photo-frame img{width:100%;height:100%;object-fit:cover;object-position:center 20%}.side-badge{position:absolute;right:0;top:42%;display:grid;gap:3px;text-transform:uppercase;letter-spacing:.45em;font-weight:900;color:var(--teal);font-size:1.1rem}.logo-strip{padding:26px 0 32px;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.08)}.strip-title{text-align:center;text-transform:uppercase;letter-spacing:.22em;font-size:.75rem;font-weight:900;color:#e8eef7;margin:0 0 22px}.logo-row{display:grid;grid-template-columns:repeat(6,1fr);gap:26px;align-items:center}.logo-row img{height:54px;width:100%;object-fit:contain;filter:grayscale(1) brightness(1.7) contrast(.9);opacity:.72;mix-blend-mode:screen}.strip-note{text-align:center;color:#9aa8bd;font-size:.9rem;margin:22px auto 0;max-width:800px}.section-heading{max-width:820px;margin:0 0 46px}.section-heading.centered{text-align:center;margin-left:auto;margin-right:auto}.section-heading h2{font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(2rem,4vw,3.25rem);line-height:1.05;letter-spacing:-.045em;margin:0}.section-heading p:not(.eyebrow){color:var(--muted);font-size:1.05rem}.card-grid{display:grid;gap:22px}.card-grid.four{grid-template-columns:repeat(4,1fr)}.card{padding:34px 28px;background:#fff;border:1px solid var(--dark-line);border-radius:var(--radius);box-shadow:0 18px 46px rgba(17,24,39,.05);min-height:250px}.card .icon{font-size:2.4rem;color:var(--magenta);margin-bottom:18px}.card h3,.service-card h3,.experience-card h3{font-family:"Space Grotesk",Inter,sans-serif;text-transform:uppercase;letter-spacing:.08em;line-height:1.05}.card p{color:var(--muted);font-size:.95rem}.skills{padding:88px 0}.skills:before,.statement:before,.final-cta:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,215,255,.08),transparent 32%),linear-gradient(45deg,transparent,rgba(240,68,255,.06));pointer-events:none}.tag-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:42px 0}.tag-grid span{padding:20px 14px;text-align:center;border:1px solid rgba(20,213,196,.25);background:rgba(255,255,255,.025);border-radius:14px;text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;font-weight:900;color:#e9f7ff}.wide-text{max-width:860px;text-align:center;margin:36px auto 0;color:#b9c6d8}.method-section{padding-bottom:72px}.method-line{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative}.method-line article{background:#fff;border:1px solid var(--dark-line);border-radius:var(--radius);padding:34px 26px;position:relative;box-shadow:0 18px 46px rgba(17,24,39,.05)}.method-line article span{display:block;font-family:"Space Grotesk";font-size:1.5rem;font-weight:900;color:var(--teal);margin-bottom:10px}.method-line article:nth-child(even) span{color:var(--magenta)}.method-line h3{margin:0 0 12px;text-transform:uppercase;letter-spacing:.08em}.method-line p{color:var(--muted);font-size:.94rem}.services-section{padding-top:32px}.service-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}.service-card{background:#fff;border:1px solid var(--dark-line);border-radius:18px;overflow:hidden;box-shadow:0 20px 52px rgba(17,24,39,.06)}.service-card h3,.service-card p,.service-card ul{padding-left:22px;padding-right:22px}.service-card h3{font-size:1.02rem;margin:22px 0 12px}.service-card p{color:var(--muted);font-size:.9rem}.service-card ul{margin:16px 0 26px;color:#455166;font-size:.83rem;padding-left:40px}.service-image{height:120px;background-size:cover;background-position:center;filter:saturate(.95)}.service-image.esports{background-image:linear-gradient(rgba(0,215,255,.28),rgba(5,11,24,.65)),url('assets/logo-qlash.png');background-size:cover,60%;background-repeat:no-repeat}.service-image.sport{background-image:linear-gradient(rgba(240,68,255,.22),rgba(5,11,24,.62)),url('assets/logo-figc.png');background-size:cover,33%;background-repeat:no-repeat}.service-image.individual{background-image:linear-gradient(rgba(5,11,24,.28),rgba(5,11,24,.75)),url('assets/daniele-stizza-profile.jpg');background-position:center 15%}.service-image.team{background-image:linear-gradient(rgba(0,215,255,.22),rgba(5,11,24,.72)),url('assets/logo-vesta.png');background-size:cover,50%;background-repeat:no-repeat}.service-image.workshop{background-image:linear-gradient(rgba(240,68,255,.18),rgba(5,11,24,.76)),url('assets/logo-fibs.png');background-size:cover,50%;background-repeat:no-repeat}.statement{padding:88px 0}.statement-grid{display:grid;grid-template-columns:120px 1fr;gap:34px;align-items:start}.quote-mark{font-family:"Space Grotesk";font-size:8rem;line-height:.8;color:var(--teal)}.statement h2{font-family:"Space Grotesk";font-size:clamp(2.3rem,5vw,4.6rem);line-height:.98;letter-spacing:-.04em;margin:0 0 24px}.statement p{max-width:790px;color:#cbd6e7}.statement-line{font-weight:700;color:#fff!important}.experience-section{padding-top:88px}.experience-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.experience-card{background:#fff;border:1px solid var(--dark-line);border-radius:var(--radius);padding:30px;box-shadow:0 18px 46px rgba(17,24,39,.05)}.experience-card h3{margin-top:0}.experience-card ul{list-style:none;margin:0;padding:0}.experience-card li{padding:18px 0;border-top:1px solid rgba(17,24,39,.08)}.experience-card li:first-child{border-top:0}.experience-card strong{display:block;margin-bottom:5px}.experience-card span{display:block;color:var(--muted);font-size:.9rem}.portfolio-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:40px}.about-section{padding-top:28px}.about-grid{display:grid;grid-template-columns:.75fr 1.25fr;gap:64px;align-items:center}.about-photo{border-radius:24px;overflow:hidden;background:var(--navy);box-shadow:var(--shadow);max-height:520px}.about-photo img{width:100%;height:100%;object-fit:cover;object-position:center 18%}.about-copy h2{font-family:"Space Grotesk";font-size:clamp(2rem,4vw,3.15rem);line-height:1.05;letter-spacing:-.04em;margin:0 0 24px}.about-copy p{color:#48556a}.credential-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:26px}.credential-grid span{border:1px solid var(--dark-line);border-radius:12px;padding:14px 16px;background:#fff;font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em}.final-cta{padding:78px 0}.final-grid{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}.final-grid h2{font-family:"Space Grotesk";font-size:clamp(2rem,4vw,3.3rem);line-height:1.04;margin:0 0 16px;letter-spacing:-.045em}.final-grid p{max-width:690px;color:#cbd6e7}.final-actions{display:grid;gap:14px;min-width:285px}.site-footer{padding:30px 0}.footer-grid{display:grid;grid-template-columns:1fr auto auto;gap:30px;align-items:center}.footer-links{display:flex;gap:22px;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:900}.footer-links a:hover{color:var(--cyan)}.site-footer p{color:#8390a5;font-size:.8rem}.footer-brand img{width:42px}.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:1050px){.desktop-nav{display:none}.menu-toggle{display:block}.header-actions .btn-small{display:none}.mobile-nav{position:fixed;z-index:999;top:76px;left:0;right:0;background:rgba(5,11,24,.96);border-bottom:1px solid rgba(255,255,255,.08);padding:22px 30px;gap:18px;flex-direction:column;color:#fff}.mobile-nav.open{display:flex}.hero-grid,.about-grid,.final-grid{grid-template-columns:1fr}.hero{padding-top:120px}.hero-visual{min-height:520px}.photo-frame{right:0}.side-badge{right:22px}.card-grid.four,.method-line{grid-template-columns:repeat(2,1fr)}.tag-grid{grid-template-columns:repeat(2,1fr)}.service-grid{grid-template-columns:repeat(2,1fr)}.experience-columns{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.footer-links{flex-wrap:wrap}.logo-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.container{width:min(100% - 28px,1160px)}.site-header{padding:0 16px}.brand div{display:none}.hero{min-height:auto;padding-bottom:44px}.hero h1{font-size:3.15rem}.hero-visual{min-height:430px}.photo-frame{border-radius:22px}.side-badge{display:none}.card-grid.four,.method-line,.service-grid{grid-template-columns:1fr}.tag-grid{grid-template-columns:1fr}.statement-grid{grid-template-columns:1fr}.quote-mark{font-size:5rem}.credential-grid{grid-template-columns:1fr}.hero-buttons,.portfolio-actions{display:grid}.logo-row{grid-template-columns:repeat(2,1fr);gap:18px}.logo-row img{height:48px}.section-light,.skills,.statement,.experience-section,.final-cta{padding:62px 0}.footer-links{display:grid}}

/* === V2 refinements: closer to the approved visual mockup === */
.side-badge{gap:10px;letter-spacing:.52em;font-size:1.18rem;right:8px;}
.side-badge span{position:relative;color:#edf6ff;text-shadow:0 0 22px rgba(0,215,255,.12)}
.side-badge span::first-letter{color:var(--teal)}
.side-badge .tone-magenta::first-letter{color:var(--magenta)}
.side-badge .tone-cyan{color:var(--teal)}
.side-badge .tone-light{color:#eef6ff}
.side-badge .end-accent::after{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--magenta);box-shadow:0 0 16px rgba(240,68,255,.85);margin-left:7px;vertical-align:middle}

.logo-strip{padding:34px 0 40px;background:linear-gradient(180deg,#060c18,#080f1f)}
.logo-row.primary-logos{display:grid;grid-template-columns:repeat(6,1fr);gap:34px;align-items:center;margin-top:10px}
.logo-row.primary-logos img{height:76px;max-width:170px;margin:0 auto;width:100%;object-fit:contain;filter:none;opacity:.96;mix-blend-mode:normal;padding:8px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.logo-row.primary-logos img[alt="Colossal Gaming"]{max-width:160px}
.logo-row.primary-logos img[alt="Vesta"]{max-width:170px}
.logo-row.primary-logos img[alt="FIBS"]{max-width:132px}
.logo-row.primary-logos img[alt="FIGC"]{max-width:116px}
.strip-note{margin-top:24px}

.icon-card-grid .card{text-align:center;min-height:245px;padding-top:42px}
.line-icon{width:56px;height:56px;margin:0 auto 22px;display:grid;place-items:center}
.line-icon svg{width:56px;height:56px;fill:none;stroke:currentColor;stroke-width:3.2;stroke-linecap:round;stroke-linejoin:round}
.line-icon.teal{color:var(--teal)}
.line-icon.violet{color:#9b5cff}
.line-icon.blue{color:#3a82ff}
.line-icon.pink{color:var(--magenta)}
.icon-card-grid .card h3{font-size:1.02rem;margin-top:0}

.skill-icon-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin:48px 0 34px;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}
.skill-item{min-height:130px;display:grid;place-items:center;text-align:center;padding:20px 18px;border-right:1px solid rgba(255,255,255,.11)}
.skill-item:nth-child(5n){border-right:0}
.skill-item:nth-child(n+6){border-top:1px solid rgba(255,255,255,.12)}
.mini-icon{width:42px;height:42px;color:var(--teal);margin-bottom:11px;display:grid;place-items:center}
.mini-icon svg{width:40px;height:40px;fill:none;stroke:currentColor;stroke-width:2.7;stroke-linecap:round;stroke-linejoin:round}
.skill-item span{text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-size:.72rem;line-height:1.35;color:#eef6ff}

.section-heading.compact{max-width:920px;margin-bottom:34px}
.section-heading.compact h2{font-size:clamp(2.1rem,4vw,3.6rem);max-width:980px;margin:0 auto 18px;line-height:1.08}
.method-timeline{grid-template-columns:repeat(4,1fr);gap:0;align-items:start;margin-top:42px}
.method-timeline article{background:transparent;border:0;border-radius:0;box-shadow:none;padding:10px 30px 28px;position:relative;min-height:180px}
.method-timeline article:not(:last-child)::after{content:"→";position:absolute;right:-14px;top:74px;font-size:2.4rem;color:#1b2433;font-weight:300}
.method-timeline article span{font-size:1.25rem;margin-bottom:8px}
.method-timeline article h3{font-size:.95rem;margin-bottom:18px}
.method-icon{width:78px;height:78px;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;color:var(--teal);background:rgba(255,255,255,.48)}
.method-icon svg{width:38px;height:38px;fill:none;stroke:currentColor;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
.method-icon.teal{color:var(--teal)}
.method-icon.violet{color:#a566ff}
.method-icon.blue{color:#3a82ff}
.method-icon.pink{color:var(--magenta)}
.method-timeline article p{text-align:left;max-width:260px;margin:0 auto;color:#556176}

.service-image{height:128px;background-size:cover;background-position:center;filter:none}
.service-image.esports{background-image:url('assets/service-esports.svg');background-size:cover;background-repeat:no-repeat;background-position:center}
.service-image.sport{background-image:url('assets/service-sport.svg');background-size:cover;background-repeat:no-repeat;background-position:center}
.service-image.individual{background-image:url('assets/service-individual.svg');background-size:cover;background-repeat:no-repeat;background-position:center}
.service-image.team{background-image:url('assets/service-team.svg');background-size:cover;background-repeat:no-repeat;background-position:center}
.service-image.workshop{background-image:url('assets/service-workshop.svg');background-size:cover;background-repeat:no-repeat;background-position:center}

.statement{position:relative;overflow:hidden;min-height:520px;padding:105px 0}
.statement-visual{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(5,11,24,.93) 0%,rgba(5,11,24,.86) 42%,rgba(5,11,24,.42) 100%),url('assets/statement-player-athlete.svg');background-size:cover;background-position:center;opacity:.95;z-index:0}
.statement:before{z-index:1;opacity:.7}
.statement .container{position:relative;z-index:2}
.statement-grid{grid-template-columns:120px minmax(0,760px);max-width:1160px}
.statement p{font-size:1rem}

@media(max-width:1050px){
  .logo-row.primary-logos{grid-template-columns:repeat(3,1fr)}
  .skill-icon-grid{grid-template-columns:repeat(2,1fr)}
  .skill-item,.skill-item:nth-child(5n){border-right:1px solid rgba(255,255,255,.11)}
  .skill-item:nth-child(2n){border-right:0}
  .skill-item:nth-child(n+3){border-top:1px solid rgba(255,255,255,.12)}
  .method-timeline{grid-template-columns:repeat(2,1fr);gap:20px}
  .method-timeline article:not(:last-child)::after{display:none}
  .method-timeline article{background:#fff;border:1px solid var(--dark-line);border-radius:var(--radius);box-shadow:0 18px 46px rgba(17,24,39,.05)}
}
@media(max-width:640px){
  .logo-row.primary-logos{grid-template-columns:repeat(2,1fr);gap:16px}
  .logo-row.primary-logos img{height:62px;max-width:150px}
  .skill-icon-grid{grid-template-columns:1fr;border-top:0}
  .skill-item,.skill-item:nth-child(2n),.skill-item:nth-child(5n){border-right:0;border-top:1px solid rgba(255,255,255,.12)}
  .method-timeline{grid-template-columns:1fr}
  .method-timeline article p{text-align:center}
  .statement{padding:72px 0;min-height:auto}
  .statement-visual{opacity:.45;background-position:center}
}


/* === V3 refinements === */
.method-icon{width:86px;height:86px;background:rgba(255,255,255,.42)}
.method-icon svg{width:42px;height:42px}
.method-timeline article p{line-height:1.55}

.service-image{height:128px;background-size:cover;background-position:center;filter:none}
.service-image.esports{background-image:linear-gradient(180deg,rgba(3,11,24,.08),rgba(3,11,24,.22)),url('assets/service-esports-photo.jpg')}
.service-image.sport{background-image:linear-gradient(180deg,rgba(3,11,24,.08),rgba(3,11,24,.22)),url('assets/service-sport-photo.jpg')}
.service-image.individual{background-image:linear-gradient(180deg,rgba(3,11,24,.08),rgba(3,11,24,.22)),url('assets/service-individual-photo.jpg')}
.service-image.team{background-image:linear-gradient(180deg,rgba(3,11,24,.08),rgba(3,11,24,.22)),url('assets/service-team-photo.jpg')}
.service-image.workshop{background-image:linear-gradient(180deg,rgba(3,11,24,.08),rgba(3,11,24,.22)),url('assets/service-workshop-photo.jpg')}

.statement{position:relative;overflow:hidden;min-height:520px;padding:105px 0}
.statement-visual{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(5,11,24,.97) 0%,rgba(5,11,24,.96) 32%,rgba(5,11,24,.84) 52%,rgba(5,11,24,.46) 100%),url('assets/statement-player-athlete-v3.jpg');background-size:cover;background-position:center;opacity:1;z-index:0}
.statement-grid{grid-template-columns:120px minmax(0,760px);max-width:1160px}
.statement p{font-size:1.02rem;line-height:1.55}


/* === V4 refinements === */
.service-image.esports{background-image:url('assets/service-esports-v4.svg')}
.service-image.sport{background-image:url('assets/service-sport-v4.svg')}
.service-image.individual{background-image:url('assets/service-individual-v4.svg')}
.service-image.team{background-image:url('assets/service-team-v4.svg')}
.service-image.workshop{background-image:url('assets/service-workshop-v4.svg')}
.statement-visual{background-image:linear-gradient(90deg,rgba(5,11,24,.97) 0%,rgba(5,11,24,.95) 30%,rgba(5,11,24,.76) 56%,rgba(5,11,24,.48) 100%),url('assets/statement-player-athlete-v4.svg')}
.method-icon svg{width:44px;height:44px}
@media(max-width:640px){.statement-visual{background-position:62% center}}


/* === Final photoreal asset swap === */
.service-image.esports{background-image:url('assets/service-esports-final.png');background-position:center}
.service-image.sport{background-image:url('assets/service-sport-final.png');background-position:center}
.service-image.individual{background-image:url('assets/service-individual-final.png');background-position:center}
.service-image.team{background-image:url('assets/service-team-final.png');background-position:center}
.service-image.workshop{background-image:url('assets/service-workshop-final.png');background-position:center}
.statement-visual{background-image:linear-gradient(90deg,rgba(5,11,24,.97) 0%,rgba(5,11,24,.95) 28%,rgba(5,11,24,.78) 52%,rgba(5,11,24,.46) 100%),url('assets/statement-player-athlete-final.png');background-size:cover;background-position:center}


/* === V7 icon image integration with original sizing === */
.mini-icon{width:60px;height:60px;margin-bottom:14px}
.mini-icon img.skill-icon-img{display:block;max-width:60px;max-height:60px;width:auto;height:auto}
.method-icon{width:86px;height:86px;border:none;background:transparent;margin:0 auto 18px;display:grid;place-items:center}
.method-icon img.method-icon-img{display:block;max-width:86px;max-height:86px;width:auto;height:auto}
@media (max-width: 900px){
  .mini-icon{width:54px;height:54px}
  .mini-icon img.skill-icon-img{max-width:54px;max-height:54px}
  .method-icon{width:74px;height:74px}
  .method-icon img.method-icon-img{max-width:74px;max-height:74px}
}


/* === V8 work-with custom icon === */
.line-icon img.work-icon-img{display:block;max-width:56px;max-height:56px;width:auto;height:auto}
@media (max-width: 900px){
  .line-icon img.work-icon-img{max-width:52px;max-height:52px}
}


/* === V9 actual requested fixes === */
.line-icon{display:grid;place-items:center;height:62px;margin-bottom:18px}
.line-icon img.work-icon-img{display:block;width:62px;height:62px;object-fit:contain}
.mini-icon{width:74px;height:74px;display:grid;place-items:center;margin:0 auto 14px}
.mini-icon img.skill-icon-img{display:block;max-width:74px;max-height:74px;width:auto;height:auto;object-fit:contain}
.method-timeline article:not(:last-child)::after{top:124px;transform:translateY(-50%)}
@media (max-width: 900px){
  .line-icon{height:56px}
  .line-icon img.work-icon-img{width:56px;height:56px}
  .mini-icon{width:66px;height:66px}
  .mini-icon img.skill-icon-img{max-width:66px;max-height:66px}
}


/* === V10 requested substitutions === */
.line-icon{display:grid;place-items:center;height:74px;margin-bottom:18px}
.line-icon img.work-icon-img{display:block;width:72px;height:72px;object-fit:contain}
.skills-panel{max-width:1320px;margin:30px auto 0}
.skills-panel img{display:block;width:100%;height:auto;border-radius:0;box-shadow:none}
@media (max-width: 900px){
  .line-icon{height:64px}
  .line-icon img.work-icon-img{width:60px;height:60px}
  .skills-panel{margin-top:22px}
}


/* === V11 Italian image panels === */
.method-panel{max-width:1380px;margin:34px auto 0}
.method-panel img{display:block;width:100%;height:auto;border-radius:0;box-shadow:none}
@media (max-width: 900px){
  .method-panel{margin-top:24px}
}


/* === V13: remove duplicate Italian method heading === */
.method-panel.single-method-graphic{margin-top:0;}
#method .method-panel.single-method-graphic img{display:block;width:100%;height:auto;}



/* === V14 mobile refinement === */
@media (max-width: 640px){
  body{
    overflow-x:hidden;
  }

  .container{
    width:min(100% - 28px, 1160px);
  }

  .hero{
    padding-top:108px;
    padding-bottom:48px;
  }

  .hero-grid{
    gap:30px;
  }

  .hero h1{
    font-size:clamp(2.7rem, 14vw, 3.5rem);
    line-height:.98;
    letter-spacing:-.055em;
  }

  .hero-lead{
    font-size:1rem;
    line-height:1.6;
  }

  .hero-buttons{
    gap:12px;
  }

  .hero-buttons .btn{
    width:100%;
  }

  .hero-visual{
    min-height:370px;
  }

  .photo-frame{
    position:relative;
    inset:auto;
    height:370px;
    border-radius:24px;
  }

  .photo-frame img{
    object-position:center 18%;
  }

  .logo-strip{
    padding:34px 0;
  }

  .logo-row{
    grid-template-columns:repeat(2,1fr);
    gap:20px 26px;
  }

  .logo-row img{
    height:52px;
  }

  .card{
    min-height:auto;
    padding:30px 24px;
  }

  .skills{
    padding-top:68px;
    padding-bottom:68px;
  }

  .skills-panel{
    width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    padding-bottom:10px;
    margin-top:28px;
  }

  .skills-panel img{
    width:820px;
    max-width:none;
  }

  .method-section{
    padding-top:68px;
    padding-bottom:68px;
  }

  .method-panel{
    width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    padding-bottom:10px;
  }

  .method-panel img{
    width:820px;
    max-width:none;
  }

  .method-timeline{
    gap:18px;
  }

  .method-timeline article{
    padding:30px 24px;
  }

  .method-timeline article p{
    text-align:left;
  }

  .service-card{
    border-radius:20px;
  }

  .service-image{
    height:150px;
  }

  .statement{
    min-height:auto;
    padding:68px 0;
  }

  .statement-visual{
    opacity:.34;
    background-position:58% center;
  }

  .statement-grid{
    grid-template-columns:1fr;
    gap:8px;
  }

  .quote-mark{
    font-size:4.6rem;
    line-height:.7;
    margin-bottom:4px;
  }

  .statement h2{
    font-size:clamp(2.15rem, 11vw, 3rem);
    line-height:1.02;
    margin-bottom:22px;
  }

  .statement p{
    font-size:1rem;
    line-height:1.62;
    max-width:100%;
  }

  .statement-line{
    margin-top:22px;
  }

  .experience-card{
    padding:26px 22px;
  }

  .experience-card li{
    padding:16px 0;
  }

  .about-grid{
    gap:30px;
  }

  .about-photo{
    max-height:420px;
  }

  .credential-grid{
    gap:10px;
  }

  .credential-grid span{
    text-align:center;
  }

  .final-grid{
    gap:28px;
  }

  .final-actions{
    width:100%;
    min-width:0;
  }

  .final-actions .btn{
    width:100%;
  }

  .footer-links{
    gap:14px;
  }
}

@media (max-width: 420px){
  .hero h1{
    font-size:2.85rem;
  }

  .hero-visual,
  .photo-frame{
    height:340px;
    min-height:340px;
  }

  .skills-panel img,
  .method-panel img{
    width:760px;
  }

  .statement h2{
    font-size:2.35rem;
  }
}


/* === V18 UX refinements === */

/* Mental skills: desktop image + mobile vertical image, no horizontal scroll */
.skills-panel-v18{
  max-width:1380px;
  margin:32px auto 0;
  overflow:visible;
  padding-bottom:0;
}
.skills-panel-v18 picture,
.skills-panel-v18 img{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  border-radius:0;
  box-shadow:none;
}
@media (max-width:640px){
  .skills-panel-v18{
    margin-top:24px;
    overflow:visible;
    padding-bottom:0;
  }
  .skills-panel-v18 img{
    width:100% !important;
    max-width:100% !important;
  }
}

/* Portfolio modal */
.portfolio-modal{
  position:fixed;
  inset:0;
  z-index:5000;
  display:none;
}
.portfolio-modal.is-open{
  display:block;
}
.portfolio-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,8,20,.78);
  backdrop-filter:blur(10px);
}
.portfolio-modal__dialog{
  position:absolute;
  inset:5vh 4vw;
  background:#061022;
  border:1px solid rgba(0,229,255,.34);
  border-radius:24px;
  box-shadow:0 28px 90px rgba(0,0,0,.45);
  overflow:hidden;
  display:grid;
  grid-template-rows:auto 1fr;
}
.portfolio-modal__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 20px;
  border-bottom:1px solid rgba(255,255,255,.09);
  color:#fff;
}
.portfolio-modal__head strong{
  font-family:"Space Grotesk", sans-serif;
  font-size:1rem;
  letter-spacing:.02em;
}
.portfolio-modal__actions{
  display:flex;
  align-items:center;
  gap:14px;
}
.portfolio-modal__actions a{
  color:var(--cyan);
  font-size:.82rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.portfolio-modal__close{
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  color:#fff;
  width:38px;
  height:38px;
  border-radius:999px;
  font-size:1.5rem;
  line-height:1;
  cursor:pointer;
}
.portfolio-modal__close:hover{
  border-color:rgba(0,229,255,.55);
  color:var(--cyan);
}
.portfolio-modal iframe{
  width:100%;
  height:100%;
  border:0;
  background:#fff;
}
body.modal-open{
  overflow:hidden;
}
@media (max-width:640px){
  .portfolio-modal__dialog{
    inset:2vh 10px;
    border-radius:18px;
  }
  .portfolio-modal__head{
    align-items:flex-start;
    padding:14px;
  }
  .portfolio-modal__actions{
    gap:10px;
  }
  .portfolio-modal__actions a{
    font-size:.72rem;
  }
}

/* About credentials: make them look like static labels, not clickable buttons */
.credential-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 24px;
  margin-top:28px;
}
.credential-grid span{
  border:0;
  border-left:2px solid var(--cyan);
  border-radius:0;
  background:transparent;
  box-shadow:none;
  padding:8px 0 8px 14px;
  color:#1f2b3f;
  font-weight:900;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.07em;
}
@media (max-width:640px){
  .credential-grid{
    grid-template-columns:1fr;
    gap:12px;
  }
  .credential-grid span{
    text-align:left;
  }
}


/* === V18.1 mobile refinement for Mental Skills === */
/* Desktop keeps the selected image panel. Mobile switches to crisp HTML cards. */
.skills-mobile-cards{
  display:none;
}

@media (max-width:640px){
  .skills-panel-v18 picture{
    display:none;
  }

  .skills-mobile-cards{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    width:100%;
    margin:0 auto;
  }

  .skill-mobile-card{
    position:relative;
    min-height:132px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:12px;
    padding:16px 8px 14px;
    border:1px solid rgba(0,229,255,.48);
    border-radius:18px;
    background:
      radial-gradient(circle at 50% 15%, rgba(0,229,255,.11), transparent 46%),
      linear-gradient(180deg, rgba(9,28,64,.92), rgba(3,12,31,.96));
    box-shadow:
      inset 0 0 0 1px rgba(0,122,255,.18),
      0 10px 24px rgba(0,0,0,.23);
    overflow:hidden;
  }

  .skill-mobile-card::before,
  .skill-mobile-card::after{
    content:"";
    position:absolute;
    width:24px;
    height:24px;
    border-color:rgba(0,229,255,.72);
    pointer-events:none;
  }

  .skill-mobile-card::before{
    top:8px;
    left:8px;
    border-top:2px solid;
    border-left:2px solid;
  }

  .skill-mobile-card::after{
    right:8px;
    bottom:8px;
    border-right:2px solid;
    border-bottom:2px solid;
  }

  .skill-mobile-card img{
    width:52px;
    height:52px;
    object-fit:contain;
    filter:drop-shadow(0 0 7px rgba(0,229,255,.55));
  }

  .skill-mobile-card span{
    display:block;
    color:#f5f8ff;
    text-align:center;
    font-family:"Space Grotesk", sans-serif;
    font-weight:900;
    font-size:.68rem;
    line-height:1.18;
    letter-spacing:.055em;
    text-transform:uppercase;
    text-shadow:0 2px 10px rgba(0,0,0,.6);
  }
}

@media (max-width:380px){
  .skills-mobile-cards{
    gap:10px;
  }

  .skill-mobile-card{
    min-height:122px;
    padding:14px 6px 12px;
  }

  .skill-mobile-card img{
    width:46px;
    height:46px;
  }

  .skill-mobile-card span{
    font-size:.62rem;
  }
}


/* === V18.3 mobile icon correction === */
/* Use padded icon assets so no symbol is cropped on mobile cards. */
@media (max-width:640px){
  .skill-mobile-card img{
    width:48px;
    height:48px;
    max-width:48px;
    max-height:48px;
    object-fit:contain;
    object-position:center;
    display:block;
  }
}

@media (max-width:380px){
  .skill-mobile-card img{
    width:44px;
    height:44px;
    max-width:44px;
    max-height:44px;
  }
}


/* === V18.5 mobile full-card update === */
/* On mobile, use the full neon card artworks directly to keep them crisp and intact. */
@media (max-width:640px){
  .skills-mobile-cards{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    width:100%;
    margin:0 auto;
    align-items:start;
  }

  .skill-mobile-card{
    min-height:auto;
    padding:0;
    gap:0;
    border:none;
    border-radius:0;
    background:none;
    box-shadow:none;
    overflow:visible;
  }

  .skill-mobile-card::before,
  .skill-mobile-card::after{
    display:none;
  }

  .skill-mobile-card img{
    width:100%;
    height:auto;
    max-width:none;
    max-height:none;
    object-fit:contain;
    object-position:center;
    display:block;
    filter:none;
    border-radius:18px;
  }

  .skill-mobile-card span{
    display:none;
  }
}

@media (max-width:380px){
  .skills-mobile-cards{
    gap:10px;
  }
}
