/* ============================================================
   MENTO.IA — Product mock, report, trust, ecosystem, CTA, footer
   ============================================================ */

/* ——————————————————— PRODUCT MOCK (student profile) ——————————————————— */
.product { background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); overflow:hidden; }
.product-layout { display:grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(34px,5vw,76px); align-items:center; margin-top: 56px; }
@media (max-width: 940px){ .product-layout{ grid-template-columns:1fr; gap:44px; } }
.product-copy .feat { list-style:none; padding:0; margin:30px 0 0; display:flex; flex-direction:column; gap:18px; }
.product-copy .feat li { display:flex; gap:14px; align-items:flex-start; }
.product-copy .feat .ic { width:38px; height:38px; border-radius:11px; flex:none; display:grid; place-items:center;
  background: color-mix(in oklab, var(--blue) 12%, white); color: var(--blue); }
.product-copy .feat .ic svg { width:20px; height:20px; }
.product-copy .feat b { display:block; font-size:16px; font-weight:700; color:var(--ink); }
.product-copy .feat span { font-size:14.5px; color: var(--ink-soft); }

/* The app frame */
.app { background:#fff; border-radius: 22px; border:1px solid var(--line); overflow:hidden;
  box-shadow: 0 50px 100px -50px rgba(16,26,51,.4), 0 20px 40px -30px rgba(16,26,51,.2);
  transform: perspective(1100px) rotateY(-5deg) rotateX(1.5deg); transition: transform .5s var(--ease); }
