@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&display=swap');

:root{
  --pink:#eb3b8b;
  --purple:#7b2cff;
  --blue:#00b8ff;
  --navy:#171027;
  --text:#272033;
  --muted:#6d6481;
  --bg:#f6efff;
  --card:#ffffff;
  --soft:#fbf7ff;
  --border:#eadcff;
  --green:#12b981;
  --amber:#f59e0b;
  --red:#ef4444;
  --shadow:0 22px 55px rgba(45,22,80,.12);
  --glow:0 18px 44px rgba(123,44,255,.10);
}

*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

body{
  font-family:"Fredoka", Arial, Helvetica, sans-serif;
  background:
    radial-gradient(circle at top left, rgba(235,59,139,.20), transparent 34%),
    radial-gradient(circle at top right, rgba(0,184,255,.18), transparent 36%),
    var(--bg);
  color:var(--text);
  min-height:100vh;
}

.hero h1,
.question,
.score{
  font-family:"Fredoka", Arial, Helvetica, sans-serif;
  font-weight:500;
}

button,input,select{
  font:inherit;
}

button{
  cursor:pointer;
}

.app-shell{
  min-height:100vh;
  padding:22px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.panel{
  width:100%;
  max-width:1040px;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(22px);
  border:1px solid rgba(255,255,255,.75);
  border-radius:28px;
  box-shadow:var(--shadow);
  overflow:hidden;
}

.hero{
  background:
    linear-gradient(135deg, rgba(235,59,139,.98), rgba(123,44,255,.96) 56%, rgba(0,184,255,.96)),
    radial-gradient(circle at 85% 20%, rgba(255,255,255,.22), transparent 30%);
  color:white;
  padding:34px;
  position:relative;
}

.brand{
  font-weight:500;
  font-size:.95rem;
  letter-spacing:.02em;
  margin-bottom:24px;
}

.hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:center;
}

.hero h1{
  font-size:clamp(2.2rem, 5vw, 4.6rem);
  line-height:.98;
  letter-spacing:-.055em;
  max-width:720px;
}

.hero p{
  margin-top:22px;
  font-size:1.12rem;
  line-height:1.65;
  max-width:620px;
  opacity:.94;
}

.hero-card{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(18px);
  border-radius:24px;
  padding:24px;
}

.hero-card h3{
  font-size:1.15rem;
  margin-bottom:16px;
}

.hero-points{
  display:grid;
  gap:12px;
}

.hero-point{
  display:flex;
  gap:12px;
  align-items:flex-start;
  line-height:1.35;
}

.tick{
  width:24px;
  height:24px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  display:grid;
  place-items:center;
  flex:0 0 24px;
}

.main{
  padding:26px;
}

.progress-wrap{
  display:none;
  margin-bottom:22px;
}

.progress-top{
  display:flex;
  justify-content:space-between;
  color:var(--muted);
  font-size:.92rem;
  margin-bottom:10px;
}

.progress-bar{
  height:12px;
  background:#eee6ff;
  border-radius:999px;
  overflow:hidden;
}

.progress-fill{
  height:100%;
  width:0%;
  background:linear-gradient(135deg,var(--pink),var(--purple),var(--blue));
  transition:.35s ease;
}

.screen{
  animation:fadeUp .28s ease both;
}

@keyframes fadeUp{
  from{opacity:0; transform:translateY(10px);}
  to{opacity:1; transform:translateY(0);}
}

.screen-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:24px;
  padding:26px;
}

.kicker{
  color:var(--purple);
  font-weight:700;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:10px;
}

.question{
  font-size:clamp(1.55rem, 4vw, 2.6rem);
  line-height:1.12;
  letter-spacing:-.025em;
  margin-bottom:12px;
}

.sub{
  color:var(--muted);
  line-height:1.65;
  margin-bottom:24px;
  max-width:720px;
}

.option-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
}

.tile{
  border:1px solid var(--border);
  border-radius:20px;
  padding:18px;
  background:#fff;
  min-height:104px;
  transition:.2s ease;
  position:relative;
}

.tile:hover{
  transform:translateY(-2px);
  border-color:#cdb9ff;
}

.tile.selected{
  border-color:var(--purple);
  background:linear-gradient(180deg,#fff,#fbf7ff);
  box-shadow:var(--glow);
}

.tile.selected::after{
  content:"✓";
  position:absolute;
  top:14px;
  right:14px;
  width:26px;
  height:26px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:700;
}

.icon{
  font-size:1.7rem;
  margin-bottom:12px;
}

.tile-title{
  font-weight:700;
  margin-bottom:6px;
}

.tile-copy{
  color:var(--muted);
  font-size:.92rem;
  line-height:1.45;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.field label{
  display:block;
  font-weight:700;
  margin-bottom:8px;
}

.field input,
.field select{
  width:100%;
  border:1px solid var(--border);
  border-radius:16px;
  padding:15px 16px;
  background:white;
  color:var(--text);
}

.field input:focus,
.field select:focus{
  outline:none;
  border-color:var(--purple);
  box-shadow:0 0 0 4px rgba(123,44,255,.10);
}

.actions{
  display:flex;
  gap:12px;
  margin-top:26px;
}

.btn{
  border:none;
  border-radius:18px;
  padding:16px 22px;
  min-height:56px;
  font-weight:700;
  background:linear-gradient(135deg,var(--pink),var(--purple),var(--blue));
  color:white;
  box-shadow:0 12px 26px rgba(123,44,255,.18);
}

.btn.secondary{
  color:var(--purple);
  background:#f4edff;
  box-shadow:none;
}

.btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}

.analysis{
  text-align:center;
  padding:46px 20px;
}

.orb{
  width:112px;
  height:112px;
  border-radius:999px;
  margin:0 auto 24px;
  background:conic-gradient(from 180deg,var(--pink),var(--purple),var(--blue),var(--pink));
  display:grid;
  place-items:center;
  animation:spin 1.3s linear infinite;
}

.orb::after{
  content:"";
  width:76px;
  height:76px;
  background:#fff;
  border-radius:999px;
}

@keyframes spin{
  to{transform:rotate(360deg);}
}

.analysis-list{
  display:grid;
  gap:12px;
  max-width:520px;
  margin:24px auto 0;
  text-align:left;
}

.analysis-item{
  background:var(--soft);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px 16px;
  color:var(--muted);
}

.result-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:18px;
}

