
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Manrope:wght@400;500;600;700;800&family=Playfair+Display:wght@600;700;800&display=swap');
:root{
  --paper:#f7f2ea; --paper2:#efe7da; --card:#fffaf2; --ink:#18363a; --muted:#6d7470;
  --petrol:#0f3f46; --petrol2:#0a2c31; --sugar:#9fb8bf; --sugar2:#d8e5e7; --taupe:#c6b59f;
  --gold:#b89562; --rose:#efe0d5; --ok:#2f7a65; --warn:#a96c2b; --bad:#9f3a3a;
  --line:rgba(24,54,58,.16); --shadow:0 24px 70px rgba(15,63,70,.13); --radius:26px;
  --head:'Playfair Display', Georgia, serif; --brand:'Cinzel', Georgia, serif; --body:'Manrope','Avenir Next','Trebuchet MS',sans-serif;
}
*{box-sizing:border-box} body{margin:0;background:radial-gradient(circle at top left,#e8f0f1 0,#f7f2ea 35%,#efe6d7 100%);color:var(--ink);font-family:var(--body);line-height:1.5;min-height:100vh} a{color:inherit;text-decoration:none} button,input,textarea,select{font:inherit} .hidden{display:none!important}
.praisi-shell{display:grid;grid-template-columns:292px minmax(0,1fr);min-height:100vh}.praisi-sidebar{position:sticky;top:0;height:100vh;padding:26px 18px;background:linear-gradient(165deg,#0a2c31,#123f45 54%,#6f6456);color:#fff;overflow:auto;box-shadow:12px 0 40px rgba(15,63,70,.15)}
.brand-block{display:flex;gap:12px;align-items:center;padding:10px 10px 28px}.brand-mark{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--sugar),#fff4db);display:grid;place-items:center;color:var(--petrol);font-family:var(--brand);font-weight:700;box-shadow:0 12px 30px rgba(0,0,0,.17)}.brand-name{font-family:var(--brand);font-size:22px;letter-spacing:.11em;text-transform:uppercase}.brand-sub{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.62)}
.nav-section{margin:14px 0 8px;padding:0 12px;font-family:var(--brand);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.54)}.side-nav{display:grid;gap:5px}.side-nav a,.logout-link{display:flex;align-items:center;gap:10px;padding:12px 13px;border-radius:17px;color:rgba(255,255,255,.82);font-weight:700;font-size:14px;border:1px solid transparent;background:transparent;cursor:pointer;text-align:left}.side-nav a:hover,.logout-link:hover{background:rgba(255,255,255,.1);color:#fff}.side-nav a.active{background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,.08));border-color:rgba(255,255,255,.22);color:#fff}.nav-icon{width:22px;text-align:center;opacity:.9}.sidebar-footer{margin-top:24px;padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:22px;background:rgba(255,255,255,.09);font-size:12px;color:rgba(255,255,255,.7)}
.praisi-main{padding:26px 34px 60px;min-width:0}.topbar{display:flex;align-items:center;gap:18px;justify-content:space-between;margin-bottom:26px}.mobile-brand{display:none}.top-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.user-chip{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:rgba(255,250,242,.72);box-shadow:0 10px 24px rgba(15,63,70,.06)}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--petrol),var(--sugar));color:#fff;display:grid;place-items:center;font-family:var(--brand);font-size:12px}.user-meta{font-size:12px;color:var(--muted)}.user-meta strong{display:block;color:var(--ink);font-size:13px}.page-hero{border:1px solid var(--line);border-radius:34px;background:linear-gradient(135deg,rgba(255,250,242,.95),rgba(216,229,231,.78));padding:34px;box-shadow:var(--shadow);position:relative;overflow:hidden;margin-bottom:24px}.page-hero:after{content:"";position:absolute;right:-80px;top:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(184,149,98,.28),transparent 65%)}.eyebrow{font-family:var(--brand);letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:700;font-size:12px}.page-hero h1,.page-title{font-family:var(--head);font-size:clamp(34px,4vw,58px);line-height:.96;margin:10px 0 12px;color:var(--petrol2)}.page-hero p{font-size:17px;max-width:760px;color:#4e5d5b;margin:0}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 18px;border-radius:999px;border:1px solid var(--line);background:#fffaf2;color:var(--ink);font-weight:800;cursor:pointer}.btn-primary{background:linear-gradient(135deg,var(--petrol),#245e66);color:#fff;border-color:transparent;box-shadow:0 16px 35px rgba(15,63,70,.22)}.btn-secondary{background:rgba(255,250,242,.75)}.btn-danger{background:#fff0ee;color:var(--bad);border-color:rgba(159,58,58,.25)}
.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:rgba(255,250,242,.88);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:0 18px 50px rgba(15,63,70,.08)}.card h2,.card h3{font-family:var(--head);font-size:28px;line-height:1.05;margin:0 0 10px;color:var(--petrol)}.card h3{font-size:23px}.card p{color:var(--muted);margin:0 0 12px}.stat-num,.metric-val,.stat-val,.kpi-val,.score-number,.score-val{font-family:var(--brand);font-size:34px;color:var(--petrol);font-weight:700}.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:var(--sugar2);font-size:12px;font-weight:800;color:var(--petrol)}
.form-grid{display:grid;gap:14px}.field label{display:block;font-weight:800;margin-bottom:7px}.input, input, textarea, select{width:100%;border:1px solid var(--line);background:#fffdf8;border-radius:18px;padding:13px 15px;color:var(--ink);outline:none}textarea{min-height:110px;resize:vertical}.message,.security-message{margin-top:12px;border-radius:16px;padding:12px 14px;background:#eef6f7;color:var(--petrol);font-weight:700}.message.ok,.security-message.success{background:#ecf7f1;color:var(--ok)}.message.err,.security-message.error{background:#fff0ee;color:var(--bad)}.message.info{background:#eef6f7;color:var(--petrol)}
table{width:100%;border-collapse:separate;border-spacing:0 10px}th{text-align:left;font-family:var(--brand);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:0 12px}td{background:#fffdf8;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 12px}td:first-child{border-left:1px solid var(--line);border-radius:16px 0 0 16px}td:last-child{border-right:1px solid var(--line);border-radius:0 16px 16px 0}.empty{padding:22px;border-radius:20px;background:#fffdf8;border:1px dashed var(--line);color:var(--muted)}
.sessions-card{margin-top:18px}.sessions-list{display:grid;gap:10px}.session-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fffdf8}.session-row p{margin:4px 0 0;font-size:13px}.session-row .btn{flex:0 0 auto}
.scan-hero,.scan-progress,.results{background:rgba(255,250,242,.9);border:1px solid var(--line);border-radius:30px;padding:26px;box-shadow:0 18px 50px rgba(15,63,70,.08);margin-bottom:18px}.scan-title,.results-title{font-family:var(--brand);letter-spacing:.13em;color:var(--petrol);font-size:15px}.scan-sub,.results-meta{color:var(--muted);margin-top:6px}.scan-input-row{display:flex;gap:12px;margin:22px 0}.scan-input{height:56px}.scan-options{display:flex;gap:10px;flex-wrap:wrap}.scan-opt{background:#fffdf8;border:1px solid var(--line);padding:10px 12px;border-radius:999px;font-size:13px}.scan-progress{display:none}.scan-progress.visible{display:block}.prog-steps{display:grid;gap:8px;margin:20px 0}.prog-step{display:flex;gap:10px;align-items:center;color:var(--muted)}.prog-step-icon{width:28px;height:28px;border-radius:50%;background:var(--sugar2);display:grid;place-items:center;font-weight:800}.prog-step.active,.prog-step.done{color:var(--petrol);font-weight:800}.prog-track{height:10px;border-radius:999px;background:#e4ddd2;overflow:hidden}.prog-fill{height:100%;background:linear-gradient(90deg,var(--petrol),var(--sugar));transition:.35s}.results{display:none}.results.visible{display:block}.score-row{display:grid;grid-template-columns:230px 1fr;gap:18px;margin-top:18px}.score-ring{position:relative;width:120px;height:120px}.score-ring svg{transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:#e5ddd2;stroke-width:10}.score-ring-fill{fill:none;stroke:var(--petrol);stroke-width:10;stroke-linecap:round}.score-num{position:absolute;inset:0;display:grid;place-items:center}.ct-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:13px;border:1px solid var(--line);border-radius:17px;background:#fffdf8;margin-bottom:8px;cursor:pointer}.ct-row.active-metric{border-color:var(--petrol);background:#edf5f6}.issue-item,.finding-item{padding:14px;border:1px solid var(--line);border-radius:18px;background:#fffdf8;margin-bottom:10px}.issue-title,.finding-title{font-weight:900;color:var(--petrol)}.issue-desc,.finding-meta{color:var(--muted);font-size:13px}.issue-badge{border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800}.ib-crit{background:#fff0ee;color:var(--bad)}.ib-warn{background:#fff7e8;color:var(--warn)}.ib-ok{background:#ecf7f1;color:var(--ok)}
.banner-preview{border:1px solid var(--line);background:linear-gradient(135deg,#102f35,#1d555d);color:#fff;border-radius:28px;padding:24px}.banner-preview h3{color:#fff}.banner-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.banner-actions button{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:10px 14px}.donut{width:190px;height:190px;border-radius:50%;background:conic-gradient(var(--petrol) 0 72%, var(--taupe) 72% 86%, var(--rose) 86% 100%);display:grid;place-items:center;margin:auto}.donut>div{width:122px;height:122px;border-radius:50%;background:var(--card);display:grid;place-items:center}.bars-wrap{display:flex;gap:10px;align-items:end;height:170px}.bar-g{display:grid;gap:8px;place-items:center;flex:1}.bar-stack{height:130px;width:24px;border-radius:999px;background:#e3dbcf;display:flex;flex-direction:column-reverse;overflow:hidden}.bar-a{background:var(--petrol);width:100%}.bar-r{background:var(--taupe);width:100%}.bar-lbl{font-size:11px;color:var(--muted)}
.bottom-nav{display:none}.gate-body{display:grid;place-items:center;min-height:100vh;padding:24px}.gate-card{width:min(560px,100%);background:rgba(255,250,242,.94);border:1px solid var(--line);border-radius:34px;padding:38px;box-shadow:var(--shadow)}.gate-brand{display:flex;align-items:center;gap:12px;font-family:var(--brand);letter-spacing:.12em;text-transform:uppercase;font-size:22px}.gate-card h1{font-family:var(--head);font-size:48px;line-height:.98;color:var(--petrol);margin:20px 0 12px}.gate-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.gate-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;min-height:46px;padding:0 18px;font-weight:800;border:1px solid var(--line);background:#fffdf8}.gate-btn.primary{background:var(--petrol);color:#fff;border:0}
@media(max-width:1050px){.praisi-shell{grid-template-columns:1fr}.praisi-sidebar{display:none}.praisi-main{padding:18px 16px 86px}.mobile-brand{display:flex;align-items:center;gap:10px}.topbar{position:sticky;top:0;z-index:20;background:rgba(247,242,234,.88);backdrop-filter:blur(18px);padding:10px 0}.grid-2,.grid-3,.grid-4,.score-row{grid-template-columns:1fr}.bottom-nav{position:fixed;bottom:12px;left:12px;right:12px;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;border:1px solid var(--line);background:rgba(255,250,242,.9);backdrop-filter:blur(16px);border-radius:24px;padding:8px;z-index:50;box-shadow:0 18px 40px rgba(15,63,70,.18)}.bottom-nav a{display:grid;place-items:center;gap:2px;font-size:18px;color:var(--muted);font-weight:800}.bottom-nav span{font-size:10px}.bottom-nav a.active{color:var(--petrol)}.scan-input-row{flex-direction:column}.page-hero{padding:26px}.gate-card{padding:28px}.gate-card h1{font-size:38px}}
.gate-brand-full{display:flex;align-items:center;justify-content:flex-start;letter-spacing:0;text-transform:none}.gate-logo-full{display:block;width:min(270px,72vw);height:auto;object-fit:contain}.gate-brand-full .gate-logo-full{filter:none!important}
.gate-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--muted);font-weight:800}.gate-divider::before,.gate-divider::after{content:"";height:1px;flex:1;background:var(--line)}.gate-google{width:100%;gap:10px;background:#fff;color:var(--petrol);text-decoration:none}.gate-google span{display:inline-grid;width:22px;height:22px;place-items:center;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:900}.gate-consent{display:flex;align-items:flex-start;gap:10px;margin-top:4px;color:var(--muted);font-size:13px;line-height:1.45}.gate-consent input{margin-top:3px;min-width:18px}.gate-consent a{font-weight:850;color:var(--petrol)}.gate-footer{width:min(560px,100%);margin:18px auto 0;text-align:center;color:var(--muted);font-size:13px;line-height:1.55}.gate-footer strong{display:block;color:var(--petrol);margin-bottom:4px}.gate-body{align-content:center}.gate-card+.gate-footer{align-self:start}
@media(max-width:1050px){.gate-body{text-align:center}.gate-card{text-align:left}.gate-brand-full{justify-content:center}.gate-actions{justify-content:center}.gate-footer{text-align:center;padding:0 16px}.gate-google{justify-content:center}.gate-consent{text-align:left}}

.two-factor-qr{width:220px;height:220px;display:block;margin:0 0 16px;padding:12px;border:1px solid var(--line);border-radius:18px;background:#fffdf8}\n

/* App shell cleanup: remove duplicated top bar and move account controls into sidebar */
.praisi-shell .topbar,
.praisi-shell header.topbar,
.praisi-main > .topbar,
.account-main > .topbar,
.app-main > .topbar {
  display: none !important;
}

.praisi-main {
  padding-top: 34px;
}

.praisi-sidebar .brand-block,
.account-sidebar .brand-block,
.app-sidebar .brand-block,
.sidebar .brand-block {
  padding: 8px 10px 14px !important;
  margin: 0 0 8px;
}

.praisi-sidebar-account {
  position: relative;
  margin: 0 0 16px;
  padding: 0 2px;
}

.praisi-account-trigger {
  width: 100%;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 11px;
  padding: 11px 10px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.055)),
    rgba(255,255,255,.07);
  color: #fff;
  box-shadow: 0 18px 38px rgba(0,0,0,.16);
  cursor: pointer;
  text-align: left;
}

.praisi-account-trigger:hover,
.praisi-sidebar-account.is-open .praisi-account-trigger {
  border-color: rgba(255,255,255,.28);
  background:
    linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,.08)),
    rgba(255,255,255,.09);
}

