:root{
  --bg:#05070c;--bg2:#08111d;--panel:rgba(13,22,37,.72);--panel2:rgba(15,28,49,.92);
  --text:#f8fafc;--muted:#a8b3c7;--soft:#64748b;--line:rgba(255,255,255,.12);
  --blue:#3b82f6;--cyan:#06b6d4;--green:#10b981;--purple:#8b5cf6;--danger:#fb7185;
  --grad:linear-gradient(135deg,var(--blue),var(--cyan),var(--green));
  --shadow:0 24px 80px rgba(0,0,0,.42);--glow:0 0 50px rgba(59,130,246,.24);
  --r:24px;--r2:34px;--max:1220px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
.container{width:min(var(--max),calc(100% - 40px));margin:auto}
.section{padding:92px 0;position:relative}
.site-bg{position:fixed;inset:0;z-index:-5;overflow:hidden;background:radial-gradient(circle at 50% -20%,rgba(59,130,246,.22),transparent 34%),linear-gradient(180deg,#05070c,#08111d 50%,#05070c)}
.grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(circle,black 15%,transparent 72%);opacity:.45}
.orb{position:absolute;border-radius:50%;filter:blur(95px);opacity:.45;animation:float 12s ease-in-out infinite alternate}
.orb-a{width:440px;height:440px;background:var(--blue);left:-110px;top:90px}
.orb-b{width:520px;height:520px;background:var(--green);right:-150px;top:520px;animation-delay:1s}
@keyframes float{to{transform:translate(40px,-35px) scale(1.08)}}
.header{position:fixed;top:0;left:0;right:0;z-index:30;padding:18px 0;transition:.25s}
.header.scrolled{background:rgba(5,7,12,.78);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);padding:12px 0}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;font-size:1.35rem}
.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:var(--grad);box-shadow:var(--glow)}
.nav{display:flex;align-items:center;gap:26px;color:var(--muted);font-weight:700}
.nav a{transition:.2s}
.nav a:hover{color:var(--text)}
.menu-btn{display:none;width:48px;height:48px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.06);color:var(--text)}
.menu-btn span{display:block;width:22px;height:2px;background:var(--text);margin:5px auto;border-radius:2px;transition:.2s}
.menu-btn[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn[aria-expanded=true] span:nth-child(2){opacity:0}
.menu-btn[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.eyebrow{display:inline-flex;padding:8px 13px;border:1px solid rgba(6,182,212,.22);background:rgba(6,182,212,.09);color:#67e8f9;border-radius:999px;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;font-weight:900;margin-bottom:18px}
h1,h2,h3{line-height:1.05;letter-spacing:-.04em}
h1{font-size:clamp(2.8rem,6vw,5.8rem);max-width:780px;margin-bottom:24px}
h2{font-size:clamp(2.1rem,4vw,4rem);margin-bottom:18px}
h1 span,h2 span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:1.18rem;color:var(--muted);max-width:680px}
.lead.small{font-size:1.05rem}
.hero{min-height:100vh;display:flex;align-items:center;padding-top:140px}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:58px;align-items:center}
.actions{display:flex;gap:14px;flex-wrap:wrap;margin:34px 0}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:18px;padding:15px 22px;font-weight:900;cursor:pointer;transition:.22s;min-height:50px}
.btn:hover{transform:translateY(-2px)}
.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.selectable:focus-visible{outline:3px solid rgba(6,182,212,.45);outline-offset:3px}
.primary{background:var(--grad);color:white;box-shadow:0 16px 42px rgba(59,130,246,.28)}
.secondary{background:rgba(255,255,255,.07);border:1px solid var(--line);color:var(--text);backdrop-filter:blur(12px)}
.full{width:100%}
.badge-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.badge-row span,.tags i{font-style:normal;padding:8px 11px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.055);color:var(--muted);font-size:.86rem}
.dashboard{background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.035));border:1px solid var(--line);border-radius:var(--r2);box-shadow:var(--shadow),var(--glow);overflow:hidden;transform:perspective(1100px) rotateY(-7deg) rotateX(4deg);transition:.35s}
.dashboard:hover{transform:perspective(1100px) rotateY(0) rotateX(0) translateY(-6px)}
.dash-top{display:flex;align-items:center;gap:8px;padding:15px 18px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.04)}
.dot{width:11px;height:11px;border-radius:50%}.red{background:#fb7185}.amber{background:#fbbf24}.green{background:#34d399}
.dash-url{margin-left:10px;background:rgba(0,0,0,.24);color:var(--soft);border-radius:999px;padding:6px 12px;font-size:.78rem;flex:1;text-align:center}
.dash-body{padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.metric,.chart,.dash-pill{background:rgba(3,7,18,.42);border:1px solid var(--line);border-radius:20px;padding:18px}
.metric.large{grid-column:1/-1}
.metric small{display:block;color:var(--soft);text-transform:uppercase;font-size:.72rem;font-weight:900;margin-bottom:8px}
.metric strong{font-size:2rem}
.bar{height:9px;background:rgba(255,255,255,.08);border-radius:99px;margin-top:12px;overflow:hidden}.bar i{display:block;height:100%;background:var(--grad);border-radius:99px}
.chart{grid-column:1/-1;height:150px;display:flex;gap:12px;align-items:end}.chart i{flex:1;background:linear-gradient(180deg,var(--cyan),var(--blue));border-radius:9px 9px 0 0;opacity:.8}
.dash-pill{font-weight:900;color:#dff7ff}.dash-pill.alt{color:#d9fff1}
.stats{padding:28px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stats-grid div,.card,.price-card,.portfolio-card,.form-card,.success-card,.contact-card,.process div{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 18px 50px rgba(0,0,0,.23);backdrop-filter:blur(18px)}
.stats-grid div{padding:22px;text-align:center}.stats-grid strong{display:block;font-size:1.55rem}.stats-grid span{color:var(--muted);font-size:.9rem}
.section-head{max-width:760px;margin-bottom:38px}.section-head p{color:var(--muted)}
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{padding:28px;position:relative;overflow:hidden;transition:.25s}
.card:before,.price-card:before,.portfolio-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent 45%);pointer-events:none}
.card:hover,.portfolio-card:hover,.price-card:hover{transform:translateY(-8px);border-color:rgba(6,182,212,.5);box-shadow:0 25px 70px rgba(0,0,0,.35)}
.icon{display:grid;place-items:center;width:48px;height:48px;border-radius:16px;background:rgba(59,130,246,.16);color:#93c5fd;font-weight:900;margin-bottom:20px}
.card h3,.portfolio-card h3{font-size:1.28rem;margin-bottom:10px}.card p,.portfolio-card p{color:var(--muted)}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.feature-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.feature-list div{padding:20px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.045)}
.feature-list b{display:block;margin-bottom:6px}.feature-list span{color:var(--muted)}
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.price-card{padding:28px;position:relative;overflow:hidden;cursor:pointer;transition:.25s}
.price-card.selected{border-color:var(--green);box-shadow:0 0 0 2px rgba(16,185,129,.24),0 24px 70px rgba(16,185,129,.14)}
.recommended{border-color:rgba(59,130,246,.55);transform:translateY(-10px)}
.popular{position:absolute;top:16px;right:16px;background:rgba(59,130,246,.22);color:#bfdbfe;border:1px solid rgba(59,130,246,.36);border-radius:999px;padding:6px 10px;font-size:.72rem;font-weight:900}
.package{display:block;color:#67e8f9;text-transform:uppercase;font-size:.72rem;font-weight:900;letter-spacing:.12em;margin-bottom:14px}
.price-card h3{font-size:2.2rem;margin-bottom:12px}.price-card p{color:var(--muted);min-height:78px}
.price-card ul{list-style:none;margin:20px 0}.price-card li{padding:8px 0;color:var(--muted);border-top:1px solid rgba(255,255,255,.07)}
.pricing-note{color:var(--muted);text-align:center;margin-top:25px}
.portfolio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.portfolio-card{padding:25px;position:relative;overflow:hidden}
.portfolio-card>span{color:#86efac;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:900}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.process{display:grid;grid-template-columns:repeat(7,1fr);gap:14px}.process div{padding:20px}.process b{color:var(--cyan);font-size:1.5rem}.process h3{font-size:1.1rem;margin:8px 0}.process p{color:var(--muted);font-size:.92rem}
.inquiry-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:34px;align-items:start}
.form-card,.success-card{padding:30px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;color:var(--text);font-weight:800;margin-bottom:16px}label input,label select,label textarea{margin-top:8px}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:16px;background:rgba(2,6,23,.68);color:var(--text);padding:14px 15px}
textarea{resize:vertical}.consent{display:flex;gap:12px;align-items:flex-start;color:var(--muted)}.consent input{width:auto;margin-top:5px}
.form-error{padding:12px;border:1px solid rgba(251,113,133,.36);background:rgba(251,113,133,.1);color:#fecdd3;border-radius:14px;margin-bottom:14px}
.selected-plan{border:1px solid rgba(16,185,129,.32);background:rgba(16,185,129,.1);border-radius:18px;padding:15px;color:#bbf7d0;margin-top:20px}
.success-card h3{font-size:2rem;margin-bottom:10px}
.contact-card{display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:36px}.contact-details p{margin-bottom:10px;color:var(--muted)}
.footer{padding:50px 0;background:rgba(0,0,0,.35);border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 2fr;gap:30px;color:var(--muted)}.footer h3{color:var(--text)}.footer nav{display:grid;gap:8px}
.hidden{display:none!important}
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:22px}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(10px)}
.modal-panel{position:relative;width:min(980px,100%);max-height:90vh;overflow:auto;background:#08111d;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);padding:28px}
.modal-close{position:absolute;top:16px;right:16px;width:44px;height:44px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.08);color:var(--text);font-size:1.7rem;cursor:pointer;z-index:2}
.demo-preview{display:grid;gap:22px}
.demo-hero{border-radius:24px;padding:32px;background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(16,185,129,.1));border:1px solid var(--line)}
.demo-hero h2{font-size:2.3rem;margin-bottom:12px;padding-right:50px}.demo-hero p{color:var(--muted);max-width:720px}
.demo-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.demo-box{background:rgba(255,255,255,.055);border:1px solid var(--line);border-radius:22px;padding:22px}
.demo-box h3{font-size:1.25rem;margin-bottom:10px}.demo-box ul{padding-left:20px;color:var(--muted)}
.demo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.demo-strip span{padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.05);font-weight:900;color:#dff7ff}
@media(max-width:1100px){.card-grid,.pricing-grid,.portfolio-grid{grid-template-columns:repeat(2,1fr)}.process{grid-template-columns:repeat(3,1fr)}.hero-grid,.split,.inquiry-wrap{grid-template-columns:1fr}.dashboard{max-width:680px;margin:auto}.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.container{width:min(100% - 28px,var(--max))}.section{padding:70px 0}.menu-btn{display:block}.nav{position:fixed;top:76px;left:14px;right:14px;display:grid;gap:8px;padding:18px;border:1px solid var(--line);border-radius:22px;background:rgba(5,7,12,.95);backdrop-filter:blur(18px);transform:translateY(-16px);opacity:0;visibility:hidden;pointer-events:none}.nav.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}.nav a{padding:13px;border-radius:14px;background:rgba(255,255,255,.045)}.hero{padding-top:120px}.hero-grid{gap:34px}.actions .btn{width:100%}.dashboard{transform:none}.dash-body{grid-template-columns:1fr}.stats-grid,.card-grid,.pricing-grid,.portfolio-grid,.feature-list,.form-row,.contact-card,.footer-grid,.demo-layout,.demo-strip{grid-template-columns:1fr}.process{grid-template-columns:1fr}.recommended{transform:none}.price-card p{min-height:auto}.modal-panel{padding:20px}.demo-hero h2{font-size:1.75rem}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;animation:none!important;transition:none!important}}

