/* ============================================================
   Triathlon Blueprint — Product Mockup Kit
   Reusable CSS-drawn pieces (devices, books, bonus cards,
   stickers, sparkles) for the product-image concepts.
   Gonzalo Yokota design system. No photos.
   ============================================================ */
@import url("_ds/gonzalo-yokota-design-system-1e341e88-7006-434e-b276-6339fc92c3a1/tokens/fonts.css");
@import url("_ds/gonzalo-yokota-design-system-1e341e88-7006-434e-b276-6339fc92c3a1/tokens/colors.css");
@import url("_ds/gonzalo-yokota-design-system-1e341e88-7006-434e-b276-6339fc92c3a1/tokens/typography.css");
@import url("_ds/gonzalo-yokota-design-system-1e341e88-7006-434e-b276-6339fc92c3a1/tokens/shape.css");

/* The DS self-hosts a DEMO cut of Elza that is missing most symbols/punctuation
   ($ + ' : / ( ) etc. all render as .notdef boxes) and "matches" the codepoint
   so it never falls through to Hanken. Hanken Grotesk (the DS's official Elza
   fallback) is glyph-complete, so we use it directly for body/UI text. */

:root{
  --ink:#1B1624; --cream:#F9F6F3; --sand:#F3EDE9; --beige:#ECE5E1;
  --sky:#5DCDF1; --coral:#FD976D; --yellow:#FDD46B; --lilac:#C9B1FB; --green:#79D287;
  --shadow:0 30px 40px -15px rgba(194,179,164,.45);
  --shadow-sm:0 12px 18px -8px rgba(120,104,86,.30);
  --hd:var(--font-heading); --bd:"Hanken Grotesk", -apple-system, system-ui, sans-serif;
}
*{box-sizing:border-box;}
body{margin:0;background:#EDE7E2;font-family:var(--bd);overflow:hidden;}
#fit{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.stage{position:relative;flex:0 0 auto;transform-origin:center;}
.pos{position:absolute;} /* wrapper: set left/top/transform/z-index/width inline */

.heading{font-family:var(--hd);font-weight:600;letter-spacing:-.03em;line-height:1;}
.sw{display:inline-flex;gap:12px;align-items:center;}
.sw svg{display:block;}

/* swim/bike/run trio — pass color via `color` on a parent */
.tri-row svg{display:block;}

/* ---------- MONITOR / SCREEN ---------- */
.monitor{width:560px;}
.monitor .screen{
  width:100%;aspect-ratio:560/344;border-radius:18px;background:
    radial-gradient(80% 120% at 50% 35%, #2c2735 0%, #1B1624 70%);
  box-shadow:var(--shadow),inset 0 0 0 6px #0f0c15;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;overflow:hidden;}
.monitor .screen::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(93,205,241,.20),transparent 60%);top:-120px;}
.tb{position:relative;text-align:center;color:#fff;}
.tb .l1{font-family:var(--hd);font-weight:600;font-size:30px;line-height:.86;letter-spacing:-.02em;}
.tb .l2{font-family:var(--hd);font-weight:600;font-size:74px;line-height:.84;letter-spacing:-.03em;text-shadow:0 0 26px rgba(255,255,255,.35);}
.tb .l3{font-family:var(--bd);font-weight:600;font-size:24px;letter-spacing:.18em;color:var(--sky);margin-top:8px;}
.monitor .stand{width:120px;height:54px;margin:0 auto;background:linear-gradient(#d8d2cc,#c7c0b9);clip-path:polygon(34% 0,66% 0,100% 100%,0 100%);}
.monitor .base{width:230px;height:14px;margin:0 auto;border-radius:8px;background:#cabfb6;box-shadow:0 12px 18px -8px rgba(0,0,0,.2);}

/* ---------- BOOK ---------- */
.book{position:relative;border-radius:6px 12px 12px 6px;box-shadow:var(--shadow);overflow:hidden;width:286px;height:392px;}
.book .pages{position:absolute;top:6px;right:0;width:14px;height:calc(100% - 12px);background:repeating-linear-gradient(90deg,#fff,#fff 1px,#e7e0d9 2px,#fff 3px);}
.book .spine{position:absolute;left:0;top:0;width:10px;height:100%;background:rgba(0,0,0,.14);z-index:2;}
.book .cover{position:absolute;inset:0 14px 0 0;padding:26px 24px;display:flex;flex-direction:column;}
.book--cream{background:#fff;} .book--cream .cover{background:var(--cream);}
.book--ink{background:#2a2632;} .book--ink .cover{background:linear-gradient(160deg,#272231,#15111c);}
.book--ink .pages{background:repeating-linear-gradient(90deg,#ded7cf,#ded7cf 1px,#c3bbb2 2px,#ded7cf 3px);}
.book .eb{font-family:var(--bd);font-weight:800;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);}
.book .t{font-family:var(--hd);font-weight:600;font-size:34px;line-height:.95;color:var(--ink);margin-top:8px;}
.book--ink .t{color:#fff;}
.book .sub{font-family:var(--bd);font-weight:600;font-size:15px;letter-spacing:.16em;color:rgba(27,22,36,.55);margin-top:2px;}
.book--ink .sub{color:rgba(255,255,255,.7);}
.book .runners{margin-top:auto;color:var(--ink);}
.book--ink .runners{color:#fff;opacity:.92;}

/* ---------- LAPTOP ---------- */
.laptop{width:496px;}
.laptop .lid{width:100%;aspect-ratio:496/300;border-radius:16px 16px 4px 4px;background:#15111c;padding:12px;box-shadow:var(--shadow);}
.laptop .disp{width:100%;height:100%;border-radius:8px;background:var(--cream);overflow:hidden;position:relative;}
.laptop .base{width:113%;height:18px;margin:0 auto;border-radius:0 0 14px 14px;background:linear-gradient(#e7e1db,#cfc7bf);position:relative;left:-6.5%;box-shadow:0 16px 22px -10px rgba(0,0,0,.25);}
.laptop .base::after{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:18%;height:7px;border-radius:0 0 8px 8px;background:#bdb4ab;}

.dash{position:absolute;inset:0;display:flex;flex-direction:column;}
.dash .bar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--beige);}
.dash .logo{font-size:15px;color:var(--ink);} .dash .logo b{font-weight:800;}
.dash .nav{display:flex;gap:14px;font-size:11px;font-weight:600;color:var(--ink);}
.dash .body{flex:1;display:flex;align-items:center;gap:20px;padding:18px 22px;background:var(--sand);}
.dash .copy{flex:1;}
.dash .copy .h{font-family:var(--hd);font-weight:600;font-size:26px;line-height:.95;color:var(--ink);}
.dash .copy .h span{display:block;font-size:13px;font-weight:400;letter-spacing:.02em;}
.dash .copy .row{display:flex;align-items:center;gap:10px;margin-top:14px;}
.dash .copy .btn{background:var(--sky);color:#fff;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:9px 14px;border-radius:9999px;}
.dash .copy .pct{font-size:11px;font-weight:700;color:var(--sky);display:flex;align-items:center;gap:6px;}
.dash .copy .pct i{width:13px;height:13px;border-radius:50%;border:2px solid var(--sky);display:inline-block;}
.dash .thumb{width:150px;height:150px;border-radius:16px;background:radial-gradient(80% 120% at 50% 30%,#2c2735,#15111c);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;box-shadow:0 16px 24px -12px rgba(0,0,0,.4);}
.dash .thumb .a{font-family:var(--hd);font-weight:600;font-size:15px;line-height:.9;}
.dash .thumb .b{font-family:var(--hd);font-weight:600;font-size:30px;line-height:.85;}
.dash .thumb .c{font-size:9px;letter-spacing:.16em;color:var(--sky);margin-top:3px;}

/* ---------- IPAD ---------- */
.ipad{width:276px;}
.ipad .body{width:100%;aspect-ratio:276/208;border-radius:18px;background:#15111c;padding:9px;box-shadow:var(--shadow);}
.ipad .disp{width:100%;height:100%;border-radius:10px;background:#fff;overflow:hidden;display:flex;flex-direction:column;}
.ipad .top{display:flex;align-items:center;justify-content:space-between;padding:7px 11px;}
.ipad .top .lg{font-size:10px;color:var(--ink);} .ipad .top .lg b{font-weight:800;}
.ipad .video{flex:1;margin:0 11px;border-radius:8px;background:linear-gradient(135deg,#6a5c4e,#2c2735);position:relative;}
.ipad .video .play{position:absolute;inset:0;margin:auto;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;}
.ipad .video .play::after{content:"";width:0;height:0;margin-left:3px;border-left:11px solid var(--sky);border-top:7px solid transparent;border-bottom:7px solid transparent;}
.ipad .cap{padding:8px 11px 11px;}
.ipad .cap .q{border:1.5px solid var(--lilac);color:#6f55c0;border-radius:7px;text-align:center;font-size:8.5px;font-weight:700;padding:5px;}
.ipad .cap .t{font-family:var(--hd);font-weight:600;font-size:12px;color:var(--ink);margin-top:6px;}

/* ---------- PHONE ---------- */
.phone{width:152px;}
.phone .body{width:100%;aspect-ratio:152/316;border-radius:26px;background:#15111c;padding:7px;box-shadow:var(--shadow);}
.phone .disp{width:100%;height:100%;border-radius:20px;background:var(--cream);overflow:hidden;position:relative;display:flex;flex-direction:column;}
.phone .notch{position:absolute;top:7px;left:50%;transform:translateX(-50%);width:54px;height:15px;background:#15111c;border-radius:0 0 9px 9px;z-index:2;}
.phone .ph-head{padding:34px 15px 10px;}
.phone .ph-head .lg{font-size:10px;color:var(--ink);} .phone .ph-head .lg b{font-weight:800;}
.phone .ph-head .t{font-family:var(--hd);font-weight:600;font-size:15px;color:var(--ink);line-height:1.04;margin-top:9px;}
.phone .ph-list{margin:10px 12px;background:#fff;border-radius:12px;box-shadow:0 8px 14px -6px rgba(0,0,0,.08);overflow:hidden;}
.phone .ph-list .li{display:flex;align-items:center;gap:9px;padding:9px 11px;border-bottom:1px solid var(--beige);font-size:9.5px;font-weight:600;color:var(--ink);}
.phone .ph-list .li:last-child{border-bottom:none;}
.phone .ph-list .li .dot{width:14px;height:14px;border-radius:50%;flex:0 0 auto;position:relative;}
.phone .ph-list .li .dot.check::after{content:"";position:absolute;left:5px;top:3.5px;width:3px;height:6px;border:solid #fff;border-width:0 1.6px 1.6px 0;transform:rotate(45deg);}
.phone .ph-list .li .dot.plus::before{content:"";position:absolute;left:6.25px;top:3.5px;width:1.5px;height:7px;border-radius:1px;background:var(--text-muted,#6b6571);}
.phone .ph-list .li .dot.plus::after{content:"";position:absolute;left:3.5px;top:6.25px;width:7px;height:1.5px;border-radius:1px;background:var(--text-muted,#6b6571);}
.phone .ph-cta{margin:auto 12px 14px;background:var(--coral);color:#fff;text-align:center;font-weight:800;font-size:9px;text-transform:uppercase;letter-spacing:.04em;padding:9px;border-radius:9999px;}

/* ---------- BONUS CARD ---------- */
.bonus{width:204px;background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:13px 15px;display:flex;align-items:center;gap:11px;}
.bonus img{width:34px;height:34px;flex:0 0 auto;}
.bonus .k{font-family:var(--bd);font-weight:800;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);}
.bonus .v{font-family:var(--hd);font-weight:600;font-size:15px;color:var(--ink);line-height:1;margin-top:3px;}

/* ---------- SPIRAL NOTEBOOK (bonus pad) ---------- */
.pad{width:170px;height:212px;background:var(--cream);border-radius:4px 4px 8px 8px;box-shadow:var(--shadow);padding:26px 16px 16px;}
.pad::before{content:"";position:absolute;top:-9px;left:10px;right:10px;height:18px;background:repeating-linear-gradient(90deg,transparent 0 8px,var(--ink) 8px 11px);opacity:.55;}
.pad .rings{position:absolute;top:-13px;left:10px;right:10px;height:20px;display:flex;justify-content:space-between;}
.pad .rings i{width:7px;height:20px;border:2.5px solid #b9b0a6;border-top:none;border-radius:0 0 7px 7px;}
.pad .pk{font-family:var(--bd);font-weight:800;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);}
.pad .pt{font-family:var(--hd);font-weight:600;font-size:21px;line-height:.95;color:var(--ink);margin-top:6px;}
.pad img{width:30px;height:30px;position:absolute;bottom:14px;right:14px;}
.pad--coral{background:var(--coral);} .pad--coral .pt{color:#fff;} .pad--coral .pk{color:rgba(255,255,255,.8);}
.pad--ink{background:linear-gradient(160deg,#272231,#15111c);} .pad--ink .pt{color:#fff;} .pad--ink .pk{color:var(--sky);}

/* ---------- BOX (typographic product box) ---------- */
.box{width:190px;height:200px;border-radius:12px;padding:22px 20px;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}
.box .bt{font-family:var(--hd);font-weight:600;font-size:30px;line-height:.86;letter-spacing:-.02em;}
.box .bb{font-family:var(--bd);font-weight:800;font-size:10px;letter-spacing:.14em;text-transform:uppercase;}
.box--ink{background:linear-gradient(160deg,#272231,#15111c);color:#fff;} .box--ink .bb{color:var(--sky);}
.box--coral{background:var(--coral);color:#fff;} .box--coral .bb{color:rgba(255,255,255,.85);}
.box--cream{background:var(--cream);color:var(--ink);} .box--cream .bb{color:var(--coral);}
.box--sky{background:var(--sky);color:#fff;} .box--sky .bb{color:rgba(255,255,255,.85);}

/* ---------- TRIATHLON ICON ROW (run/bike/swim brand pictograms) ---------- */
.tri-icons{display:flex;gap:9px;align-items:center;margin-top:auto;}
.tri-icons img{width:25px;height:25px;display:block;}
.tri-icons.sm img{width:21px;height:21px;}
.tri-icons .chip-ic{width:34px;height:34px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);display:grid;place-items:center;}
.tri-icons .chip-ic img{width:22px;height:22px;}

/* ---------- LAPTOP NAV CHEVRON ---------- */
.dash .nav .cv{display:inline-block;width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:translateY(-2px) rotate(45deg);margin-left:3px;}

/* ---------- CLEAN BONUS TAG ---------- */
.bonus-tag{display:inline-flex;flex-direction:column;align-items:center;gap:3px;background:var(--coral);color:#fff;border-radius:18px;padding:13px 22px;box-shadow:var(--shadow-sm);}
.bonus-tag .w{font-family:var(--hd);font-weight:600;font-size:26px;line-height:.9;}
.bonus-tag .s{font-weight:800;font-size:10px;letter-spacing:.1em;text-transform:uppercase;opacity:.92;}
.bonus-tag--ink{background:var(--ink);} .bonus-tag--ink .s{color:var(--yellow);opacity:1;}
.bonus-tag--yellow{background:var(--yellow);color:var(--ink);} .bonus-tag--yellow .s{opacity:.7;}

/* ---------- DISC ---------- */
.disc{border-radius:50%;}

/* ---------- STICKERS & SPARKLES ---------- */
.bonus-sticker{text-align:center;}
.bonus-sticker .word{font-family:var(--hd);font-weight:600;font-size:34px;color:var(--ink);transform:rotate(-3deg);}
.bonus-sticker .sub{font-family:var(--bd);font-weight:800;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--coral);transform:rotate(-3deg);}
.arc{position:absolute;}
.star{color:var(--sky);} .star.y{color:var(--yellow);} .star.c{color:var(--coral);} .star.l{color:var(--lilac);}
.star svg{display:block;}
.pricetag{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:var(--yellow);box-shadow:var(--shadow-sm);text-align:center;}
.pricetag .was{font-size:11px;font-weight:700;color:rgba(27,22,36,.55);text-decoration:line-through;}
.pricetag .now{font-family:var(--hd);font-weight:600;font-size:30px;color:var(--ink);line-height:.85;}
.pricetag.lg{width:150px;height:150px;}
.pricetag.lg .was{font-size:17px;}
.pricetag.lg .now{font-size:52px;}
.pricetag.lg .now small{font-size:30px;font-weight:600;vertical-align:8px;}
.pricetag.xl{width:184px;height:184px;}
.pricetag.xl .was{font-size:20px;}
.pricetag.xl .now{font-size:64px;}
.pricetag.xl .now small{font-size:36px;font-weight:600;vertical-align:10px;}
.bonus-tag.big{padding:18px 30px;border-radius:22px;gap:4px;}
.bonus-tag.big .w{font-size:34px;}
.bonus-tag.big .s{font-size:11.5px;}