.app:hover { transform: perspective(1100px) rotateY(-2deg) rotateX(0deg); }
.app-bar { display:flex; align-items:center; gap:10px; padding: 13px 18px; border-bottom:1px solid var(--line); background: var(--paper); }
.app-bar .dots { display:flex; gap:6px; } .app-bar .dots i { width:10px;height:10px;border-radius:50%; background: var(--line); }
.app-bar .who { margin-left:auto; display:flex; align-items:center; gap:9px; font-size:13px; color: var(--ink-soft); }
.app-bar .av { width:26px;height:26px;border-radius:50%; background: var(--grad); color:#fff; font-size:12px; font-weight:700; display:grid; place-items:center; }
.app-body { padding: 22px; display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.card { background: var(--paper); border:1px solid var(--line); border-radius: 16px; padding: 18px; }
.card .ct { font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color: var(--ink-faint); margin-bottom: 14px; display:flex; justify-content:space-between; align-items:center; }
.card.span2 { grid-column: 1 / -1; }

/* progress ring */
.ring-wrap { display:flex; align-items:center; gap:18px; }
.ring { --p:0; width:84px; height:84px; border-radius:50%; flex:none;
  background: conic-gradient(var(--violet) calc(var(--p)*1%), var(--line) 0); display:grid; place-items:center; }
.ring::after { content:""; position:absolute; }
.ring .inner { width:64px; height:64px; border-radius:50%; background:#fff; display:grid; place-items:center; }
.ring .inner b { font-size:21px; font-weight:800; letter-spacing:-.02em; }
.ring-meta b { font-size:15px; } .ring-meta p { font-size:13px; color:var(--ink-soft); }

/* RIASEC bars */
.bars { display:flex; flex-direction:column; gap:11px; }
.bar-row { display:grid; grid-template-columns: 88px 1fr 36px; align-items:center; gap:12px; font-size:13px; }
.bar-row .track { height:8px; border-radius:999px; background: var(--line); overflow:hidden; }
.bar-row .fill { height:100%; border-radius:999px; background: var(--grad); width:var(--v,0%); transition: width 1.1s var(--ease-out); }
.bar-row .pct { text-align:right; font-weight:700; font-variant-numeric:tabular-nums; color: var(--ink-soft); }

/* strength chips */
.chips { display:flex; flex-wrap:wrap; gap:8px; }
.chips span { font-size:13px; font-weight:600; padding:7px 13px; border-radius:999px; background: var(--tint-violet); color: color-mix(in oklab,var(--violet) 70%, var(--ink)); }
.chips span:nth-child(3n+2){ background: var(--tint-teal); color: color-mix(in oklab,var(--teal) 75%, var(--ink)); }
.chips span:nth-child(3n+3){ background: var(--tint-gold); color: color-mix(in oklab,var(--gold) 78%, var(--ink)); }

/* mini timeline */
.mini-tl { display:flex; align-items:center; gap:0; }
.mini-tl .seg { flex:1; height:6px; background: var(--line); position:relative; }
.mini-tl .seg.done { background: var(--grad-tri); }
.mini-tl .yr { display:flex; justify-content:space-between; font-size:11px; color:var(--ink-faint); margin-top:8px; font-weight:600; }

/* ——————————————————— REPORT (3 readings) ——————————————————— */
.report-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:20px; margin-top:56px; }
@media (max-width: 860px){ .report-grid{ grid-template-columns:1fr; } }
.rcard { padding: 30px 28px; border-radius: var(--radius-lg); border:1px solid var(--line); background: var(--rb); transition: transform .5s var(--ease); }
.rcard:hover { transform: translateY(-6px); }
.rcard .rt { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.rcard .rt .ic { width:46px;height:46px;border-radius:13px; display:grid; place-items:center; background:#fff; box-shadow: 0 6px 16px -8px rgba(6,7,84,.28); }
.rcard .rt .ic svg { width:22px; height:22px; }
.rcard.r1 .rt .ic { color: var(--blue); } .rcard.r2 .rt .ic { color: #1f63c9; } .rcard.r3 .rt .ic { color: #0a86b8; }
.rcard h3 { font-size:21px; }
.rcard p { font-size:15px; color:var(--ink-soft); }
.rcard .rtags { display:flex; flex-wrap:wrap; gap:6px; margin-top:20px; }
.rcard .rtags span { font-size:12px; font-weight:600; color:var(--ink-soft); padding:4px 10px; border-radius:999px; background:rgba(255,255,255,.6); border:1px solid var(--line); }
.rcard.r1{ --rb: var(--tint-blue); } .rcard.r2{ --rb: var(--tint-violet); } .rcard.r3{ --rb: var(--tint-teal); }

/* ——————————————————— SCHOOLS ——————————————————— */
.school-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap:18px; margin-top:56px; }
.scard { padding:26px 24px; border-radius: var(--radius); border:1px solid var(--line); background: var(--paper); transition: transform .5s var(--ease), border-color .4s; }
.scard:hover { transform: translateY(-5px); border-color: color-mix(in oklab,var(--blue) 40%, var(--line)); }
.scard .ic { width:42px;height:42px;border-radius:12px; display:grid; place-items:center; background: var(--tint-blue); color:var(--blue); margin-bottom:18px; }
.scard .ic svg { width:22px; height:22px; }
.scard h4 { font-size:17px; margin-bottom:8px; }
.scard p { font-size:14px; color:var(--ink-soft); }
.eq-bar { display:flex; align-items:center; justify-content:center; gap:16px; margin-top:46px; padding:18px;
  border-radius:999px; background: var(--cosmos); color:#fff; font-weight:700; font-size: clamp(15px,2vw,20px); letter-spacing:-.01em; flex-wrap:wrap; }
.eq-bar .op { color: var(--teal); font-family: var(--serif); font-style:italic; }
.eq-bar .gt { background: var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ——————————————————— TRUST ——————————————————— */
.trust-stats { display:grid; grid-template-columns: repeat(4,1fr); gap:24px; margin-top:54px; }
@media (max-width: 760px){ .trust-stats{ grid-template-columns:1fr 1fr; gap:30px; } }
.tstat .num { font-size: clamp(38px,5vw,62px); font-weight:800; letter-spacing:-.03em; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.tstat .lbl { font-size:14px; color:var(--ink-soft); margin-top:4px; }
.logos { display:grid; grid-template-columns: repeat(auto-fit,minmax(120px,1fr)); gap:14px; margin-top:54px; }
.logo-cell { height:74px; border-radius:14px; border:1px solid var(--line); display:grid; place-items:center;
  background: var(--paper); color: var(--ink-faint); font-weight:700; font-size:13px; letter-spacing:.02em; text-align:center; padding:0 12px; transition: all .4s; }
.logo-cell:hover { color: var(--ink); border-color: color-mix(in oklab,var(--blue) 30%, var(--line)); }
.quotes { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:46px; }
@media (max-width: 760px){ .quotes{ grid-template-columns:1fr; } }
.quote { padding:30px; border-radius: var(--radius-lg); background: var(--qb,var(--paper-2)); border:1px solid var(--line); }
.quote .qm { font-family:var(--serif); font-style:italic; font-size:44px; line-height:.6; color:var(--violet); }
.quote p { font-size:17px; line-height:1.5; margin:10px 0 18px; color:var(--ink); }
.quote .by { display:flex; align-items:center; gap:12px; }
.quote .by .av { width:40px;height:40px;border-radius:50%; background:var(--grad); color:#fff; display:grid; place-items:center; font-weight:700; }
.quote .by b { font-size:14px; display:block; } .quote .by span { font-size:13px; color:var(--ink-soft); }
.quote.q2 { --qb: color-mix(in oklab, var(--teal) 7%, white); } .quote.q2 .qm { color: var(--teal); }

/* ——————————————————— ECOSYSTEM ——————————————————— */
.eco { position:relative; }
.eco-layout { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,72px); align-items:center; margin-top:56px; }
@media (max-width: 880px){ .eco-layout{ grid-template-columns:1fr; } }
.eco-diagram { position:relative; aspect-ratio: 1/.82; display:grid; place-items:center; }
.eco-core { position:relative; z-index:3; padding: 22px 34px; border-radius:999px; background: var(--grad); color:#fff;
  font-weight:800; font-size:26px; letter-spacing:-.02em; box-shadow: 0 24px 50px -20px color-mix(in oklab,var(--violet) 70%, transparent); }
.eco-core small { display:block; font-size:11px; font-weight:600; letter-spacing:.12em; opacity:.8; text-transform:uppercase; }
.eco-node { position:absolute; padding:11px 17px; border-radius:999px; background:var(--paper); border:1px solid var(--line);
  font-weight:700; font-size:14px; box-shadow: 0 14px 30px -18px rgba(16,26,51,.4); display:flex; align-items:center; gap:8px; transition: transform .5s var(--ease); }
.eco-node .nd { width:8px;height:8px;border-radius:50%; }
.eco-node:hover { transform: scale(1.06); }
.eco-node.n1 { top:6%; left:6%; } .eco-node.n2 { top:14%; right:2%; }
.eco-node.n3 { bottom:16%; left:0%; } .eco-node.n4 { bottom:6%; right:8%; }
.eco-node.live { background: color-mix(in oklab,var(--violet) 10%, white); border-color: color-mix(in oklab,var(--violet) 40%, var(--line)); }
.eco-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.eco-list li { padding:18px 20px; border-radius:16px; border:1px solid var(--line); display:flex; gap:14px; align-items:flex-start; transition: all .4s; }
.eco-list li:hover { border-color: color-mix(in oklab,var(--blue) 30%, var(--line)); background: var(--paper-2); }
.eco-list .tag { font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:4px 9px; border-radius:999px; flex:none; margin-top:2px; }
.eco-list .tag.on { background: var(--grad); color:#fff; } .eco-list .tag.soon { background: var(--line); color:var(--ink-faint); }
.eco-list .tag.plus { background: var(--cosmos); color:#fff; }
.eco-list b { font-size:16px; } .eco-list p { font-size:14px; color:var(--ink-soft); }
.eco-list li.eco-more { background: var(--paper-2); border-style:dashed; }
.eco-orbits { position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.eco-node.n3 .nd, .eco-node.n4 .nd { opacity:.6; }

/* ——————————————————— FINAL CTA ——————————————————— */
.final { background: var(--cosmos); color:#fff; position:relative; overflow:hidden; }
.final .glow { opacity:.4; }
.final-inner { position:relative; z-index:2; text-align:left; }
.final h2 { font-size: clamp(34px,6vw,82px); line-height:1.02; }
.final h2 .b3 { color: var(--teal); }
.final p.lead { color: rgba(255,255,255,.66); max-width:620px; margin-top:24px; }
.final-cards { display:grid; grid-template-columns: 1fr; gap:18px; margin-top:50px; max-width: 540px; }
.final-cards .fcard.primary { display:flex; flex-direction:column; align-items:flex-start; }
@media (max-width: 760px){ .final-cards{ grid-template-columns:1fr; } }
.fcard { padding:34px; border-radius: var(--radius-lg); border:1px solid rgba(255,255,255,.12); }
.fcard.primary { background: var(--grad); }
.fcard.ghost { background: rgba(255,255,255,.04); }
.fcard h3 { font-size:22px; margin-bottom:8px; }
.fcard p { font-size:15px; color: rgba(255,255,255,.78); margin-bottom:22px; }
.fcard.primary p { color: rgba(255,255,255,.9); }

/* ——————————————————— FOOTER ——————————————————— */
.footer { background: var(--cosmos); color: rgba(255,255,255,.6); padding: 60px 0 40px; border-top:1px solid rgba(255,255,255,.08); }
.footer-top { display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer .logo { color:#fff; font-size:22px; } .footer .logo .mento { color:#fff; }
.footer-cols { display:flex; gap: clamp(30px,6vw,80px); flex-wrap:wrap; }
.footer-col h5 { font-size:12px; letter-spacing:.12em; text-transform:uppercase; color: rgba(255,255,255,.45); margin:0 0 14px; font-weight:700; }
.footer-col a { display:block; font-size:14.5px; color: rgba(255,255,255,.7); margin-bottom:9px; transition: color .25s; }
.footer-col a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-top:28px; font-size:13px; }

/* ——————————————————— TWEAKS PANEL ——————————————————— */
#tweaks { position: fixed; right: 20px; bottom: 20px; z-index: 999; width: 290px; font-family: var(--sans);
  background: #fff; border:1px solid var(--line); border-radius: 18px; box-shadow: 0 30px 70px -25px rgba(16,26,51,.5);
  overflow:hidden; transform: translateY(140%); transition: transform .5s var(--ease); }
#tweaks.show { transform: none; }
.tw-head { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid var(--line); }
.tw-head b { font-size:14px; font-weight:800; letter-spacing:-.01em; }
.tw-head button { color: var(--ink-faint); font-size:18px; line-height:1; }
.tw-body { padding: 16px 18px 20px; max-height: 70vh; overflow:auto; }
.tw-sec { margin-bottom:18px; } .tw-sec:last-child{ margin-bottom:0; }
.tw-sec > label { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color: var(--ink-faint); display:block; margin-bottom:9px; }
.tw-opts { display:flex; gap:7px; flex-wrap:wrap; }
.tw-opts button { padding:7px 12px; border-radius:10px; border:1px solid var(--line); font-size:13px; font-weight:600; color:var(--ink-soft); transition: all .25s; }
.tw-opts button.active { background: var(--ink); color:#fff; border-color: var(--ink); }
.tw-sw { display:flex; gap:8px; }
.tw-sw button { width:34px; height:34px; border-radius:10px; border:2px solid transparent; transition: all .25s; }
.tw-sw button.active { border-color: var(--ink); transform: scale(1.08); }
