/* =========================================================
   UAlberta Portal - design system
   ========================================================= */

:root{
  --uap-sidebar:#1f3d37;
  --uap-sidebar-hover:#284c44;
  --uap-accent:#26675c;
  --uap-accent-dark:#184a41;
  --uap-accent-soft:#e6efec;
  --uap-bg:#f4f6f5;
  --uap-surface:#ffffff;
  --uap-border:#e5ebe8;
  --uap-text:#1b2f2c;
  --uap-text-muted:#6b7f79;
  --uap-text-subtle:#94a5a0;
  --uap-danger:#d64545;
  --uap-warning:#c47a1f;
  --uap-success:#26675c;
  --uap-radius:14px;
  --uap-radius-sm:10px;
  --uap-shadow:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
}

/* Reset + fullpage takeover */
html.uap-standalone-html,body.uap-standalone{margin:0;padding:0;background:var(--uap-bg)}
body.uap-portal-page{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--uap-text);background:var(--uap-bg);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;margin:0;
}
/* When the theme still wraps the shortcode, force it to escape the constrained layout. */
body.uap-portal-page .site-header,
body.uap-portal-page .site-footer,
body.uap-portal-page .wp-site-blocks > header,
body.uap-portal-page .wp-site-blocks > footer,
body.uap-portal-page .entry-title,
body.uap-portal-page .entry-header,
body.uap-portal-page .wp-block-post-title,
body.uap-portal-page .wp-block-template-part,
body.uap-portal-page .wp-block-site-title{display:none!important}
body.uap-portal-page .wp-site-blocks,
body.uap-portal-page .wp-block-group,
body.uap-portal-page .entry-content,
body.uap-portal-page .wp-block-post-content,
body.uap-portal-page .site-main,
body.uap-portal-page .site-content,
body.uap-portal-page main{
  margin:0!important;padding:0!important;max-width:none!important;width:100%!important;
  background:var(--uap-bg)!important;
}
body.uap-portal-page .wp-block-post-content > *{max-width:none!important}
body.uap-portal-page .is-layout-constrained > *{max-width:none!important;margin-left:0!important;margin-right:0!important}

.uap-app{
  display:grid;
  grid-template-columns:260px 1fr;
  grid-template-rows:72px 1fr;
  min-height:100vh;
}
.uap-app *{box-sizing:border-box}
.uap-app a{color:inherit;text-decoration:none}
.uap-app button{font-family:inherit;cursor:pointer;border:0;background:none}
.uap-app h1,.uap-app h2,.uap-app h3,.uap-app h4{margin:0;line-height:1.2;color:var(--uap-text)}
.uap-app p{margin:0}

/* ===== Topbar ===== */
.uap-topbar{
  grid-column:1/3;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;background:var(--uap-surface);
  border-bottom:1px solid var(--uap-border);
  position:sticky;top:0;z-index:20;
}
.uap-brand{display:flex;align-items:center;gap:14px}
.uap-brand-logo{height:40px;width:auto;display:block}
.uap-brand-divider{width:1px;height:28px;background:var(--uap-border)}
.uap-brand-sub{font-size:11px;color:var(--uap-text-muted);letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.uap-top-actions{display:flex;align-items:center;gap:16px}
.uap-bell{
  width:40px;height:40px;border-radius:10px;
  display:grid;place-items:center;position:relative;
  transition:background .15s;color:var(--uap-text);
}
.uap-bell:hover{background:var(--uap-accent-soft)}
.uap-bell .uap-dot{
  position:absolute;top:10px;right:11px;
  width:8px;height:8px;background:var(--uap-danger);
  border-radius:50%;border:2px solid #fff;
}
.uap-user-wrap{position:relative}
.uap-user{
  display:flex;align-items:center;gap:10px;
  padding:6px 10px 6px 6px;border-radius:10px;
  transition:background .15s;color:var(--uap-text);
  cursor:pointer;background:transparent;font-family:inherit;
}
.uap-user:hover{background:var(--uap-accent-soft)}
.uap-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--uap-accent);color:#fff;
  display:grid;place-items:center;font-weight:600;font-size:13px;
  object-fit:cover;
}
.uap-user-name{font-weight:600;font-size:14px}
.uap-user svg{color:var(--uap-text-muted);transition:transform .15s}
.uap-user-wrap.is-open .uap-user svg:last-child{transform:rotate(180deg)}