/* London Eye scroll background */
.london-scroll-bg {
  position: fixed;
  inset: 0;
  z-index: -5;
  overflow: hidden;
  background: #050914;
}

.london-layer {
  position: absolute;
  inset: -4%;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transform: scale(1.04) translateY(0);
  transition: opacity 0.15s linear, transform 0.15s linear;
  will-change: opacity, transform;
}

.london-layer-top {
  background-image: url("../img/london-eye-top.png");
  opacity: 1;
}

.london-layer-mid {
  background-image: url("../img/london-eye-mid.png");
}

.london-layer-low {
  background-image: url("../img/london-eye-low.png");
}

.london-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 20%, rgba(0, 229, 255, 0.16), transparent 32%),
    radial-gradient(circle at 85% 70%, rgba(34, 197, 94, 0.14), transparent 34%),
    linear-gradient(90deg, rgba(4, 8, 18, 0.90), rgba(4, 8, 18, 0.55) 45%, rgba(4, 8, 18, 0.80)),
    linear-gradient(180deg, rgba(4, 8, 18, 0.86), rgba(4, 8, 18, 0.50) 45%, rgba(4, 8, 18, 0.92));
  pointer-events: none;
}

.london-scroll-bg .grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 72%);
  pointer-events: none;
}

body.london-bg-active .site-bg {
  display: none;
}

