/* ==============================================================
   WORK PAGE — editorial case-study layout with themed backgrounds.
   Each .case section gets its own color world via .case-bg-*.
   ============================================================== */

/* === HERO === */
.work-hero {position:relative;padding:180px 0 80px;background:#000;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.05)}
.wh-ambient {position:absolute;inset:0;pointer-events:none}
.wh-orb {position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;will-change:transform}
.wh-orb-1 {top:-10%;left:5%;width:520px;height:520px;background:radial-gradient(circle,rgba(255,107,40,.32),transparent 65%);animation:wh-float-a 14s ease-in-out infinite}
.wh-orb-2 {bottom:-15%;right:8%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,150,80,.22),transparent 65%);animation:wh-float-b 18s ease-in-out infinite}
.wh-grid {position:absolute;inset:0;background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
    background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 60% at center 40%,#000 35%,transparent 90%);
    -webkit-mask-image:radial-gradient(ellipse 80% 60% at center 40%,#000 35%,transparent 90%)}
@keyframes wh-float-a {0%,100% {transform:translate(0,0)} 50% {transform:translate(40px,-30px)}}
@keyframes wh-float-b {0%,100% {transform:translate(0,0)} 50% {transform:translate(-50px,20px)}}

.wh-eyebrow {display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.22em;color:rgba(255,255,255,.7);text-transform:uppercase;margin-bottom:24px}
.wh-eyebrow-dot {width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px rgba(255,107,40,.7);animation:wh-pulse 2.5s ease-in-out infinite}
@keyframes wh-pulse {0%,100% {opacity:1;transform:scale(1)} 50% {opacity:.55;transform:scale(.85)}}

.wh-title {font-family:var(--display);font-size:clamp(2.8rem,7vw,6.2rem);font-weight:900;letter-spacing:-.045em;line-height:.98;color:#fff;margin:0 0 28px;max-width:18ch}
.wh-line {display:block}
.wh-line-em {color:rgba(255,255,255,.85)}
.wh-line-em em {font-family:var(--editorial);font-style:italic;font-weight:600;color:var(--accent2);letter-spacing:-.025em}
.wh-sub {font-size:clamp(1rem,1.3vw,1.2rem);color:rgba(255,255,255,.72);line-height:1.7;max-width:620px;margin:0 0 48px}

.wh-stats {display:inline-flex;align-items:center;gap:32px;padding:18px 32px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.025);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.wh-stat {display:flex;flex-direction:column;gap:2px;line-height:1}
.wh-stat strong {font-family:var(--display);font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.wh-stat span {font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.18em;color:rgba(255,255,255,.85);text-transform:uppercase;margin-top:4px}
.wh-stat-divider {width:1px;height:32px;background:rgba(255,255,255,.1)}

/* === PORTFOLIO === */
.portfolio {background:#000}

/* === CASE === */
.case {position:relative;padding:120px 0;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.05)}
.case-bg {position:absolute;inset:0;pointer-events:none;z-index:0}
.case-bg-grad {position:absolute;inset:0;opacity:.55}
.case-bg-grid {position:absolute;inset:0;background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
    background-size:80px 80px;mask-image:radial-gradient(ellipse 70% 60% at center,#000 25%,transparent 85%);
    -webkit-mask-image:radial-gradient(ellipse 70% 60% at center,#000 25%,transparent 85%)}
.case-bg-orb {position:absolute;width:700px;height:700px;border-radius:50%;filter:blur(120px);opacity:.45}

/* Themed colors */
.case-sc .case-bg-grad {background:radial-gradient(ellipse 80% 60% at 25% 30%,rgba(40,90,160,.4),transparent 60%),radial-gradient(ellipse 70% 55% at 80% 75%,rgba(80,120,180,.22),transparent 65%),linear-gradient(180deg,#070a14 0%,#040508 100%)}
.case-sc .case-bg-orb {top:-15%;right:-10%;background:radial-gradient(circle,rgba(60,120,200,.5),transparent 65%)}
.case-sc .case-tag {color:#7fb0e8}
.case-sc .case-title-em {color:#7fb0e8}
.case-sc .case-num {color:#7fb0e8}
.case-sc .case-cta {color:#a4c7ed;border-color:rgba(127,176,232,.35)}
.case-sc .case-cta:hover {border-color:#7fb0e8;background:rgba(127,176,232,.08);color:#fff}

.case-vk .case-bg-grad {background:radial-gradient(ellipse 80% 60% at 70% 30%,rgba(40,140,80,.32),transparent 60%),radial-gradient(ellipse 70% 55% at 20% 75%,rgba(70,160,100,.18),transparent 65%),linear-gradient(180deg,#06120c 0%,#03070a 100%)}
.case-vk .case-bg-orb {top:-12%;left:-15%;background:radial-gradient(circle,rgba(60,170,90,.45),transparent 65%)}
.case-vk .case-tag {color:#8ddca8}
.case-vk .case-title-em {color:#8ddca8;font-style:italic}
.case-vk .case-num {color:#8ddca8}
.case-vk .case-cta {color:#a4ecb7;border-color:rgba(141,220,168,.35)}
.case-vk .case-cta:hover {border-color:#8ddca8;background:rgba(141,220,168,.08);color:#fff}

.case-mf .case-bg-grad {background:radial-gradient(ellipse 80% 60% at 30% 70%,rgba(40,100,180,.36),transparent 60%),radial-gradient(ellipse 70% 55% at 80% 30%,rgba(80,160,210,.18),transparent 65%),linear-gradient(180deg,#070d14 0%,#03060a 100%)}
.case-mf .case-bg-orb {bottom:-15%;right:-10%;background:radial-gradient(circle,rgba(70,140,210,.45),transparent 65%)}
.case-mf .case-tag {color:#7cc0e6}
.case-mf .case-title-em {color:#7cc0e6}
.case-mf .case-num {color:#7cc0e6}
.case-mf .case-cta {color:#a8d4ef;border-color:rgba(124,192,230,.35)}
.case-mf .case-cta:hover {border-color:#7cc0e6;background:rgba(124,192,230,.08);color:#fff}

.case-am .case-bg-grad {background:radial-gradient(ellipse 80% 60% at 75% 35%,rgba(255,107,40,.36),transparent 60%),radial-gradient(ellipse 70% 55% at 20% 75%,rgba(255,150,80,.18),transparent 65%),linear-gradient(180deg,#140905 0%,#080403 100%)}
.case-am .case-bg-orb {top:-15%;right:-10%;background:radial-gradient(circle,rgba(255,107,40,.5),transparent 65%)}
.case-am .case-tag {color:#ffb27a}
.case-am .case-title-em {color:#ff8a45}
.case-am .case-num {color:#ffb27a}
.case-am .case-cta {color:#ffc89a;border-color:rgba(255,178,122,.35)}
.case-am .case-cta:hover {border-color:#ffb27a;background:rgba(255,178,122,.08);color:#fff}

.case-inner {position:relative;z-index:1}

.case-head {display:flex;align-items:baseline;justify-content:space-between;gap:18px;margin-bottom:48px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08)}
.case-num {font-family:var(--mono);font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase}
.case-tag {font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-align:right;opacity:.85}

.case-body {display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start}
.case-body-alt {grid-template-columns:1fr 1.2fr;direction:rtl}
.case-body-alt > * {direction:ltr}

/* Mockup column */
.case-mockup {display:block;position:relative;cursor:pointer;transition:transform .5s var(--ease)}
.case-mockup:hover {transform:translateY(-6px)}
.case-mockup-hint {position:absolute;bottom:14px;left:50%;transform:translateX(-50%) translateY(8px);font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.22em;color:#fff;background:rgba(0,0,0,.85);padding:9px 20px;border-radius:60px;border:1px solid rgba(255,255,255,.12);opacity:0;transition:.35s var(--ease);pointer-events:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.case-mockup:hover .case-mockup-hint {opacity:1;transform:translateX(-50%) translateY(0)}
/* Touch devices don't have hover — show the hint by default so users know
   the mockup is tappable. */
@media (hover: none) {
  .case-mockup-hint {opacity:1;transform:translateX(-50%) translateY(0);bottom:18px}
}

/* Info column */
.case-info {padding-top:8px}
.case-title {font-family:var(--display);font-size:clamp(2.2rem,4.4vw,3.8rem);font-weight:800;letter-spacing:-.045em;line-height:1;color:#fff;margin:0 0 20px}
.case-title-em {font-family:var(--editorial);font-style:italic;font-weight:500;letter-spacing:-.025em}
.case-lede {font-size:clamp(1rem,1.2vw,1.15rem);color:rgba(255,255,255,.7);line-height:1.7;margin:0 0 32px;max-width:46ch}

.case-scope {margin-bottom:32px}
.case-scope-label {display:block;font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.22em;color:rgba(255,255,255,.85);text-transform:uppercase;margin-bottom:12px}
.case-scope-tags {display:flex;flex-wrap:wrap;gap:7px}
.case-scope-tags span {padding:6px 14px;font-size:.78rem;font-weight:500;border-radius:60px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.75)}

.case-kpis {display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:24px 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:32px}
.kpi {display:flex;flex-direction:column;gap:6px}
.kpi strong {font-family:var(--display);font-size:1.85rem;font-weight:800;color:#fff;letter-spacing:-.025em;line-height:1}
.kpi strong small {font-family:var(--mono);font-size:.55em;font-weight:500;letter-spacing:.05em;color:rgba(255,255,255,.7);margin-left:1px}
.kpi em {font-style:normal;font-size:.72rem;font-weight:500;color:rgba(255,255,255,.7);line-height:1.4;letter-spacing:.01em}

.case-cta {display:inline-flex;align-items:center;gap:10px;padding:14px 24px;font-family:var(--font);font-size:.82rem;font-weight:600;letter-spacing:.04em;border:1px solid;border-radius:60px;background:transparent;transition:.4s var(--ease)}
.case-cta svg {transition:transform .4s var(--ease)}
.case-cta:hover svg {transform:translate(3px,-3px)}

/* === LIVE MOCKUP EMBEDS === */
.live-mockup {border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#0a0a0a;box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04) inset;transition:.5s var(--ease)}
.case-mockup:hover .live-mockup {box-shadow:0 50px 120px rgba(0,0,0,.7),0 0 0 1px rgba(255,107,40,.3) inset}
.lm-chrome {display:flex;align-items:center;gap:10px;padding:11px 16px;background:#101012;border-bottom:1px solid rgba(255,255,255,.06)}
.lm-dots {display:flex;gap:6px}
.lm-dots i {width:10px;height:10px;border-radius:50%;display:block}
.lm-dots i:nth-child(1) {background:#ff5f57}
.lm-dots i:nth-child(2) {background:#febc2e}
.lm-dots i:nth-child(3) {background:#28c840}
.lm-url {flex:1;display:flex;align-items:center;gap:6px;background:#0a0a0c;border:1px solid rgba(255,255,255,.06);border-radius:6px;padding:6px 12px;font-size:.7rem;color:#888;font-family:var(--mono)}
.lm-live-dot {width:8px;height:8px;border-radius:50%;background:#28c840;box-shadow:0 0 8px rgba(40,200,64,.6);animation:pulse-dot 2s infinite}
@keyframes pulse-dot {0%,100% {opacity:1} 50% {opacity:.5}}
/* Static screenshot previews — 1280×800 captures (62.5% aspect ratio).
   Removed the iframe approach because per-site rendering at scaled viewports
   produced black gaps where asymmetric layouts didn't fill the frame. */
.lm-viewport {position:relative;width:100%;height:0;padding-bottom:62.5%;overflow:hidden;background:#0a0a0a}
.lm-shot {position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform 1.2s cubic-bezier(.22,.85,.28,1)}
.case-mockup:hover .lm-shot {transform:scale(1.03)}

/* === CTA SECTION === */
.work-cta {padding:120px 0 140px;background:#000;position:relative}
.wcta-card {position:relative;text-align:center;max-width:780px;margin:0 auto;padding:64px 40px;border:1px solid rgba(255,107,40,.18);border-radius:24px;background:linear-gradient(155deg,rgba(20,12,8,.6),rgba(8,5,4,.7));overflow:hidden;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.wcta-glow {position:absolute;top:-50%;left:50%;transform:translateX(-50%);width:120%;height:200%;background:radial-gradient(ellipse 50% 35% at center top,rgba(255,107,40,.22),transparent 65%);pointer-events:none}
.wcta-eyebrow {display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.22em;color:rgba(255,255,255,.7);text-transform:uppercase;margin-bottom:20px;position:relative}
.wcta-eyebrow i {width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:wh-pulse 2.5s ease-in-out infinite}
.wcta-title {font-family:var(--display);font-size:clamp(2rem,4.6vw,3.6rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:#fff;margin:0 0 18px;position:relative}
.wcta-title em {font-family:var(--editorial);font-style:italic;font-weight:500;color:var(--accent2);letter-spacing:-.025em}
.wcta-sub {font-size:clamp(.98rem,1.15vw,1.1rem);color:rgba(255,255,255,.74);line-height:1.7;max-width:540px;margin:0 auto 32px;position:relative}
.wcta-btns {display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* === RESPONSIVE === */
@media (max-width:1024px) {
    .case-body, .case-body-alt {grid-template-columns:1fr;gap:48px;direction:ltr}
    .case {padding:96px 0}
}

@media (max-width:768px) {
    .work-hero {padding:130px 0 56px}
    .wh-stats {gap:18px;padding:14px 20px;flex-wrap:wrap;justify-content:center}
    .wh-stat strong {font-size:1.2rem}
    .wh-stat-divider {display:none}
    .case {padding:72px 0}
    .case-head {flex-direction:column;align-items:flex-start;gap:8px}
    .case-tag {text-align:left}
    .case-kpis {grid-template-columns:1fr;gap:14px}
    .kpi {flex-direction:row;align-items:baseline;gap:14px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}
    .kpi:last-child {border-bottom:none;padding-bottom:0}
    .kpi strong {font-size:1.5rem;min-width:80px}
    .case-mockup-hint {font-size:.55rem;padding:7px 14px}
    .work-cta {padding:80px 0 100px}
    .wcta-card {padding:48px 24px}
    .wcta-btns {flex-direction:column;width:100%}
    .wcta-btns .btn {width:100%;justify-content:center}
}

/* Phone — pull the hero in tighter so the headline + sub aren't pushed
   so far down the viewport on first paint. */
@media (max-width:560px) {
    .work-hero {padding:100px 0 44px}
    .wh-title {font-size:clamp(2.2rem,8.5vw,3rem)}
    .wh-sub {font-size:1rem}
    .wh-stats {padding:12px 16px;gap:14px}
    .case {padding:56px 0}
    .case-inner {padding:0}
    .case-title {font-size:clamp(1.8rem,7vw,2.4rem)}
    .case-lede {font-size:.98rem}
    .kpi strong {font-size:1.3rem;min-width:70px}
    .case-cta {padding:12px 20px;font-size:.78rem}
}