.uap-user-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  min-width:240px;background:#fff;
  border:1px solid var(--uap-border);
  border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.12);
  padding:8px;display:none;z-index:30;
}
.uap-user-wrap.is-open .uap-user-menu{display:block}
.uap-user-menu-head{
  padding:10px 12px 12px;
  border-bottom:1px solid var(--uap-border);
  margin-bottom:6px;
}
.uap-user-menu-name{display:block;font-weight:600;color:var(--uap-text);font-size:14px}
.uap-user-menu-mail{display:block;color:var(--uap-text-muted);font-size:12.5px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uap-user-menu a{
  display:flex!important;align-items:center;gap:10px;
  padding:10px 12px;border-radius:8px;
  font-size:14px;color:var(--uap-text);text-decoration:none;
  transition:background .12s,color .12s;
}
.uap-user-menu a:hover{background:var(--uap-accent-soft);color:var(--uap-accent)}
.uap-user-menu a svg{color:var(--uap-text-muted);flex:none}
.uap-user-menu a:hover svg{color:var(--uap-accent)}
.uap-user-menu-sep{height:1px;background:var(--uap-border);margin:6px 0}
.uap-user-menu-logout{color:#c43d3d!important}
.uap-user-menu-logout svg{color:#c43d3d!important}
.uap-user-menu-logout:hover{background:#fbe9e9!important;color:#8a2424!important}
.uap-user-menu-logout:hover svg{color:#8a2424!important}

/* ===== Sidebar ===== */
.uap-sidebar{
  background:var(--uap-sidebar);color:#d6e3df;
  padding:24px 16px;
  display:flex;flex-direction:column;
  position:sticky;top:72px;height:calc(100vh - 72px);
}
.uap-sidebar-label{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:#8fb0a7;padding:4px 12px 16px;
}
.uap-nav{display:flex;flex-direction:column;gap:4px}
.uap-nav a{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:10px;
  font-weight:500;font-size:14px;color:#cfdedb;
  transition:background .15s,color .15s;
}
.uap-nav a svg{flex:none;opacity:.9}
.uap-nav a:hover{background:var(--uap-sidebar-hover);color:#fff}
.uap-nav a.is-active{
  background:#fff;color:var(--uap-accent-dark);font-weight:600;
  box-shadow:0 1px 2px rgba(0,0,0,.08);
}
.uap-nav a.is-active svg{color:var(--uap-accent-dark);opacity:1}
.uap-badge{
  margin-left:auto;background:var(--uap-accent);color:#fff;
  font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;min-width:20px;text-align:center;
}
.uap-nav a.is-active .uap-badge{background:var(--uap-accent)}
.uap-sidebar-bottom{
  margin-top:auto;display:flex;flex-direction:column;gap:2px;
  padding-top:16px;border-top:1px solid rgba(255,255,255,.08);
}
.uap-sidebar-bottom a{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;border-radius:10px;
  color:#aabfba;font-size:13.5px;transition:background .15s,color .15s;
}
.uap-sidebar-bottom a:hover{background:var(--uap-sidebar-hover);color:#fff}

/* ===== Main ===== */
.uap-main{
  padding:28px 40px 40px;max-width:1320px;margin:0 auto;width:100%;
}
.uap-grid{display:grid;gap:20px}
.uap-grid-top{grid-template-columns:minmax(0,1fr) minmax(0,1.35fr)}
.uap-grid-bottom{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:20px}
.uap-grid-msgs{grid-template-columns:minmax(0,360px) minmax(0,1fr)}

/* ===== Card ===== */
.uap-card{
  background:var(--uap-surface);
  border:1px solid var(--uap-border);
  border-radius:var(--uap-radius);
  padding:28px;box-shadow:var(--uap-shadow);
}
.uap-card-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;gap:12px;
}
.uap-card-title{
  font-size:16px;font-weight:600;margin:0;
  display:flex;align-items:center;gap:10px;
}
.uap-card-title svg{color:var(--uap-accent)}
.uap-card-foot{
  text-align:center;border-top:1px solid var(--uap-border);
  margin-top:20px;padding-top:16px;
}
.uap-card-foot a{color:var(--uap-accent);font-weight:500;font-size:13px}
.uap-card-foot a:hover{color:var(--uap-accent-dark)}

/* ===== Greeting ===== */
.uap-hello{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center}
.uap-hello h1{font-size:26px;font-weight:700;letter-spacing:-.01em;margin:0 0 10px}
.uap-hello p{color:var(--uap-text-muted);max-width:32ch;font-size:14px}
.uap-hello-illus{
  width:170px;height:150px;flex:none;
  background:linear-gradient(180deg,#f1f6f4 0%,#e6efec 100%);
  border-radius:12px;display:grid;place-items:center;
}

/* ===== Progress ===== */
.uap-progress-head h2{font-size:18px;font-weight:600;margin:0 0 4px}
.uap-progress-head .uap-sub{color:var(--uap-text-muted);font-size:13px}
.uap-steps{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  margin:28px 0 20px;position:relative;
}
.uap-step{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:2}
.uap-step-dot{
  width:36px;height:36px;border-radius:50%;
  background:#fff;border:2px solid var(--uap-border);
  display:grid;place-items:center;
  font-size:13px;font-weight:600;color:var(--uap-text-subtle);
  transition:all .15s;
}
.uap-step.is-done .uap-step-dot{background:var(--uap-accent);border-color:var(--uap-accent);color:#fff}
.uap-step.is-active .uap-step-dot{background:var(--uap-accent);border-color:var(--uap-accent);color:#fff;box-shadow:0 0 0 4px var(--uap-accent-soft)}
.uap-step-label{font-size:12px;font-weight:500;color:var(--uap-text-muted);text-align:center;line-height:1.3}
.uap-step.is-done .uap-step-label,.uap-step.is-active .uap-step-label{color:var(--uap-text)}
.uap-step.is-active .uap-step-label{color:var(--uap-accent)}
.uap-step-date{font-size:11px;color:var(--uap-text-subtle)}
.uap-steps::before{
  content:"";position:absolute;top:18px;left:10%;right:10%;
  height:2px;background:var(--uap-border);z-index:1;
}
.uap-steps::after{
  content:"";position:absolute;top:18px;left:10%;
  height:2px;background:var(--uap-accent);z-index:1;
  width:var(--progress,0%);transition:width .3s;
}
.uap-progress-info{
  display:flex;align-items:center;gap:12px;
  background:var(--uap-accent-soft);border-radius:var(--uap-radius-sm);
  padding:14px 16px;color:var(--uap-accent-dark);font-size:13.5px;
}
.uap-progress-info svg{flex:none;color:var(--uap-accent)}

/* ===== Docs ===== */
.uap-doc-intro{
  display:flex;align-items:flex-start;gap:8px;
  font-size:12.5px;color:var(--uap-text-muted);margin-bottom:16px;
}
.uap-doc-list{display:flex;flex-direction:column;gap:10px}
.uap-doc-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border:1px solid var(--uap-border);
  border-radius:var(--uap-radius-sm);
  transition:border-color .15s,background .15s;
}
.uap-doc-row:hover{border-color:var(--uap-accent);background:#fafcfb}
.uap-doc-icon{
  width:36px;height:36px;flex:none;border-radius:8px;
  background:var(--uap-accent-soft);color:var(--uap-accent);
  display:grid;place-items:center;
}
.uap-doc-body{flex:1;min-width:0}
.uap-doc-name{font-weight:600;font-size:13.5px;margin:0 0 2px;display:flex;align-items:center;gap:8px}
.uap-doc-desc{font-size:12px;color:var(--uap-text-muted);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uap-status{
  font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:600;
  letter-spacing:.02em;text-transform:uppercase;
}
.uap-status-en_attente{background:#fff5e6;color:#a8640e}
.uap-status-valide{background:var(--uap-accent-soft);color:var(--uap-accent)}
.uap-status-refuse{background:#fbe9e9;color:var(--uap-danger)}

.uap-app .uap-btn,
.uap-app button.uap-btn,
.uap-app a.uap-btn{
  padding:8px 16px!important;border-radius:8px!important;font-weight:500!important;font-size:13px!important;
  display:inline-flex!important;align-items:center!important;gap:6px!important;white-space:nowrap!important;
  transition:all .15s!important;border:1px solid transparent!important;
  cursor:pointer!important;text-decoration:none!important;font-family:inherit!important;
}
.uap-app .uap-btn-primary{background:#26675c!important;background-color:#26675c!important;color:#ffffff!important;border-color:#26675c!important}
.uap-app .uap-btn-primary *{color:#ffffff!important;stroke:#ffffff!important}
.uap-app .uap-btn-primary:hover{background:#184a41!important;background-color:#184a41!important;border-color:#184a41!important}
.uap-app .uap-btn-outline{background:#ffffff!important;color:#1b2f2c!important;border-color:#e5ebe8!important}
.uap-app .uap-btn-outline:hover{border-color:#26675c!important;color:#26675c!important}
.uap-app .uap-btn-ghost{background:transparent!important;color:#6b7f79!important;border-color:transparent!important}
.uap-app .uap-btn-ghost:hover{background:#e6efec!important;color:#26675c!important}
.uap-app .uap-btn-dark{background:#132a25!important;background-color:#132a25!important;color:#ffffff!important;border-color:#132a25!important}
.uap-app .uap-btn-dark *{color:#ffffff!important;stroke:#ffffff!important}
.uap-app .uap-btn-dark:hover{background:#1f3d37!important;background-color:#1f3d37!important;border-color:#1f3d37!important}
.uap-app .uap-btn[disabled]{opacity:.6;cursor:not-allowed}

.uap-doc-note{
  display:flex;align-items:center;gap:8px;
  margin-top:16px;padding-top:14px;border-top:1px solid var(--uap-border);
  font-size:12px;color:var(--uap-text-muted);
}

/* ===== Messagerie ===== */
.uap-msg-list{display:flex;flex-direction:column;gap:2px}
.uap-msg-item{
  padding:14px 0;border-bottom:1px solid var(--uap-border);
  display:block;
}
.uap-msg-item:last-child{border-bottom:0}
.uap-msg-item.is-open{background:var(--uap-accent-soft);border-radius:8px;padding:14px}
.uap-msg-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.uap-msg-from{font-size:12px;color:var(--uap-text-muted);font-weight:500}
.uap-msg-time{font-size:12px;color:var(--uap-text-subtle)}
.uap-msg-subject{font-weight:600;font-size:14px;margin:0 0 4px;display:flex;align-items:center;gap:8px}
.uap-msg-subject .uap-unread{width:8px;height:8px;background:var(--uap-accent);border-radius:50%;flex:none}
.uap-msg-excerpt{font-size:12.5px;color:var(--uap-text-muted);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.uap-thread-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding-bottom:16px;border-bottom:1px solid var(--uap-border);margin-bottom:16px;
}
.uap-thread-date{font-size:12px;color:var(--uap-text-subtle)}
.uap-thread-body{display:flex;flex-direction:column;gap:14px;max-height:480px;overflow-y:auto;padding-right:4px}
.uap-bubble{
  background:#fafcfb;border:1px solid var(--uap-border);
  border-radius:12px;padding:14px 16px;
}
.uap-bubble.is-me{background:var(--uap-accent-soft);border-color:#c9dcd6;align-self:flex-end;max-width:85%}
.uap-bubble-head{display:flex;gap:10px;align-items:center;margin-bottom:6px;font-size:12px;color:var(--uap-text-muted)}
.uap-bubble-from{font-weight:600;color:var(--uap-text)}
.uap-bubble-body{font-size:14px;line-height:1.55}
.uap-bubble-body p{margin:0 0 8px}
.uap-bubble-body p:last-child{margin:0}
.uap-thread-reply{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.uap-thread-reply textarea{
  width:100%;border:1px solid var(--uap-border);border-radius:8px;
  padding:12px 14px;font:inherit;resize:vertical;
}
.uap-thread-reply textarea:focus{outline:none;border-color:var(--uap-accent)}
.uap-thread-reply button{align-self:flex-end}

.uap-empty-text{color:var(--uap-text-muted);font-size:13.5px;padding:20px 0;text-align:center}
.uap-empty-cta{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:28px 16px;text-align:center;
}
.uap-empty-cta svg{color:#b5c8c3}
.uap-empty-cta p{color:var(--uap-text-muted);font-size:13.5px;margin:0}
.uap-empty-center{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:60px 20px;color:var(--uap-text-muted);text-align:center;
}
.uap-empty-center svg{color:var(--uap-border)}

/* ===== School files ===== */
.uap-file-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border:1px solid var(--uap-border);
  border-radius:var(--uap-radius-sm);margin-bottom:10px;
  transition:border-color .15s,background .15s;
}
.uap-file-row:hover{border-color:var(--uap-accent);background:#fafcfb}
.uap-file-icon{
  width:36px;height:44px;flex:none;border-radius:6px;
  background:var(--uap-accent-soft);color:var(--uap-accent);
  display:grid;place-items:center;position:relative;
}
.uap-file-icon::after{
  content:"PDF";position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  font-size:8px;font-weight:700;letter-spacing:.04em;
}
.uap-file-body{flex:1;min-width:0}
.uap-file-name{font-weight:600;font-size:13.5px;margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uap-file-meta{font-size:12px;color:var(--uap-text-muted);margin:0}
.uap-file-dl{
  width:36px;height:36px;border-radius:8px;border:1px solid var(--uap-border);
  display:grid;place-items:center;color:var(--uap-text-muted);
  transition:all .15s;
}
.uap-file-dl:hover{border-color:var(--uap-accent);color:var(--uap-accent);background:var(--uap-accent-soft)}

/* ===== Timeline (suivi) ===== */
.uap-timeline{margin-top:32px;padding-top:24px;border-top:1px solid var(--uap-border);display:flex;flex-direction:column;gap:18px}
.uap-timeline-item{
  padding:16px 20px;border:1px solid var(--uap-border);border-radius:var(--uap-radius-sm);
}
.uap-timeline-item.is-done{background:#fafcfb;border-left:3px solid var(--uap-accent)}
.uap-timeline-item.is-active{border-left:3px solid var(--uap-accent);background:var(--uap-accent-soft)}
.uap-timeline-item.is-future{opacity:.55}
.uap-timeline-item h4{font-size:14.5px;margin:0 0 6px}
.uap-timeline-text{font-size:13px;color:var(--uap-text-muted);margin:0}

/* ===== Profil ===== */
.uap-profile{display:grid;grid-template-columns:180px 1fr;gap:12px 24px;margin-bottom:24px}
.uap-profile dt{font-size:12px;color:var(--uap-text-muted);letter-spacing:.04em;text-transform:uppercase;padding:6px 0}
.uap-profile dd{font-size:14px;font-weight:500;margin:0;padding:6px 0}
.uap-profile-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Profile edit form fields (reused generic field styles inside portal) */
.uap-app .uap-field{display:block;margin-bottom:16px}
.uap-app .uap-field label{
  display:block!important;font-size:13.5px!important;font-weight:600!important;
  color:var(--uap-text)!important;margin-bottom:6px!important;
}
.uap-app .uap-field input[type=text],
.uap-app .uap-field input[type=email],
.uap-app .uap-field input[type=password],
.uap-app .uap-field input[type=tel]{
  display:block!important;width:100%!important;
  padding:12px 14px!important;
  font:inherit!important;font-size:14.5px!important;
  border:1px solid var(--uap-border-strong,#d4ddd8)!important;
  border-radius:10px!important;
  background:#fff!important;color:var(--uap-text)!important;
  line-height:1.4!important;
  transition:border-color .15s,box-shadow .15s!important;
}
.uap-app .uap-field input:focus{
  outline:none!important;
  border-color:var(--uap-accent)!important;
  box-shadow:0 0 0 4px rgba(38,103,92,.1)!important;
}
.uap-app .uap-field input[readonly],
.uap-app .uap-field input[disabled]{
  background:#f3f8f5!important;color:#6b7f79!important;
}

/* ===== Paramètres ===== */
.uap-setting-row{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:20px 0;border-bottom:1px solid var(--uap-border);
}
.uap-setting-row:last-child{border-bottom:0}
.uap-setting-row h4{font-size:14.5px;margin:0 0 4px}
.uap-setting-row p{font-size:13px;color:var(--uap-text-muted);margin:0;max-width:60ch}
.uap-toggle{position:relative;display:inline-block;width:44px;height:24px}
.uap-toggle input{display:none}
.uap-toggle span{
  position:absolute;inset:0;background:var(--uap-border);border-radius:999px;cursor:pointer;
  transition:background .2s;
}
.uap-toggle span::before{
  content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;
}
.uap-toggle input:checked + span{background:var(--uap-accent)}
.uap-toggle input:checked + span::before{transform:translateX(20px)}

/* ===== Modal ===== */
.uap-modal{
  position:fixed;inset:0;background:rgba(16,24,40,.5);
  display:grid;place-items:center;z-index:100;padding:20px;
}
.uap-modal[hidden]{display:none}
.uap-modal-card{
  background:#fff;border-radius:var(--uap-radius);padding:28px;
  width:100%;max-width:520px;box-shadow:0 20px 40px rgba(0,0,0,.2);
}
.uap-modal-card h3{margin:0 0 20px;font-size:18px}
.uap-modal-card form{display:flex;flex-direction:column;gap:8px}
.uap-modal-card label{font-size:12px;font-weight:600;color:var(--uap-text-muted);letter-spacing:.03em;text-transform:uppercase;margin-top:10px}
.uap-modal-card input[type=text],
.uap-modal-card textarea{
  border:1px solid var(--uap-border);border-radius:8px;padding:12px 14px;font:inherit;
  transition:border-color .15s;
}
.uap-modal-card input:focus,
.uap-modal-card textarea:focus{outline:none;border-color:var(--uap-accent)}
.uap-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}

/* ===== Footer ===== */
.uap-footer{
  text-align:center;padding:28px 0 8px;
  font-size:12px;color:var(--uap-text-subtle);
  display:flex;align-items:center;justify-content:center;gap:8px;
}

/* ===== Toast ===== */
.uap-toast{
  position:fixed;bottom:24px;right:24px;z-index:200;
  background:var(--uap-sidebar);color:#fff;
  padding:12px 18px;border-radius:10px;font-size:13.5px;
  box-shadow:0 10px 30px rgba(0,0,0,.2);
  opacity:0;transform:translateY(8px);transition:all .2s;
}
.uap-toast.is-show{opacity:1;transform:translateY(0)}
.uap-toast.is-error{background:var(--uap-danger)}

/* ===== Responsive ===== */
@media (max-width:1080px){
  .uap-grid-top{grid-template-columns:1fr}
  .uap-grid-bottom{grid-template-columns:1fr}
  .uap-grid-msgs{grid-template-columns:1fr}
  .uap-profile{grid-template-columns:1fr}
  .uap-profile dt{padding:0}
}
@media (max-width:720px){
  .uap-app{grid-template-columns:1fr}
  .uap-sidebar{display:none}
  .uap-main{padding:20px}
  .uap-brand-sub,.uap-brand-divider,.uap-user-name{display:none}
  .uap-topbar{padding:0 16px}
  .uap-user-menu{min-width:220px;right:-4px}
}