@media (max-width: 760px) {
  .london-layer {
    inset: -8%;
    background-position: center top;
  }

  .london-overlay {
    background:
      linear-gradient(180deg, rgba(4, 8, 18, 0.88), rgba(4, 8, 18, 0.62) 45%, rgba(4, 8, 18, 0.94)),
      linear-gradient(90deg, rgba(4, 8, 18, 0.88), rgba(4, 8, 18, 0.62));
  }
}

/* Camera-descent realism tuning */
.london-scroll-bg {
  perspective: 1200px;
}

.london-layer {
  filter: saturate(1.08) contrast(1.08) brightness(0.92);
  transform-origin: center center;
}

.london-layer-top {
  background-position: center 50%;
}

.london-layer-mid {
  background-position: center 54%;
}

.london-layer-low {
  background-position: center 58%;
}

.london-overlay {
  backdrop-filter: blur(0.4px);
}

.hero,
.section,
.site-footer {
  position: relative;
  z-index: 1;
}


/* Procedural 3D London canvas background */
#londonScene3D {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: -3;
}

.london-layer {
  display: none !important;
}

.london-scroll-bg {
  position: fixed;
  inset: 0;
  overflow: hidden;
  background: #050914;
  z-index: -10;
}

.london-overlay {
  z-index: -2;
  background:
    radial-gradient(circle at 18% 20%, rgba(0, 229, 255, 0.15), transparent 30%),
    radial-gradient(circle at 84% 72%, rgba(34, 197, 94, 0.14), transparent 34%),
    linear-gradient(90deg, rgba(3, 7, 18, 0.92), rgba(3, 7, 18, 0.48) 45%, rgba(3, 7, 18, 0.84)),
    linear-gradient(180deg, rgba(3, 7, 18, 0.82), rgba(3, 7, 18, 0.36) 45%, rgba(3, 7, 18, 0.94));
}