.score-card{
  background:linear-gradient(180deg,#fff,#fbf7ff);
  border:1px solid var(--border);
  border-radius:24px;
  padding:26px;
  text-align:center;
}

.score{
  font-size:3.8rem;
  letter-spacing:-.045em;
  font-weight:700;
  background:linear-gradient(135deg,var(--pink),var(--purple),var(--blue));
  -webkit-background-clip:text;
  color:transparent;
}

.band{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:10px 14px;
  font-weight:700;
  margin-top:10px;
}

.band.green{background:#ecfdf5;color:#047857;}
.band.amber{background:#fffbeb;color:#b45309;}
.band.red{background:#fef2f2;color:#b91c1c;}

.result-section{
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:18px;
  margin-bottom:14px;
}

.result-section h3{
  margin-bottom:10px;
}

.chip-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.chip{
  background:#f5efff;
  color:#4f259e;
  border:1px solid #e1d2ff;
  border-radius:999px;
  padding:9px 12px;
  font-weight:700;
  font-size:.9rem;
}

.small-note{
  color:var(--muted);
  line-height:1.55;
}


.impact-text{
  font-size:1.35rem;
  line-height:1.35;
  font-weight:700;
  color:var(--text);
  margin:18px 0;
}

.impact-mini{
  margin-top:18px;
  display:inline-flex;
  gap:6px;
  align-items:center;
  background:#f5efff;
  border:1px solid #e1d2ff;
  border-radius:999px;
  padding:10px 14px;
  color:#4f259e;
  font-weight:700;
}

@media(max-width:760px){
  .app-shell{padding:12px; align-items:flex-start;}
  .panel{border-radius:24px;}
  .hero{padding:28px;}
  .hero-grid{grid-template-columns:1fr;}
  .main{padding:18px;}
  .screen-card{padding:22px;}
  .option-grid,.form-grid,.result-grid{grid-template-columns:1fr;}
  .actions{flex-direction:column-reverse;}
  .btn{width:100%;}
}

/* Premium gloss refresh - lighter, less chunky, more consultancy-style */
.panel{
  position:relative;
}

.panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.95), transparent);
  pointer-events:none;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(115deg, rgba(255,255,255,.20), transparent 28%),
    radial-gradient(circle at 82% 12%, rgba(255,255,255,.34), transparent 18%);
  pointer-events:none;
  mix-blend-mode:screen;
}

.hero > *{
  position:relative;
  z-index:1;
}

.hero h1{
  font-weight:600;
  letter-spacing:-.035em;
}

.hero-card,
.screen-card,
.score-card,
.result-section,
.tile{
  box-shadow:0 18px 42px rgba(45,22,80,.07);
}

.tile{
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(253,249,255,.92));
}

.tile:hover{
  box-shadow:var(--glow);
}

.btn{
  position:relative;
  overflow:hidden;
}

.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(115deg, rgba(255,255,255,.34), transparent 42%);
  pointer-events:none;
}

.results-hero{
  display:flex;
  justify-content:space-between;
  gap:20px;
  align-items:flex-start;
  margin-bottom:20px;
  padding:24px;
  border-radius:24px;
  color:#fff;
  background:
    linear-gradient(135deg, rgba(235,59,139,.96), rgba(123,44,255,.94) 58%, rgba(0,184,255,.92)),
    radial-gradient(circle at 84% 10%, rgba(255,255,255,.28), transparent 28%);
  box-shadow:0 18px 48px rgba(123,44,255,.18);
  position:relative;
  overflow:hidden;
}

.results-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(115deg, rgba(255,255,255,.22), transparent 34%);
  pointer-events:none;
}

.results-hero > *{
  position:relative;
  z-index:1;
}

.results-hero .kicker,
.results-hero .sub{
  color:rgba(255,255,255,.86);
}

.results-hero .question{
  color:#fff;
  margin-bottom:8px;
}

.report-badge{
  min-width:170px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.28);
  border-radius:18px;
  padding:14px 16px;
  backdrop-filter:blur(14px);
}

.report-badge span{
  display:block;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  opacity:.78;
  margin-bottom:5px;
}

.report-badge strong{
  font-size:.86rem;
  word-break:break-word;
}

.premium-grid{
  grid-template-columns:.72fr 1.28fr;
}

.premium-score{
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(251,247,255,.92)),
    radial-gradient(circle at 50% 0%, rgba(123,44,255,.10), transparent 44%);
}

.score-note{
  margin-top:-4px;
  font-size:.9rem;
}

.band{
  font-size:.92rem;
  padding:8px 12px;
}

.impact-panel{
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,247,255,.94));
}

.impact-text{
  font-size:1.18rem;
  line-height:1.42;
  font-weight:700;
  margin:14px 0;
}

.impact-mini{
  margin-top:14px;
  font-size:.92rem;
  background:rgba(245,239,255,.78);
}

.coverage-premium{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
}

.coverage-status{
  min-width:190px;
  text-align:right;
}

.coverage-status strong,
.coverage-status span{
  display:block;
}

.coverage-status span{
  color:var(--muted);
  font-size:.86rem;
  margin-top:4px;
}

.recommendation-list{
  display:grid;
  gap:10px;
}

.recommendation-item{
  display:flex;
  gap:10px;
  align-items:flex-start;
  background:rgba(246,239,255,.54);
  border:1px solid rgba(225,210,255,.72);
  border-radius:16px;
  padding:12px 14px;
}

.recommendation-item span{
  width:22px;
  height:22px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  color:#fff;
  flex:0 0 22px;
  font-size:.8rem;
}

.recommendation-item p{
  line-height:1.45;
  color:var(--text);
}

