/* Magno Sites — landing styles (builds on shared/css/base.css) */
.logo b { color: var(--accent); }

/* type scale */
.display { font-family: var(--font-display); font-weight: 700; line-height: .98; letter-spacing: -.02em; font-size: clamp(44px, 8vw, 116px); }
.h2 { font-family: var(--font-display); font-weight: 600; font-size: clamp(32px,5vw,68px); line-height: 1.0; letter-spacing: -.02em; }
.lead { font-size: clamp(17px,2vw,21px); color: var(--muted); max-width: 56ch; }
.accent { color: var(--accent); }

/* hero */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; padding: 120px 0 80px; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; background:
  radial-gradient(60% 50% at 75% 20%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 70%),
  radial-gradient(50% 50% at 10% 90%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 70%); }
.hero .wrap { position: relative; z-index: 1; }
.hero-grid { display: grid; gap: 40px; align-items: center; }
@media (min-width: 980px){ .hero-grid { grid-template-columns: 1.15fr .85fr; } }
.hero p.kick { font-weight: 600; letter-spacing: .04em; color: var(--accent); margin-bottom: 18px; }
.hero .display em { font-style: normal; color: var(--accent); }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.hero-note { margin-top: 18px; font-size: 14px; color: var(--muted); }

/* device mock in hero */
.device { border-radius: 18px; overflow: hidden; border: 1px solid var(--line); box-shadow: 0 40px 90px -40px rgba(0,0,0,.45); background: #fff; aspect-ratio: 4/3; }
.device img, .device video { width: 100%; height: 100%; object-fit: cover; }

/* dark spotlight scrub */
.spotlight .scrim { background: linear-gradient(180deg, rgba(16,18,22,.4), rgba(16,18,22,.2) 45%, rgba(16,18,22,.75)); }
.spotlight .scrub-overlay { color: #fff; }
.spotlight .stage-h { font-family: var(--font-display); font-weight: 700; font-size: clamp(36px,6vw,92px); line-height: 1; letter-spacing: -.02em; }
.spotlight .stage-h em { color: var(--accent); font-style: normal; }

/* work / portfolio */
.work-card { position: relative; overflow: hidden; border-radius: var(--radius); border: 1px solid var(--line); background: var(--card); display: block; }
.work-card .thumb { aspect-ratio: 16/10; overflow: hidden; background: var(--ink-deep); }
.work-card .thumb img, .work-card .thumb video { width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.work-card:hover .thumb img { transform: scale(1.05); }
.work-card .wc-body { padding: 22px 24px; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.work-card h3 { font-family: var(--font-display); font-weight: 600; font-size: 24px; }
.work-card .wc-body span { color: var(--muted); font-size: 14px; }
.work-card .arrow { color: var(--accent); font-weight: 700; }

/* value points */
.value { display: grid; gap: 18px; }
.value .vrow { display: grid; gap: 8px; padding: 26px 0; border-top: 1px solid var(--line); }
@media (min-width:780px){ .value .vrow { grid-template-columns: .4fr 1.6fr; gap: 30px; align-items: baseline; } }
.value h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(22px,3vw,30px); }
.value p { color: var(--muted); max-width: 60ch; }

/* pricing */
.plan { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 34px; display: flex; flex-direction: column; }
.plan.feat { border-color: var(--accent); box-shadow: 0 30px 70px -40px color-mix(in srgb, var(--accent) 60%, transparent); position: relative; }
.plan .tag { position: absolute; top: -12px; left: 34px; background: var(--accent); color: #fff; font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 5px 12px; border-radius: 999px; }
.plan h3 { font-family: var(--font-display); font-weight: 600; font-size: 24px; }
.plan .price { font-family: var(--font-display); font-weight: 700; font-size: 52px; line-height: 1; margin: 12px 0 4px; }
.plan .price small { font-family: var(--font-body); font-size: 15px; color: var(--muted); font-weight: 500; }
.plan ul { list-style: none; padding: 0; margin: 18px 0 26px; display: grid; gap: 10px; }
.plan li { padding-left: 24px; position: relative; font-size: 15px; }
.plan li::before { content: "→"; position: absolute; left: 0; color: var(--accent); }
.plan .btn { margin-top: auto; }

/* process steps */
.steps { counter-reset: s; display: grid; gap: 18px; }
@media (min-width:820px){ .steps { grid-template-columns: repeat(3,1fr); } }
.step { border-top: 2px solid var(--accent); padding-top: 18px; }
.step .n { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--accent); }
.step h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; margin: 6px 0; }
.step p { color: var(--muted); font-size: 15px; }

/* final */
.final { background: var(--ink-deep); color: #fff; border-radius: var(--radius); text-align: center; padding: clamp(52px,9vw,120px) 24px; }
.final .h2 em { color: var(--accent); font-style: normal; }

.illus { font-size: 12px; color: var(--muted); }

/* ---- device showcase ---- */
.showcase { position: relative; background: var(--ink-deep); color: #fff; overflow: hidden; min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding: 70px 0; }
.showcase-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .45; z-index: 0; }
.showcase-scrim { position: absolute; inset: 0; z-index: 1; background: radial-gradient(75% 65% at 50% 45%, transparent, rgba(16,18,22,.72)); }
.showcase-head { position: relative; z-index: 2; text-align: center; margin-bottom: 8px; padding: 0 20px; }
.showcase-head .h2 { color: #fff; } .showcase-head .h2 em { color: var(--accent); font-style: normal; }
.showcase-stage { position: relative; z-index: 2; height: 70vh; width: 92vw; max-width: 1180px; margin: 0 auto; perspective: 1600px; }
.dev-wrap { position: absolute; transform-style: preserve-3d; }
.device { transform-style: preserve-3d; will-change: transform; display: block; }
.device-screen { display: block; overflow: hidden; background: #000; box-shadow: 0 44px 90px -30px rgba(0,0,0,.75); }
.device.laptop .device-screen { border: 9px solid #20232b; border-bottom: none; border-radius: 14px 14px 0 0; }
.device.laptop .device-screen img { width: 100%; display: block; aspect-ratio: 16/10; object-fit: cover; object-position: top; }
.device.laptop::after { content: ""; display: block; height: 15px; margin: 0 -4%; background: linear-gradient(#262932, #15171c); border-radius: 0 0 16px 16px; box-shadow: 0 22px 40px -20px rgba(0,0,0,.8); }
.device.phone .device-screen { border: 7px solid #20232b; border-radius: 30px; }
.device.phone .device-screen img { width: 100%; display: block; aspect-ratio: 9/19; object-fit: cover; object-position: top; }
/* cascade arrangement (resting positions; JS flies them in) */
.dev-b2h   { left: 0;    top: 6%;  width: 32%; z-index: 1; }
.dev-livix { right: 0;   top: 2%;  width: 35%; z-index: 2; }
.dev-forge { left: 35%;  top: 41%; width: 31%; z-index: 4; }
.dev-lume  { left: 7%;   top: 47%; width: 11.5%; z-index: 5; }
.dev-marin { right: 8%;  top: 45%; width: 11.5%; z-index: 3; }
/* bigger, readable callouts placed in open space, arrow pointing at the device */
.showcase .callout-label { font-size: 14px; padding: 8px 16px; }
.showcase .callout-arrow { width: 40px; }
.dev-b2h   .callout { top: 16%; left: 100%; }     /* to the right, points left (rev) */
.dev-livix .callout { top: 60%; right: 100%; }    /* to the left, points right */
.dev-forge .callout { bottom: 100%; left: 26%; }  /* above the front laptop */
.dev-lume  .callout { bottom: 102%; left: -20%; } /* above-left of phone */
.dev-marin .callout { bottom: 102%; right: -20%; }/* above-right of phone (rev) */
@media (max-width: 760px) {
  .showcase-stage { height: 90vh; }
  .device.laptop .device-screen img { object-position: top left; }
  /* vertical cascade on mobile so devices do not pile up */
  .dev-b2h   { width: 55%; left: 0;  top: 1%; }
  .dev-livix { width: 57%; right: 0; top: 18%; }
  .dev-forge { width: 55%; left: 9%; top: 37%; }
  .dev-lume  { width: 27%; left: 3%; top: 60%; }
  .dev-marin { width: 27%; right: 3%; top: 58%; }
  .showcase .callout-label { font-size: 11px; padding: 5px 10px; } .showcase .callout-arrow { width: 22px; }
}