.london-scroll-bg .grid {
  z-index: -1;
}

/* Fix: make procedural London background clearer / less dark */
.london-overlay {
  background:
    radial-gradient(circle at 18% 20%, rgba(0, 229, 255, 0.06), transparent 28%),
    radial-gradient(circle at 84% 72%, rgba(34, 197, 94, 0.05), transparent 32%),
    linear-gradient(90deg, rgba(3, 7, 18, 0.45), rgba(3, 7, 18, 0.12) 45%, rgba(3, 7, 18, 0.38)),
    linear-gradient(180deg, rgba(3, 7, 18, 0.35), rgba(3, 7, 18, 0.08) 45%, rgba(3, 7, 18, 0.48)) !important;
  backdrop-filter: none !important;
}

#londonScene3D {
  filter: brightness(1.25) contrast(1.08) saturate(1.15);
}

.london-scroll-bg .grid {
  opacity: 0.18;
}


/* Photoreal 3D-style generated London background */
#londonScene3D {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: -4;
  filter: brightness(1.12) contrast(1.08) saturate(1.12);
}

.london-layer {
  display: none !important;
}

.london-scroll-bg {
  position: fixed;
  inset: 0;
  overflow: hidden;
  background: #08111f;
  z-index: -10;
}

.london-overlay {
  z-index: -2;
  background:
    radial-gradient(circle at 19% 18%, rgba(0, 229, 255, 0.055), transparent 30%),
    radial-gradient(circle at 80% 72%, rgba(34, 197, 94, 0.05), transparent 34%),
    linear-gradient(90deg, rgba(3, 7, 18, 0.40), rgba(3, 7, 18, 0.08) 45%, rgba(3, 7, 18, 0.36)),
    linear-gradient(180deg, rgba(3, 7, 18, 0.28), rgba(3, 7, 18, 0.04) 46%, rgba(3, 7, 18, 0.44)) !important;
  backdrop-filter: none !important;
}