.next-step-panel{
  background:linear-gradient(180deg, #fff, #fbf7ff);
}

@media(max-width:760px){
  .results-hero,
  .coverage-premium{
    flex-direction:column;
  }

  .report-badge,
  .coverage-status{
    width:100%;
    text-align:left;
  }

  .score{
    font-size:3.35rem;
  }
}

/* Premium refinement v2 - slimmer, sharper, less chunky */
:root{
  --shadow:0 20px 70px rgba(25,12,45,.10);
  --glow:0 16px 38px rgba(123,44,255,.09);
  --border:#eee4ff;
}

body{
  background:
    radial-gradient(circle at 0% 0%, rgba(235,59,139,.13), transparent 30%),
    radial-gradient(circle at 100% 0%, rgba(0,184,255,.13), transparent 34%),
    linear-gradient(135deg,#fbf7ff 0%,#f7f0ff 42%,#eff9ff 100%);
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}

.app-shell{
  padding:18px;
  align-items:flex-start;
}

.panel{
  max-width:1120px;
  border-radius:24px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:0 22px 80px rgba(33,16,64,.10);
}

.hero{
  padding:36px 46px 34px;
  border-radius:24px 24px 0 0;
}

.brand{
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.03em;
  margin-bottom:24px;
  opacity:.92;
}

.hero-grid{
  gap:42px;
}

.hero h1{
  font-weight:500;
  font-size:clamp(2.35rem,4.4vw,4.05rem);
  line-height:1.03;
  letter-spacing:-.04em;
  max-width:620px;
}

.hero p{
  font-size:1.02rem;
  line-height:1.62;
  max-width:560px;
  opacity:.9;
}

.hero-card{
  border-radius:22px;
  padding:24px 26px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 18px 42px rgba(23,16,39,.08);
}

.hero-card h3{
  font-weight:600;
  font-size:1rem;
}

.hero-point{
  font-size:.96rem;
  font-weight:400;
}

.tick{
  width:22px;
  height:22px;
  flex-basis:22px;
  font-size:.8rem;
}

.main{
  padding:28px 30px 34px;
}

.screen-card{
  border-radius:22px;
  padding:30px 32px;
  border:1px solid rgba(234,220,255,.82);
  box-shadow:0 18px 54px rgba(45,22,80,.055);
}

.kicker{
  font-size:.76rem;
  font-weight:700;
  letter-spacing:.135em;
  color:#7441e8;
}

.question{
  font-size:clamp(1.75rem,3.2vw,2.65rem);
  line-height:1.1;
  font-weight:500;
  letter-spacing:-.035em;
  max-width:850px;
}

.sub,
.small-note{
  font-weight:400;
  color:#756b8a;
}

.option-grid{
  gap:12px;
}

.tile{
  min-height:92px;
  padding:18px 18px 16px;
  border-radius:18px;
  border:1px solid #eadcff;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(253,250,255,.92));
  box-shadow:0 12px 34px rgba(45,22,80,.045);
}

.tile:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 38px rgba(45,22,80,.07);
}

.tile.selected{
  border-color:#a879ff;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,244,255,.94)),
    radial-gradient(circle at top right, rgba(123,44,255,.08), transparent 35%);
  box-shadow:0 16px 42px rgba(123,44,255,.085);
}

.tile.selected::after{
  width:22px;
  height:22px;
  top:12px;
  right:12px;
  font-size:.8rem;
  font-weight:600;
}

.icon{
  font-size:1.2rem;
  margin-bottom:9px;
  opacity:.9;
}

.tile-title{
  font-size:.98rem;
  font-weight:600;
  margin-bottom:4px;
}

.tile-copy{
  font-size:.88rem;
  line-height:1.36;
  font-weight:400;
}

.field label{
  font-size:.9rem;
  font-weight:600;
}

.field input,
.field select{
  border-radius:14px;
  padding:13px 15px;
  font-weight:400;
}

.btn{
  min-height:48px;
  border-radius:15px;
  padding:13px 20px;
  font-size:.95rem;
  font-weight:600;
  box-shadow:0 14px 32px rgba(123,44,255,.14);
}

.progress-bar{
  height:8px;
  background:#f1e9ff;
}

.progress-top{
  font-size:.82rem;
}

.results-premium{
  display:grid;
  gap:14px;
}

.results-hero{
  margin-bottom:2px;
  padding:24px 28px;
  border-radius:22px;
  box-shadow:0 18px 54px rgba(123,44,255,.13);
}

.results-hero .question{
  font-size:clamp(1.9rem,3vw,3.05rem);
  font-weight:500;
}

.results-hero .sub{
  max-width:680px;
  font-size:.98rem;
  line-height:1.55;
}

.report-badge{
  border-radius:16px;
  padding:12px 14px;
  min-width:150px;
  font-weight:400;
}

.result-grid{
  gap:14px;
}

.premium-grid{
  grid-template-columns:.62fr 1.38fr;
}

.score-card,
.result-section{
  border-radius:20px;
  border:1px solid rgba(234,220,255,.86);
  box-shadow:0 14px 44px rgba(45,22,80,.052);
}

.score-card{
  padding:22px 20px;
}

.score{
  font-size:3.05rem;
  line-height:1;
  font-weight:600;
  letter-spacing:-.055em;
  margin:10px 0 6px;
}

.score-note{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.band{
  padding:7px 11px;
  font-size:.82rem;
  font-weight:600;
}

.result-section{
  padding:20px 22px;
  margin-bottom:0;
  background:rgba(255,255,255,.96);
}

.result-section h3{
  font-size:1.08rem;
  line-height:1.2;
  font-weight:600;
  letter-spacing:-.015em;
  margin-bottom:9px;
}

.impact-panel{
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(252,249,255,.95)),
    radial-gradient(circle at 100% 0%, rgba(0,184,255,.08), transparent 34%);
}

.impact-text{
  font-size:1.08rem;
  line-height:1.46;
  font-weight:600;
  margin:12px 0;
  max-width:720px;
}

.impact-mini{
  margin-top:12px;
  padding:8px 12px;
  font-size:.82rem;
  font-weight:600;
  background:rgba(246,239,255,.72);
}

.chip{
  padding:7px 10px;
  font-size:.82rem;
  font-weight:600;
  background:rgba(246,239,255,.74);
}

.coverage-premium{
  align-items:flex-start;
}

.coverage-status{
  min-width:175px;
}

.recommendation-panel{
  background:linear-gradient(180deg,#fff,#fcfaff);
}

.recommendation-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.recommendation-item{
  padding:11px 12px;
  border-radius:14px;
  background:rgba(250,247,255,.8);
  border:1px solid rgba(225,210,255,.62);
}

.recommendation-item span{
  width:19px;
  height:19px;
  flex-basis:19px;
  font-size:.68rem;
  font-weight:600;
}

.recommendation-item p{
  font-size:.92rem;
  line-height:1.42;
  font-weight:400;
}

.next-step-panel .actions{
  margin-top:18px;
}

@media(max-width:900px){
  .premium-grid,
  .recommendation-list{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .app-shell{padding:10px;}
  .panel{border-radius:20px;}
  .hero{padding:28px 22px;}
  .hero h1{font-size:2.45rem;}
  .main{padding:18px 14px 24px;}
  .screen-card{padding:22px 18px;}
  .tile{min-height:84px;}
  .results-hero{padding:22px 18px;}
  .score{font-size:2.8rem;}
}

.coverage-meta{
  margin-top:10px;
  color:var(--muted);
  font-size:.92rem;
}

.network-table{
  grid-column:1 / -1;
  display:grid;
  gap:10px;
  margin-top:6px;
}

.network-row{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr .7fr;
  gap:12px;
  align-items:center;
  padding:13px 14px;
  border:1px solid var(--border);
  border-radius:18px;
  background:linear-gradient(180deg,#fff,rgba(251,247,255,.72));
}

.network-row.best{
  border-color:rgba(123,44,255,.32);
  box-shadow:0 12px 28px rgba(123,44,255,.08);
}

.network-row span,
.network-row small{
  display:block;
  margin-top:2px;
  color:var(--muted);
  font-size:.82rem;
  line-height:1.25;
}

.network-row strong{
  font-weight:600;
}

@media (max-width:720px){
  .network-row{
    grid-template-columns:1fr 1fr;
  }
}

/* Local prototype helper */
.prototype-field{
  background:rgba(255,255,255,.72);
  border:1px dashed #d8c6ff;
  border-radius:22px;
  padding:16px;
}

.field-help{
  margin:8px 0 0;
  font-size:.86rem;
  line-height:1.45;
  color:#6e6389;
}


/* Prototype Ofcom check */
.prototype-check-panel{
  margin-top:22px;
  border:1px solid rgba(123,44,255,.18);
  background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(247,242,255,.78));
  border-radius:24px;
  padding:18px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
}

.prototype-check-panel h3{
  margin:0 0 4px;
  font-size:1rem;
  letter-spacing:0;
}

.btn.compact{
  padding:12px 18px;
  font-size:.9rem;
}

.prototype-check-result{
  grid-column:1 / -1;
}

.coverage-preview-card{
  border:1px solid rgba(123,44,255,.16);
  border-radius:18px;
  background:#fff;
  padding:14px;
  display:grid;
  gap:8px;
}

.coverage-preview-card strong{
  color:var(--text);
  font-weight:700;
}

@media (max-width:760px){
  .prototype-check-panel{
    grid-template-columns:1fr;
  }

  .btn.compact{
    width:100%;
  }
}

.build-marker{
  position:fixed;
  right:10px;
  bottom:10px;
  z-index:9999;
  font:600 11px/1.2 system-ui, sans-serif;
  color:#5c3bb4;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(124,44,255,.18);
  border-radius:999px;
  padding:6px 9px;
  box-shadow:0 8px 24px rgba(39,32,51,.08);
  pointer-events:none;
}

.debug-note{
  font-size:.82rem;
  line-height:1.35;
  color:#6f6384;
  margin-top:8px;
}

.prototype-check-panel{
  border:1px solid rgba(124,44,255,.22);
  background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(246,239,255,.74));
}

/* 8K consultancy redesign pass - restrained, executive, thinner UI */
:root{
  --ink:#181225;
  --text:#252033;
  --muted:#6f6780;
  --line:rgba(53,35,82,.105);
  --panel:#ffffff;
  --wash:#fbf9ff;
  --mist:#f5f0ff;
  --shadow:0 28px 90px rgba(28,18,49,.10);
  --shadow-soft:0 14px 42px rgba(28,18,49,.055);
  --premium-gradient:linear-gradient(135deg,#eb3b8b 0%,#7b2cff 52%,#00b8ff 100%);
}

body{
  background:
    radial-gradient(circle at 4% 0%, rgba(235,59,139,.10), transparent 28%),
    radial-gradient(circle at 98% 2%, rgba(0,184,255,.12), transparent 30%),
    linear-gradient(135deg,#fff 0%,#faf7ff 46%,#f2fbff 100%);
  color:var(--text);
}

.app-shell{
  padding:20px;
}

.panel{
  max-width:1180px;
  border-radius:26px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.hero{
  padding:38px 50px 42px;
  min-height:338px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:
    linear-gradient(135deg, rgba(235,59,139,.97), rgba(123,44,255,.95) 54%, rgba(0,184,255,.94)),
    radial-gradient(circle at 88% 16%, rgba(255,255,255,.34), transparent 20%);
}

.hero::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:22px;
  pointer-events:none;
}

.hero-topline{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  margin-bottom:32px;
}

.brand,
.hero-meta,
.hero-eyebrow{
  font-size:.76rem;
  line-height:1.1;
  text-transform:uppercase;
  letter-spacing:.155em;
  font-weight:600;
}

.brand{margin:0;}
.hero-meta{color:rgba(255,255,255,.72);}
.hero-eyebrow{color:rgba(255,255,255,.78); margin-bottom:14px;}

.hero-grid{
  grid-template-columns:1.05fr .95fr;
  gap:56px;
}

.hero h1{
  max-width:650px;
  font-size:clamp(2.55rem,4.6vw,4.45rem);
  line-height:.98;
  letter-spacing:-.045em;
  font-weight:600;
}

.hero p{
  margin-top:22px;
  max-width:610px;
  font-size:1.02rem;
  line-height:1.65;
  color:rgba(255,255,255,.88);
}

.executive-card{
  align-self:stretch;
  border-radius:24px;
  padding:26px;
  background:rgba(255,255,255,.105);
  border:1px solid rgba(255,255,255,.25);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.24), 0 22px 52px rgba(20,12,38,.10);
}

.executive-card h3{
  font-size:.95rem;
  text-transform:uppercase;
  letter-spacing:.13em;
  font-weight:600;
  color:rgba(255,255,255,.88);
  margin-bottom:18px;
}

.hero-points{gap:13px;}
.hero-point{
  display:grid;
  grid-template-columns:36px 1fr;
  gap:13px;
  align-items:start;
  padding:11px 0;
  border-bottom:1px solid rgba(255,255,255,.13);
}
.hero-point:last-child{border-bottom:0;}
.hero-point span:last-child{display:grid;gap:3px;}
.hero-point strong{font-size:1rem;font-weight:600;color:#fff;}
.hero-point small{font-size:.84rem;line-height:1.35;color:rgba(255,255,255,.72);}
.tick{
  width:32px;
  height:32px;
  border-radius:12px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.20);
  font-size:.68rem;
  font-weight:700;
}

.main{padding:30px;}

.screen-card{
  border-radius:24px;
  padding:34px 38px;
  background:rgba(255,255,255,.96);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}

.kicker{
  color:#6f39f4;
  font-size:.72rem;
  letter-spacing:.16em;
  font-weight:700;
  margin-bottom:12px;
}
.question{
  color:var(--ink);
  font-weight:600;
  font-size:clamp(1.9rem,3.25vw,3rem);
  letter-spacing:-.042em;
  line-height:1.04;
}
.sub{
  max-width:760px;
  margin-top:14px;
  margin-bottom:26px;
  color:#716982;
  font-size:1rem;
  line-height:1.62;
}

.consultancy-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:28px;
}
.consultancy-strip > div{
  min-height:136px;
  padding:20px;
  border-radius:20px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(251,248,255,.95));
  border:1px solid rgba(64,38,101,.10);
  box-shadow:0 12px 34px rgba(30,18,52,.045);
}
.consultancy-strip span{
  display:inline-flex;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.12em;
  color:#7b2cff;
  margin-bottom:18px;
}
.consultancy-strip strong,
.consultancy-strip small{display:block;}
.consultancy-strip strong{font-size:1.05rem;font-weight:600;color:var(--ink);}
.consultancy-strip small{margin-top:7px;color:var(--muted);line-height:1.42;}

.progress-wrap{margin-bottom:22px;}
.progress-top{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:#7c728f;}
.progress-bar{height:6px;background:#f2ecff;}
.progress-fill{background:var(--premium-gradient);}

.option-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.tile{
  min-height:88px;
  padding:17px 18px;
  border-radius:18px;
  display:grid;
  grid-template-columns:36px 1fr;
  column-gap:14px;
  align-items:center;
  text-align:left;
  background:linear-gradient(180deg,#fff,#fdfbff);
  border:1px solid rgba(53,35,82,.11);
  box-shadow:0 10px 26px rgba(30,18,52,.038);
}
.tile:hover{transform:translateY(-1px);border-color:rgba(123,44,255,.28);box-shadow:0 14px 32px rgba(30,18,52,.06);}
.tile.selected{border-color:rgba(123,44,255,.48);box-shadow:0 18px 38px rgba(123,44,255,.095);}
.tile.selected::after{width:20px;height:20px;top:12px;right:12px;font-size:.72rem;}
.icon{grid-row:1 / span 2;font-size:1.12rem;margin:0;opacity:.82;}
.tile-title{font-size:1rem;font-weight:600;color:var(--ink);}
.tile-copy{font-size:.88rem;line-height:1.38;color:#726982;}

.form-grid{gap:18px;}
.field label{font-size:.82rem;text-transform:uppercase;letter-spacing:.09em;color:#3b314f;font-weight:700;}
.field input,.field select{
  min-height:52px;
  border-radius:14px;
  border:1px solid rgba(53,35,82,.13);
  background:#fff;
  box-shadow:0 8px 22px rgba(30,18,52,.025);
}
.field input:focus,.field select:focus{border-color:#8d63ff;box-shadow:0 0 0 4px rgba(123,44,255,.09);}
.prototype-field{display:none;}

.actions{gap:12px;margin-top:28px;}
.btn{
  min-height:50px;
  border-radius:14px;
  padding:13px 22px;
  font-weight:700;
  letter-spacing:-.01em;
  background:var(--premium-gradient);
  box-shadow:0 16px 34px rgba(123,44,255,.18);
}
.btn.secondary{background:#f5efff;color:#6b35df;box-shadow:none;}
.btn.compact{min-height:46px;padding:12px 18px;}

.results-premium{gap:16px;}
.results-hero{
  border-radius:24px;
  padding:28px 32px;
  background:
    linear-gradient(135deg,rgba(24,18,37,.98),rgba(56,28,98,.96) 48%,rgba(24,108,160,.94)),
    radial-gradient(circle at 88% 15%, rgba(0,184,255,.24), transparent 22%);
  box-shadow:0 24px 70px rgba(27,18,48,.16);
}
.results-hero .kicker{color:rgba(255,255,255,.68);}
.results-hero .question{color:#fff;font-size:clamp(2rem,3vw,3.1rem);}
.results-hero .sub{color:rgba(255,255,255,.75);}
.report-badge{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);}

.executive-summary-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.summary-metric{
  padding:18px 20px;
  border-radius:20px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 12px 34px rgba(30,18,52,.045);
}
.summary-metric span,
.summary-metric small{display:block;color:var(--muted);}
.summary-metric span{font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;font-weight:700;margin-bottom:10px;}
.summary-metric strong{display:block;color:var(--ink);font-size:1.28rem;line-height:1.08;font-weight:600;margin-bottom:7px;}
.summary-metric small{font-size:.84rem;line-height:1.36;}

.premium-grid{grid-template-columns:.52fr 1.48fr;gap:14px;}
.score-card,.result-section{border:1px solid var(--line);border-radius:22px;box-shadow:0 14px 38px rgba(30,18,52,.045);}
.score-card{padding:24px 22px;background:linear-gradient(180deg,#fff,#fcfaff);}
.score{font-size:3.1rem;font-weight:600;margin:9px 0 5px;}
.score-note{font-size:.7rem;letter-spacing:.13em;color:#817790;}
.band{font-size:.8rem;font-weight:700;padding:7px 11px;}
.result-section{padding:22px 24px;background:#fff;}
.result-section h3{font-size:1.05rem;font-weight:600;color:var(--ink);letter-spacing:-.015em;margin-bottom:10px;}
.impact-text{font-size:1.18rem;line-height:1.44;font-weight:600;color:#20192e;}
.impact-mini,.chip{border-color:rgba(123,44,255,.16);background:#f7f1ff;color:#5226a7;}
.chip{padding:7px 11px;}
.coverage-premium{display:grid;grid-template-columns:1fr 210px;gap:20px;}
.coverage-status{text-align:right;min-width:0;}
.network-table{grid-column:1 / -1;}
.network-row{border-radius:16px;padding:12px 14px;background:linear-gradient(180deg,#fff,#fdfbff);}
.recommendation-list{grid-template-columns:repeat(2,minmax(0,1fr));}
.recommendation-item{background:#fbf8ff;border-color:rgba(53,35,82,.10);}
.recommendation-item span{background:var(--premium-gradient);}
.next-step-panel{background:linear-gradient(135deg,#fff,#f9f4ff);}

.prototype-check-panel{
  border-radius:22px;
  padding:20px 22px;
  background:linear-gradient(135deg,#fff,#fbf8ff);
  border:1px solid rgba(53,35,82,.10);
  box-shadow:0 12px 34px rgba(30,18,52,.045);
}
.prototype-check-panel h3{font-weight:600;color:var(--ink);}
.debug-note{color:#8a8099;font-size:.78rem;}
.coverage-preview-card{border-color:rgba(53,35,82,.10);box-shadow:0 10px 26px rgba(30,18,52,.04);}
.build-marker{font-size:10px;opacity:.72;}

@media(max-width:920px){
  .hero-grid,.consultancy-strip,.executive-summary-grid,.premium-grid,.recommendation-list{grid-template-columns:1fr;}
  .coverage-premium{grid-template-columns:1fr;}
  .coverage-status{text-align:left;}
}
@media(max-width:760px){
  .app-shell{padding:10px;}
  .hero{padding:30px 22px;min-height:auto;}
  .hero-topline{align-items:flex-start;flex-direction:column;gap:8px;margin-bottom:24px;}
  .hero h1{font-size:2.55rem;}
  .hero p{font-size:.98rem;}
  .main{padding:16px 12px 22px;}
  .screen-card,.result-section{padding:22px 18px;}
  .option-grid,.form-grid{grid-template-columns:1fr;}
  .tile{min-height:82px;}
  .actions{flex-direction:column-reverse;}
  .btn{width:100%;}
  .results-hero{padding:24px 18px;}
  .network-row{grid-template-columns:1fr;}
}

/* Moonshot gloss pass - less dominant header, more premium/glass, less chunky */
:root{
  --moon-ink:#171124;
  --moon-muted:#6b627d;
  --moon-line:rgba(47,31,75,.10);
  --moon-glass:rgba(255,255,255,.72);
  --moon-shadow:0 24px 90px rgba(28,18,49,.095);
  --moon-soft-shadow:0 14px 50px rgba(28,18,49,.055);
  --premium-gradient:linear-gradient(135deg,#eb3b8b 0%,#8c2cff 46%,#00b8ff 100%);
}

body{
  background:
    radial-gradient(circle at 7% -4%, rgba(235,59,139,.14), transparent 28%),
    radial-gradient(circle at 93% 0%, rgba(0,184,255,.16), transparent 30%),
    linear-gradient(135deg,#fff 0%,#fbf8ff 45%,#f1fbff 100%);
}

.app-shell{
  padding:18px 20px 28px;
  align-items:flex-start;
}

.panel{
  max-width:1180px;
  border-radius:28px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.88);
  box-shadow:var(--moon-shadow);
  backdrop-filter:blur(24px);
  overflow:hidden;
}

.panel::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95), inset 0 0 0 1px rgba(255,255,255,.36);
}

.hero{
  min-height:0;
  padding:26px 34px 28px;
  display:block;
  border-radius:28px 28px 0 0;
  background:
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.26), transparent 22%),
    radial-gradient(circle at 82% 10%, rgba(255,255,255,.34), transparent 20%),
    linear-gradient(135deg, rgba(235,59,139,.94) 0%, rgba(123,44,255,.94) 50%, rgba(0,184,255,.92) 100%);
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.18);
}

.hero::before{
  inset:14px 16px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.02));
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(112deg,rgba(255,255,255,.26) 0%,rgba(255,255,255,.06) 22%,transparent 48%),
    linear-gradient(180deg,rgba(255,255,255,.10),transparent 46%);
  mix-blend-mode:screen;
  pointer-events:none;
}

.hero-topline{
  margin-bottom:18px;
}

.brand,
.hero-meta,
.hero-eyebrow{
  letter-spacing:.16em;
  font-weight:600;
  font-size:.68rem;
}

.hero-meta{
  opacity:.72;
}

.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.17);
}

.hero-grid{
  grid-template-columns:1.02fr .98fr;
  gap:32px;
  align-items:end;
}

.hero h1{
  max-width:590px;
  font-size:clamp(2.05rem,3.25vw,3.35rem);
  line-height:1.02;
  font-weight:600;
  letter-spacing:-.04em;
  text-wrap:balance;
}

.hero p{
  margin-top:14px;
  max-width:560px;
  font-size:.98rem;
  line-height:1.52;
  color:rgba(255,255,255,.86);
}

.executive-card{
  border-radius:22px;
  padding:18px 20px;
  background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.075));
  border:1px solid rgba(255,255,255,.25);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.32), 0 18px 52px rgba(20,12,38,.09);
}

.executive-card h3{
  font-size:.75rem;
  letter-spacing:.16em;
  margin-bottom:10px;
}

.hero-points{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px 12px;
}

.hero-point{
  grid-template-columns:28px 1fr;
  gap:10px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.11);
}

.hero-point:nth-last-child(-n+2){border-bottom:0;}
.hero-point strong{font-size:.88rem;font-weight:600;}
.hero-point small{font-size:.74rem;line-height:1.28;color:rgba(255,255,255,.68);}
.tick{
  width:26px;
  height:26px;
  border-radius:10px;
  font-size:.6rem;
  background:rgba(255,255,255,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.24);
}

.main{
  padding:24px 28px 32px;
}

.screen-card{
  border-radius:24px;
  padding:30px 34px;
  background:rgba(255,255,255,.84);
  backdrop-filter:blur(14px);
  border:1px solid rgba(47,31,75,.095);
  box-shadow:var(--moon-soft-shadow);
}

.kicker{
  color:#7240ed;
  letter-spacing:.17em;
  font-size:.68rem;
}

.question{
  color:var(--moon-ink);
  font-size:clamp(1.7rem,2.8vw,2.62rem);
  line-height:1.07;
  font-weight:600;
  letter-spacing:-.04em;
  text-wrap:balance;
}

.sub,
.small-note{
  color:var(--moon-muted);
  font-size:.96rem;
}

.consultancy-strip{
  gap:10px;
  margin-top:22px;
}

.consultancy-strip > div{
  min-height:112px;
  padding:17px 18px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(252,249,255,.88));
  border:1px solid rgba(47,31,75,.09);
  box-shadow:0 12px 38px rgba(28,18,49,.045), inset 0 1px 0 rgba(255,255,255,.9);
}

.consultancy-strip span{margin-bottom:13px;font-size:.64rem;}
.consultancy-strip strong{font-size:.96rem;}
.consultancy-strip small{font-size:.83rem;line-height:1.36;}

.progress-wrap{margin-bottom:18px;}
.progress-bar{height:5px;background:rgba(236,226,255,.82);}
.progress-fill{box-shadow:0 0 18px rgba(0,184,255,.26);}

.option-grid{gap:10px;}
.tile{
  min-height:78px;
  padding:14px 16px;
  border-radius:16px;
  grid-template-columns:30px 1fr;
  column-gap:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(253,251,255,.90));
  border:1px solid rgba(47,31,75,.10);
  box-shadow:0 10px 28px rgba(28,18,49,.035), inset 0 1px 0 rgba(255,255,255,.9);
}
.tile:hover{box-shadow:0 14px 34px rgba(28,18,49,.055);}
.tile.selected{
  border-color:rgba(123,44,255,.44);
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(249,244,255,.92)),
    radial-gradient(circle at 96% 0%,rgba(0,184,255,.12),transparent 34%);
}
.icon{font-size:1rem;}
.tile-title{font-size:.94rem;}
.tile-copy{font-size:.82rem;}
.tile.selected::after{width:18px;height:18px;top:10px;right:10px;font-size:.66rem;}

.field input,.field select{
  min-height:48px;
  border-radius:13px;
}

.actions{margin-top:24px;}
.btn{
  min-height:46px;
  border-radius:13px;
  padding:12px 20px;
  box-shadow:0 16px 38px rgba(123,44,255,.16), inset 0 1px 0 rgba(255,255,255,.28);
}
.btn.secondary{
  background:rgba(245,239,255,.86);
  color:#6733d8;
}

.results-hero{
  padding:24px 28px;
  border-radius:22px;
  background:
    radial-gradient(circle at 90% 12%,rgba(255,255,255,.18),transparent 20%),
    linear-gradient(135deg,rgba(23,17,36,.97),rgba(64,34,112,.94) 48%,rgba(16,125,178,.90));
}
.results-hero .question{font-size:clamp(1.8rem,2.7vw,2.8rem);}
.executive-summary-grid{gap:10px;}
.summary-metric{padding:15px 17px;border-radius:18px;}
.summary-metric strong{font-size:1.08rem;}
.premium-grid{grid-template-columns:.46fr 1.54fr;}
.score-card,.result-section{
  border-radius:19px;
  border:1px solid rgba(47,31,75,.095);
  box-shadow:0 12px 36px rgba(28,18,49,.042);
}
.score-card{padding:20px 18px;}
.score{font-size:2.7rem;}
.result-section{padding:19px 21px;}
.impact-text{font-size:1.06rem;font-weight:600;}
.recommendation-list{gap:8px;}
.recommendation-item{padding:10px 11px;border-radius:13px;}
.network-row{border-radius:14px;}
.prototype-check-panel{padding:18px 20px;border-radius:20px;}

@media(max-width:920px){
  .hero-grid,.hero-points{grid-template-columns:1fr;}
  .hero-point:nth-last-child(-n+2){border-bottom:1px solid rgba(255,255,255,.11);}
  .hero-point:last-child{border-bottom:0;}
}
@media(max-width:760px){
  .app-shell{padding:8px;}
  .panel{border-radius:22px;}
  .hero{padding:24px 18px 22px;}
  .hero h1{font-size:2.18rem;}
  .hero p{font-size:.92rem;}
  .main{padding:14px 10px 20px;}
  .screen-card{padding:20px 16px;}
  .tile{min-height:74px;}
}

/* === Wow Layer 20260605-004 === */
.journey-layout.has-intelligence{
  display:grid;
  grid-template-columns:minmax(0,1fr) 280px;
  gap:20px;
  align-items:start;
}

.live-map-card{
  position:sticky;
  top:18px;
  border:1px solid rgba(123,44,255,.16);
  border-radius:22px;
  padding:18px;
  background:
    radial-gradient(circle at 15% 0%, rgba(235,59,139,.16), transparent 34%),
    radial-gradient(circle at 100% 20%, rgba(0,184,255,.14), transparent 40%),
    rgba(255,255,255,.78);
  box-shadow:0 20px 60px rgba(39,32,51,.08);
  backdrop-filter:blur(18px);
}

.live-map-card > span,
.diagnosis-panel > span{
  display:block;
  margin-bottom:8px;
  color:#7b2cff;
  font-size:.72rem;
  letter-spacing:.16em;
  font-weight:700;
  text-transform:uppercase;
}

.live-map-card > strong{
  display:block;
  color:var(--ink);
  font-size:1.05rem;
  margin-bottom:14px;
}

.map-lines{display:grid;gap:10px;margin:14px 0;}
.map-line{display:grid;grid-template-columns:12px 1fr auto;gap:9px;align-items:center;font-size:.88rem;color:#5f5570;}
.map-line i{width:10px;height:10px;border-radius:999px;background:#cdbdff;box-shadow:0 0 0 5px rgba(123,44,255,.08);}
.map-line.high i{background:#eb3b8b;box-shadow:0 0 16px rgba(235,59,139,.38);}
.map-line.medium i{background:#7b2cff;box-shadow:0 0 16px rgba(123,44,255,.32);}
.map-line.low i{background:#00b8ff;box-shadow:0 0 16px rgba(0,184,255,.28);}
.map-line p{margin:0;font-weight:600;color:#272033;}
.map-line em{font-style:normal;font-size:.72rem;color:#8a7b9b;}
.live-map-card small{color:#8a7b9b;font-size:.78rem;}

.compact-results-hero{
  min-height:auto !important;
  padding:28px 30px !important;
  border-radius:28px !important;
}

.diagnosis-panel{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.75);
  border-radius:28px;
  padding:28px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(255,255,255,.62)),
    radial-gradient(circle at 0% 0%, rgba(235,59,139,.14), transparent 34%),
    radial-gradient(circle at 100% 20%, rgba(0,184,255,.14), transparent 38%);
  box-shadow:0 24px 80px rgba(39,32,51,.09);
  backdrop-filter:blur(22px);
}

.diagnosis-panel::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(115deg, transparent 0%, rgba(255,255,255,.5) 38%, transparent 54%);
  transform:translateX(-65%);
  opacity:.8;
  pointer-events:none;
}

.diagnosis-panel p{
  position:relative;
  z-index:1;
  max-width:980px;
  margin:0;
  color:#272033;
  font-size:clamp(1.28rem,2vw,1.85rem);
  line-height:1.35;
  font-weight:500;
  letter-spacing:-.025em;
}

.gap-card .gap-bars{display:grid;gap:14px;margin:22px 0;}
.gap-row{display:grid;gap:8px;}
.gap-row div:first-child{display:flex;justify-content:space-between;gap:12px;font-size:.82rem;color:#6f6580;}
.gap-row strong{color:#272033;font-weight:650;}
.gap-track{height:9px;border-radius:999px;background:#eee7ff;overflow:hidden;}
.gap-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#eb3b8b,#7b2cff,#00b8ff);box-shadow:0 0 18px rgba(123,44,255,.28);}

.map-panel{display:grid;grid-template-columns:250px 1fr;gap:26px;align-items:center;}
.dependency-map{position:relative;display:grid;grid-template-columns:180px 1fr;gap:22px;align-items:center;min-height:180px;}
.map-core{width:160px;height:160px;border-radius:50%;display:grid;place-items:center;text-align:center;color:#fff;font-weight:700;background:radial-gradient(circle at 35% 20%,#fff4,transparent 30%),linear-gradient(135deg,#eb3b8b,#7b2cff,#00b8ff);box-shadow:0 24px 70px rgba(123,44,255,.24);}
.map-core span{max-width:100px;line-height:1.15;}
.map-spokes{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.map-node{border:1px solid rgba(123,44,255,.14);background:#fff;border-radius:18px;padding:14px 16px;box-shadow:0 14px 40px rgba(39,32,51,.045);}
.map-node strong{display:block;font-weight:650;color:#272033;margin-bottom:3px;}
.map-node span{font-size:.78rem;color:#7b2cff;font-weight:700;letter-spacing:.08em;text-transform:uppercase;}
.map-node.high{background:linear-gradient(135deg,#fff,#fff5fb);}
.map-node.medium{background:linear-gradient(135deg,#fff,#f8f4ff);}
.map-node.low{background:linear-gradient(135deg,#fff,#f2fbff);}

.timeline-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:18px;}
.timeline-item{position:relative;border:1px solid rgba(123,44,255,.13);border-radius:20px;padding:18px;background:linear-gradient(180deg,#fff,#fcfaff);box-shadow:0 14px 38px rgba(39,32,51,.045);}
.timeline-item::before{content:"";position:absolute;left:18px;top:-7px;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#eb3b8b,#7b2cff,#00b8ff);box-shadow:0 0 0 7px rgba(123,44,255,.08);}
.timeline-item span{display:block;color:#7b2cff;font-size:.74rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;margin-bottom:12px;}
.timeline-item strong{display:block;font-size:1rem;color:#272033;margin-bottom:8px;}
.timeline-item p{margin:0;color:#6f6580;line-height:1.45;font-size:.92rem;}

.coverage-lens{grid-template-columns:minmax(0,1fr) 280px !important;}
.candidate-only{text-align:left !important;border:1px solid rgba(123,44,255,.14);border-radius:22px;padding:18px;background:linear-gradient(180deg,#fff,#faf7ff);}
.candidate-details{margin-top:14px;padding-top:14px;border-top:1px solid rgba(123,44,255,.12);display:grid;gap:8px;}
.candidate-details p{margin:0;color:#6f6580;font-size:.88rem;}
.candidate-details strong{display:inline;color:#272033;font-size:inherit;}

.pathway-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:16px;}
.pathway-item{border:1px solid rgba(123,44,255,.13);border-radius:20px;padding:18px;background:linear-gradient(180deg,#fff,#fcfaff);box-shadow:0 14px 38px rgba(39,32,51,.045);}
.pathway-item span{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:12px;background:#f1e9ff;color:#7b2cff;font-weight:800;font-size:.8rem;margin-bottom:12px;}
.pathway-item p{margin:0;color:#4f465e;line-height:1.45;font-size:.94rem;}

@media (max-width: 980px){
  .journey-layout.has-intelligence,
  .map-panel,
  .dependency-map,
  .coverage-lens{grid-template-columns:1fr !important;}
  .live-map-card{position:relative;top:auto;}
  .timeline-grid,.pathway-list,.map-spokes{grid-template-columns:1fr;}
  .map-core{width:140px;height:140px;}
}
