59f13a74f9
Build and Push Docker Images / Build Backend (FastAPI) (push) Successful in 12s
Build and Push Docker Images / Build Frontend (Next.js) (push) Successful in 48s
Build and Push Docker Images / Build Pipeline (Meltano + dbt + Airflow) (push) Successful in 13s
Build and Push Docker Images / Trigger Portainer Update (push) Successful in 1s
MOB-07: Admissions deadlines strip becomes a horizontal snap-scroller
on ≤640px instead of a cramped 2×2 grid (which forced "Secondary ·
Deadline" track labels down to 9.6px). Cards stay readable, the right
edge fades to signal more content past the viewport, .chipTrack font
bumped to 0.7rem.
MOB-09: Result-card line3 (headline metric + secondary stats) was
crowding everything onto one row. Force the first .stat (Attainment
8 / RWM headline) to flex-basis 100% on mobile so delta-vs-LA and
pupil count wrap below it with a visible row-gap. Applied to both
SchoolRow (primary) and SecondarySchoolRow.
MOB-12: MetricTooltip ⓘ icons rendered at ~9px and relied on :hover
(which doesn't fire on touch). Hide the whole .wrapper at ≤640px —
metric labels themselves carry the meaning. Saves building a
tap-to-show layer for now.
MOB-13: The "Ofsted pending / No inspection on record" empty state
took a full hero card to communicate non-information. Add a
data-ofsted-state attribute on the hero chip; on ≤640px, the
"none" state collapses to a single muted line.
MOB-17: Already had Type+Action columns hidden on rankings mobile —
no change needed beyond marking complete.
MOB-18: Long metric headers ("Reading, Writing & Maths Combined %")
forced the value column wide. Drop .valueHeader to 0.625rem with
white-space: normal at ≤640px so labels wrap onto 2 short lines.
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
94 lines
1.9 KiB
CSS
94 lines
1.9 KiB
CSS
.wrapper {
|
|
position: relative;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
margin-left: 0.3em;
|
|
}
|
|
|
|
.icon {
|
|
font-size: 0.85em;
|
|
color: var(--text-muted, #8a7a72);
|
|
cursor: help;
|
|
line-height: 1;
|
|
user-select: none;
|
|
transition: color 0.15s ease;
|
|
}
|
|
|
|
.wrapper:hover .icon {
|
|
color: var(--accent-coral, #e07256);
|
|
}
|
|
|
|
.tooltip {
|
|
visibility: hidden;
|
|
opacity: 0;
|
|
position: absolute;
|
|
bottom: calc(100% + 6px);
|
|
left: 50%;
|
|
transform: translateX(-50%);
|
|
z-index: 9999;
|
|
width: 220px;
|
|
background: var(--bg-primary, #faf7f2);
|
|
border: 1px solid var(--border-color, #e8ddd4);
|
|
border-radius: 10px;
|
|
box-shadow: 0 4px 16px rgba(44, 36, 32, 0.15);
|
|
padding: 0.6rem 0.75rem;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 0.3rem;
|
|
pointer-events: none;
|
|
transition: opacity 0.15s ease, visibility 0.15s ease;
|
|
}
|
|
|
|
/* Keep tooltip visible when hovering over it */
|
|
.wrapper:hover .tooltip {
|
|
visibility: visible;
|
|
opacity: 1;
|
|
}
|
|
|
|
/* Small arrow pointing down */
|
|
.tooltip::after {
|
|
content: '';
|
|
position: absolute;
|
|
top: 100%;
|
|
left: 50%;
|
|
transform: translateX(-50%);
|
|
border: 5px solid transparent;
|
|
border-top-color: var(--border-color, #e8ddd4);
|
|
}
|
|
|
|
.tooltipLabel {
|
|
font-weight: 600;
|
|
font-size: 0.75rem;
|
|
color: var(--text-primary, #2c2420);
|
|
}
|
|
|
|
.tooltipPlain {
|
|
font-size: 0.75rem;
|
|
color: var(--text-secondary, #5a4a44);
|
|
line-height: 1.4;
|
|
}
|
|
|
|
.tooltipDetail {
|
|
font-size: 0.7rem;
|
|
color: var(--text-muted, #8a7a72);
|
|
line-height: 1.4;
|
|
margin-top: 0.1rem;
|
|
}
|
|
|
|
/* Flip tooltip below when near top of screen */
|
|
@media (max-width: 480px) {
|
|
.tooltip {
|
|
width: 180px;
|
|
}
|
|
}
|
|
|
|
/* On phones the icon was rendering at ~9px and the tooltip relied on
|
|
:hover, which doesn't fire on touch. Rather than build a tap-to-show
|
|
layer with backdrop dismissal, hide the helper entirely — the metric
|
|
labels themselves carry the meaning. */
|
|
@media (max-width: 640px) {
|
|
.wrapper {
|
|
display: none;
|
|
}
|
|
}
|