.london-scroll-bg .grid {
  opacity: 0.08 !important;
}

.hero,
.section,
.site-footer {
  position: relative;
  z-index: 1;
}


/* Elite abstract 3D generated background */
#elite3DBackground {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: -5;
  filter: saturate(1.12) contrast(1.08) brightness(1.02);
}

#londonScene3D {
  display: none !important;
}

.london-layer {
  display: none !important;
}

.london-scroll-bg {
  position: fixed;
  inset: 0;
  overflow: hidden;
  z-index: -20;
  background:
    radial-gradient(circle at 20% 18%, rgba(0, 229, 255, 0.16), transparent 28%),
    radial-gradient(circle at 82% 72%, rgba(34, 197, 94, 0.13), transparent 32%),
    linear-gradient(135deg, #030712 0%, #07111f 40%, #020617 100%);
}

.london-overlay {
  z-index: -2;
  background:
    radial-gradient(circle at 28% 20%, rgba(0, 229, 255, 0.08), transparent 28%),
    radial-gradient(circle at 78% 76%, rgba(34, 197, 94, 0.07), transparent 34%),
    linear-gradient(90deg, rgba(3, 7, 18, 0.58), rgba(3, 7, 18, 0.18) 45%, rgba(3, 7, 18, 0.52)),
    linear-gradient(180deg, rgba(3, 7, 18, 0.36), rgba(3, 7, 18, 0.08) 44%, rgba(3, 7, 18, 0.66)) !important;
  backdrop-filter: none !important;
}

.london-scroll-bg .grid {
  opacity: 0.12 !important;
}

.hero,
.section,
.site-footer {
  position: relative;
  z-index: 2;
}

/* Ultra-slim elite agency typography upgrade */
:root {
  --font-display: "Aptos Display", "SF Pro Display", "Segoe UI Variable Display", "Aptos", "Inter", "Helvetica Neue", Arial, sans-serif;
  --font-body: "Aptos", "SF Pro Text", "Segoe UI Variable Text", "Segoe UI", "Inter", "Helvetica Neue", Arial, sans-serif;
  --font-ui: "Aptos", "SF Pro Text", "Segoe UI", "Inter", "Helvetica Neue", Arial, sans-serif;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: geometricPrecision;
}

body {
  font-family: var(--font-body) !important;
  font-weight: 350 !important;
  letter-spacing: -0.012em;
  font-feature-settings: "kern", "liga", "calt";
}

h1,
h2,
h3,
.hero-title,
.section-title,
.price,
.stat strong {
  font-family: var(--font-display) !important;
  font-weight: 520 !important;
  letter-spacing: -0.072em;
  line-height: 0.91;
}

.hero-title {
  font-size: clamp(3.25rem, 8.7vw, 7.6rem) !important;
  font-weight: 510 !important;
  letter-spacing: -0.082em;
  line-height: 0.90;
  max-width: 1120px;
  text-wrap: balance;
}

.section-title {
  font-size: clamp(2.35rem, 5.4vw, 5.15rem) !important;
  font-weight: 500 !important;
  letter-spacing: -0.074em;
  line-height: 0.92;
  text-wrap: balance;
}

h3,
.card h3,
.price-card h3,
.portfolio-card h3,
.process-card h3,
.contact-card h3 {
  font-weight: 520 !important;
  letter-spacing: -0.048em;
  line-height: 1.02;
}

.hero-subtitle,
.section-lead,
.card p,
.price-card li,
.portfolio-card p,
.process-card p,
.contact-card p,
.footer-text,
p,
li {
  font-family: var(--font-body) !important;
  font-weight: 330 !important;
  letter-spacing: -0.012em;
  line-height: 1.72;
}

.hero-subtitle {
  font-size: clamp(1.02rem, 1.55vw, 1.22rem) !important;
  font-weight: 330 !important;
  max-width: 820px;
}

.brand-mark {
  font-family: var(--font-display) !important;
  font-weight: 620 !important;
  letter-spacing: -0.078em;
}

.brand-text {
  font-family: var(--font-display) !important;
  font-weight: 560 !important;
  letter-spacing: -0.06em;
}

.nav a {
  font-family: var(--font-ui) !important;
  font-size: 0.76rem;
  font-weight: 520 !important;
  letter-spacing: 0.075em;
  text-transform: uppercase;
}

.hero-kicker,
.section-kicker,
.badge,
.trust-badges span,
.demo-tag,
.price-card .label {
  font-family: var(--font-ui) !important;
  font-size: 0.74rem;
  font-weight: 560 !important;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.btn,
button,
input,
select,
textarea {
  font-family: var(--font-ui) !important;
}

.btn,
button {
  font-weight: 560 !important;
  letter-spacing: 0.015em;
}

.price {
  font-weight: 500 !important;
  letter-spacing: -0.078em;
}

.stat strong {
  font-weight: 500 !important;
}

input,
select,
textarea {
  font-size: 1rem;
  font-weight: 350 !important;
  letter-spacing: -0.012em;
}

/* Make cards feel lighter and more premium */
.card,
.price-card,
.portfolio-card,
.process-card,
.contact-card {
  font-weight: 350;
}

.card b,
.price-card b,
.portfolio-card b,
.process-card b {
  font-weight: 560 !important;
}

@media (max-width: 760px) {
  h1,
  h2,
  h3,
  .hero-title,
  .section-title {
    letter-spacing: -0.062em;
  }

  .hero-title {
    font-size: clamp(2.85rem, 14.8vw, 4.8rem) !important;
    font-weight: 500 !important;
    line-height: 0.92;
  }

  .section-title {
    font-size: clamp(2.1rem, 10.8vw, 3.5rem) !important;
    font-weight: 500 !important;
    line-height: 0.94;
  }

  .hero-subtitle,
  .section-lead,
  p,
  li {
    font-size: 0.98rem;
    line-height: 1.66;
  }

  .nav a {
    font-size: 0.82rem;
    font-weight: 520 !important;
    letter-spacing: 0.05em;
  }

  .hero-kicker,
  .section-kicker,
  .badge,
  .trust-badges span,
  .demo-tag {
    font-size: 0.72rem;
    letter-spacing: 0.11em;
  }
}



/* Package detail expansion */
.price-card {
  overflow: hidden;
}

.price-card.expanded {
  transform: translateY(-6px);
}

.package-details {
  margin-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 1.25rem;
  animation: packageReveal .28s ease both;
}

.package-details-inner {
  display: grid;
  gap: 1rem;
}

.package-subtitle {
  color: rgba(226, 232, 240, .92);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0;
}

.package-detail-block {
  padding: 1rem;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 1.1rem;
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
}

.package-detail-block strong {
  display: block;
  color: #ffffff;
  font-weight: 560 !important;
  letter-spacing: -0.02em;
  margin-bottom: .35rem;
}

.package-detail-block p {
  margin: 0;
  color: rgba(226, 232, 240, .76);
  font-size: .94rem;
  line-height: 1.58;
}

.package-detail-block ul {
  margin: .55rem 0 0;
  padding-left: 1.15rem;
  display: grid;
  gap: .35rem;
}

.package-detail-block li {
  color: rgba(226, 232, 240, .78);
  font-size: .93rem;
  line-height: 1.5;
}

.package-note {
  color: rgba(125, 249, 255, .86);
  font-size: .94rem;
  line-height: 1.55;
  margin: 0;
}

.package-continue {
  width: 100%;
  justify-content: center;
  margin-top: .25rem;
}

.selected-plan span {
  display: inline-block;
  margin-left: .45rem;
  color: rgba(125, 249, 255, .9);
}

@keyframes packageReveal {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 760px) {
  .package-detail-block {
    padding: .9rem;
    border-radius: .95rem;
  }

  .package-subtitle,
  .package-detail-block p,
  .package-detail-block li,
  .package-note {
    font-size: .92rem;
  }
}


/* Strong visible package detail panels */
.package-details-panel {
  display: none;
  margin-top: 1.35rem;
  padding-top: 1.35rem;
  border-top: 1px solid rgba(255, 255, 255, .14);
}

.price-card.package-open .package-details-panel,
.price-card.expanded .package-details-panel {
  display: block !important;
}

.package-details-shell {
  display: grid;
  gap: 1rem;
  animation: packageDetailsVisible .28s ease both;
}

.package-details-intro {
  margin: 0;
  color: rgba(240, 249, 255, .92);
  font-size: .98rem;
  line-height: 1.62;
}

.package-details-block {
  padding: 1rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(255, 255, 255, .12);
  background:
    radial-gradient(circle at 0% 0%, rgba(0, 229, 255, .10), transparent 42%),
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
}

.package-details-block strong {
  display: block;
  color: #ffffff;
  font-weight: 560 !important;
  margin-bottom: .45rem;
  letter-spacing: -0.025em;
}

.package-details-block p {
  margin: 0;
  color: rgba(226, 232, 240, .78);
  font-size: .93rem;
  line-height: 1.55;
}

.package-details-block ul {
  margin: .55rem 0 0;
  padding-left: 1.15rem;
  display: grid;
  gap: .38rem;
}

.package-details-block li {
  color: rgba(226, 232, 240, .80);
  font-size: .92rem;
  line-height: 1.48;
}

.package-details-result {
  color: rgba(125, 249, 255, .90);
  font-size: .94rem;
  line-height: 1.55;
  padding: .9rem 1rem;
  border-radius: 1rem;
  background: rgba(0, 229, 255, .07);
  border: 1px solid rgba(0, 229, 255, .16);
}

.package-select-final {
  width: 100%;
  justify-content: center;
  margin-top: .15rem;
}

.price-card.package-open {
  border-color: rgba(0, 229, 255, .42) !important;
  box-shadow:
    0 24px 80px rgba(0, 0, 0, .32),
    0 0 0 1px rgba(0, 229, 255, .10),
    0 0 48px rgba(0, 229, 255, .10);
}

@keyframes packageDetailsVisible {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 760px) {
  .package-details-panel {
    margin-top: 1rem;
    padding-top: 1rem;
  }

  .package-details-block {
    padding: .9rem;
    border-radius: .95rem;
  }

  .package-details-intro,
  .package-details-block p,
  .package-details-block li,
  .package-details-result {
    font-size: .9rem;
  }
}


/* Package expansion final fix: only active card takes space */
.price-card:not(.package-open) .package-details-panel,
.price-card:not(.package-open) .package-details,
.price-card:not(.expanded) .package-details-panel,
.price-card:not(.expanded) .package-details {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

.price-card.package-open .package-details-panel {
  display: block !important;
  height: auto !important;
  max-height: none !important;
  margin-top: 1.35rem !important;
  padding-top: 1.35rem !important;
}

.price-card:not(.package-open) {
  align-self: start;
}


/* Portfolio demo preview hint */
.demo-preview-hint {
  margin-top: 1rem;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  color: rgba(125, 249, 255, .94);
  background: rgba(0, 229, 255, .075);
  border: 1px solid rgba(0, 229, 255, .18);
  font-size: .82rem;
  letter-spacing: -0.01em;
}

.portfolio-card[data-demo="trades"] {
  position: relative;
  border-color: rgba(0, 229, 255, .24) !important;
}

.portfolio-card[data-demo="trades"]:hover {
  box-shadow:
    0 24px 90px rgba(0,0,0,.32),
    0 0 52px rgba(0,229,255,.12);
}

.brand-logo,
.logo-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

.brand-logo img,
.logo-brand img,
.site-logo-img {
  width: 42px;
  height: 42px;
  object-fit: contain;
  border-radius: 14px;
  filter: drop-shadow(0 10px 24px rgba(83, 228, 255, .22));
}

.brand-logo span {
  color: inherit;
  font-weight: 700;
  letter-spacing: -0.04em;
}

/* Final WD2 favicon-style brand logo fix */
.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 11px !important;
  text-decoration: none !important;
  color: inherit !important;
  font-weight: 700 !important;
  letter-spacing: -0.045em !important;
}

.brand-logo img {
  width: 46px !important;
  height: 46px !important;
  object-fit: contain !important;
  border-radius: 16px !important;
  filter: drop-shadow(0 12px 28px rgba(83, 228, 255, .30)) !important;
}

.brand-logo span {
  color: inherit !important;
  font-size: 22px !important;
  line-height: 1 !important;
}

/* Refined WD2 favicon-style logo */
.brand-logo img,
.logo-brand img,
.site-logo-img {
  width: 34px !important;
  height: 34px !important;
  object-fit: contain !important;
  border-radius: 12px !important;
  filter: drop-shadow(0 8px 18px rgba(15, 63, 154, .18)) !important;
}

.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  text-decoration: none !important;
}

.brand-logo span {
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: -0.045em !important;
  line-height: 1 !important;
}

/* Final blue-flame pointed-top logo sizing */
.brand-logo img {
  width: 62px !important;
  height: 62px !important;
  object-fit: contain !important;
  border-radius: 18px !important;
  filter: drop-shadow(0 14px 30px rgba(8, 47, 127, .28)) !important;
}

.brand-logo span {
  font-size: 21px !important;
  font-weight: 700 !important;
  letter-spacing: -0.045em !important;
}

/* reddrop logo */
.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
}

.brand-logo img {
  width: 48px !important;
  height: 48px !important;
  object-fit: contain !important;
  border-radius: 12px !important;
}

.brand-logo span {
  color: inherit !important;
  font-weight: 700 !important;
}

/* reddrop1 image-only logo */
.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-decoration: none !important;
}

.brand-logo img {
  width: 84px !important;
  height: 84px !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.brand-logo span {
  display: none !important;
}

/* Original reddrop1 logo - use image as-is */
.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  text-decoration: none !important;
}

.brand-logo img {
  width: 84px !important;
  height: 84px !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.brand-logo span {
  display: none !important;
}

/* reddrop3 logo - use image as uploaded */
.brand-logo {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  text-decoration: none !important;
}

.brand-logo img {
  width: 84px !important;
  height: 84px !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.brand-logo span {
  display: none !important;
}