.praisi-account-avatar {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  background: linear-gradient(135deg, #fff7dc, #9fb8bf);
  color: #0a2c31;
  font-family: var(--brand);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75), 0 12px 28px rgba(0,0,0,.18);
}

.praisi-account-copy {
  min-width: 0;
  display: grid;
  gap: 1px;
}

.praisi-account-copy strong {
  color: #fff !important;
  font-size: 13px;
  line-height: 1.15;
  font-weight: 900;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.praisi-account-role {
  color: rgba(255,255,255,.72);
  font-size: 10px;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.praisi-account-copy small {
  color: rgba(255,255,255,.62);
  font-size: 11px;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.praisi-account-caret {
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(255,255,255,.7);
  border-bottom: 2px solid rgba(255,255,255,.7);
  transform: rotate(45deg);
  transition: transform .18s ease;
}

.praisi-sidebar-account.is-open .praisi-account-caret {
  transform: rotate(-135deg);
}

.praisi-account-panel {
  display: none;
  margin: 8px 0 0;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  background: rgba(7, 31, 36, .46);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}

.praisi-sidebar-account.is-open .praisi-account-panel {
  display: grid;
  gap: 4px;
}

.praisi-account-panel-link {
  min-height: 38px;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 9px;
  border-radius: 14px;
  color: #ffffff !important;
  font-size: 13px;
  font-weight: 800;
}

.praisi-account-panel-link:hover,
.praisi-account-panel-link.active {
  background: rgba(255,255,255,.11);
  color: #ffffff !important;
}

.praisi-account-panel-link span,
.praisi-account-panel-link strong,
.praisi-account-panel-link .praisi-account-panel-icon {
  color: #ffffff !important;
}

.praisi-account-panel-icon {
  flex: 0 0 26px;
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(255,255,255,.09);
  color: #fff;
}

.praisi-account-panel-icon svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
  display: block;
}

@media(max-width:1050px){
  .praisi-main {
    padding-top: 18px;
  }
}

/* Unified internal navigation - premium grouped menu */
.praisi-sidebar .brand-block,
.account-sidebar .brand-block,
.app-sidebar .brand-block,
.sidebar .brand-block{
  padding-bottom:18px;
}
.praisi-nav-wrap{
  display:grid;
  gap:8px;
}
.praisi-nav-group{
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:rgba(255,255,255,.045);
  overflow:hidden;
}
.praisi-nav-group[open]{
  background:rgba(255,255,255,.07);
}
.praisi-nav-group summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:42px;
  padding:0 12px;
  cursor:pointer;
  list-style:none;
  color:rgba(255,255,255,.70);
  font-family:var(--brand);
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.praisi-nav-group summary::-webkit-details-marker{
  display:none;
}
.praisi-nav-group summary:after{
  content:"";
  width:7px;
  height:7px;
  border-right:1.8px solid currentColor;
  border-bottom:1.8px solid currentColor;
  transform:rotate(45deg);
  transition:transform .18s ease;
  opacity:.8;
}
.praisi-nav-group[open] summary:after{
  transform:rotate(-135deg);
}
.praisi-nav-group .side-nav{
  padding:0 7px 8px;
  gap:4px;
}
.praisi-sidebar .praisi-nav-link,
.account-sidebar .praisi-nav-link,
.app-sidebar .praisi-nav-link,
.sidebar .praisi-nav-link{
  min-height:42px;
  border-radius:15px;
  padding:10px 11px;
  gap:11px;
}
.praisi-sidebar .nav-icon,
.account-sidebar .nav-icon,
.app-sidebar .nav-icon,
.sidebar .nav-icon{
  flex:0 0 28px;
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.13);
  border-radius:11px;
  background:rgba(255,255,255,.08);
  color:#fff;
  opacity:1;
}
.praisi-sidebar .nav-icon svg,
.account-sidebar .nav-icon svg,
.app-sidebar .nav-icon svg,
.sidebar .nav-icon svg{
  width:15px;
  height:15px;
  fill:currentColor;
  display:block;
}
.praisi-sidebar .nav-label,
.account-sidebar .nav-label,
.app-sidebar .nav-label,
.sidebar .nav-label{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.praisi-sidebar .praisi-nav-link:hover .nav-icon,
.praisi-sidebar .praisi-nav-link.active .nav-icon,
.account-sidebar .praisi-nav-link:hover .nav-icon,
.account-sidebar .praisi-nav-link.active .nav-icon,
.app-sidebar .praisi-nav-link:hover .nav-icon,
.app-sidebar .praisi-nav-link.active .nav-icon,
.sidebar .praisi-nav-link:hover .nav-icon,
.sidebar .praisi-nav-link.active .nav-icon{
  background:linear-gradient(135deg,rgba(216,229,231,.30),rgba(184,149,98,.24));
  border-color:rgba(255,255,255,.28);
}
.praisi-sidebar .logout-link.praisi-nav-link,
.account-sidebar .logout-link.praisi-nav-link,
.app-sidebar .logout-link.praisi-nav-link,
.sidebar .logout-link.praisi-nav-link{
  width:100%;
  margin-top:14px;
}
.bottom-nav .bottom-icon{
  display:grid;
  place-items:center;
  width:21px;
  height:21px;
}
.bottom-nav .bottom-icon svg{
  width:18px;
  height:18px;
  fill:currentColor;
}
@media(max-width:1050px){
  .bottom-nav{
    grid-template-columns:repeat(5,minmax(0,1fr));
  }
  .bottom-nav a{
    min-width:0;
  }
}
html.praisi-auth-checking body{visibility:hidden!important}


.praisi-nav-link.is-locked,
.bottom-nav a.is-locked,
.praisi-account-panel-link.is-locked {
  opacity: .42;
  cursor: not-allowed;
  filter: grayscale(.25);
}

.praisi-nav-link.is-locked .nav-label::after,
.bottom-nav a.is-locked span::after,
.praisi-account-panel-link.is-locked span:last-child::after {
  content: " · piano superiore";
  font-size: 11px;
  font-weight: 700;
  color: rgba(218, 171, 76, .95);
}
