/* ============================================================
   PHAROS — The Harbour (keeper dApp)
   ============================================================ */
.harbourhead { padding: calc(var(--nav-h) + var(--s-5)) 0 var(--s-3); }
.harbourhead__row { display: flex; justify-content: space-between; align-items: flex-end; gap: 1.5rem; flex-wrap: wrap; }
.harbourhead h1 { font-size: var(--t-h1); margin: 0.8rem 0 0; }
.kwallet { display: flex; align-items: center; gap: 0.7rem; font-family: var(--font-mono); font-size: var(--t-small); color: var(--dim);
  border: 1px solid var(--hair); border-radius: var(--r-pill); padding: 0.5rem 1rem; background: var(--glass); }
.kwallet__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--signal); box-shadow: 0 0 9px var(--signal); }

.guestbar { margin: 0 0 var(--s-3); padding: 0.9rem 1.2rem; border: 1px dashed var(--hair-strong); border-radius: var(--r-md);
  background: var(--glass); display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.guestbar p { margin: 0; color: var(--dim); font-size: var(--t-small); flex: 1; }
.guestbar .amber { color: var(--light); }

.hgrid { display: grid; grid-template-columns: 360px 1fr; gap: var(--s-4); align-items: start; }
@media (max-width: 980px){ .hgrid{ grid-template-columns: 1fr; } }

/* standing card */
.standing { padding: 1.8rem; }
.standing__order { display: flex; align-items: baseline; gap: 0.7rem; margin: 0.3rem 0 0.2rem; }
.standing__order strong { font-family: var(--font-display); font-size: 2.6rem; color: var(--light); line-height: 1; }
.standing__lm { font-family: var(--font-mono); font-size: var(--t-small); color: var(--dim); }
.standing__lm b { color: var(--foam); }
.standing__bar { height: 8px; border-radius: 99px; background: rgba(255,255,255,0.07); overflow: hidden; margin: 1.2rem 0 0.5rem; }
.standing__bar i { display: block; height: 100%; width: 0; border-radius: 99px; background: linear-gradient(to right, var(--light-deep), var(--light)); box-shadow: 0 0 12px var(--light-glow); transition: width 0.8s var(--ease-out); }
.standing__next { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: 0.08em; color: var(--dim); text-transform: uppercase; }

.actions { display: grid; gap: 1px; background: var(--hair); border: 1px solid var(--hair); border-radius: var(--r-md); overflow: hidden; margin-top: 1.4rem; }
.action { background: var(--glass); padding: 1.2rem 1.3rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.action__txt { display: flex; flex-direction: column; gap: 0.2rem; }
.action__txt strong { font-family: var(--font-display); font-size: 1.2rem; color: var(--foam); font-weight: 400; }
.action__txt span { font-size: var(--t-small); color: var(--dim); }
.action__txt span b { color: var(--light); font-family: var(--font-mono); }
.act-btn { font-family: var(--font-sans); font-weight: 600; font-size: var(--t-small); cursor: pointer; white-space: nowrap;
  border: 0; border-radius: var(--r-pill); padding: 0.65rem 1.2rem; background: var(--light); color: var(--ground); transition: transform var(--fast), box-shadow var(--med), opacity var(--fast); box-shadow: var(--bloom); }
.act-btn:hover { transform: translateY(-1px); }
.act-btn:disabled { background: var(--glass-2); color: var(--dimmer); box-shadow: none; cursor: not-allowed; }

/* towers panel */
.kpanel { padding: 1.6rem 1.8rem; }
.kpanel__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.2rem; }
.kpanel__head h2 { font-size: var(--t-h3); }
.ktowers { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 1rem; }
.ktower { border: 1px solid var(--hair); border-radius: var(--r-md); overflow: hidden; background: radial-gradient(80% 60% at 50% 100%, var(--glass-2), transparent); transition: border-color var(--fast); }
.ktower:hover { border-color: var(--light-deep); }
.ktower__art { height: 180px; } .ktower__art .lh-svg { width: 100%; height: 100%; }
.ktower__meta { padding: 0.7rem 0.9rem; border-top: 1px solid var(--hair-soft); display: flex; justify-content: space-between; align-items: center; }
.ktower__id { font-family: var(--font-mono); font-size: var(--t-small); color: var(--foam); }
.ktower__tier { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light); }

/* embedded watch */
.hwatch { margin-top: var(--s-4); }
.hwatch__stage { position: relative; aspect-ratio: 16/9; overflow: hidden; padding: 0; background: linear-gradient(to bottom, #07111f, #040a14); border-radius: var(--r-lg); border: 1px solid var(--hair); }
#harbourCanvas { width: 100%; height: 100%; display: block; cursor: crosshair; }
.hwatch__hud { position: absolute; top: 1rem; left: 1.1rem; display: flex; gap: 1.4rem; z-index: 3; pointer-events: none; }
.hwatch__hud .label { font-size: 0.6rem; }
.hwatch__hud strong { font-family: var(--font-display); font-size: 1.3rem; color: var(--light); line-height: 1; }
.hwatch__storm { position: absolute; top: 1.1rem; right: 1.1rem; display: flex; align-items: center; gap: 0.6rem; z-index: 3; pointer-events: none; }
.hwatch__storm .label { font-size: 0.6rem; }
.hwatch__storm-bar { width: 110px; height: 5px; border-radius: 99px; background: rgba(255,255,255,0.1); overflow: hidden; }
.hwatch__storm-bar i { display: block; height: 100%; width: 0; background: linear-gradient(to right, var(--signal), #c95b5b); transition: width 0.3s; }
.hwatch__overlay { position: absolute; inset: 0; z-index: 5; display: grid; place-items: center; background: rgba(4,10,20,0.7); backdrop-filter: blur(3px); transition: opacity var(--med); text-align: center; padding: 1rem; }
.hwatch__overlay.is-hidden { opacity: 0; pointer-events: none; }
.hwatch__overlay h3 { font-size: 1.6rem; margin: 0.5rem 0; }
.hwatch__overlay .btn { margin-top: 1rem; }

/* empty state */
.kdark { text-align: center; padding: var(--s-6) 0; }
.kdark__tower { width: 150px; height: 200px; margin: 0 auto 1.5rem; opacity: 0.5; }
.kdark h2 { font-size: var(--t-h2); margin-bottom: 0.8rem; }
.kdark p { color: var(--dim); max-width: 44ch; margin: 0 auto 1.8rem; }
