/* ==========================================================================
   Team.Qube — Tool Universe page styles
   ========================================================================== */

/* .section-pad lebt in app.scss (von Home + Tools genutzt) */

/* ------------------------------ QUBE HERO ------------------------------ */
.qube-hero{
  position:relative;
  background:linear-gradient(170deg, #0e1a18 0%, #0b1514 40%, #101d1b 100%);
  color:#eaf0ff;overflow:hidden;
  padding:clamp(40px,6vw,72px) 0 clamp(56px,7vw,100px);
}
.qube-hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:120px;
  background:linear-gradient(to bottom,transparent,var(--bg));
  pointer-events:none;z-index:3;
}
.qube-hero .iso-bg{
  position:absolute;inset:-20%;z-index:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(30deg, rgba(59,179,164,.07) 0 1.4px, transparent 1.4px 64px),
    repeating-linear-gradient(150deg, rgba(59,179,164,.07) 0 1.4px, transparent 1.4px 64px),
    repeating-linear-gradient(270deg, rgba(59,179,164,.05) 0 1.4px, transparent 1.4px 37px);
  -webkit-mask-image:radial-gradient(70% 70% at 50% 50%, #000 0%, transparent 75%);
          mask-image:radial-gradient(70% 70% at 50% 50%, #000 0%, transparent 75%);
}
.q-head{position:relative;z-index:2;text-align:center;max-width:720px;margin:0 auto clamp(18px,3vw,34px)}
.q-head .eyebrow{justify-content:center;color:#3BB3A4}
.q-head .eyebrow::before{background:#3BB3A4}
.q-head h1{color:#fff;margin-bottom:18px}
.q-head h1 .accent{color:#3BB3A4}
.q-head p{color:#9BB1AD;font-size:clamp(1.02rem,1.5vw,1.22rem);max-width:60ch;margin:0 auto}

/* stage: the connected map */
.q-stage{position:relative;z-index:2;width:min(88vw,660px);margin:clamp(10px,2vw,24px) auto 0;aspect-ratio:1}
.q-lines{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.q-line{stroke-dasharray:5 10;animation:qflow 4s linear infinite;transition:opacity .3s}
@keyframes qflow{to{stroke-dashoffset:-60}}
@media(prefers-reduced-motion:reduce){.q-line{animation:none}}
.q-ring{position:absolute;border:1px solid rgba(59,179,164,.08);border-radius:50%;pointer-events:none}
.q-ring.r1{left:18%;top:18%;width:64%;height:64%}
.q-ring.r2{left:7%;top:7%;width:86%;height:86%;border-style:dashed;border-color:rgba(59,179,164,.05)}

/* core */
.q-core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}
.q-core-disc{width:clamp(100px,18%,140px);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 50% 35%,rgba(59,179,164,.35),rgba(13,122,112,.12) 60%,transparent 72%);display:grid;place-items:center;border:1px solid rgba(127,227,214,.25);box-shadow:0 0 50px rgba(59,179,164,.35),inset 0 0 20px rgba(127,227,214,.10)}
.q-core-disc svg{width:60%;color:#fff}
.q-core-lbl{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#7fe3d6;white-space:nowrap;font-weight:600}

/* node: each tool cube */
.q-node{
  position:absolute;transform:translate(-50%,-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:none;border:none;padding:0;color:#dde4f5;cursor:pointer;
}
.q-node svg.iso{
  width:var(--sz,54px);height:auto;
  filter:drop-shadow(0 4px 14px color-mix(in srgb,var(--tc) 30%,transparent));
  transition:transform .28s ease,filter .28s ease;
}
.q-node .nlbl{font-size:.76rem;font-weight:600;color:#e7edfb;text-shadow:0 1px 5px rgba(0,0,0,.6);transition:color .2s;white-space:nowrap}
.q-node:hover{z-index:6}
.q-node:hover svg.iso{transform:translateY(-7px) scale(1.14);filter:drop-shadow(0 10px 24px color-mix(in srgb,var(--tc) 50%,transparent))}
.q-node:hover .nlbl{color:#fff}
.q-node:focus-visible{outline:2px solid var(--tc);outline-offset:4px;border-radius:6px}

/* tooltip */
.q-node .q-tip{
  position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%) scale(.92);
  background:#1a2624;border:1px solid rgba(255,255,255,.12);color:#c8dbd7;
  font-size:.78rem;font-weight:500;line-height:1.35;
  padding:8px 14px;border-radius:10px;max-width:260px;white-space:normal;text-align:center;
  pointer-events:none;opacity:0;transition:opacity .22s ease,transform .22s ease;
  box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:10;
}
.q-node:hover .q-tip{opacity:1;transform:translateX(-50%) scale(1)}

/* float animation staggered */
.q-float{animation:qfloat 7s ease-in-out infinite}
@keyframes qfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media(prefers-reduced-motion:reduce){.q-float{animation:none}}

/* hover line highlight */
.q-node:hover ~ .q-lines .q-line,
.q-stage:not(:has(.q-node:hover)) .q-line{opacity:.35}
.q-node[data-idx]:hover ~ .q-lines .q-line{opacity:.12}

/* mobile cube grid */
.q-grid{display:none;position:relative;z-index:2;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.q-chip{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:18px 8px 14px;border-radius:14px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  color:#dde4f5;transition:background .15s,transform .15s;cursor:pointer;
}
.q-chip:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.q-chip svg.iso{width:40px;height:auto;filter:drop-shadow(0 4px 12px color-mix(in srgb,var(--tc) 30%,transparent))}
.q-chip span{font-size:.74rem;font-weight:600;text-align:center;line-height:1.2}

.q-hint{position:relative;z-index:2;text-align:center;margin-top:clamp(28px,4vw,48px);color:#8b97b4;font-size:.92rem;display:flex;flex-direction:column;align-items:center;gap:10px}
.q-hint .chev{width:24px;height:24px;color:#3BB3A4;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@media(prefers-reduced-motion:reduce){.q-hint .chev{animation:none}}

/* ------------------------------ DETAIL SECTIONS ------------------------------ */
.details-intro{text-align:center;max-width:680px;margin:clamp(56px,8vw,96px) auto clamp(10px,2vw,24px)}
.tool-detail{position:relative;padding:clamp(46px,6vw,76px) 0;border-top:1px solid var(--border)}
.td-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,68px);align-items:center}
.tool-detail:nth-child(even) .td-visual{order:-1}
.td-copy .eyebrow{color:var(--tc)}
.td-copy .eyebrow::before{background:var(--tc)}
.td-num{font-size:.82rem;font-weight:600;color:var(--text-muted);letter-spacing:.08em;margin-bottom:14px}
.td-copy h2{margin-bottom:10px}
.td-copy h2 .dot{color:var(--tc)}
.td-tag{font-size:1.16rem;font-weight:600;color:var(--tc);margin-bottom:18px;line-height:1.35}
.td-copy .is{color:var(--text-muted);font-size:1.04rem;margin-bottom:26px;max-width:54ch}
.td-can{display:flex;flex-direction:column;gap:13px;margin-bottom:30px}
.can-item{display:flex;gap:13px;align-items:flex-start}
.can-item .ck{flex:none;width:24px;height:24px;border-radius:7px;background:color-mix(in srgb,var(--tc) 16%,var(--surface));color:var(--tc);display:grid;place-items:center;margin-top:1px}
.can-item .ck svg{width:14px;height:14px}
.can-item span{font-size:1rem}
.can-item b{font-weight:600}
.td-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-tool{background:var(--tc);color:#fff;box-shadow:0 10px 26px -12px var(--tc)}
.btn-tool:hover{transform:translateY(-2px);box-shadow:0 16px 32px -12px var(--tc);filter:brightness(1.05)}
.td-back{font-size:.92rem;font-weight:500;color:var(--text-muted);display:inline-flex;align-items:center;gap:6px;transition:color .15s}
.td-back:hover{color:var(--tc)}
.td-back svg{width:15px;height:15px}

/* visual placeholder */
.td-visual{position:relative}
.ph{position:relative;aspect-ratio:4/3;border-radius:20px;overflow:hidden;border:1px solid var(--border);
  background:
    repeating-linear-gradient(135deg,color-mix(in srgb,var(--tc) 9%,var(--surface)) 0 14px,color-mix(in srgb,var(--tc) 4%,var(--surface)) 14px 28px);
  box-shadow:var(--shadow)}
.ph .ph-top{position:absolute;top:0;left:0;right:0;height:42px;background:color-mix(in srgb,var(--tc) 14%,var(--surface));border-bottom:1px solid var(--border);display:flex;align-items:center;gap:7px;padding:0 16px}
.ph .ph-top i{width:9px;height:9px;border-radius:50%;background:color-mix(in srgb,var(--tc) 55%,var(--surface))}
.ph .ph-mark{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:18px;background:var(--tc);display:grid;place-items:center;box-shadow:0 12px 30px -10px var(--tc)}
.ph .ph-mark span{width:26px;height:26px;border-radius:8px;background:#fff;opacity:.92}
.ph .ph-label{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;letter-spacing:.04em;color:var(--text-muted);background:var(--surface);padding:5px 12px;border-radius:999px;border:1px solid var(--border);white-space:nowrap}
.flash{animation:flash 1.1s ease}
@keyframes flash{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--tc) 60%,transparent)}40%{box-shadow:0 0 0 10px color-mix(in srgb,var(--tc) 0%,transparent)}100%{box-shadow:none}}

/* ------------------------------ CTA STRIP ------------------------------ */
.cta{background:var(--surface-2);border-top:1px solid var(--border);text-align:center;padding:clamp(56px,8vw,92px) 0}
.cta h2{margin-bottom:14px}
.cta p{color:var(--text-muted);max-width:48ch;margin:0 auto 30px;font-size:1.08rem}

/* ------------------------------ RESPONSIVE ------------------------------ */
@media (max-width:920px){
  .td-inner{grid-template-columns:1fr;gap:30px}
  .tool-detail:nth-child(even) .td-visual{order:0}
}
@media (max-width:680px){
  .q-stage{display:none}
  .q-grid{display:grid}
}
@media (max-width:560px){
  .q-grid{grid-template-columns:repeat(2,1fr)}
  .td-actions{flex-direction:column;align-items:stretch}
  .td-actions .btn{justify-content:center}
}
